[InstCombine] Signed saturation patterns
[llvm-complete.git] / test / CodeGen / AMDGPU / GlobalISel / legalize-atomicrmw-sub.mir
blob974cd3f12e3b68def0a9c7d547ffdf5f931dd532
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -mtriple=amdgcn-mesa-mesa3d -mcpu=tahiti -O0 -run-pass=legalizer %s -o - | FileCheck %s
3 # RUN: llc -mtriple=amdgcn-mesa-mesa3d -mcpu=fiji -O0 -run-pass=legalizer %s -o - | FileCheck %s
5 ---
6 name: atomicrmw_sub_global_i32
8 body: |
9   bb.0:
10     liveins: $sgpr0_sgpr1, $sgpr2
11     ; CHECK-LABEL: name: atomicrmw_sub_global_i32
12     ; CHECK: [[COPY:%[0-9]+]]:_(p1) = COPY $sgpr0_sgpr1
13     ; CHECK: [[COPY1:%[0-9]+]]:_(s32) = COPY $sgpr2
14     ; CHECK: [[ATOMICRMW_SUB:%[0-9]+]]:_(s32) = G_ATOMICRMW_SUB [[COPY]](p1), [[COPY1]] :: (load store seq_cst 4, addrspace 1)
15     %0:_(p1) = COPY $sgpr0_sgpr1
16     %1:_(s32) = COPY $sgpr2
17     %2:_(s32) = G_ATOMICRMW_SUB %0, %1 :: (load store seq_cst 4, addrspace 1)
18 ...
20 ---
21 name: atomicrmw_sub_local_i32
23 body: |
24   bb.0:
25     liveins: $sgpr0, $sgpr1
26     ; CHECK-LABEL: name: atomicrmw_sub_local_i32
27     ; CHECK: [[COPY:%[0-9]+]]:_(p3) = COPY $sgpr0
28     ; CHECK: [[COPY1:%[0-9]+]]:_(s32) = COPY $sgpr1
29     ; CHECK: [[ATOMICRMW_SUB:%[0-9]+]]:_(s32) = G_ATOMICRMW_SUB [[COPY]](p3), [[COPY1]] :: (load store seq_cst 4, addrspace 3)
30     %0:_(p3) = COPY $sgpr0
31     %1:_(s32) = COPY $sgpr1
32     %2:_(s32) = G_ATOMICRMW_SUB %0, %1 :: (load store seq_cst 4, addrspace 3)
33 ...
35 ---
36 name: atomicrmw_sub_global_i64
38 body: |
39   bb.0:
40     liveins: $sgpr0_sgpr1, $sgpr2
41     ; CHECK-LABEL: name: atomicrmw_sub_global_i64
42     ; CHECK: [[COPY:%[0-9]+]]:_(p1) = COPY $sgpr0_sgpr1
43     ; CHECK: [[COPY1:%[0-9]+]]:_(s32) = COPY $sgpr2
44     ; CHECK: [[ATOMICRMW_SUB:%[0-9]+]]:_(s32) = G_ATOMICRMW_SUB [[COPY]](p1), [[COPY1]] :: (load store seq_cst 4, addrspace 1)
45     %0:_(p1) = COPY $sgpr0_sgpr1
46     %1:_(s32) = COPY $sgpr2
47     %2:_(s32) = G_ATOMICRMW_SUB %0, %1 :: (load store seq_cst 4, addrspace 1)
48 ...
50 ---
51 name: atomicrmw_sub_local_i64
53 body: |
54   bb.0:
55     liveins: $sgpr0, $sgpr1
56     ; CHECK-LABEL: name: atomicrmw_sub_local_i64
57     ; CHECK: [[COPY:%[0-9]+]]:_(p3) = COPY $sgpr0
58     ; CHECK: [[COPY1:%[0-9]+]]:_(s32) = COPY $sgpr1
59     ; CHECK: [[ATOMICRMW_SUB:%[0-9]+]]:_(s32) = G_ATOMICRMW_SUB [[COPY]](p3), [[COPY1]] :: (load store seq_cst 4, addrspace 3)
60     %0:_(p3) = COPY $sgpr0
61     %1:_(s32) = COPY $sgpr1
62     %2:_(s32) = G_ATOMICRMW_SUB %0, %1 :: (load store seq_cst 4, addrspace 3)
63 ...