-
Notifications
You must be signed in to change notification settings - Fork 236
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
local_size_x_id layout qualifier is unrecognized in GLSL compatibility mode #5948
Comments
This feature is not yet supported in Slang. If we are to add support for it, we should just allow: layout(local_size_x= WG_SIZE) in; Or [numthreads(WG_SIZE, 1, 1)] But right now the sizes are restricted to compile time constants only, and a specialization constant is not a compile time constant. Slang does have link time constants and they are allowed in numthreads decoration. However you will need to use slang to specialize the shader instead of doing it with the Vulkan api. See https://shader-slang.com/slang/user-guide/link-time-specialization.html |
Okay, thanks for the info. I happen to have a bit too much time right now, so I'll probably try to implement this for fun at some point soon and submit some kind of draft PR once it seems to work properly. I already hacked together something that barely works with the GLSL backend only, but what I really need for my hobby project is the SPIR-V backend. What I'm currently doing in my project is embedding the SPIR-V into the executable and not shipping a compiler with the program, but I'll consider Slang's own specialization if this turns out to be too complicated to implement. |
If you just want to add the same local_size_x_id qualifier for glsl input, this shouldn’t be hard. Properly allowing use of specialization constant directly in local_size_x is a bit harder. |
In GLSL/Vulkan, it's possible to define the workgroup size using a specialization constant, using
local_size_{x,y,z}_id = <specialization constant id>
. This is e.g. useful for ensuring that the workgroup size matches the subgroup size. It appears to not yet be supported by slangc's GLSL compatibility mode.Output:
(Also, is this feature available via HLSL or Slang proper? I guess this is a GLSL compatibility bug in any case, but in practice I only have like two fairly simple shaders that do this, so porting them to Slang up-front wouldn't too big of a deal.)
The text was updated successfully, but these errors were encountered: