this post was submitted on 04 Jan 2024
40 points (95.5% liked)
Steam Deck
15239 readers
206 users here now
A place to discuss and support all things Steam Deck.
Replacement for r/steamdeck_linux.
As Lemmy doesn't have flairs yet, you can use these prefixes to indicate what type of post you have made, eg:
[Flair] My post title
The following is a list of suggested flairs:
[Discussion] - General discussion.
[Help] - A request for help or support.
[News] - News about the deck.
[PSA] - Sharing important information.
[Game] - News / info about a game on the deck.
[Update] - An update to a previous post.
[Meta] - Discussion about this community.
Some more Steam Deck specific flairs:
[Boot Screen] - Custom boot screens/videos.
[Selling] - If you are selling your deck.
These are not enforced, but they are encouraged.
Rules:
- Follow the rules of Sopuli
- Posts must be related to the Steam Deck in an obvious way.
- No piracy, there are other communities for that.
- Discussion of emulators are allowed, but no discussion on how to illegally acquire ROMs.
- This is a place of civil discussion, no trolling.
- Have fun.
founded 3 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
view the rest of the comments
TL;DR: Shader recompilation sucks, but it's inevitable; it's how you can play DirectX games on Linux.
Shaders describe how to render stuff. The game feeds the GPU some shader code and a list of points, and shaders get used to turn those points into triangles, and those triangles get turned into filled shapes that are rendered to the screen. The triangles themselves are quite to translate back and forth (I'm pretty sure all you need to do is invert the Z-axis because Microsoft chose a different default coordinate system), but that's not as easy with the shader code.
Linux, Windows, and various consoles can use Vulkan to do graphics; it's basically an open DirectX alternative (it's more complicated than that but let's just pretend it is). Vulkan uses a completely different type of GPU code that will get translated to about the same code that ends up being executed, but the intermediate storage that the game interacts with is different.
This is where shader recompilation comes in: the DirectX shaders get intercepted when the game tries to run them, much like how requests to open and read files are intercepted and turned into Linux operations, and the code gets ripped apart, interpreted, and rebuilt into shaders that can be used by the Vulkan graphics code. The game doesn't know this is happening because the recompilation makes it seem like the game is running on real DirectX.
Because this reinterpretation takes a bunch of processing power and halts the game if it doesn't happen during a loading screen (which is the case in most modern games), the result of this recompilation gets saved to disk, assuming there's space. Next time the game is trying to load the shaders that were already processed, it loads them from the SSD rather than doing the hard work again, basically making the translation instantaneously.
Fun fact: early versions of Elden Ring shipped with a bug that caused the shaders to get loaded over and over again in some cases, causing frame drops and slowdowns on Windows, but Linux players were barely affected because that stuff is basically the norm on DXVK and the runtime was already optimized for it.
This shader recompilation step happens on all kinds of GPU-code-to-GPU-code translation software (DXVK on Linux, but also on console emulators like Dolphin, and more). Steam fixes most of this problem by doing the recompilation on their side, storing the results, and having the Deck download the precompiled shader caches with games. That's why there's an extra download step for Steam games on Linux, and why games take up more space than on Windows. However, but you can't use Steam's DX11 shader caches with DX12, and I believe Steam only precompiles the DX11 caches.
A theoretical fix would be to download the shader caches from someone else who already went through the entire game with your patches applied. Unfortunately, sharing shader caches is not something I've seen outside of the Dolphin community. In some circumstances, you can tell the computer to generate all of these caches in bulk outside of the game so you can play smoothly, but I'm not sure if this is available in PC games.
I'm not sure what the patch changes exactly, so it's hard to say what the exact problem is. Normally, recompiled shaders are cached on the file system so that they'll be loaded instantly the next time they're used, and the frame drop should only occur when you're loading large new areas which requires loading new shader code. If you're seeing slowdowns every time you go through previous areas, it could be that the modifications cause problems with the shader cache, in which case the shader recompilation needs to take place every time. If you only get slowdowns for new areas/enemies/objects/animations, then the system is probably Working As Intended and I don't think there are any workarounds.
The only alternative to shader recompilation system would be Microsoft porting DirectX to Linux, but that's never ever going to happen.
this answer should be pinned somewhere! thank you for writing it
I'll just play with dx11, ty x the info.