1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -march=amdgcn -mcpu=tahiti -run-pass=instruction-select -verify-machineinstrs -o - %s | FileCheck -check-prefix=GFX6 %s
3 # RUN: llc -march=amdgcn -mcpu=fiji -run-pass=instruction-select -verify-machineinstrs -o - %s | FileCheck -check-prefix=GFX8 %s
4 # RUN: llc -march=amdgcn -mcpu=gfx900 -run-pass=instruction-select -verify-machineinstrs -o - %s | FileCheck -check-prefix=GFX9 %s
5 # RUN: llc -march=amdgcn -mcpu=gfx1010 -run-pass=instruction-select -verify-machineinstrs -o - %s | FileCheck -check-prefix=GFX10 %s
14 liveins: $sgpr0, $sgpr1
16 ; GFX6-LABEL: name: usubo_s32_s1_sss
17 ; GFX6: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
18 ; GFX6: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
19 ; GFX6: [[S_SUB_U32_:%[0-9]+]]:sreg_32 = S_SUB_U32 [[COPY]], [[COPY1]], implicit-def $scc
20 ; GFX6: [[COPY2:%[0-9]+]]:sreg_32 = COPY $scc
21 ; GFX6: $scc = COPY [[COPY2]]
22 ; GFX6: [[S_CSELECT_B32_:%[0-9]+]]:sreg_32 = S_CSELECT_B32 [[COPY]], [[COPY1]], implicit $scc
23 ; GFX6: S_ENDPGM 0, implicit [[S_SUB_U32_]], implicit [[S_CSELECT_B32_]]
24 ; GFX8-LABEL: name: usubo_s32_s1_sss
25 ; GFX8: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
26 ; GFX8: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
27 ; GFX8: [[S_SUB_U32_:%[0-9]+]]:sreg_32 = S_SUB_U32 [[COPY]], [[COPY1]], implicit-def $scc
28 ; GFX8: [[COPY2:%[0-9]+]]:sreg_32 = COPY $scc
29 ; GFX8: $scc = COPY [[COPY2]]
30 ; GFX8: [[S_CSELECT_B32_:%[0-9]+]]:sreg_32 = S_CSELECT_B32 [[COPY]], [[COPY1]], implicit $scc
31 ; GFX8: S_ENDPGM 0, implicit [[S_SUB_U32_]], implicit [[S_CSELECT_B32_]]
32 ; GFX9-LABEL: name: usubo_s32_s1_sss
33 ; GFX9: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
34 ; GFX9: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
35 ; GFX9: [[S_SUB_U32_:%[0-9]+]]:sreg_32 = S_SUB_U32 [[COPY]], [[COPY1]], implicit-def $scc
36 ; GFX9: [[COPY2:%[0-9]+]]:sreg_32 = COPY $scc
37 ; GFX9: $scc = COPY [[COPY2]]
38 ; GFX9: [[S_CSELECT_B32_:%[0-9]+]]:sreg_32 = S_CSELECT_B32 [[COPY]], [[COPY1]], implicit $scc
39 ; GFX9: S_ENDPGM 0, implicit [[S_SUB_U32_]], implicit [[S_CSELECT_B32_]]
40 ; GFX10-LABEL: name: usubo_s32_s1_sss
41 ; GFX10: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
42 ; GFX10: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr1
43 ; GFX10: [[S_SUB_U32_:%[0-9]+]]:sreg_32 = S_SUB_U32 [[COPY]], [[COPY1]], implicit-def $scc
44 ; GFX10: [[COPY2:%[0-9]+]]:sreg_32 = COPY $scc
45 ; GFX10: $scc = COPY [[COPY2]]
46 ; GFX10: [[S_CSELECT_B32_:%[0-9]+]]:sreg_32 = S_CSELECT_B32 [[COPY]], [[COPY1]], implicit $scc
47 ; GFX10: S_ENDPGM 0, implicit [[S_SUB_U32_]], implicit [[S_CSELECT_B32_]]
48 %0:sgpr(s32) = COPY $sgpr0
49 %1:sgpr(s32) = COPY $sgpr1
50 %2:sgpr(s32), %3:sgpr(s32) = G_USUBO %0, %1
51 %4:sgpr(s32) = G_SELECT %3, %0, %1
52 S_ENDPGM 0, implicit %2, implicit %4
56 name: usubo_s32_s1_vvv
62 liveins: $vgpr0, $vgpr1
64 ; GFX6-LABEL: name: usubo_s32_s1_vvv
65 ; GFX6: [[COPY:%[0-9]+]]:vgpr_32 = COPY $vgpr0
66 ; GFX6: [[COPY1:%[0-9]+]]:vgpr_32 = COPY $vgpr1
67 ; GFX6: [[V_SUB_CO_U32_e64_:%[0-9]+]]:vgpr_32, [[V_SUB_CO_U32_e64_1:%[0-9]+]]:sreg_64_xexec = V_SUB_CO_U32_e64 [[COPY]], [[COPY1]], 0, implicit $exec
68 ; GFX6: [[V_CNDMASK_B32_e64_:%[0-9]+]]:vgpr_32 = V_CNDMASK_B32_e64 0, [[COPY1]], 0, [[COPY]], [[V_SUB_CO_U32_e64_1]], implicit $exec
69 ; GFX6: S_ENDPGM 0, implicit [[V_SUB_CO_U32_e64_]], implicit [[V_CNDMASK_B32_e64_]]
70 ; GFX8-LABEL: name: usubo_s32_s1_vvv
71 ; GFX8: [[COPY:%[0-9]+]]:vgpr_32 = COPY $vgpr0
72 ; GFX8: [[COPY1:%[0-9]+]]:vgpr_32 = COPY $vgpr1
73 ; GFX8: [[V_SUB_CO_U32_e64_:%[0-9]+]]:vgpr_32, [[V_SUB_CO_U32_e64_1:%[0-9]+]]:sreg_64_xexec = V_SUB_CO_U32_e64 [[COPY]], [[COPY1]], 0, implicit $exec
74 ; GFX8: [[V_CNDMASK_B32_e64_:%[0-9]+]]:vgpr_32 = V_CNDMASK_B32_e64 0, [[COPY1]], 0, [[COPY]], [[V_SUB_CO_U32_e64_1]], implicit $exec
75 ; GFX8: S_ENDPGM 0, implicit [[V_SUB_CO_U32_e64_]], implicit [[V_CNDMASK_B32_e64_]]
76 ; GFX9-LABEL: name: usubo_s32_s1_vvv
77 ; GFX9: [[COPY:%[0-9]+]]:vgpr_32 = COPY $vgpr0
78 ; GFX9: [[COPY1:%[0-9]+]]:vgpr_32 = COPY $vgpr1
79 ; GFX9: [[V_SUB_CO_U32_e64_:%[0-9]+]]:vgpr_32, [[V_SUB_CO_U32_e64_1:%[0-9]+]]:sreg_64_xexec = V_SUB_CO_U32_e64 [[COPY]], [[COPY1]], 0, implicit $exec
80 ; GFX9: [[V_CNDMASK_B32_e64_:%[0-9]+]]:vgpr_32 = V_CNDMASK_B32_e64 0, [[COPY1]], 0, [[COPY]], [[V_SUB_CO_U32_e64_1]], implicit $exec
81 ; GFX9: S_ENDPGM 0, implicit [[V_SUB_CO_U32_e64_]], implicit [[V_CNDMASK_B32_e64_]]
82 ; GFX10-LABEL: name: usubo_s32_s1_vvv
83 ; GFX10: [[COPY:%[0-9]+]]:vgpr_32 = COPY $vgpr0
84 ; GFX10: [[COPY1:%[0-9]+]]:vgpr_32 = COPY $vgpr1
85 ; GFX10: [[V_SUB_CO_U32_e64_:%[0-9]+]]:vgpr_32, [[V_SUB_CO_U32_e64_1:%[0-9]+]]:sreg_32_xm0_xexec = V_SUB_CO_U32_e64 [[COPY]], [[COPY1]], 0, implicit $exec
86 ; GFX10: [[V_CNDMASK_B32_e64_:%[0-9]+]]:vgpr_32 = V_CNDMASK_B32_e64 0, [[COPY1]], 0, [[COPY]], [[V_SUB_CO_U32_e64_1]], implicit $exec
87 ; GFX10: S_ENDPGM 0, implicit [[V_SUB_CO_U32_e64_]], implicit [[V_CNDMASK_B32_e64_]]
88 %0:vgpr(s32) = COPY $vgpr0
89 %1:vgpr(s32) = COPY $vgpr1
90 %2:vgpr(s32), %3:vcc(s1) = G_USUBO %0, %1
91 %4:vgpr(s32) = G_SELECT %3, %0, %1
92 S_ENDPGM 0, implicit %2, implicit %4
96 name: usubo_s32_s1_vsv
102 liveins: $sgpr0, $vgpr0
104 ; GFX6-LABEL: name: usubo_s32_s1_vsv
105 ; GFX6: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
106 ; GFX6: [[COPY1:%[0-9]+]]:vgpr_32 = COPY $vgpr0
107 ; GFX6: [[V_SUB_CO_U32_e64_:%[0-9]+]]:vgpr_32, [[V_SUB_CO_U32_e64_1:%[0-9]+]]:sreg_64_xexec = V_SUB_CO_U32_e64 [[COPY]], [[COPY1]], 0, implicit $exec
108 ; GFX6: [[V_MOV_B32_e32_:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 0, implicit $exec
109 ; GFX6: [[V_MOV_B32_e32_1:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 1, implicit $exec
110 ; GFX6: [[V_CNDMASK_B32_e64_:%[0-9]+]]:vgpr_32 = V_CNDMASK_B32_e64 0, [[V_MOV_B32_e32_1]], 0, [[V_MOV_B32_e32_]], [[V_SUB_CO_U32_e64_1]], implicit $exec
111 ; GFX6: S_ENDPGM 0, implicit [[V_SUB_CO_U32_e64_]], implicit [[V_CNDMASK_B32_e64_]]
112 ; GFX8-LABEL: name: usubo_s32_s1_vsv
113 ; GFX8: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
114 ; GFX8: [[COPY1:%[0-9]+]]:vgpr_32 = COPY $vgpr0
115 ; GFX8: [[V_SUB_CO_U32_e64_:%[0-9]+]]:vgpr_32, [[V_SUB_CO_U32_e64_1:%[0-9]+]]:sreg_64_xexec = V_SUB_CO_U32_e64 [[COPY]], [[COPY1]], 0, implicit $exec
116 ; GFX8: [[V_MOV_B32_e32_:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 0, implicit $exec
117 ; GFX8: [[V_MOV_B32_e32_1:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 1, implicit $exec
118 ; GFX8: [[V_CNDMASK_B32_e64_:%[0-9]+]]:vgpr_32 = V_CNDMASK_B32_e64 0, [[V_MOV_B32_e32_1]], 0, [[V_MOV_B32_e32_]], [[V_SUB_CO_U32_e64_1]], implicit $exec
119 ; GFX8: S_ENDPGM 0, implicit [[V_SUB_CO_U32_e64_]], implicit [[V_CNDMASK_B32_e64_]]
120 ; GFX9-LABEL: name: usubo_s32_s1_vsv
121 ; GFX9: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
122 ; GFX9: [[COPY1:%[0-9]+]]:vgpr_32 = COPY $vgpr0
123 ; GFX9: [[V_SUB_CO_U32_e64_:%[0-9]+]]:vgpr_32, [[V_SUB_CO_U32_e64_1:%[0-9]+]]:sreg_64_xexec = V_SUB_CO_U32_e64 [[COPY]], [[COPY1]], 0, implicit $exec
124 ; GFX9: [[V_MOV_B32_e32_:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 0, implicit $exec
125 ; GFX9: [[V_MOV_B32_e32_1:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 1, implicit $exec
126 ; GFX9: [[V_CNDMASK_B32_e64_:%[0-9]+]]:vgpr_32 = V_CNDMASK_B32_e64 0, [[V_MOV_B32_e32_1]], 0, [[V_MOV_B32_e32_]], [[V_SUB_CO_U32_e64_1]], implicit $exec
127 ; GFX9: S_ENDPGM 0, implicit [[V_SUB_CO_U32_e64_]], implicit [[V_CNDMASK_B32_e64_]]
128 ; GFX10-LABEL: name: usubo_s32_s1_vsv
129 ; GFX10: [[COPY:%[0-9]+]]:sreg_32 = COPY $sgpr0
130 ; GFX10: [[COPY1:%[0-9]+]]:vgpr_32 = COPY $vgpr0
131 ; GFX10: [[V_SUB_CO_U32_e64_:%[0-9]+]]:vgpr_32, [[V_SUB_CO_U32_e64_1:%[0-9]+]]:sreg_32_xm0_xexec = V_SUB_CO_U32_e64 [[COPY]], [[COPY1]], 0, implicit $exec
132 ; GFX10: [[V_MOV_B32_e32_:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 0, implicit $exec
133 ; GFX10: [[V_MOV_B32_e32_1:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 1, implicit $exec
134 ; GFX10: [[V_CNDMASK_B32_e64_:%[0-9]+]]:vgpr_32 = V_CNDMASK_B32_e64 0, [[V_MOV_B32_e32_1]], 0, [[V_MOV_B32_e32_]], [[V_SUB_CO_U32_e64_1]], implicit $exec
135 ; GFX10: S_ENDPGM 0, implicit [[V_SUB_CO_U32_e64_]], implicit [[V_CNDMASK_B32_e64_]]
136 %0:sgpr(s32) = COPY $sgpr0
137 %1:vgpr(s32) = COPY $vgpr0
138 %2:vgpr(s32), %3:vcc(s1) = G_USUBO %0, %1
139 %4:vgpr(s32) = G_CONSTANT i32 0
140 %5:vgpr(s32) = G_CONSTANT i32 1
141 %6:vgpr(s32) = G_SELECT %3, %4, %5
142 S_ENDPGM 0, implicit %2, implicit %6
146 name: usubo_s32_s1_vvs
148 regBankSelected: true
152 liveins: $sgpr0, $vgpr0
154 ; GFX6-LABEL: name: usubo_s32_s1_vvs
155 ; GFX6: [[COPY:%[0-9]+]]:vgpr_32 = COPY $vgpr0
156 ; GFX6: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr0
157 ; GFX6: [[V_SUB_CO_U32_e64_:%[0-9]+]]:vgpr_32, [[V_SUB_CO_U32_e64_1:%[0-9]+]]:sreg_64_xexec = V_SUB_CO_U32_e64 [[COPY]], [[COPY1]], 0, implicit $exec
158 ; GFX6: [[V_MOV_B32_e32_:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 0, implicit $exec
159 ; GFX6: [[V_MOV_B32_e32_1:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 1, implicit $exec
160 ; GFX6: [[V_CNDMASK_B32_e64_:%[0-9]+]]:vgpr_32 = V_CNDMASK_B32_e64 0, [[V_MOV_B32_e32_1]], 0, [[V_MOV_B32_e32_]], [[V_SUB_CO_U32_e64_1]], implicit $exec
161 ; GFX6: S_ENDPGM 0, implicit [[V_SUB_CO_U32_e64_]], implicit [[V_CNDMASK_B32_e64_]]
162 ; GFX8-LABEL: name: usubo_s32_s1_vvs
163 ; GFX8: [[COPY:%[0-9]+]]:vgpr_32 = COPY $vgpr0
164 ; GFX8: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr0
165 ; GFX8: [[V_SUB_CO_U32_e64_:%[0-9]+]]:vgpr_32, [[V_SUB_CO_U32_e64_1:%[0-9]+]]:sreg_64_xexec = V_SUB_CO_U32_e64 [[COPY]], [[COPY1]], 0, implicit $exec
166 ; GFX8: [[V_MOV_B32_e32_:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 0, implicit $exec
167 ; GFX8: [[V_MOV_B32_e32_1:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 1, implicit $exec
168 ; GFX8: [[V_CNDMASK_B32_e64_:%[0-9]+]]:vgpr_32 = V_CNDMASK_B32_e64 0, [[V_MOV_B32_e32_1]], 0, [[V_MOV_B32_e32_]], [[V_SUB_CO_U32_e64_1]], implicit $exec
169 ; GFX8: S_ENDPGM 0, implicit [[V_SUB_CO_U32_e64_]], implicit [[V_CNDMASK_B32_e64_]]
170 ; GFX9-LABEL: name: usubo_s32_s1_vvs
171 ; GFX9: [[COPY:%[0-9]+]]:vgpr_32 = COPY $vgpr0
172 ; GFX9: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr0
173 ; GFX9: [[V_SUB_CO_U32_e64_:%[0-9]+]]:vgpr_32, [[V_SUB_CO_U32_e64_1:%[0-9]+]]:sreg_64_xexec = V_SUB_CO_U32_e64 [[COPY]], [[COPY1]], 0, implicit $exec
174 ; GFX9: [[V_MOV_B32_e32_:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 0, implicit $exec
175 ; GFX9: [[V_MOV_B32_e32_1:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 1, implicit $exec
176 ; GFX9: [[V_CNDMASK_B32_e64_:%[0-9]+]]:vgpr_32 = V_CNDMASK_B32_e64 0, [[V_MOV_B32_e32_1]], 0, [[V_MOV_B32_e32_]], [[V_SUB_CO_U32_e64_1]], implicit $exec
177 ; GFX9: S_ENDPGM 0, implicit [[V_SUB_CO_U32_e64_]], implicit [[V_CNDMASK_B32_e64_]]
178 ; GFX10-LABEL: name: usubo_s32_s1_vvs
179 ; GFX10: [[COPY:%[0-9]+]]:vgpr_32 = COPY $vgpr0
180 ; GFX10: [[COPY1:%[0-9]+]]:sreg_32 = COPY $sgpr0
181 ; GFX10: [[V_SUB_CO_U32_e64_:%[0-9]+]]:vgpr_32, [[V_SUB_CO_U32_e64_1:%[0-9]+]]:sreg_32_xm0_xexec = V_SUB_CO_U32_e64 [[COPY]], [[COPY1]], 0, implicit $exec
182 ; GFX10: [[V_MOV_B32_e32_:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 0, implicit $exec
183 ; GFX10: [[V_MOV_B32_e32_1:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 1, implicit $exec
184 ; GFX10: [[V_CNDMASK_B32_e64_:%[0-9]+]]:vgpr_32 = V_CNDMASK_B32_e64 0, [[V_MOV_B32_e32_1]], 0, [[V_MOV_B32_e32_]], [[V_SUB_CO_U32_e64_1]], implicit $exec
185 ; GFX10: S_ENDPGM 0, implicit [[V_SUB_CO_U32_e64_]], implicit [[V_CNDMASK_B32_e64_]]
186 %0:vgpr(s32) = COPY $vgpr0
187 %1:sgpr(s32) = COPY $sgpr0
188 %2:vgpr(s32), %3:vcc(s1) = G_USUBO %0, %1
189 %4:vgpr(s32) = G_CONSTANT i32 0
190 %5:vgpr(s32) = G_CONSTANT i32 1
191 %6:vgpr(s32) = G_SELECT %3, %4, %5
192 S_ENDPGM 0, implicit %2, implicit %6