-
Notifications
You must be signed in to change notification settings - Fork 86
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
webgpu/api/validation: Fix vertex_shader_input_location_limit test #767
base: main
Are you sure you want to change the base?
Conversation
const success = { | ||
// [[location(n)]] decoration must be a "non-negative i32 literal" | ||
// TODO: Dawn raises a "Attribute location (N) over limits" error at | ||
// shader creation time for N>15. Is this right? |
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.
@Kangz - It seems to me that Dawn might be validating too early here. Please can you advise?
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.
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.
... restricted the locations themselves to be under the limit after some discussion that that was most likely sufficient, and forward-compatible with relaxing the restriction.
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.
Thanks. Made both the shader
and pipeline
conditions both dependent on the location being [0..kMaxVertexAttributes)
Previews, as seen when this build job started (cd2eac6): |
Shader compilation / validation will fail for vertex attributes that are out of bounds.
cd2eac6
to
9317e7c
Compare
Previews, as seen when this build job started (9317e7c): |
let vsModule: GPUShaderModule | undefined; | ||
|
||
this.expectValidationError(() => { | ||
vsModule = this.device.createShaderModule({ code: vertexShader }); | ||
}, !success.shader); | ||
|
||
if (vsModule === undefined) { | ||
return; | ||
} |
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.
Allowing vsModule
to be undefined isn't actually necessary here (checked locally). It's technically still unsound (as is an as
cast) because I don't think the compiler knows the callback of expectValidationError is always called, or that it didn't throw a caught exception. But it works anyway.
let vsModule: GPUShaderModule | undefined; | |
this.expectValidationError(() => { | |
vsModule = this.device.createShaderModule({ code: vertexShader }); | |
}, !success.shader); | |
if (vsModule === undefined) { | |
return; | |
} | |
let vsModule: GPUShaderModule; | |
this.expectValidationError(() => { | |
vsModule = this.device.createShaderModule({ code: vertexShader }); | |
}, !success.shader); |
this.expectValidationError(() => { | ||
this.device.createRenderPipeline({ | ||
vertex: { | ||
module: vsModule, | ||
module: vsModule as GPUShaderModule, |
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.
module: vsModule as GPUShaderModule, | |
module: vsModule, |
const success = testLocation < kMaxVertexAttributes; | ||
const success = { | ||
shader: testLocation >= 0 && testLocation < kMaxVertexAttributes, | ||
pipeline: testLocation >= 0 && testLocation < kMaxVertexAttributes, |
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.
In this case the pipeline creation would actually fail for either of two separate reasons: shader module was invalid, and shaderLocation was out of bounds. We can't tell which one.
If it's allowed for a shader to have a subset of the attributes defined by the pipeline (I'm not sure, but I think it is allowed), only the shaderLocation
being out of bounds should be tested here.
@@ -396,7 +413,10 @@ g.test('vertex_shader_input_location_limit') | |||
}, | |||
]; | |||
|
|||
const success = testLocation < kMaxVertexAttributes; | |||
const success = { | |||
shader: testLocation >= 0 && testLocation < kMaxVertexAttributes, |
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.
The fact that this is only used in one test kind of indicates this test should be somewhere else - it's a test of createShaderModule and not of the vertex state setup in createRenderPipeline.
If indeed this should fail in createShaderModule, then I think it's really a shader validation test (src/webgpu/shader/validation/
)
The WGSL spec states that the
[[location(n)]]
decoration must be a "non-negative i32 literal".