1
+ ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
1
2
; RUN: llc -mtriple=amdgcn -verify-machineinstrs < %s | FileCheck -check-prefix=GCN %s
2
3
3
- ; GCN-LABEL: {{^}}and_i1_sext_bool:
4
- ; GCN: v_cmp_{{gt|le}}_u32_e{{32|64}} [[CC:[^,]+]], v{{[0-9]+}}, v{{[0-9]+}}
5
- ; GCN: v_cndmask_b32_e{{32|64}} [[VAL:v[0-9]+]], 0, v{{[0-9]+}}, [[CC]]
6
- ; GCN: store_dword {{.*}}[[VAL]]
7
- ; GCN-NOT: v_cndmask_b32_e64 v{{[0-9]+}}, {{0|-1}}, {{0|-1}}
8
- ; GCN-NOT: v_and_b32_e32
9
-
10
4
define amdgpu_kernel void @and_i1_sext_bool (ptr addrspace (1 ) nocapture %arg ) {
5
+ ; GCN-LABEL: and_i1_sext_bool:
6
+ ; GCN: ; %bb.0: ; %bb
7
+ ; GCN-NEXT: s_load_dwordx2 s[0:1], s[4:5], 0x9
8
+ ; GCN-NEXT: s_mov_b32 s3, 0xf000
9
+ ; GCN-NEXT: s_mov_b32 s2, 0
10
+ ; GCN-NEXT: v_lshlrev_b32_e32 v2, 2, v0
11
+ ; GCN-NEXT: v_mov_b32_e32 v3, 0
12
+ ; GCN-NEXT: s_waitcnt lgkmcnt(0)
13
+ ; GCN-NEXT: buffer_load_dword v4, v[2:3], s[0:3], 0 addr64
14
+ ; GCN-NEXT: v_cmp_gt_u32_e32 vcc, v0, v1
15
+ ; GCN-NEXT: s_waitcnt vmcnt(0)
16
+ ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v4, vcc
17
+ ; GCN-NEXT: buffer_store_dword v0, v[2:3], s[0:3], 0 addr64
18
+ ; GCN-NEXT: s_endpgm
11
19
bb:
12
20
%x = tail call i32 @llvm.amdgcn.workitem.id.x ()
13
21
%y = tail call i32 @llvm.amdgcn.workitem.id.y ()
@@ -20,112 +28,120 @@ bb:
20
28
ret void
21
29
}
22
30
23
- ; GCN-LABEL: {{^}}and_sext_bool_fcmp:
24
- ; GCN: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
25
- ; GCN-NEXT: v_cmp_eq_f32_e32 vcc, 0, v0
26
- ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
27
- ; GCN-NEXT: s_setpc_b64
28
31
define i32 @and_sext_bool_fcmp (float %x , i32 %y ) {
32
+ ; GCN-LABEL: and_sext_bool_fcmp:
33
+ ; GCN: ; %bb.0:
34
+ ; GCN-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
35
+ ; GCN-NEXT: v_cmp_eq_f32_e32 vcc, 0, v0
36
+ ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
37
+ ; GCN-NEXT: s_setpc_b64 s[30:31]
29
38
%cmp = fcmp oeq float %x , 0 .0
30
39
%sext = sext i1 %cmp to i32
31
40
%and = and i32 %sext , %y
32
41
ret i32 %and
33
42
}
34
43
35
- ; GCN-LABEL: {{^}}and_sext_bool_fpclass:
36
- ; GCN: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
37
- ; GCN-NEXT: v_mov_b32_e32 [[K:v[0-9]+]], 0x7b
38
- ; GCN-NEXT: v_cmp_class_f32_e32 vcc, v0, [[K]]
39
- ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
40
- ; GCN-NEXT: s_setpc_b64
41
44
define i32 @and_sext_bool_fpclass (float %x , i32 %y ) {
45
+ ; GCN-LABEL: and_sext_bool_fpclass:
46
+ ; GCN: ; %bb.0:
47
+ ; GCN-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
48
+ ; GCN-NEXT: v_mov_b32_e32 v2, 0x7b
49
+ ; GCN-NEXT: v_cmp_class_f32_e32 vcc, v0, v2
50
+ ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
51
+ ; GCN-NEXT: s_setpc_b64 s[30:31]
42
52
%class = call i1 @llvm.is.fpclass (float %x , i32 123 )
43
53
%sext = sext i1 %class to i32
44
54
%and = and i32 %sext , %y
45
55
ret i32 %and
46
56
}
47
57
48
- ; GCN-LABEL: {{^}}and_sext_bool_uadd_w_overflow:
49
- ; GCN: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
50
- ; GCN-NEXT: v_add_i32_e32 v0, vcc, v0, v1
51
- ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
52
- ; GCN-NEXT: s_setpc_b64
53
58
define i32 @and_sext_bool_uadd_w_overflow (i32 %x , i32 %y ) {
59
+ ; GCN-LABEL: and_sext_bool_uadd_w_overflow:
60
+ ; GCN: ; %bb.0:
61
+ ; GCN-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
62
+ ; GCN-NEXT: v_add_i32_e32 v0, vcc, v0, v1
63
+ ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
64
+ ; GCN-NEXT: s_setpc_b64 s[30:31]
54
65
%uadd = call { i32 , i1 } @llvm.uadd.with.overflow.i32 (i32 %x , i32 %y )
55
66
%carry = extractvalue { i32 , i1 } %uadd , 1
56
67
%sext = sext i1 %carry to i32
57
68
%and = and i32 %sext , %y
58
69
ret i32 %and
59
70
}
60
71
61
- ; GCN-LABEL: {{^}}and_sext_bool_usub_w_overflow:
62
- ; GCN: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
63
- ; GCN-NEXT: v_sub_i32_e32 v0, vcc, v0, v1
64
- ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
65
- ; GCN-NEXT: s_setpc_b64
66
72
define i32 @and_sext_bool_usub_w_overflow (i32 %x , i32 %y ) {
73
+ ; GCN-LABEL: and_sext_bool_usub_w_overflow:
74
+ ; GCN: ; %bb.0:
75
+ ; GCN-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
76
+ ; GCN-NEXT: v_sub_i32_e32 v0, vcc, v0, v1
77
+ ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
78
+ ; GCN-NEXT: s_setpc_b64 s[30:31]
67
79
%uadd = call { i32 , i1 } @llvm.usub.with.overflow.i32 (i32 %x , i32 %y )
68
80
%carry = extractvalue { i32 , i1 } %uadd , 1
69
81
%sext = sext i1 %carry to i32
70
82
%and = and i32 %sext , %y
71
83
ret i32 %and
72
84
}
73
85
74
- ; GCN-LABEL: {{^}}and_sext_bool_sadd_w_overflow:
75
- ; GCN: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
76
- ; GCN-NEXT: v_cmp_gt_i32_e32 vcc, 0, v1
77
- ; GCN-NEXT: v_add_i32_e64 v2, s[4:5], v0, v1
78
- ; GCN-NEXT: v_cmp_lt_i32_e64 s[4:5], v2, v0
79
- ; GCN-NEXT: s_xor_b64 vcc, vcc, s[4:5]
80
- ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
81
- ; GCN-NEXT: s_setpc_b64
82
86
define i32 @and_sext_bool_sadd_w_overflow (i32 %x , i32 %y ) {
87
+ ; GCN-LABEL: and_sext_bool_sadd_w_overflow:
88
+ ; GCN: ; %bb.0:
89
+ ; GCN-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
90
+ ; GCN-NEXT: v_cmp_gt_i32_e32 vcc, 0, v1
91
+ ; GCN-NEXT: v_add_i32_e64 v2, s[4:5], v0, v1
92
+ ; GCN-NEXT: v_cmp_lt_i32_e64 s[4:5], v2, v0
93
+ ; GCN-NEXT: s_xor_b64 vcc, vcc, s[4:5]
94
+ ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
95
+ ; GCN-NEXT: s_setpc_b64 s[30:31]
83
96
%uadd = call { i32 , i1 } @llvm.sadd.with.overflow.i32 (i32 %x , i32 %y )
84
97
%carry = extractvalue { i32 , i1 } %uadd , 1
85
98
%sext = sext i1 %carry to i32
86
99
%and = and i32 %sext , %y
87
100
ret i32 %and
88
101
}
89
102
90
- ; GCN-LABEL: {{^}}and_sext_bool_ssub_w_overflow:
91
- ; GCN: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
92
- ; GCN-NEXT: v_cmp_gt_i32_e32 vcc, 0, v1
93
- ; GCN-NEXT: v_add_i32_e64 v2, s[4:5], v0, v1
94
- ; GCN-NEXT: v_cmp_lt_i32_e64 s[4:5], v2, v0
95
- ; GCN-NEXT: s_xor_b64 vcc, vcc, s[4:5]
96
- ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
97
- ; GCN-NEXT: s_setpc_b64
98
103
define i32 @and_sext_bool_ssub_w_overflow (i32 %x , i32 %y ) {
104
+ ; GCN-LABEL: and_sext_bool_ssub_w_overflow:
105
+ ; GCN: ; %bb.0:
106
+ ; GCN-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
107
+ ; GCN-NEXT: v_cmp_gt_i32_e32 vcc, 0, v1
108
+ ; GCN-NEXT: v_add_i32_e64 v2, s[4:5], v0, v1
109
+ ; GCN-NEXT: v_cmp_lt_i32_e64 s[4:5], v2, v0
110
+ ; GCN-NEXT: s_xor_b64 vcc, vcc, s[4:5]
111
+ ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
112
+ ; GCN-NEXT: s_setpc_b64 s[30:31]
99
113
%uadd = call { i32 , i1 } @llvm.sadd.with.overflow.i32 (i32 %x , i32 %y )
100
114
%carry = extractvalue { i32 , i1 } %uadd , 1
101
115
%sext = sext i1 %carry to i32
102
116
%and = and i32 %sext , %y
103
117
ret i32 %and
104
118
}
105
119
106
- ; GCN-LABEL: {{^}}and_sext_bool_smul_w_overflow:
107
- ; GCN: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
108
- ; GCN-NEXT: v_mul_hi_i32 v2, v0, v1
109
- ; GCN-NEXT: v_mul_lo_u32 v0, v0, v1
110
- ; GCN-NEXT: v_ashrrev_i32_e32 v0, 31, v0
111
- ; GCN-NEXT: v_cmp_ne_u32_e32 vcc, v2, v0
112
- ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
113
- ; GCN-NEXT: s_setpc_b64
114
120
define i32 @and_sext_bool_smul_w_overflow (i32 %x , i32 %y ) {
121
+ ; GCN-LABEL: and_sext_bool_smul_w_overflow:
122
+ ; GCN: ; %bb.0:
123
+ ; GCN-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
124
+ ; GCN-NEXT: v_mul_hi_i32 v2, v0, v1
125
+ ; GCN-NEXT: v_mul_lo_u32 v0, v0, v1
126
+ ; GCN-NEXT: v_ashrrev_i32_e32 v0, 31, v0
127
+ ; GCN-NEXT: v_cmp_ne_u32_e32 vcc, v2, v0
128
+ ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
129
+ ; GCN-NEXT: s_setpc_b64 s[30:31]
115
130
%uadd = call { i32 , i1 } @llvm.smul.with.overflow.i32 (i32 %x , i32 %y )
116
131
%carry = extractvalue { i32 , i1 } %uadd , 1
117
132
%sext = sext i1 %carry to i32
118
133
%and = and i32 %sext , %y
119
134
ret i32 %and
120
135
}
121
136
122
- ; GCN-LABEL: {{^}}and_sext_bool_umul_w_overflow:
123
- ; GCN: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
124
- ; GCN-NEXT: v_mul_hi_u32 v0, v0, v1
125
- ; GCN-NEXT: v_cmp_ne_u32_e32 vcc, 0, v0
126
- ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
127
- ; GCN-NEXT: s_setpc_b64
128
137
define i32 @and_sext_bool_umul_w_overflow (i32 %x , i32 %y ) {
138
+ ; GCN-LABEL: and_sext_bool_umul_w_overflow:
139
+ ; GCN: ; %bb.0:
140
+ ; GCN-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
141
+ ; GCN-NEXT: v_mul_hi_u32 v0, v0, v1
142
+ ; GCN-NEXT: v_cmp_ne_u32_e32 vcc, 0, v0
143
+ ; GCN-NEXT: v_cndmask_b32_e32 v0, 0, v1, vcc
144
+ ; GCN-NEXT: s_setpc_b64 s[30:31]
129
145
%uadd = call { i32 , i1 } @llvm.umul.with.overflow.i32 (i32 %x , i32 %y )
130
146
%carry = extractvalue { i32 , i1 } %uadd , 1
131
147
%sext = sext i1 %carry to i32
0 commit comments