mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-06-14 10:33:42 +00:00
When an initializer is present, use type inference instead of explicitly typing `var` and `let` declarations. This reduces the size of the generated WGSL and improves readability. Change-Id: I241ee2108279b550735945940f2b62bbbd493708 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/132142 Commit-Queue: David Neto <dneto@google.com> Kokoro: Kokoro <noreply+kokoro@google.com> Auto-Submit: James Price <jrprice@google.com> Reviewed-by: David Neto <dneto@google.com>
43 lines
784 B
WebGPU Shading Language
43 lines
784 B
WebGPU Shading Language
struct S_atomic {
|
|
/* @offset(0) */
|
|
x : i32,
|
|
/* @offset(4) */
|
|
a : atomic<u32>,
|
|
/* @offset(8) */
|
|
y : u32,
|
|
}
|
|
|
|
struct S {
|
|
/* @offset(0) */
|
|
x : i32,
|
|
/* @offset(4) */
|
|
a : u32,
|
|
/* @offset(8) */
|
|
y : u32,
|
|
}
|
|
|
|
var<private> local_invocation_index_1 : u32;
|
|
|
|
var<workgroup> wg : S_atomic;
|
|
|
|
fn compute_main_inner(local_invocation_index_2 : u32) {
|
|
wg.x = 0i;
|
|
atomicStore(&(wg.a), 0u);
|
|
wg.y = 0u;
|
|
workgroupBarrier();
|
|
atomicStore(&(wg.a), 1u);
|
|
return;
|
|
}
|
|
|
|
fn compute_main_1() {
|
|
let x_35 = local_invocation_index_1;
|
|
compute_main_inner(x_35);
|
|
return;
|
|
}
|
|
|
|
@compute @workgroup_size(1i, 1i, 1i)
|
|
fn compute_main(@builtin(local_invocation_index) local_invocation_index_1_param : u32) {
|
|
local_invocation_index_1 = local_invocation_index_1_param;
|
|
compute_main_1();
|
|
}
|