1 ; This test makes sure that these instructions are properly eliminated. 2 ; 3 ; RUN: opt < %s -instcombine -S | \ 4 ; RUN: not grep {tobool} 5 ; END. 6 define i32 @main(i32 %argc, i8** %argv) nounwind ssp { 7 entry: 8 %and = and i32 %argc, 1 ; <i32> [#uses=1] 9 %tobool = icmp ne i32 %and, 0 ; <i1> [#uses=1] 10 %and2 = and i32 %argc, 2 ; <i32> [#uses=1] 11 %tobool3 = icmp ne i32 %and2, 0 ; <i1> [#uses=1] 12 %or.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 13 %retval.0 = select i1 %or.cond, i32 2, i32 1 ; <i32> [#uses=1] 14 ret i32 %retval.0 15 } 16 17 define i32 @main2(i32 %argc, i8** nocapture %argv) nounwind readnone ssp { 18 entry: 19 %and = and i32 %argc, 1 ; <i32> [#uses=1] 20 %tobool = icmp eq i32 %and, 0 ; <i1> [#uses=1] 21 %and2 = and i32 %argc, 2 ; <i32> [#uses=1] 22 %tobool3 = icmp eq i32 %and2, 0 ; <i1> [#uses=1] 23 %or.cond = or i1 %tobool, %tobool3 ; <i1> [#uses=1] 24 %storemerge = select i1 %or.cond, i32 0, i32 1 ; <i32> [#uses=1] 25 ret i32 %storemerge 26 } 27 28 ; tests to check combining (icmp eq (A & B), C) & (icmp eq (A & D), E) 29 ; tests to check if (icmp eq (A & B), 0) is treated like (icmp eq (A & B), B) 30 ; if B is a single bit constant 31 32 ; (icmp eq (A & B), 0) & (icmp eq (A & D), 0) -> (icmp eq (A & (B|D)), 0) 33 define i32 @main3(i32 %argc, i8** nocapture %argv) nounwind readnone ssp { 34 entry: 35 %and = and i32 %argc, 7 ; <i32> [#uses=1] 36 %tobool = icmp eq i32 %and, 0 ; <i1> [#uses=1] 37 %and2 = and i32 %argc, 48 ; <i32> [#uses=1] 38 %tobool3 = icmp eq i32 %and2, 0 ; <i1> [#uses=1] 39 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 40 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 41 ret i32 %storemerge 42 } 43 44 define i32 @main3b(i32 %argc, i8** nocapture %argv) nounwind readnone ssp { 45 entry: 46 %and = and i32 %argc, 7 ; <i32> [#uses=1] 47 %tobool = icmp eq i32 %and, 0 ; <i1> [#uses=1] 48 %and2 = and i32 %argc, 16 ; <i32> [#uses=1] 49 %tobool3 = icmp ne i32 %and2, 16 ; <i1> [#uses=1] 50 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 51 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 52 ret i32 %storemerge 53 } 54 55 define i32 @main3e_like(i32 %argc, i32 %argc2, i32 %argc3, i8** nocapture %argv) 56 nounwind readnone ssp { 57 entry: 58 %and = and i32 %argc, %argc2 ; <i32> [#uses=1] 59 %tobool = icmp eq i32 %and, 0 ; <i1> [#uses=1] 60 %and2 = and i32 %argc, %argc3 ; <i32> [#uses=1] 61 %tobool3 = icmp eq i32 %and2, 0 ; <i1> [#uses=1] 62 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 63 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 64 ret i32 %storemerge 65 } 66 67 ; (icmp ne (A & B), 0) | (icmp ne (A & D), 0) -> (icmp ne (A & (B|D)), 0) 68 define i32 @main3c(i32 %argc, i8** nocapture %argv) nounwind readnone ssp { 69 entry: 70 %and = and i32 %argc, 7 ; <i32> [#uses=1] 71 %tobool = icmp ne i32 %and, 0 ; <i1> [#uses=1] 72 %and2 = and i32 %argc, 48 ; <i32> [#uses=1] 73 %tobool3 = icmp ne i32 %and2, 0 ; <i1> [#uses=1] 74 %or.cond = or i1 %tobool, %tobool3 ; <i1> [#uses=1] 75 %storemerge = select i1 %or.cond, i32 0, i32 1 ; <i32> [#uses=1] 76 ret i32 %storemerge 77 } 78 79 define i32 @main3d(i32 %argc, i8** nocapture %argv) nounwind readnone ssp { 80 entry: 81 %and = and i32 %argc, 7 ; <i32> [#uses=1] 82 %tobool = icmp ne i32 %and, 0 ; <i1> [#uses=1] 83 %and2 = and i32 %argc, 16 ; <i32> [#uses=1] 84 %tobool3 = icmp eq i32 %and2, 16 ; <i1> [#uses=1] 85 %or.cond = or i1 %tobool, %tobool3 ; <i1> [#uses=1] 86 %storemerge = select i1 %or.cond, i32 0, i32 1 ; <i32> [#uses=1] 87 ret i32 %storemerge 88 } 89 90 define i32 @main3f_like(i32 %argc, i32 %argc2, i32 %argc3, i8** nocapture %argv) 91 nounwind readnone ssp { 92 entry: 93 %and = and i32 %argc, %argc2 ; <i32> [#uses=1] 94 %tobool = icmp ne i32 %and, 0 ; <i1> [#uses=1] 95 %and2 = and i32 %argc, %argc3 ; <i32> [#uses=1] 96 %tobool3 = icmp ne i32 %and2, 0 ; <i1> [#uses=1] 97 %or.cond = or i1 %tobool, %tobool3 ; <i1> [#uses=1] 98 %storemerge = select i1 %or.cond, i32 0, i32 1 ; <i32> [#uses=1] 99 ret i32 %storemerge 100 } 101 102 ; (icmp eq (A & B), B) & (icmp eq (A & D), D) -> (icmp eq (A & (B|D)), (B|D)) 103 define i32 @main4(i32 %argc, i8** nocapture %argv) nounwind readnone ssp { 104 entry: 105 %and = and i32 %argc, 7 ; <i32> [#uses=1] 106 %tobool = icmp eq i32 %and, 7 ; <i1> [#uses=1] 107 %and2 = and i32 %argc, 48 ; <i32> [#uses=1] 108 %tobool3 = icmp eq i32 %and2, 48 ; <i1> [#uses=1] 109 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 110 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 111 ret i32 %storemerge 112 } 113 114 define i32 @main4b(i32 %argc, i8** nocapture %argv) nounwind readnone ssp { 115 entry: 116 %and = and i32 %argc, 7 ; <i32> [#uses=1] 117 %tobool = icmp eq i32 %and, 7 ; <i1> [#uses=1] 118 %and2 = and i32 %argc, 16 ; <i32> [#uses=1] 119 %tobool3 = icmp ne i32 %and2, 0 ; <i1> [#uses=1] 120 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 121 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 122 ret i32 %storemerge 123 } 124 125 define i32 @main4e_like(i32 %argc, i32 %argc2, i32 %argc3, i8** nocapture %argv) 126 nounwind readnone ssp { 127 entry: 128 %and = and i32 %argc, %argc2 ; <i32> [#uses=1] 129 %tobool = icmp eq i32 %and, %argc2 ; <i1> [#uses=1] 130 %and2 = and i32 %argc, %argc3 ; <i32> [#uses=1] 131 %tobool3 = icmp eq i32 %and2, %argc3 ; <i1> [#uses=1] 132 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 133 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 134 ret i32 %storemerge 135 } 136 137 ; (icmp ne (A & B), B) | (icmp ne (A & D), D) -> (icmp ne (A & (B|D)), (B|D)) 138 define i32 @main4c(i32 %argc, i8** nocapture %argv) nounwind readnone ssp { 139 entry: 140 %and = and i32 %argc, 7 ; <i32> [#uses=1] 141 %tobool = icmp ne i32 %and, 7 ; <i1> [#uses=1] 142 %and2 = and i32 %argc, 48 ; <i32> [#uses=1] 143 %tobool3 = icmp ne i32 %and2, 48 ; <i1> [#uses=1] 144 %or.cond = or i1 %tobool, %tobool3 ; <i1> [#uses=1] 145 %storemerge = select i1 %or.cond, i32 0, i32 1 ; <i32> [#uses=1] 146 ret i32 %storemerge 147 } 148 149 define i32 @main4d(i32 %argc, i8** nocapture %argv) nounwind readnone ssp { 150 entry: 151 %and = and i32 %argc, 7 ; <i32> [#uses=1] 152 %tobool = icmp ne i32 %and, 7 ; <i1> [#uses=1] 153 %and2 = and i32 %argc, 16 ; <i32> [#uses=1] 154 %tobool3 = icmp eq i32 %and2, 0 ; <i1> [#uses=1] 155 %or.cond = or i1 %tobool, %tobool3 ; <i1> [#uses=1] 156 %storemerge = select i1 %or.cond, i32 0, i32 1 ; <i32> [#uses=1] 157 ret i32 %storemerge 158 } 159 160 define i32 @main4f_like(i32 %argc, i32 %argc2, i32 %argc3, i8** nocapture %argv) 161 nounwind readnone ssp { 162 entry: 163 %and = and i32 %argc, %argc2 ; <i32> [#uses=1] 164 %tobool = icmp ne i32 %and, %argc2 ; <i1> [#uses=1] 165 %and2 = and i32 %argc, %argc3 ; <i32> [#uses=1] 166 %tobool3 = icmp ne i32 %and2, %argc3 ; <i1> [#uses=1] 167 %or.cond = or i1 %tobool, %tobool3 ; <i1> [#uses=1] 168 %storemerge = select i1 %or.cond, i32 0, i32 1 ; <i32> [#uses=1] 169 ret i32 %storemerge 170 } 171 172 ; (icmp eq (A & B), A) & (icmp eq (A & D), A) -> (icmp eq (A & (B&D)), A) 173 define i32 @main5_like(i32 %argc, i32 %argc2, i8** nocapture %argv) 174 nounwind readnone ssp { 175 entry: 176 %and = and i32 %argc, 7 ; <i32> [#uses=1] 177 %tobool = icmp eq i32 %and, 7 ; <i1> [#uses=1] 178 %and2 = and i32 %argc2, 7 ; <i32> [#uses=1] 179 %tobool3 = icmp eq i32 %and2, 7 ; <i1> [#uses=1] 180 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 181 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 182 ret i32 %storemerge 183 } 184 185 define i32 @main5e_like(i32 %argc, i32 %argc2, i32 %argc3, i8** nocapture %argv) 186 nounwind readnone ssp { 187 entry: 188 %and = and i32 %argc, %argc2 ; <i32> [#uses=1] 189 %tobool = icmp eq i32 %and, %argc ; <i1> [#uses=1] 190 %and2 = and i32 %argc, %argc3 ; <i32> [#uses=1] 191 %tobool3 = icmp eq i32 %and2, %argc ; <i1> [#uses=1] 192 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 193 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 194 ret i32 %storemerge 195 } 196 197 ; (icmp ne (A & B), A) | (icmp ne (A & D), A) -> (icmp ne (A & (B&D)), A) 198 define i32 @main5c_like(i32 %argc, i32 %argc2, i8** nocapture %argv) 199 nounwind readnone ssp { 200 entry: 201 %and = and i32 %argc, 7 ; <i32> [#uses=1] 202 %tobool = icmp ne i32 %and, 7 ; <i1> [#uses=1] 203 %and2 = and i32 %argc2, 7 ; <i32> [#uses=1] 204 %tobool3 = icmp ne i32 %and2, 7 ; <i1> [#uses=1] 205 %or.cond = or i1 %tobool, %tobool3 ; <i1> [#uses=1] 206 %storemerge = select i1 %or.cond, i32 0, i32 1 ; <i32> [#uses=1] 207 ret i32 %storemerge 208 } 209 210 define i32 @main5f_like(i32 %argc, i32 %argc2, i32 %argc3, i8** nocapture %argv) 211 nounwind readnone ssp { 212 entry: 213 %and = and i32 %argc, %argc2 ; <i32> [#uses=1] 214 %tobool = icmp ne i32 %and, %argc ; <i1> [#uses=1] 215 %and2 = and i32 %argc, %argc3 ; <i32> [#uses=1] 216 %tobool3 = icmp ne i32 %and2, %argc ; <i1> [#uses=1] 217 %or.cond = or i1 %tobool, %tobool3 ; <i1> [#uses=1] 218 %storemerge = select i1 %or.cond, i32 0, i32 1 ; <i32> [#uses=1] 219 ret i32 %storemerge 220 } 221 222 ; (icmp eq (A & B), C) & (icmp eq (A & D), E) -> (icmp eq (A & (B|D)), (C|E)) 223 ; if B, C, D, E are constant, and it's possible 224 define i32 @main6(i32 %argc, i8** nocapture %argv) nounwind readnone ssp { 225 entry: 226 %and = and i32 %argc, 7 ; <i32> [#uses=1] 227 %tobool = icmp eq i32 %and, 3 ; <i1> [#uses=1] 228 %and2 = and i32 %argc, 48 ; <i32> [#uses=1] 229 %tobool3 = icmp eq i32 %and2, 16 ; <i1> [#uses=1] 230 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 231 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 232 ret i32 %storemerge 233 } 234 235 define i32 @main6b(i32 %argc, i8** nocapture %argv) nounwind readnone ssp { 236 entry: 237 %and = and i32 %argc, 7 ; <i32> [#uses=1] 238 %tobool = icmp eq i32 %and, 3 ; <i1> [#uses=1] 239 %and2 = and i32 %argc, 16 ; <i32> [#uses=1] 240 %tobool3 = icmp ne i32 %and2, 0 ; <i1> [#uses=1] 241 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 242 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 243 ret i32 %storemerge 244 } 245 246 ; (icmp ne (A & B), C) | (icmp ne (A & D), E) -> (icmp ne (A & (B|D)), (C|E)) 247 ; if B, C, D, E are constant, and it's possible 248 define i32 @main6c(i32 %argc, i8** nocapture %argv) nounwind readnone ssp { 249 entry: 250 %and = and i32 %argc, 7 ; <i32> [#uses=1] 251 %tobool = icmp ne i32 %and, 3 ; <i1> [#uses=1] 252 %and2 = and i32 %argc, 48 ; <i32> [#uses=1] 253 %tobool3 = icmp ne i32 %and2, 16 ; <i1> [#uses=1] 254 %or.cond = or i1 %tobool, %tobool3 ; <i1> [#uses=1] 255 %storemerge = select i1 %or.cond, i32 0, i32 1 ; <i32> [#uses=1] 256 ret i32 %storemerge 257 } 258 259 define i32 @main6d(i32 %argc, i8** nocapture %argv) nounwind readnone ssp { 260 entry: 261 %and = and i32 %argc, 7 ; <i32> [#uses=1] 262 %tobool = icmp ne i32 %and, 3 ; <i1> [#uses=1] 263 %and2 = and i32 %argc, 16 ; <i32> [#uses=1] 264 %tobool3 = icmp eq i32 %and2, 0 ; <i1> [#uses=1] 265 %or.cond = or i1 %tobool, %tobool3 ; <i1> [#uses=1] 266 %storemerge = select i1 %or.cond, i32 0, i32 1 ; <i32> [#uses=1] 267 ret i32 %storemerge 268 } 269 270 ; test parameter permutations 271 ; (B & A) == B & (D & A) == D 272 define i32 @main7a(i32 %argc, i32 %argc2, i32 %argc3, i8** nocapture %argv) 273 nounwind readnone ssp { 274 entry: 275 %and1 = and i32 %argc2, %argc ; <i32> [#uses=1] 276 %tobool = icmp eq i32 %and1, %argc2 ; <i1> [#uses=1] 277 %and2 = and i32 %argc3, %argc ; <i32> [#uses=1] 278 %tobool3 = icmp eq i32 %and2, %argc3 ; <i1> [#uses=1] 279 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 280 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 281 ret i32 %storemerge 282 } 283 284 ; B == (A & B) & D == (A & D) 285 define i32 @main7b(i32 %argc, i32 %argc2, i32 %argc3, i8** nocapture %argv) 286 nounwind readnone ssp { 287 entry: 288 %and1 = and i32 %argc, %argc2 ; <i32> [#uses=1] 289 %tobool = icmp eq i32 %argc2, %and1 ; <i1> [#uses=1] 290 %and2 = and i32 %argc, %argc3 ; <i32> [#uses=1] 291 %tobool3 = icmp eq i32 %argc3, %and2 ; <i1> [#uses=1] 292 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 293 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 294 ret i32 %storemerge 295 } 296 297 ; B == (B & A) & D == (D & A) 298 define i32 @main7c(i32 %argc, i32 %argc2, i32 %argc3, i8** nocapture %argv) 299 nounwind readnone ssp { 300 entry: 301 %and1 = and i32 %argc2, %argc ; <i32> [#uses=1] 302 %tobool = icmp eq i32 %argc2, %and1 ; <i1> [#uses=1] 303 %and2 = and i32 %argc3, %argc ; <i32> [#uses=1] 304 %tobool3 = icmp eq i32 %argc3, %and2 ; <i1> [#uses=1] 305 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 306 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 307 ret i32 %storemerge 308 } 309 310 ; (A & (B & C)) == (B & C) & (A & (D & E)) == (D & E) 311 define i32 @main7d(i32 %argc, i32 %argc2, i32 %argc3, 312 i32 %argc4, i32 %argc5, i8** nocapture %argv) 313 nounwind readnone ssp { 314 entry: 315 %bc = and i32 %argc2, %argc4 ; <i32> [#uses=1] 316 %de = and i32 %argc3, %argc5 ; <i32> [#uses=1] 317 %and1 = and i32 %argc, %bc ; <i32> [#uses=1] 318 %tobool = icmp eq i32 %and1, %bc ; <i1> [#uses=1] 319 %and2 = and i32 %argc, %de ; <i32> [#uses=1] 320 %tobool3 = icmp eq i32 %and2, %de ; <i1> [#uses=1] 321 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 322 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 323 ret i32 %storemerge 324 } 325 326 ; ((B & C) & A) == (B & C) & ((D & E) & A) == (D & E) 327 define i32 @main7e(i32 %argc, i32 %argc2, i32 %argc3, 328 i32 %argc4, i32 %argc5, i8** nocapture %argv) 329 nounwind readnone ssp { 330 entry: 331 %bc = and i32 %argc2, %argc4 ; <i32> [#uses=1] 332 %de = and i32 %argc3, %argc5 ; <i32> [#uses=1] 333 %and1 = and i32 %bc, %argc ; <i32> [#uses=1] 334 %tobool = icmp eq i32 %and1, %bc ; <i1> [#uses=1] 335 %and2 = and i32 %de, %argc ; <i32> [#uses=1] 336 %tobool3 = icmp eq i32 %and2, %de ; <i1> [#uses=1] 337 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 338 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 339 ret i32 %storemerge 340 } 341 342 ; (B & C) == (A & (B & C)) & (D & E) == (A & (D & E)) 343 define i32 @main7f(i32 %argc, i32 %argc2, i32 %argc3, 344 i32 %argc4, i32 %argc5, i8** nocapture %argv) 345 nounwind readnone ssp { 346 entry: 347 %bc = and i32 %argc2, %argc4 ; <i32> [#uses=1] 348 %de = and i32 %argc3, %argc5 ; <i32> [#uses=1] 349 %and1 = and i32 %argc, %bc ; <i32> [#uses=1] 350 %tobool = icmp eq i32 %bc, %and1 ; <i1> [#uses=1] 351 %and2 = and i32 %argc, %de ; <i32> [#uses=1] 352 %tobool3 = icmp eq i32 %de, %and2 ; <i1> [#uses=1] 353 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 354 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 355 ret i32 %storemerge 356 } 357 358 ; (B & C) == ((B & C) & A) & (D & E) == ((D & E) & A) 359 define i32 @main7g(i32 %argc, i32 %argc2, i32 %argc3, 360 i32 %argc4, i32 %argc5, i8** nocapture %argv) 361 nounwind readnone ssp { 362 entry: 363 %bc = and i32 %argc2, %argc4 ; <i32> [#uses=1] 364 %de = and i32 %argc3, %argc5 ; <i32> [#uses=1] 365 %and1 = and i32 %bc, %argc ; <i32> [#uses=1] 366 %tobool = icmp eq i32 %bc, %and1 ; <i1> [#uses=1] 367 %and2 = and i32 %de, %argc ; <i32> [#uses=1] 368 %tobool3 = icmp eq i32 %de, %and2 ; <i1> [#uses=1] 369 %and.cond = and i1 %tobool, %tobool3 ; <i1> [#uses=1] 370 %storemerge = select i1 %and.cond, i32 0, i32 1 ; <i32> [#uses=1] 371 ret i32 %storemerge 372 } 373