this post was submitted on 22 Nov 2023
23 points (87.1% liked)

Linux Gaming

14771 readers
184 users here now

Discussions and news about gaming on the GNU/Linux family of operating systems (including the Steam Deck). Potentially a $HOME away from home for disgruntled /r/linux_gaming denizens of the redditarian demesne.

This page can be subscribed to via RSS.

Original /r/linux_gaming pengwing by uoou.

Resources

WWW:

Discord:

IRC:

Matrix:

Telegram:

founded 1 year ago
MODERATORS
 

Hey all, I have a RTX 3060 and a Ryzen 5600G and I'm on Ubuntu 22.04. Since Steam has shader pre-processing on Linux I thought I'd ask on a Linux gaming community about this. I noticed that when Steam processes Vulkan shaders, it uses the CPU (my CPU heats up a lot and the process manager shows CPU being used while GPU is not used at all). Is there a way to make Steam use the GPU to process Vulkan shaders instead, or am I wrong and Vulkan shaders have to be processed on CPU? I'd presume that things like shaders would process faster on a GPU (it takes a long time for them to process on the CPU). Anyone know anything about this?

top 12 comments
sorted by: hot top controversial new old
[–] [email protected] 37 points 9 months ago (1 children)

Your CPU compiles shaders, the GPU runs them. Vulkan shader pre-processing is a form of pre-compiling all the possible shaders your GPU might need before it runs the game (to avoid stutters and freezes later). This is done on the CPU.

[–] [email protected] 3 points 9 months ago

Thanks! Makes sense. I saw "shaders" and linked it to the GPU.

[–] [email protected] 27 points 9 months ago (1 children)

I don't believe that there's a shader compiler that runs on the GPU.

[–] [email protected] 0 points 9 months ago (1 children)

Valve created the ACO shader compiler, but it's only for AMD GPUs.

[–] [email protected] 17 points 9 months ago (1 children)

ACO runs on the CPU.

The output it produces is for AMD GPUs.

[–] [email protected] 1 points 9 months ago

Oh, my bad. I think I misremembered.

[–] [email protected] 0 points 9 months ago* (last edited 9 months ago) (3 children)

I ran into this exact same problem and spent a painfully long week trying to fix it. Unfortunately I couldn't... My only solution was to switch distros and the problem disappeared. I went with Fedora and now every game works like a dream. I still don't know what the issue was but it seems to be something to do with having an AMD system and using steam on Ubuntu.

Probably not the solution you're looking for, but it is a solution!

[–] [email protected] 13 points 9 months ago* (last edited 9 months ago) (1 children)

You can turn off shader precompilation in Steam, but that's not tied to the distro.

If you have it off, you won't need to have the pass run before starting a game, but then the problem that it was aimed at solving comes up -- shader compilation has to happen during gameplay, and this can cause momentary hiccups when a shader is used for the first time.

Steam can optionally do background shader compilation, in which case it'll run at some point after updating a game, rather than right before a game runs. That may or may not be what one wants.

[–] [email protected] 2 points 9 months ago

Interesting! I think I'll keep it on and just deal with the fact that it runs on CPU and takes a while, then. I was just wondering if it running on CPU was a mistake or something wrong on my part.

[–] [email protected] 2 points 9 months ago (1 children)

My guess is your mesa driver was old so you didn't have graphics pipeline library enabled by default. distros doesn't differ but packages.

[–] [email protected] 1 points 9 months ago

Nope. Had the latest mesa drivers I could get and it still didn't work.

[–] [email protected] 1 points 9 months ago

All-amd Ubuntu user here. No issues.