//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=CHECK):-vk -emit-spirv-directly // CHECK: 1 // CHECK-NEXT: 2 // CHECK-NEXT: 3 // CHECK-NEXT: 4 // CHECK-NEXT: 5 // CHECK-NEXT: 6 // CHECK-NEXT: 7 // CHECK-NEXT: 8 //TEST_INPUT:ubuffer(data=[1 2 3 4 5 6 7 8], stride=4, count=256):name=input ByteAddressBuffer input; //TEST_INPUT:ubuffer(stride=4, count=256):out,name=outputBuffer RWStructuredBuffer outputBuffer; using namespace linalg; groupshared uint32_t[256] tempShared; [numthreads(32, 1, 1)] void computeMain() { let stride = 16; let mat = coopMatLoad(input, 0, stride); mat.Store(tempShared, 0, stride); let result = coopMatLoad(tempShared, 0, stride); result.Store(outputBuffer, 0, stride); }