struct S {
int x;
uint a[10];
uint y;
};
groupshared S wg;
struct tint_symbol_1 {
uint local_invocation_index : SV_GroupIndex;
void compute_main_inner(uint local_invocation_index) {
{
wg.x = 0;
wg.y = 0u;
}
for(uint idx = local_invocation_index; (idx < 10u); idx = (idx + 1u)) {
const uint i = idx;
uint atomic_result = 0u;
InterlockedExchange(wg.a[i], 0u, atomic_result);
GroupMemoryBarrierWithGroupSync();
uint atomic_result_1 = 0u;
InterlockedExchange(wg.a[4], 1u, atomic_result_1);
[numthreads(1, 1, 1)]
void compute_main(tint_symbol_1 tint_symbol) {
compute_main_inner(tint_symbol.local_invocation_index);
return;