From 30fd3c63fb4af9ea8d482c75921710df1b40e59e Mon Sep 17 00:00:00 2001 From: venkataram-nv Date: Thu, 31 Jul 2025 15:12:21 -0700 Subject: Add matrix select intrinsic (#7566) * Add matrix select intrinsic * Fix hlsl test * Restrict matrix select to HLSL * Better test for HLSL side * Select route for GLSL/SPIRV * Exclude matrices from select legalization * Exclude CUDA from select test * Inline and move * format code --------- Co-authored-by: slangbot <186143334+slangbot@users.noreply.github.com> --- tests/language-feature/matrix-select.slang | 45 ++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 tests/language-feature/matrix-select.slang (limited to 'tests/language-feature') diff --git a/tests/language-feature/matrix-select.slang b/tests/language-feature/matrix-select.slang new file mode 100644 index 000000000..a3cab6906 --- /dev/null +++ b/tests/language-feature/matrix-select.slang @@ -0,0 +1,45 @@ +//TEST(compute):COMPARE_COMPUTE_EX(filecheck-buffer=CHK):-dx12 -use-dxil -compute -shaderobj -output-using-type -xslang -matrix-layout-column-major +//TEST(compute):COMPARE_COMPUTE_EX(filecheck-buffer=CHK):-dx12 -use-dxil -compute -shaderobj -output-using-type -xslang -matrix-layout-row-major +//TEST(compute):COMPARE_COMPUTE_EX(filecheck-buffer=CHK):-vk -compute -shaderobj -output-using-type -xslang -matrix-layout-column-major +//TEST(compute):COMPARE_COMPUTE_EX(filecheck-buffer=CHK):-vk -compute -shaderobj -output-using-type -xslang -matrix-layout-row-major +//TEST(compute):COMPARE_COMPUTE_EX(filecheck-buffer=CHK):-mtl -compute -output-using-type -xslang -matrix-layout-column-major +//TEST(compute):COMPARE_COMPUTE_EX(filecheck-buffer=CHK):-mtl -compute -output-using-type -xslang -matrix-layout-row-major +//TEST(compute):COMPARE_COMPUTE_EX(filecheck-buffer=CHK):-wgpu -compute -output-using-type -xslang -matrix-layout-column-major +//TEST(compute):COMPARE_COMPUTE_EX(filecheck-buffer=CHK):-wgpu -compute -output-using-type -xslang -matrix-layout-row-major + +//TEST_INPUT:ubuffer(data=[0], stride=4):out,name=outputBuffer +RWStructuredBuffer outputBuffer; + +int selectDims(bool cond) +{ + return select( + matrix(cond), + matrix(1), + matrix(0) + )[0][0]; +} + +int selectDimsDigit(int x) +{ + return selectDims(((x >> D) & 0b1) == 0b1) << D; +} + +[numthreads(1, 1, 1)] +void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID) +{ + int x = 324; + + int s = 0; + s += selectDimsDigit<2, 2, 0>(x); + s += selectDimsDigit<2, 3, 1>(x); + s += selectDimsDigit<2, 4, 2>(x); + s += selectDimsDigit<3, 2, 3>(x); + s += selectDimsDigit<3, 3, 4>(x); + s += selectDimsDigit<3, 4, 5>(x); + s += selectDimsDigit<4, 2, 6>(x); + s += selectDimsDigit<4, 3, 7>(x); + s += selectDimsDigit<4, 4, 8>(x); + + // CHK: 324 + outputBuffer[0] = s; +} \ No newline at end of file -- cgit v1.2.3