Skip to content

Commit

Permalink
Initial commit (#4016)
Browse files Browse the repository at this point in the history
Co-authored-by: Peter McNeeley <[email protected]>
  • Loading branch information
petermcneeleychromium and Peter McNeeley authored Nov 19, 2024
1 parent 327fb7b commit 467c899
Showing 1 changed file with 21 additions and 12 deletions.
33 changes: 21 additions & 12 deletions src/webgpu/shader/validation/shader_io/align.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,10 @@ const kTests = {
},
one: {
src: '@align(1)',
pass: true,
pass: false,
// EXCEPTION: Error: Unexpected validation error occurred:
// Error while parsing WGSL: :6:10 error: alignment must be a
// multiple of '4' bytes for the 'uniform' address space @align(1) a: i32,
},
four_a: {
src: '@align(4)',
Expand Down Expand Up @@ -45,6 +48,14 @@ const kTests = {
},
const_expr: {
src: '@align(i_val + 4 - 6)',
pass: false,
// EXCEPTION: Error: Unexpected validation error occurred:
// Error while parsing WGSL: :6:10 error: alignment must be a
// multiple of '4' bytes for the 'uniform' address space
// @align(i_val + 4 - 6) a: i32
},
const_expr_2: {
src: '@align(i_val + 8 - 4)',
pass: true,
},
large: {
Expand Down Expand Up @@ -185,7 +196,7 @@ g.test('required_alignment')
{ name: 'mat3x4<f16>', storage: 8, uniform: 8 },
{ name: 'mat4x4<f16>', storage: 8, uniform: 8 },
{ name: 'array<vec2<i32>, 2>', storage: 8, uniform: 16 },
{ name: 'array<vec4<i32>, 2>', storage: 8, uniform: 16 },
{ name: 'array<vec4<i32>, 2>', storage: 16, uniform: 16 },
{ name: 'S', storage: 8, uniform: 16 },
])
.beginSubcases()
Expand Down Expand Up @@ -218,15 +229,12 @@ g.test('required_alignment')
`;
}

let align = t.params.align;
if (t.params.align === 'alignment') {
// Alignment value listed in the spec
if (t.params.address_space === 'storage') {
align = `${t.params.type.storage}`;
} else {
align = `${t.params.type.uniform}`;
}
}
// Alignment value listed in the spec
const min_align =
t.params.address_space === 'storage'
? `${t.params.type.storage}`
: `${t.params.type.uniform}`;
const align = t.params.align === 'alignment' ? min_align : t.params.align;

let address_space = 'uniform';
if (t.params.address_space === 'storage') {
Expand All @@ -252,7 +260,8 @@ g.test('required_alignment')
// requires that inner vec2 to have an align 16 which can only be done by specifying `vec4`
// instead.
const fails =
t.params.address_space === 'uniform' && t.params.type.name.startsWith('array<vec2');
(t.params.address_space === 'uniform' && t.params.type.name.startsWith('array<vec2')) ||
align < min_align;

t.expectCompileResult(!fails, code);
});
Expand Down

0 comments on commit 467c899

Please sign in to comment.