-
Notifications
You must be signed in to change notification settings - Fork 969
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
Fix set_push_constants
for render bundles
#6540
Conversation
`self` is immutable in the function `finish()` [see line 345], so I cannot
take these vectors from `self`. Since this is my first time modifying
wgpu-core, I don't feel confident enough to change the signature of the
method and make `self` mutable.
I also just verified that I get a compiler error when I change `self` to
`&mut self` because at least one of the callers to `finish` wasn't
expecting it to be mutable.
I'll rely on your judgment on how to proceed.
…On Wed, Nov 13, 2024 at 12:34 PM Nicolas Silva ***@***.***> wrote:
***@***.**** commented on this pull request.
------------------------------
In wgpu-core/src/command/bundle.rs
<#6540 (comment)>:
> @@ -543,8 +543,8 @@ impl RenderBundleEncoder {
label: desc.label.as_ref().map(|cow| cow.to_string()),
commands,
dynamic_offsets: flat_dynamic_offsets,
- string_data: Vec::new(),
- push_constant_data: Vec::new(),
+ string_data: self.base.string_data.clone(),
I think that this should be std::mem::take(&mut self.base.string_data)
(and same thing for the push constant data.
—
Reply to this email directly, view it on GitHub
<#6540 (review)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/ABC2LIIULVTK24UFS5JWZVD2AOZT5AVCNFSM6AAAAABRXDWEIKVHI2DSMVQWIX3LMV43YUDVNRWFEZLROVSXG5CSMV3GSZLXHMZDIMZUGM2TKOJQGY>
.
You are receiving this because you authored the thread.Message ID:
***@***.***>
|
I realized the argument is self. So we own it. I can just use |
Fix code that runs on my machine, my test suite complains about.
My changes fixed one bug, but it seems there is another bug in the Vulkan and DX12 implementation. For now, I can fix the code so that it works on everything else, but I don't know enough about the internal implementations of Vulkan or DX12. For Vulcan there is an error message that makes no sense. For DX12, naga seems to produce bad code, and there is a compiler failure. My code in the test suite is just a basic use of SetPushConstant on a RenderPassEncoder and a RenderBundleEncoder. The fact that the code is now running successfully on RenderBundleEncoders means that I've fixed the generic bug. Someone else is going to need to fix the implementation specific bugs, since I don't know about the internals. |
The DX12 issue is #5683 / #5571, can you wrap the push constants in the shader in a struct? That should get things working. I think the Vulkan validation error is #4502. Can you change the test to not use non-0 start ranges? This will most likely become a validation error emitted by us in the future as the WebGPU spec proposal also doesn't allow users to specify non-0 start ranges. |
I've converted the code to use a struct. The naga compiler does the right thing now. Since push_constants no longer exists in WGPU or WebGPU, I was using the Vulkan documentation as my guide. According to those specs, one can separate the vertex shader constants from the fragment shader constants, and specify that a certain byte-range of the constants are are only for the vertex shader or only for the fragment shader. When doing this, you are also required to call set_push_constants separately for each of the byte-ranges. So I performed multiple tests.
It seems that there are two possibly new bugs:
I will resubmit my PR using #2 above, and exclude DX12. |
I have opened two additional bugs: BUG #6558. SetPushConstant on Dx12 gives wrong results This PR fixes yet a third bug and adds a test that succeeds on GL and Metal and actually tests SetPushConstant. How do I proceed? Right now, the test suite isn't even running. |
Thanks for looking into these issues! I left a comment in #6558 (comment), could you try seeing if avoiding arrays gets things working on DX12? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good, thank you!
set_push_constants
for render bundles
Fixes #6532.
Fixes #2683.
The use of
RenderBundleEncoder.SetPushConstants
would cause a panic on the subsequent call toRenderPass.ExecuteBundles()
. The.finish()
method was failing to copy itspush_constant_data
from the render bundle encoder to the render bundle.Currently
string_data
is unused, but it seemed safest to copy it to prevent future bugs.I have confirmed with a toy program that the old code panics and the new code works (and correctly accesses the pushed constants).