xref: /llvm-project/llvm/test/CodeGen/DirectX/bufferUpdateCounter.ll (revision 011b618644113996e2c0a8e57db40f89d20878e3)
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