From a9d1cc5daaf2cf72be88f7ebf4a2e3c3da68abc9 Mon Sep 17 00:00:00 2001 From: Jay Kwak <82421531+jkwak-work@users.noreply.github.com> Date: Thu, 24 Jul 2025 13:36:30 -0700 Subject: Add test for Metal pointer uniform parameter (#7850) * Add test for Metal pointer uniform parameter * Update the test to include runtime result * Adding CUDA to the test * Adding -render-features argument-buffer-tier-2 --- tests/metal/metal-pointer-uniform.slang | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 tests/metal/metal-pointer-uniform.slang (limited to 'tests') diff --git a/tests/metal/metal-pointer-uniform.slang b/tests/metal/metal-pointer-uniform.slang new file mode 100644 index 000000000..4a0ddb8fd --- /dev/null +++ b/tests/metal/metal-pointer-uniform.slang @@ -0,0 +1,33 @@ +//TEST:SIMPLE(filecheck=CHECK_MTL): -target metal -stage compute -entry computeMain +//TEST:SIMPLE(filecheck=CHECK_AIR): -target metallib -stage compute -entry computeMain +//TEST:COMPARE_COMPUTE(filecheck-buffer=CHECK): -vk -emit-spirv-directly +//TEST:COMPARE_COMPUTE(filecheck-buffer=CHECK): -metal -render-features argument-buffer-tier-2 +//TEST:COMPARE_COMPUTE(filecheck-buffer=CHECK): -cuda +//TEST:COMPARE_COMPUTE(filecheck-buffer=CHECK): -cpu + +// This reproduces the specific case that was failing where uniform pointers +// are used for buffer copy operations with array indexing targeting Metal. + +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer +RWStructuredBuffer outputBuffer; + +//CHECK_MTL: int{{.*}}device{{ *\*}} src + +// "indirect_argument" means a pointer +//CHECK_AIR: !"int", !"src{{[^"]*}}", !"air.indirect_argument" + +//TEST_INPUT: set src = ubuffer(data=[1 2 3 4 5 6 7 8],stride=4); +uniform int* src; + +[shader("compute")] +[numthreads(4,1,1)] +void computeMain(uint3 threadID : SV_DispatchThreadID) +{ + let input = src[threadID.x]; + outputBuffer[threadID.x] = input; +} + +//CHECK:1 +//CHECK-NEXT:2 +//CHECK-NEXT:3 +//CHECK-NEXT:4 -- cgit v1.2.3