You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Extends what we already do for i1 types and don't serialize vXi1 logical expressions to improve ILP.
llvm-test-suite numbers
#64840 (comment)
indicate that both reassociations are a net win.
Fixes#64840Fixes#63946
Copy file name to clipboardExpand all lines: llvm/test/Transforms/Reassociate/reassoc_bool_vec.ll
+72-71Lines changed: 72 additions & 71 deletions
Original file line number
Diff line number
Diff line change
@@ -4,13 +4,13 @@
4
4
define <8 x i1> @vector0(<8 x i1> %b0, <8 x i1> %b1, <8 x i1> %b2, <8 x i1> %b3, <8 x i1> %b4, <8 x i1> %b5, <8 x i1> %b6, <8 x i1> %b7) {
5
5
; CHECK-LABEL: define <8 x i1> @vector0(
6
6
; CHECK-SAME: <8 x i1> [[B0:%.*]], <8 x i1> [[B1:%.*]], <8 x i1> [[B2:%.*]], <8 x i1> [[B3:%.*]], <8 x i1> [[B4:%.*]], <8 x i1> [[B5:%.*]], <8 x i1> [[B6:%.*]], <8 x i1> [[B7:%.*]]) {
7
-
; CHECK-NEXT: [[OR67:%.*]] = or <8 x i1> [[B1]], [[B0]]
8
-
; CHECK-NEXT: [[OR45:%.*]] = or <8 x i1> [[OR67]], [[B2]]
9
-
; CHECK-NEXT: [[OR4567:%.*]] = or <8 x i1> [[OR45]], [[B3]]
10
-
; CHECK-NEXT: [[OR23:%.*]] = or <8 x i1> [[OR4567]], [[B4]]
11
-
; CHECK-NEXT: [[OR01:%.*]] = or <8 x i1> [[OR23]], [[B5]]
12
-
; CHECK-NEXT: [[OR0123:%.*]] = or <8 x i1> [[OR01]], [[B6]]
13
-
; CHECK-NEXT: [[OR01234567:%.*]] = or <8 x i1> [[OR0123]], [[B7]]
7
+
; CHECK-NEXT: [[OR01:%.*]] = or <8 x i1> [[B0]], [[B1]]
8
+
; CHECK-NEXT: [[OR23:%.*]] = or <8 x i1> [[B2]], [[B3]]
9
+
; CHECK-NEXT: [[OR45:%.*]] = or <8 x i1> [[B4]], [[B5]]
10
+
; CHECK-NEXT: [[OR67:%.*]] = or <8 x i1> [[B6]], [[B7]]
11
+
; CHECK-NEXT: [[OR0123:%.*]] = or <8 x i1> [[OR01]], [[OR23]]
12
+
; CHECK-NEXT: [[OR4567:%.*]] = or <8 x i1> [[OR45]], [[OR67]]
13
+
; CHECK-NEXT: [[OR01234567:%.*]] = or <8 x i1> [[OR0123]], [[OR4567]]
14
14
; CHECK-NEXT: ret <8 x i1> [[OR01234567]]
15
15
;
16
16
%or01 = or <8 x i1> %b0, %b1
@@ -26,13 +26,13 @@ define <8 x i1> @vector0(<8 x i1> %b0, <8 x i1> %b1, <8 x i1> %b2, <8 x i1> %b3,
26
26
define <8 x i1> @vector1(<8 x i1> %b0, <8 x i1> %b1, <8 x i1> %b2, <8 x i1> %b3, <8 x i1> %b4, <8 x i1> %b5, <8 x i1> %b6, <8 x i1> %b7) {
27
27
; CHECK-LABEL: define <8 x i1> @vector1(
28
28
; CHECK-SAME: <8 x i1> [[B0:%.*]], <8 x i1> [[B1:%.*]], <8 x i1> [[B2:%.*]], <8 x i1> [[B3:%.*]], <8 x i1> [[B4:%.*]], <8 x i1> [[B5:%.*]], <8 x i1> [[B6:%.*]], <8 x i1> [[B7:%.*]]) {
29
-
; CHECK-NEXT: [[OR67:%.*]] = and <8 x i1> [[B1]], [[B0]]
30
-
; CHECK-NEXT: [[OR45:%.*]] = and <8 x i1> [[OR67]], [[B2]]
31
-
; CHECK-NEXT: [[OR4567:%.*]] = and <8 x i1> [[OR45]], [[B3]]
32
-
; CHECK-NEXT: [[OR23:%.*]] = and <8 x i1> [[OR4567]], [[B4]]
33
-
; CHECK-NEXT: [[OR01:%.*]] = and <8 x i1> [[OR23]], [[B5]]
34
-
; CHECK-NEXT: [[OR0123:%.*]] = and <8 x i1> [[OR01]], [[B6]]
35
-
; CHECK-NEXT: [[OR01234567:%.*]] = and <8 x i1> [[OR0123]], [[B7]]
29
+
; CHECK-NEXT: [[OR01:%.*]] = and <8 x i1> [[B0]], [[B1]]
30
+
; CHECK-NEXT: [[OR23:%.*]] = and <8 x i1> [[B2]], [[B3]]
31
+
; CHECK-NEXT: [[OR45:%.*]] = and <8 x i1> [[B4]], [[B5]]
32
+
; CHECK-NEXT: [[OR67:%.*]] = and <8 x i1> [[B6]], [[B7]]
33
+
; CHECK-NEXT: [[OR0123:%.*]] = and <8 x i1> [[OR01]], [[OR23]]
34
+
; CHECK-NEXT: [[OR4567:%.*]] = and <8 x i1> [[OR45]], [[OR67]]
35
+
; CHECK-NEXT: [[OR01234567:%.*]] = and <8 x i1> [[OR0123]], [[OR4567]]
36
36
; CHECK-NEXT: ret <8 x i1> [[OR01234567]]
37
37
;
38
38
%or01 = and <8 x i1> %b0, %b1
@@ -48,27 +48,28 @@ define <8 x i1> @vector1(<8 x i1> %b0, <8 x i1> %b1, <8 x i1> %b2, <8 x i1> %b3,
48
48
define <8 x i1> @vector2(<8 x i1> %a, <8 x i1> %b0, <8 x i1> %b1, <8 x i1> %b2, <8 x i1> %b3, <8 x i1> %b4, <8 x i1> %b5, <8 x i1> %b6, <8 x i1> %b7) {
49
49
; CHECK-LABEL: define <8 x i1> @vector2(
50
50
; CHECK-SAME: <8 x i1> [[A:%.*]], <8 x i1> [[B0:%.*]], <8 x i1> [[B1:%.*]], <8 x i1> [[B2:%.*]], <8 x i1> [[B3:%.*]], <8 x i1> [[B4:%.*]], <8 x i1> [[B5:%.*]], <8 x i1> [[B6:%.*]], <8 x i1> [[B7:%.*]]) {
51
-
; CHECK-NEXT: [[OR0:%.*]] = or <8 x i1> [[B0]], [[A]]
52
-
; CHECK-NEXT: [[OR1:%.*]] = or <8 x i1> [[B1]], [[A]]
53
-
; CHECK-NEXT: [[OR2:%.*]] = or <8 x i1> [[B2]], [[A]]
54
-
; CHECK-NEXT: [[OR3:%.*]] = or <8 x i1> [[B3]], [[A]]
55
-
; CHECK-NEXT: [[OR4:%.*]] = or <8 x i1> [[B4]], [[A]]
56
-
; CHECK-NEXT: [[OR5:%.*]] = or <8 x i1> [[B5]], [[A]]
57
-
; CHECK-NEXT: [[OR6:%.*]] = or <8 x i1> [[B6]], [[A]]
58
-
; CHECK-NEXT: [[OR7:%.*]] = or <8 x i1> [[B7]], [[A]]
59
-
; CHECK-NEXT: [[XOR2:%.*]] = xor <8 x i1> [[OR1]], [[OR0]]
60
-
; CHECK-NEXT: [[OR045:%.*]] = xor <8 x i1> [[XOR2]], [[OR2]]
61
-
; CHECK-NEXT: [[XOR3:%.*]] = xor <8 x i1> [[OR045]], [[OR3]]
62
-
; CHECK-NEXT: [[XOR4:%.*]] = xor <8 x i1> [[XOR3]], [[OR4]]
63
-
; CHECK-NEXT: [[XOR5:%.*]] = xor <8 x i1> [[XOR4]], [[OR5]]
64
-
; CHECK-NEXT: [[XOR6:%.*]] = xor <8 x i1> [[XOR5]], [[OR6]]
51
+
; CHECK-NEXT: [[OR0:%.*]] = or <8 x i1> [[A]], [[B0]]
52
+
; CHECK-NEXT: [[OR1:%.*]] = or <8 x i1> [[A]], [[B1]]
53
+
; CHECK-NEXT: [[OR2:%.*]] = or <8 x i1> [[A]], [[B2]]
54
+
; CHECK-NEXT: [[OR3:%.*]] = or <8 x i1> [[A]], [[B3]]
55
+
; CHECK-NEXT: [[OR7:%.*]] = or <8 x i1> [[A]], [[B4]]
56
+
; CHECK-NEXT: [[OR5:%.*]] = or <8 x i1> [[A]], [[B5]]
57
+
; CHECK-NEXT: [[OR6:%.*]] = or <8 x i1> [[A]], [[B6]]
58
+
; CHECK-NEXT: [[OR8:%.*]] = or <8 x i1> [[A]], [[B7]]
59
+
; CHECK-NEXT: [[OR045:%.*]] = xor <8 x i1> [[OR0]], [[OR1]]
60
+
; CHECK-NEXT: [[XOR2:%.*]] = xor <8 x i1> [[OR045]], [[OR2]]
61
+
; CHECK-NEXT: [[XOR6:%.*]] = xor <8 x i1> [[XOR2]], [[OR3]]
65
62
; CHECK-NEXT: [[XOR7:%.*]] = xor <8 x i1> [[XOR6]], [[OR7]]
63
+
; CHECK-NEXT: [[OR023:%.*]] = xor <8 x i1> [[XOR7]], [[OR5]]
64
+
; CHECK-NEXT: [[XOR4:%.*]] = xor <8 x i1> [[OR023]], [[OR6]]
65
+
; CHECK-NEXT: [[XOR8:%.*]] = xor <8 x i1> [[XOR4]], [[OR8]]
66
66
; CHECK-NEXT: [[OR4560:%.*]] = or <8 x i1> [[OR045]], [[XOR2]]
67
-
; CHECK-NEXT: [[OR023:%.*]] = or <8 x i1> [[OR4560]], [[XOR3]]
67
+
; CHECK-NEXT: [[OR23:%.*]] = or <8 x i1> [[XOR6]], [[XOR7]]
68
68
; CHECK-NEXT: [[OR001:%.*]] = or <8 x i1> [[OR023]], [[XOR4]]
69
+
; CHECK-NEXT: [[XOR5:%.*]] = or <8 x i1> [[OR045]], [[XOR8]]
70
+
; CHECK-NEXT: [[OR123:%.*]] = or <8 x i1> [[OR4560]], [[OR23]]
69
71
; CHECK-NEXT: [[OR0123:%.*]] = or <8 x i1> [[OR001]], [[XOR5]]
70
-
; CHECK-NEXT: [[OR01234567:%.*]] = or <8 x i1> [[OR0123]], [[XOR6]]
71
-
; CHECK-NEXT: [[OR1234567:%.*]] = or <8 x i1> [[OR01234567]], [[XOR7]]
72
+
; CHECK-NEXT: [[OR1234567:%.*]] = or <8 x i1> [[OR123]], [[OR0123]]
72
73
; CHECK-NEXT: ret <8 x i1> [[OR1234567]]
73
74
;
74
75
%or0 = or <8 x i1> %b0, %a
@@ -99,20 +100,20 @@ define <8 x i1> @vector2(<8 x i1> %a, <8 x i1> %b0, <8 x i1> %b1, <8 x i1> %b2,
99
100
define <8 x i1> @vector3(<8 x i1> %a, <8 x i1> %b0, <8 x i1> %b1, <8 x i1> %b2, <8 x i1> %b3, <8 x i1> %b4, <8 x i1> %b5, <8 x i1> %b6, <8 x i1> %b7) {
100
101
; CHECK-LABEL: define <8 x i1> @vector3(
101
102
; CHECK-SAME: <8 x i1> [[A:%.*]], <8 x i1> [[B0:%.*]], <8 x i1> [[B1:%.*]], <8 x i1> [[B2:%.*]], <8 x i1> [[B3:%.*]], <8 x i1> [[B4:%.*]], <8 x i1> [[B5:%.*]], <8 x i1> [[B6:%.*]], <8 x i1> [[B7:%.*]]) {
102
-
; CHECK-NEXT: [[OR0:%.*]] = or <8 x i1> [[B0]], [[A]]
103
-
; CHECK-NEXT: [[OR1:%.*]] = or <8 x i1> [[B1]], [[A]]
104
-
; CHECK-NEXT: [[OR2:%.*]] = or <8 x i1> [[B2]], [[A]]
105
-
; CHECK-NEXT: [[OR3:%.*]] = or <8 x i1> [[B3]], [[A]]
106
-
; CHECK-NEXT: [[OR4:%.*]] = or <8 x i1> [[B4]], [[A]]
107
-
; CHECK-NEXT: [[OR5:%.*]] = or <8 x i1> [[B5]], [[A]]
108
-
; CHECK-NEXT: [[OR6:%.*]] = or <8 x i1> [[B6]], [[A]]
109
-
; CHECK-NEXT: [[OR7:%.*]] = or <8 x i1> [[B7]], [[A]]
103
+
; CHECK-NEXT: [[OR1:%.*]] = or <8 x i1> [[A]], [[B0]]
104
+
; CHECK-NEXT: [[OR0:%.*]] = or <8 x i1> [[A]], [[B1]]
105
+
; CHECK-NEXT: [[OR2:%.*]] = or <8 x i1> [[A]], [[B2]]
106
+
; CHECK-NEXT: [[OR4:%.*]] = or <8 x i1> [[A]], [[B3]]
107
+
; CHECK-NEXT: [[XOR2:%.*]] = or <8 x i1> [[A]], [[B4]]
108
+
; CHECK-NEXT: [[OR3:%.*]] = or <8 x i1> [[A]], [[B5]]
109
+
; CHECK-NEXT: [[XOR0:%.*]] = or <8 x i1> [[A]], [[B6]]
110
+
; CHECK-NEXT: [[OR5:%.*]] = or <8 x i1> [[A]], [[B7]]
110
111
; CHECK-NEXT: [[XOR3:%.*]] = xor <8 x i1> [[OR1]], [[OR0]]
111
-
; CHECK-NEXT: [[XOR2:%.*]] = xor <8 x i1> [[XOR3]], [[OR2]]
112
+
; CHECK-NEXT: [[XOR1:%.*]] = xor <8 x i1> [[OR2]], [[OR4]]
112
113
; CHECK-NEXT: [[XOR7:%.*]] = xor <8 x i1> [[XOR2]], [[OR3]]
113
-
; CHECK-NEXT: [[XOR0:%.*]] = xor <8 x i1> [[XOR7]], [[OR4]]
114
114
; CHECK-NEXT: [[XOR4:%.*]] = xor <8 x i1> [[XOR0]], [[OR5]]
115
-
; CHECK-NEXT: [[XOR5:%.*]] = xor <8 x i1> [[XOR4]], [[OR6]]
115
+
; CHECK-NEXT: [[XOR5:%.*]] = xor <8 x i1> [[XOR3]], [[XOR1]]
116
+
; CHECK-NEXT: [[OR7:%.*]] = xor <8 x i1> [[XOR7]], [[XOR4]]
116
117
; CHECK-NEXT: [[OR4560:%.*]] = xor <8 x i1> [[XOR5]], [[OR7]]
117
118
; CHECK-NEXT: ret <8 x i1> [[OR4560]]
118
119
;
@@ -137,20 +138,20 @@ define <8 x i1> @vector3(<8 x i1> %a, <8 x i1> %b0, <8 x i1> %b1, <8 x i1> %b2,
137
138
define <8 x i1> @vector4(<8 x i1> %a, <8 x i1> %b0, <8 x i1> %b1, <8 x i1> %b2, <8 x i1> %b3, <8 x i1> %b4, <8 x i1> %b5, <8 x i1> %b6, <8 x i1> %b7) {
138
139
; CHECK-LABEL: define <8 x i1> @vector4(
139
140
; CHECK-SAME: <8 x i1> [[A:%.*]], <8 x i1> [[B0:%.*]], <8 x i1> [[B1:%.*]], <8 x i1> [[B2:%.*]], <8 x i1> [[B3:%.*]], <8 x i1> [[B4:%.*]], <8 x i1> [[B5:%.*]], <8 x i1> [[B6:%.*]], <8 x i1> [[B7:%.*]]) {
140
-
; CHECK-NEXT: [[XOR0:%.*]] = xor <8 x i1> [[B0]], [[A]]
141
-
; CHECK-NEXT: [[XOR1:%.*]] = xor <8 x i1> [[B1]], [[A]]
142
-
; CHECK-NEXT: [[XOR2:%.*]] = xor <8 x i1> [[B2]], [[A]]
143
-
; CHECK-NEXT: [[XOR3:%.*]] = xor <8 x i1> [[B3]], [[A]]
144
-
; CHECK-NEXT: [[XOR4:%.*]] = xor <8 x i1> [[B4]], [[A]]
145
-
; CHECK-NEXT: [[XOR5:%.*]] = xor <8 x i1> [[B5]], [[A]]
146
-
; CHECK-NEXT: [[XOR6:%.*]] = xor <8 x i1> [[B6]], [[A]]
147
-
; CHECK-NEXT: [[XOR7:%.*]] = xor <8 x i1> [[B7]], [[A]]
141
+
; CHECK-NEXT: [[XOR1:%.*]] = xor <8 x i1> [[A]], [[B0]]
142
+
; CHECK-NEXT: [[XOR0:%.*]] = xor <8 x i1> [[A]], [[B1]]
143
+
; CHECK-NEXT: [[XOR2:%.*]] = xor <8 x i1> [[A]], [[B2]]
144
+
; CHECK-NEXT: [[XOR4:%.*]] = xor <8 x i1> [[A]], [[B3]]
145
+
; CHECK-NEXT: [[AND2:%.*]] = xor <8 x i1> [[A]], [[B4]]
146
+
; CHECK-NEXT: [[XOR3:%.*]] = xor <8 x i1> [[A]], [[B5]]
147
+
; CHECK-NEXT: [[AND1:%.*]] = xor <8 x i1> [[A]], [[B6]]
148
+
; CHECK-NEXT: [[XOR5:%.*]] = xor <8 x i1> [[A]], [[B7]]
148
149
; CHECK-NEXT: [[AND3:%.*]] = and <8 x i1> [[XOR1]], [[XOR0]]
149
-
; CHECK-NEXT: [[AND2:%.*]] = and <8 x i1> [[AND3]], [[XOR2]]
150
+
; CHECK-NEXT: [[AND4:%.*]] = and <8 x i1> [[XOR2]], [[XOR4]]
150
151
; CHECK-NEXT: [[OR23:%.*]] = and <8 x i1> [[AND2]], [[XOR3]]
151
-
; CHECK-NEXT: [[AND1:%.*]] = and <8 x i1> [[OR23]], [[XOR4]]
152
152
; CHECK-NEXT: [[AND0:%.*]] = and <8 x i1> [[AND1]], [[XOR5]]
153
-
; CHECK-NEXT: [[OR01:%.*]] = and <8 x i1> [[AND0]], [[XOR6]]
153
+
; CHECK-NEXT: [[OR01:%.*]] = and <8 x i1> [[AND3]], [[AND4]]
154
+
; CHECK-NEXT: [[XOR7:%.*]] = and <8 x i1> [[OR23]], [[AND0]]
154
155
; CHECK-NEXT: [[OR0123:%.*]] = and <8 x i1> [[OR01]], [[XOR7]]
155
156
; CHECK-NEXT: ret <8 x i1> [[OR0123]]
156
157
;
@@ -175,29 +176,29 @@ define <8 x i1> @vector4(<8 x i1> %a, <8 x i1> %b0, <8 x i1> %b1, <8 x i1> %b2,
175
176
define <8 x i1> @vector5(<8 x i1> %a, <8 x i1> %b0, <8 x i1> %b1, <8 x i1> %b2, <8 x i1> %b3, <8 x i1> %b4, <8 x i1> %b5, <8 x i1> %b6, <8 x i1> %b7) {
176
177
; CHECK-LABEL: define <8 x i1> @vector5(
177
178
; CHECK-SAME: <8 x i1> [[A:%.*]], <8 x i1> [[B0:%.*]], <8 x i1> [[B1:%.*]], <8 x i1> [[B2:%.*]], <8 x i1> [[B3:%.*]], <8 x i1> [[B4:%.*]], <8 x i1> [[B5:%.*]], <8 x i1> [[B6:%.*]], <8 x i1> [[B7:%.*]]) {
178
-
; CHECK-NEXT: [[XOR0:%.*]] = xor <8 x i1> [[B0]], [[A]]
179
-
; CHECK-NEXT: [[XOR1:%.*]] = xor <8 x i1> [[B1]], [[A]]
180
-
; CHECK-NEXT: [[XOR2:%.*]] = xor <8 x i1> [[B2]], [[A]]
181
-
; CHECK-NEXT: [[XOR3:%.*]] = xor <8 x i1> [[B3]], [[A]]
182
-
; CHECK-NEXT: [[XOR4:%.*]] = xor <8 x i1> [[B4]], [[A]]
183
-
; CHECK-NEXT: [[XOR5:%.*]] = xor <8 x i1> [[B5]], [[A]]
184
-
; CHECK-NEXT: [[XOR6:%.*]] = xor <8 x i1> [[B6]], [[A]]
185
-
; CHECK-NEXT: [[XOR7:%.*]] = xor <8 x i1> [[B7]], [[A]]
186
-
; CHECK-NEXT: [[OR3:%.*]] = or <8 x i1> [[B1]], [[B0]]
179
+
; CHECK-NEXT: [[OR3:%.*]] = xor <8 x i1> [[A]], [[B0]]
180
+
; CHECK-NEXT: [[XOR0:%.*]] = xor <8 x i1> [[A]], [[B1]]
181
+
; CHECK-NEXT: [[OR23:%.*]] = xor <8 x i1> [[A]], [[B2]]
182
+
; CHECK-NEXT: [[XOR1:%.*]] = xor <8 x i1> [[A]], [[B3]]
183
+
; CHECK-NEXT: [[OR0:%.*]] = xor <8 x i1> [[A]], [[B4]]
184
+
; CHECK-NEXT: [[XOR2:%.*]] = xor <8 x i1> [[A]], [[B5]]
185
+
; CHECK-NEXT: [[OR0123:%.*]] = xor <8 x i1> [[A]], [[B6]]
186
+
; CHECK-NEXT: [[XOR3:%.*]] = xor <8 x i1> [[A]], [[B7]]
187
187
; CHECK-NEXT: [[OR2:%.*]] = or <8 x i1> [[OR3]], [[XOR0]]
188
-
; CHECK-NEXT: [[OR23:%.*]] = or <8 x i1> [[OR2]], [[B2]]
189
188
; CHECK-NEXT: [[OR1:%.*]] = or <8 x i1> [[OR23]], [[XOR1]]
190
-
; CHECK-NEXT: [[OR0:%.*]] = or <8 x i1> [[OR1]], [[B3]]
191
189
; CHECK-NEXT: [[OR01:%.*]] = or <8 x i1> [[OR0]], [[XOR2]]
192
-
; CHECK-NEXT: [[OR0123:%.*]] = or <8 x i1> [[OR01]], [[B4]]
193
190
; CHECK-NEXT: [[OR7:%.*]] = or <8 x i1> [[OR0123]], [[XOR3]]
194
-
; CHECK-NEXT: [[OR6:%.*]] = or <8 x i1> [[OR7]], [[B5]]
195
-
; CHECK-NEXT: [[OR67:%.*]] = or <8 x i1> [[OR6]], [[XOR4]]
196
-
; CHECK-NEXT: [[OR5:%.*]] = or <8 x i1> [[OR67]], [[B6]]
197
-
; CHECK-NEXT: [[OR4:%.*]] = or <8 x i1> [[OR5]], [[XOR5]]
198
-
; CHECK-NEXT: [[OR45:%.*]] = or <8 x i1> [[OR4]], [[B7]]
191
+
; CHECK-NEXT: [[OR45:%.*]] = or <8 x i1> [[B0]], [[B1]]
192
+
; CHECK-NEXT: [[XOR6:%.*]] = or <8 x i1> [[B2]], [[B3]]
193
+
; CHECK-NEXT: [[OR6:%.*]] = or <8 x i1> [[B4]], [[B5]]
194
+
; CHECK-NEXT: [[OR8:%.*]] = or <8 x i1> [[B6]], [[B7]]
195
+
; CHECK-NEXT: [[OR4:%.*]] = or <8 x i1> [[OR2]], [[OR1]]
196
+
; CHECK-NEXT: [[OR24:%.*]] = or <8 x i1> [[OR01]], [[OR7]]
199
197
; CHECK-NEXT: [[OR4567:%.*]] = or <8 x i1> [[OR45]], [[XOR6]]
200
-
; CHECK-NEXT: [[OR01234567:%.*]] = or <8 x i1> [[OR4567]], [[XOR7]]
198
+
; CHECK-NEXT: [[OR67:%.*]] = or <8 x i1> [[OR6]], [[OR8]]
199
+
; CHECK-NEXT: [[OR123:%.*]] = or <8 x i1> [[OR4]], [[OR24]]
200
+
; CHECK-NEXT: [[OR4568:%.*]] = or <8 x i1> [[OR4567]], [[OR67]]
201
+
; CHECK-NEXT: [[OR01234567:%.*]] = or <8 x i1> [[OR4568]], [[OR123]]
0 commit comments