| groupshared int4 src_workgroup[4]; |
| |
| void tint_zero_workgroup_memory(uint local_idx) { |
| { |
| for(uint idx = local_idx; (idx < 4u); idx = (idx + 1u)) { |
| uint i = idx; |
| src_workgroup[i] = (0).xxxx; |
| } |
| } |
| GroupMemoryBarrierWithGroupSync(); |
| } |
| |
| struct S { |
| int4 arr[4]; |
| }; |
| |
| static int4 src_private[4] = (int4[4])0; |
| cbuffer cbuffer_src_uniform : register(b0) { |
| uint4 src_uniform[4]; |
| }; |
| RWByteAddressBuffer src_storage : register(u1); |
| RWByteAddressBuffer tint_symbol : register(u2); |
| RWByteAddressBuffer dst_nested : register(u3); |
| |
| typedef int4 ret_arr_ret[4]; |
| ret_arr_ret ret_arr() { |
| int4 tint_symbol_4[4] = (int4[4])0; |
| return tint_symbol_4; |
| } |
| |
| S ret_struct_arr() { |
| S tint_symbol_5 = (S)0; |
| return tint_symbol_5; |
| } |
| |
| void tint_symbol_store(uint offset, int4 value[4]) { |
| int4 array_1[4] = value; |
| { |
| for(uint i_1 = 0u; (i_1 < 4u); i_1 = (i_1 + 1u)) { |
| tint_symbol.Store4((offset + (i_1 * 16u)), asuint(array_1[i_1])); |
| } |
| } |
| } |
| |
| typedef int4 src_uniform_load_ret[4]; |
| src_uniform_load_ret src_uniform_load(uint offset) { |
| int4 arr_1[4] = (int4[4])0; |
| { |
| for(uint i_2 = 0u; (i_2 < 4u); i_2 = (i_2 + 1u)) { |
| const uint scalar_offset = ((offset + (i_2 * 16u))) / 4; |
| arr_1[i_2] = asint(src_uniform[scalar_offset / 4]); |
| } |
| } |
| return arr_1; |
| } |
| |
| typedef int4 src_storage_load_ret[4]; |
| src_storage_load_ret src_storage_load(uint offset) { |
| int4 arr_2[4] = (int4[4])0; |
| { |
| for(uint i_3 = 0u; (i_3 < 4u); i_3 = (i_3 + 1u)) { |
| arr_2[i_3] = asint(src_storage.Load4((offset + (i_3 * 16u)))); |
| } |
| } |
| return arr_2; |
| } |
| |
| void dst_nested_store_2(uint offset, int value[2]) { |
| int array_4[2] = value; |
| { |
| for(uint i_4 = 0u; (i_4 < 2u); i_4 = (i_4 + 1u)) { |
| dst_nested.Store((offset + (i_4 * 4u)), asuint(array_4[i_4])); |
| } |
| } |
| } |
| |
| void dst_nested_store_1(uint offset, int value[3][2]) { |
| int array_3[3][2] = value; |
| { |
| for(uint i_5 = 0u; (i_5 < 3u); i_5 = (i_5 + 1u)) { |
| dst_nested_store_2((offset + (i_5 * 8u)), array_3[i_5]); |
| } |
| } |
| } |
| |
| void dst_nested_store(uint offset, int value[4][3][2]) { |
| int array_2[4][3][2] = value; |
| { |
| for(uint i_6 = 0u; (i_6 < 4u); i_6 = (i_6 + 1u)) { |
| dst_nested_store_1((offset + (i_6 * 24u)), array_2[i_6]); |
| } |
| } |
| } |
| |
| void foo(int4 src_param[4]) { |
| int4 src_function[4] = (int4[4])0; |
| int4 tint_symbol_6[4] = {(1).xxxx, (2).xxxx, (3).xxxx, (3).xxxx}; |
| tint_symbol_store(0u, tint_symbol_6); |
| tint_symbol_store(0u, src_param); |
| tint_symbol_store(0u, ret_arr()); |
| int4 src_let[4] = (int4[4])0; |
| tint_symbol_store(0u, src_let); |
| tint_symbol_store(0u, src_function); |
| tint_symbol_store(0u, src_private); |
| tint_symbol_store(0u, src_workgroup); |
| S tint_symbol_1 = ret_struct_arr(); |
| tint_symbol_store(0u, tint_symbol_1.arr); |
| tint_symbol_store(0u, src_uniform_load(0u)); |
| tint_symbol_store(0u, src_storage_load(0u)); |
| int src_nested[4][3][2] = (int[4][3][2])0; |
| dst_nested_store(0u, src_nested); |
| } |
| |
| struct tint_symbol_3 { |
| uint local_invocation_index : SV_GroupIndex; |
| }; |
| |
| void main_inner(uint local_invocation_index) { |
| tint_zero_workgroup_memory(local_invocation_index); |
| int4 ary[4] = (int4[4])0; |
| foo(ary); |
| } |
| |
| [numthreads(1, 1, 1)] |
| void main(tint_symbol_3 tint_symbol_2) { |
| main_inner(tint_symbol_2.local_invocation_index); |
| return; |
| } |