1; RUN: opt -S -dxil-op-lower %s | FileCheck %s 2 3 4target triple = "dxil-pc-shadermodel6.6-compute" 5 6 ; CHECK-LABEL: define void @update_counter_decrement_vector() { 7define void @update_counter_decrement_vector() { 8 ; CHECK: [[BIND:%.*]] = call %dx.types.Handle @dx.op.createHandleFromBinding(i32 217, 9 %buffer = call target("dx.TypedBuffer", <4 x float>, 0, 0, 0) 10 @llvm.dx.resource.handlefrombinding.tdx.TypedBuffer_v4f32_0_0_0( 11 i32 0, i32 0, i32 1, i32 0, i1 false) 12 13 ; CHECK-NEXT: [[BUFFANOT:%.*]] = call %dx.types.Handle @dx.op.annotateHandle(i32 216, %dx.types.Handle [[BIND]] 14 ; CHECK-NEXT: [[REG:%.*]] = call i32 @dx.op.bufferUpdateCounter(i32 70, %dx.types.Handle [[BUFFANOT]], i8 -1){{$}} 15 %1 = call i32 @llvm.dx.resource.updatecounter(target("dx.TypedBuffer", <4 x float>, 0, 0, 0) %buffer, i8 -1) 16 ret void 17} 18 19 ; CHECK-LABEL: define void @update_counter_increment_vector() { 20define void @update_counter_increment_vector() { 21 ; CHECK: [[BIND:%.*]] = call %dx.types.Handle @dx.op.createHandleFromBinding(i32 217, 22 %buffer = call target("dx.TypedBuffer", <4 x float>, 0, 0, 0) 23 @llvm.dx.resource.handlefrombinding.tdx.TypedBuffer_v4f32_0_0_0( 24 i32 0, i32 0, i32 1, i32 0, i1 false) 25 ; CHECK-NEXT: [[BUFFANOT:%.*]] = call %dx.types.Handle @dx.op.annotateHandle(i32 216, %dx.types.Handle [[BIND]] 26 ; CHECK-NEXT: [[REG:%.*]] = call i32 @dx.op.bufferUpdateCounter(i32 70, %dx.types.Handle [[BUFFANOT]], i8 1){{$}} 27 %1 = call i32 @llvm.dx.resource.updatecounter(target("dx.TypedBuffer", <4 x float>, 0, 0, 0) %buffer, i8 1) 28 ret void 29} 30 31; CHECK-LABEL: define void @update_counter_decrement_scalar() { 32define void @update_counter_decrement_scalar() { 33 ; CHECK: [[BIND:%.*]] = call %dx.types.Handle @dx.op.createHandleFromBinding(i32 217, 34 %buffer = call target("dx.RawBuffer", i8, 0, 0) 35 @llvm.dx.resource.handlefrombinding.tdx.RawBuffer_i8_0_0t( 36 i32 1, i32 8, i32 1, i32 0, i1 false) 37 ; CHECK-NEXT: [[BUFFANOT:%.*]] = call %dx.types.Handle @dx.op.annotateHandle(i32 216, %dx.types.Handle [[BIND]] 38 ; CHECK-NEXT: [[REG:%.*]] = call i32 @dx.op.bufferUpdateCounter(i32 70, %dx.types.Handle [[BUFFANOT]], i8 -1){{$}} 39 %1 = call i32 @llvm.dx.resource.updatecounter(target("dx.RawBuffer", i8, 0, 0) %buffer, i8 -1) 40 ret void 41} 42