1; This test makes sure that these instructions are properly eliminated. 2; 3; RUN: opt < %s -instcombine -S | FileCheck %s 4 5define i32 @test1(i32 %A) { 6; CHECK-LABEL: @test1( 7; CHECK: ret i32 %A 8 %B = shl i32 %A, 0 ; <i32> [#uses=1] 9 ret i32 %B 10} 11 12define i32 @test2(i8 %A) { 13; CHECK-LABEL: @test2( 14; CHECK: ret i32 0 15 %shift.upgrd.1 = zext i8 %A to i32 ; <i32> [#uses=1] 16 %B = shl i32 0, %shift.upgrd.1 ; <i32> [#uses=1] 17 ret i32 %B 18} 19 20define i32 @test3(i32 %A) { 21; CHECK-LABEL: @test3( 22; CHECK: ret i32 %A 23 %B = ashr i32 %A, 0 ; <i32> [#uses=1] 24 ret i32 %B 25} 26 27define i32 @test4(i8 %A) { 28; CHECK-LABEL: @test4( 29; CHECK: ret i32 0 30 %shift.upgrd.2 = zext i8 %A to i32 ; <i32> [#uses=1] 31 %B = ashr i32 0, %shift.upgrd.2 ; <i32> [#uses=1] 32 ret i32 %B 33} 34 35 36define i32 @test5(i32 %A) { 37; CHECK-LABEL: @test5( 38; CHECK: ret i32 undef 39 %B = lshr i32 %A, 32 ;; shift all bits out 40 ret i32 %B 41} 42 43define <4 x i32> @test5_splat_vector(<4 x i32> %A) { 44; CHECK-LABEL: @test5_splat_vector( 45; CHECK: ret <4 x i32> undef 46 %B = lshr <4 x i32> %A, <i32 32, i32 32, i32 32, i32 32> ;; shift all bits out 47 ret <4 x i32> %B 48} 49 50define <4 x i32> @test5_zero_vector(<4 x i32> %A) { 51; CHECK-LABEL: @test5_zero_vector( 52; CHECK-NEXT: ret <4 x i32> %A 53 %B = lshr <4 x i32> %A, zeroinitializer 54 ret <4 x i32> %B 55} 56 57define <4 x i32> @test5_non_splat_vector(<4 x i32> %A) { 58; CHECK-LABEL: @test5_non_splat_vector( 59; CHECK-NOT: ret <4 x i32> undef 60 %B = lshr <4 x i32> %A, <i32 32, i32 1, i32 2, i32 3> 61 ret <4 x i32> %B 62} 63 64define i32 @test5a(i32 %A) { 65; CHECK-LABEL: @test5a( 66; CHECK: ret i32 undef 67 %B = shl i32 %A, 32 ;; shift all bits out 68 ret i32 %B 69} 70 71define <4 x i32> @test5a_splat_vector(<4 x i32> %A) { 72; CHECK-LABEL: @test5a_splat_vector( 73; CHECK: ret <4 x i32> undef 74 %B = shl <4 x i32> %A, <i32 32, i32 32, i32 32, i32 32> ;; shift all bits out 75 ret <4 x i32> %B 76} 77 78define <4 x i32> @test5a_non_splat_vector(<4 x i32> %A) { 79; CHECK-LABEL: @test5a_non_splat_vector( 80; CHECK-NOT: ret <4 x i32> undef 81 %B = shl <4 x i32> %A, <i32 32, i32 1, i32 2, i32 3> 82 ret <4 x i32> %B 83} 84 85define i32 @test5b() { 86; CHECK-LABEL: @test5b( 87; CHECK: ret i32 0 88 %B = ashr i32 undef, 2 ;; top two bits must be equal, so not undef 89 ret i32 %B 90} 91 92define i32 @test5b2(i32 %A) { 93; CHECK-LABEL: @test5b2( 94; CHECK: ret i32 0 95 %B = ashr i32 undef, %A ;; top %A bits must be equal, so not undef 96 ret i32 %B 97} 98 99define i32 @test6(i32 %A) { 100; CHECK-LABEL: @test6( 101; CHECK-NEXT: mul i32 %A, 6 102; CHECK-NEXT: ret i32 103 %B = shl i32 %A, 1 ;; convert to an mul instruction 104 %C = mul i32 %B, 3 105 ret i32 %C 106} 107 108define i32 @test6a(i32 %A) { 109; CHECK-LABEL: @test6a( 110; CHECK-NEXT: mul i32 %A, 6 111; CHECK-NEXT: ret i32 112 %B = mul i32 %A, 3 113 %C = shl i32 %B, 1 ;; convert to an mul instruction 114 ret i32 %C 115} 116 117define i32 @test7(i8 %A) { 118; CHECK-LABEL: @test7( 119; CHECK-NEXT: ret i32 -1 120 %shift.upgrd.3 = zext i8 %A to i32 121 %B = ashr i32 -1, %shift.upgrd.3 ;; Always equal to -1 122 ret i32 %B 123} 124 125;; (A << 5) << 3 === A << 8 == 0 126define i8 @test8(i8 %A) { 127; CHECK-LABEL: @test8( 128; CHECK: ret i8 0 129 %B = shl i8 %A, 5 ; <i8> [#uses=1] 130 %C = shl i8 %B, 3 ; <i8> [#uses=1] 131 ret i8 %C 132} 133 134;; (A << 7) >> 7 === A & 1 135define i8 @test9(i8 %A) { 136; CHECK-LABEL: @test9( 137; CHECK-NEXT: and i8 %A, 1 138; CHECK-NEXT: ret i8 139 %B = shl i8 %A, 7 ; <i8> [#uses=1] 140 %C = lshr i8 %B, 7 ; <i8> [#uses=1] 141 ret i8 %C 142} 143 144;; This transformation is deferred to DAGCombine: 145;; (A >> 7) << 7 === A & 128 146;; The shl may be valuable to scalar evolution. 147define i8 @test10(i8 %A) { 148; CHECK-LABEL: @test10( 149; CHECK-NEXT: and i8 %A, -128 150; CHECK-NEXT: ret i8 151 %B = lshr i8 %A, 7 ; <i8> [#uses=1] 152 %C = shl i8 %B, 7 ; <i8> [#uses=1] 153 ret i8 %C 154} 155 156;; Allow the simplification when the lshr shift is exact. 157define i8 @test10a(i8 %A) { 158; CHECK-LABEL: @test10a( 159; CHECK-NEXT: ret i8 %A 160 %B = lshr exact i8 %A, 7 161 %C = shl i8 %B, 7 162 ret i8 %C 163} 164 165;; This transformation is deferred to DAGCombine: 166;; (A >> 3) << 4 === (A & 0x1F) << 1 167;; The shl may be valuable to scalar evolution. 168define i8 @test11(i8 %A) { 169; CHECK-LABEL: @test11( 170; CHECK: shl i8 171; CHECK-NEXT: ret i8 172 %a = mul i8 %A, 3 ; <i8> [#uses=1] 173 %B = lshr i8 %a, 3 ; <i8> [#uses=1] 174 %C = shl i8 %B, 4 ; <i8> [#uses=1] 175 ret i8 %C 176} 177 178;; Allow the simplification in InstCombine when the lshr shift is exact. 179define i8 @test11a(i8 %A) { 180; CHECK-LABEL: @test11a( 181; CHECK-NEXT: mul i8 %A, 6 182; CHECK-NEXT: ret i8 183 %a = mul i8 %A, 3 184 %B = lshr exact i8 %a, 3 185 %C = shl i8 %B, 4 186 ret i8 %C 187} 188 189;; This is deferred to DAGCombine unless %B is single-use. 190;; (A >> 8) << 8 === A & -256 191define i32 @test12(i32 %A) { 192; CHECK-LABEL: @test12( 193; CHECK-NEXT: and i32 %A, -256 194; CHECK-NEXT: ret i32 195 %B = ashr i32 %A, 8 ; <i32> [#uses=1] 196 %C = shl i32 %B, 8 ; <i32> [#uses=1] 197 ret i32 %C 198} 199 200;; This transformation is deferred to DAGCombine: 201;; (A >> 3) << 4 === (A & -8) * 2 202;; The shl may be valuable to scalar evolution. 203define i8 @test13(i8 %A) { 204; CHECK-LABEL: @test13( 205; CHECK: shl i8 206; CHECK-NEXT: ret i8 207 %a = mul i8 %A, 3 ; <i8> [#uses=1] 208 %B = ashr i8 %a, 3 ; <i8> [#uses=1] 209 %C = shl i8 %B, 4 ; <i8> [#uses=1] 210 ret i8 %C 211} 212 213define i8 @test13a(i8 %A) { 214; CHECK-LABEL: @test13a( 215; CHECK-NEXT: mul i8 %A, 6 216; CHECK-NEXT: ret i8 217 %a = mul i8 %A, 3 218 %B = ashr exact i8 %a, 3 219 %C = shl i8 %B, 4 220 ret i8 %C 221} 222 223;; D = ((B | 1234) << 4) === ((B << 4)|(1234 << 4) 224define i32 @test14(i32 %A) { 225; CHECK-LABEL: @test14( 226; CHECK-NEXT: %B = and i32 %A, -19760 227; CHECK-NEXT: or i32 %B, 19744 228; CHECK-NEXT: ret i32 229 %B = lshr i32 %A, 4 ; <i32> [#uses=1] 230 %C = or i32 %B, 1234 ; <i32> [#uses=1] 231 %D = shl i32 %C, 4 ; <i32> [#uses=1] 232 ret i32 %D 233} 234 235;; D = ((B | 1234) << 4) === ((B << 4)|(1234 << 4) 236define i32 @test14a(i32 %A) { 237; CHECK-LABEL: @test14a( 238; CHECK-NEXT: and i32 %A, 77 239; CHECK-NEXT: ret i32 240 %B = shl i32 %A, 4 ; <i32> [#uses=1] 241 %C = and i32 %B, 1234 ; <i32> [#uses=1] 242 %D = lshr i32 %C, 4 ; <i32> [#uses=1] 243 ret i32 %D 244} 245 246define i32 @test15(i1 %C) { 247; CHECK-LABEL: @test15( 248; CHECK-NEXT: select i1 %C, i32 12, i32 4 249; CHECK-NEXT: ret i32 250 %A = select i1 %C, i32 3, i32 1 ; <i32> [#uses=1] 251 %V = shl i32 %A, 2 ; <i32> [#uses=1] 252 ret i32 %V 253} 254 255define i32 @test15a(i1 %C) { 256; CHECK-LABEL: @test15a( 257; CHECK-NEXT: select i1 %C, i32 512, i32 128 258; CHECK-NEXT: ret i32 259 %A = select i1 %C, i8 3, i8 1 ; <i8> [#uses=1] 260 %shift.upgrd.4 = zext i8 %A to i32 ; <i32> [#uses=1] 261 %V = shl i32 64, %shift.upgrd.4 ; <i32> [#uses=1] 262 ret i32 %V 263} 264 265define i1 @test16(i32 %X) { 266; CHECK-LABEL: @test16( 267; CHECK-NEXT: and i32 %X, 16 268; CHECK-NEXT: icmp ne i32 269; CHECK-NEXT: ret i1 270 %tmp.3 = ashr i32 %X, 4 271 %tmp.6 = and i32 %tmp.3, 1 272 %tmp.7 = icmp ne i32 %tmp.6, 0 273 ret i1 %tmp.7 274} 275 276define i1 @test17(i32 %A) { 277; CHECK-LABEL: @test17( 278; CHECK-NEXT: and i32 %A, -8 279; CHECK-NEXT: icmp eq i32 280; CHECK-NEXT: ret i1 281 %B = lshr i32 %A, 3 ; <i32> [#uses=1] 282 %C = icmp eq i32 %B, 1234 ; <i1> [#uses=1] 283 ret i1 %C 284} 285 286 287define i1 @test18(i8 %A) { 288; CHECK-LABEL: @test18( 289; CHECK: ret i1 false 290 291 %B = lshr i8 %A, 7 ; <i8> [#uses=1] 292 ;; false 293 %C = icmp eq i8 %B, 123 ; <i1> [#uses=1] 294 ret i1 %C 295} 296 297define i1 @test19(i32 %A) { 298; CHECK-LABEL: @test19( 299; CHECK-NEXT: icmp ult i32 %A, 4 300; CHECK-NEXT: ret i1 301 %B = ashr i32 %A, 2 ; <i32> [#uses=1] 302 ;; (X & -4) == 0 303 %C = icmp eq i32 %B, 0 ; <i1> [#uses=1] 304 ret i1 %C 305} 306 307 308define i1 @test19a(i32 %A) { 309; CHECK-LABEL: @test19a( 310; CHECK-NEXT: icmp ugt i32 %A, -5 311; CHECK-NEXT: ret i1 312 %B = ashr i32 %A, 2 ; <i32> [#uses=1] 313 ;; X >u ~4 314 %C = icmp eq i32 %B, -1 ; <i1> [#uses=1] 315 ret i1 %C 316} 317 318define i1 @test20(i8 %A) { 319; CHECK-LABEL: @test20( 320; CHECK: ret i1 false 321 %B = ashr i8 %A, 7 ; <i8> [#uses=1] 322 ;; false 323 %C = icmp eq i8 %B, 123 ; <i1> [#uses=1] 324 ret i1 %C 325} 326 327define i1 @test21(i8 %A) { 328; CHECK-LABEL: @test21( 329; CHECK-NEXT: and i8 %A, 15 330; CHECK-NEXT: icmp eq i8 331; CHECK-NEXT: ret i1 332 %B = shl i8 %A, 4 ; <i8> [#uses=1] 333 %C = icmp eq i8 %B, -128 ; <i1> [#uses=1] 334 ret i1 %C 335} 336 337define i1 @test22(i8 %A) { 338; CHECK-LABEL: @test22( 339; CHECK-NEXT: and i8 %A, 15 340; CHECK-NEXT: icmp eq i8 341; CHECK-NEXT: ret i1 342 %B = shl i8 %A, 4 ; <i8> [#uses=1] 343 %C = icmp eq i8 %B, 0 ; <i1> [#uses=1] 344 ret i1 %C 345} 346 347define i8 @test23(i32 %A) { 348; CHECK-LABEL: @test23( 349; CHECK-NEXT: trunc i32 %A to i8 350; CHECK-NEXT: ret i8 351 352 ;; casts not needed 353 %B = shl i32 %A, 24 ; <i32> [#uses=1] 354 %C = ashr i32 %B, 24 ; <i32> [#uses=1] 355 %D = trunc i32 %C to i8 ; <i8> [#uses=1] 356 ret i8 %D 357} 358 359define i8 @test24(i8 %X) { 360; CHECK-LABEL: @test24( 361; CHECK-NEXT: and i8 %X, 3 362; CHECK-NEXT: ret i8 363 %Y = and i8 %X, -5 ; <i8> [#uses=1] 364 %Z = shl i8 %Y, 5 ; <i8> [#uses=1] 365 %Q = ashr i8 %Z, 5 ; <i8> [#uses=1] 366 ret i8 %Q 367} 368 369define i32 @test25(i32 %tmp.2, i32 %AA) { 370; CHECK-LABEL: @test25( 371; CHECK-NEXT: and i32 %tmp.2, -131072 372; CHECK-NEXT: add i32 %{{[^,]*}}, %AA 373; CHECK-NEXT: and i32 %{{[^,]*}}, -131072 374; CHECK-NEXT: ret i32 375 %x = lshr i32 %AA, 17 ; <i32> [#uses=1] 376 %tmp.3 = lshr i32 %tmp.2, 17 ; <i32> [#uses=1] 377 %tmp.5 = add i32 %tmp.3, %x ; <i32> [#uses=1] 378 %tmp.6 = shl i32 %tmp.5, 17 ; <i32> [#uses=1] 379 ret i32 %tmp.6 380} 381 382define <2 x i32> @test25_vector(<2 x i32> %tmp.2, <2 x i32> %AA) { 383; CHECK-LABEL: @test25_vector( 384; CHECK: %tmp.3 = lshr <2 x i32> %tmp.2, <i32 17, i32 17> 385; CHECK-NEXT: shl <2 x i32> %tmp.3, <i32 17, i32 17> 386; CHECK-NEXT: add <2 x i32> %tmp.51, %AA 387; CHECK-NEXT: and <2 x i32> %x2, <i32 -131072, i32 -131072> 388; CHECK-NEXT: ret <2 x i32> 389 %x = lshr <2 x i32> %AA, <i32 17, i32 17> 390 %tmp.3 = lshr <2 x i32> %tmp.2, <i32 17, i32 17> 391 %tmp.5 = add <2 x i32> %tmp.3, %x 392 %tmp.6 = shl <2 x i32> %tmp.5, <i32 17, i32 17> 393 ret <2 x i32> %tmp.6 394} 395 396;; handle casts between shifts. 397define i32 @test26(i32 %A) { 398; CHECK-LABEL: @test26( 399; CHECK-NEXT: and i32 %A, -2 400; CHECK-NEXT: ret i32 401 %B = lshr i32 %A, 1 ; <i32> [#uses=1] 402 %C = bitcast i32 %B to i32 ; <i32> [#uses=1] 403 %D = shl i32 %C, 1 ; <i32> [#uses=1] 404 ret i32 %D 405} 406 407 408define i1 @test27(i32 %x) nounwind { 409; CHECK-LABEL: @test27( 410; CHECK-NEXT: and i32 %x, 8 411; CHECK-NEXT: icmp ne i32 412; CHECK-NEXT: ret i1 413 %y = lshr i32 %x, 3 414 %z = trunc i32 %y to i1 415 ret i1 %z 416} 417 418define i8 @test28(i8 %x) { 419entry: 420; CHECK-LABEL: @test28( 421; CHECK: icmp slt i8 %x, 0 422; CHECK-NEXT: br i1 423 %tmp1 = lshr i8 %x, 7 424 %cond1 = icmp ne i8 %tmp1, 0 425 br i1 %cond1, label %bb1, label %bb2 426 427bb1: 428 ret i8 0 429 430bb2: 431 ret i8 1 432} 433 434define i8 @test28a(i8 %x, i8 %y) { 435entry: 436; This shouldn't be transformed. 437; CHECK-LABEL: @test28a( 438; CHECK: %tmp1 = lshr i8 %x, 7 439; CHECK: %cond1 = icmp eq i8 %tmp1, 0 440; CHECK: br i1 %cond1, label %bb2, label %bb1 441 %tmp1 = lshr i8 %x, 7 442 %cond1 = icmp ne i8 %tmp1, 0 443 br i1 %cond1, label %bb1, label %bb2 444bb1: 445 ret i8 %tmp1 446bb2: 447 %tmp2 = add i8 %tmp1, %y 448 ret i8 %tmp2 449} 450 451 452define i32 @test29(i64 %d18) { 453entry: 454 %tmp916 = lshr i64 %d18, 32 455 %tmp917 = trunc i64 %tmp916 to i32 456 %tmp10 = lshr i32 %tmp917, 31 457 ret i32 %tmp10 458; CHECK-LABEL: @test29( 459; CHECK: %tmp916 = lshr i64 %d18, 63 460; CHECK: %tmp10 = trunc i64 %tmp916 to i32 461} 462 463 464define i32 @test30(i32 %A, i32 %B, i32 %C) { 465 %X = shl i32 %A, %C 466 %Y = shl i32 %B, %C 467 %Z = and i32 %X, %Y 468 ret i32 %Z 469; CHECK-LABEL: @test30( 470; CHECK: %X1 = and i32 %A, %B 471; CHECK: %Z = shl i32 %X1, %C 472} 473 474define i32 @test31(i32 %A, i32 %B, i32 %C) { 475 %X = lshr i32 %A, %C 476 %Y = lshr i32 %B, %C 477 %Z = or i32 %X, %Y 478 ret i32 %Z 479; CHECK-LABEL: @test31( 480; CHECK: %X1 = or i32 %A, %B 481; CHECK: %Z = lshr i32 %X1, %C 482} 483 484define i32 @test32(i32 %A, i32 %B, i32 %C) { 485 %X = ashr i32 %A, %C 486 %Y = ashr i32 %B, %C 487 %Z = xor i32 %X, %Y 488 ret i32 %Z 489; CHECK-LABEL: @test32( 490; CHECK: %X1 = xor i32 %A, %B 491; CHECK: %Z = ashr i32 %X1, %C 492; CHECK: ret i32 %Z 493} 494 495define i1 @test33(i32 %X) { 496 %tmp1 = shl i32 %X, 7 497 %tmp2 = icmp slt i32 %tmp1, 0 498 ret i1 %tmp2 499; CHECK-LABEL: @test33( 500; CHECK: %tmp1.mask = and i32 %X, 16777216 501; CHECK: %tmp2 = icmp ne i32 %tmp1.mask, 0 502} 503 504define i1 @test34(i32 %X) { 505 %tmp1 = lshr i32 %X, 7 506 %tmp2 = icmp slt i32 %tmp1, 0 507 ret i1 %tmp2 508; CHECK-LABEL: @test34( 509; CHECK: ret i1 false 510} 511 512define i1 @test35(i32 %X) { 513 %tmp1 = ashr i32 %X, 7 514 %tmp2 = icmp slt i32 %tmp1, 0 515 ret i1 %tmp2 516; CHECK-LABEL: @test35( 517; CHECK: %tmp2 = icmp slt i32 %X, 0 518; CHECK: ret i1 %tmp2 519} 520 521define i128 @test36(i128 %A, i128 %B) { 522entry: 523 %tmp27 = shl i128 %A, 64 524 %tmp23 = shl i128 %B, 64 525 %ins = or i128 %tmp23, %tmp27 526 %tmp45 = lshr i128 %ins, 64 527 ret i128 %tmp45 528 529; CHECK-LABEL: @test36( 530; CHECK: %tmp231 = or i128 %B, %A 531; CHECK: %ins = and i128 %tmp231, 18446744073709551615 532; CHECK: ret i128 %ins 533} 534 535define i64 @test37(i128 %A, i32 %B) { 536entry: 537 %tmp27 = shl i128 %A, 64 538 %tmp22 = zext i32 %B to i128 539 %tmp23 = shl i128 %tmp22, 96 540 %ins = or i128 %tmp23, %tmp27 541 %tmp45 = lshr i128 %ins, 64 542 %tmp46 = trunc i128 %tmp45 to i64 543 ret i64 %tmp46 544 545; CHECK-LABEL: @test37( 546; CHECK: %tmp23 = shl nuw nsw i128 %tmp22, 32 547; CHECK: %ins = or i128 %tmp23, %A 548; CHECK: %tmp46 = trunc i128 %ins to i64 549} 550 551define i32 @test38(i32 %x) nounwind readnone { 552 %rem = srem i32 %x, 32 553 %shl = shl i32 1, %rem 554 ret i32 %shl 555; CHECK-LABEL: @test38( 556; CHECK-NEXT: and i32 %x, 31 557; CHECK-NEXT: shl i32 1 558; CHECK-NEXT: ret i32 559} 560 561; <rdar://problem/8756731> 562; CHECK-LABEL: @test39( 563define i8 @test39(i32 %a0) { 564entry: 565 %tmp4 = trunc i32 %a0 to i8 566; CHECK: and i8 %tmp49, 64 567 %tmp5 = shl i8 %tmp4, 5 568 %tmp48 = and i8 %tmp5, 32 569 %tmp49 = lshr i8 %tmp48, 5 570 %tmp50 = mul i8 %tmp49, 64 571 %tmp51 = xor i8 %tmp50, %tmp5 572 %tmp52 = and i8 %tmp51, -128 573 %tmp53 = lshr i8 %tmp52, 7 574 %tmp54 = mul i8 %tmp53, 16 575; CHECK: %0 = shl i8 %tmp4, 2 576; CHECK: %tmp54 = and i8 %0, 16 577 %tmp55 = xor i8 %tmp54, %tmp51 578; CHECK: ret i8 %tmp551 579 ret i8 %tmp55 580} 581 582; PR9809 583define i32 @test40(i32 %a, i32 %b) nounwind { 584 %shl1 = shl i32 1, %b 585 %shl2 = shl i32 %shl1, 2 586 %div = udiv i32 %a, %shl2 587 ret i32 %div 588; CHECK-LABEL: @test40( 589; CHECK-NEXT: add i32 %b, 2 590; CHECK-NEXT: lshr i32 %a 591; CHECK-NEXT: ret i32 592} 593 594define i32 @test41(i32 %a, i32 %b) nounwind { 595 %1 = shl i32 1, %b 596 %2 = shl i32 %1, 3 597 ret i32 %2 598; CHECK-LABEL: @test41( 599; CHECK-NEXT: shl i32 8, %b 600; CHECK-NEXT: ret i32 601} 602 603define i32 @test42(i32 %a, i32 %b) nounwind { 604 %div = lshr i32 4096, %b ; must be exact otherwise we'd divide by zero 605 %div2 = udiv i32 %a, %div 606 ret i32 %div2 607; CHECK-LABEL: @test42( 608; CHECK-NEXT: lshr exact i32 4096, %b 609} 610 611define i32 @test43(i32 %a, i32 %b) nounwind { 612 %div = shl i32 4096, %b ; must be exact otherwise we'd divide by zero 613 %div2 = udiv i32 %a, %div 614 ret i32 %div2 615; CHECK-LABEL: @test43( 616; CHECK-NEXT: add i32 %b, 12 617; CHECK-NEXT: lshr 618; CHECK-NEXT: ret 619} 620 621define i32 @test44(i32 %a) nounwind { 622 %y = shl nuw i32 %a, 1 623 %z = shl i32 %y, 4 624 ret i32 %z 625; CHECK-LABEL: @test44( 626; CHECK-NEXT: %y = shl i32 %a, 5 627; CHECK-NEXT: ret i32 %y 628} 629 630define i32 @test45(i32 %a) nounwind { 631 %y = lshr exact i32 %a, 1 632 %z = lshr i32 %y, 4 633 ret i32 %z 634; CHECK-LABEL: @test45( 635; CHECK-NEXT: %y = lshr i32 %a, 5 636; CHECK-NEXT: ret i32 %y 637} 638 639define i32 @test46(i32 %a) { 640 %y = ashr exact i32 %a, 3 641 %z = shl i32 %y, 1 642 ret i32 %z 643; CHECK-LABEL: @test46( 644; CHECK-NEXT: %z = ashr exact i32 %a, 2 645; CHECK-NEXT: ret i32 %z 646} 647 648define i32 @test47(i32 %a) { 649 %y = lshr exact i32 %a, 3 650 %z = shl i32 %y, 1 651 ret i32 %z 652; CHECK-LABEL: @test47( 653; CHECK-NEXT: %z = lshr exact i32 %a, 2 654; CHECK-NEXT: ret i32 %z 655} 656 657define i32 @test48(i32 %x) { 658 %A = lshr exact i32 %x, 1 659 %B = shl i32 %A, 3 660 ret i32 %B 661; CHECK-LABEL: @test48( 662; CHECK-NEXT: %B = shl i32 %x, 2 663; CHECK-NEXT: ret i32 %B 664} 665 666define i32 @test49(i32 %x) { 667 %A = ashr exact i32 %x, 1 668 %B = shl i32 %A, 3 669 ret i32 %B 670; CHECK-LABEL: @test49( 671; CHECK-NEXT: %B = shl i32 %x, 2 672; CHECK-NEXT: ret i32 %B 673} 674 675define i32 @test50(i32 %x) { 676 %A = shl nsw i32 %x, 1 677 %B = ashr i32 %A, 3 678 ret i32 %B 679; CHECK-LABEL: @test50( 680; CHECK-NEXT: %B = ashr i32 %x, 2 681; CHECK-NEXT: ret i32 %B 682} 683 684define i32 @test51(i32 %x) { 685 %A = shl nuw i32 %x, 1 686 %B = lshr i32 %A, 3 687 ret i32 %B 688; CHECK-LABEL: @test51( 689; CHECK-NEXT: %B = lshr i32 %x, 2 690; CHECK-NEXT: ret i32 %B 691} 692 693define i32 @test52(i32 %x) { 694 %A = shl nsw i32 %x, 3 695 %B = ashr i32 %A, 1 696 ret i32 %B 697; CHECK-LABEL: @test52( 698; CHECK-NEXT: %B = shl nsw i32 %x, 2 699; CHECK-NEXT: ret i32 %B 700} 701 702define i32 @test53(i32 %x) { 703 %A = shl nuw i32 %x, 3 704 %B = lshr i32 %A, 1 705 ret i32 %B 706; CHECK-LABEL: @test53( 707; CHECK-NEXT: %B = shl nuw i32 %x, 2 708; CHECK-NEXT: ret i32 %B 709} 710 711define i32 @test54(i32 %x) { 712 %shr2 = lshr i32 %x, 1 713 %shl = shl i32 %shr2, 4 714 %and = and i32 %shl, 16 715 ret i32 %and 716; CHECK-LABEL: @test54( 717; CHECK: shl i32 %x, 3 718} 719 720 721define i32 @test55(i32 %x) { 722 %shr2 = lshr i32 %x, 1 723 %shl = shl i32 %shr2, 4 724 %or = or i32 %shl, 8 725 ret i32 %or 726; CHECK-LABEL: @test55( 727; CHECK: shl i32 %x, 3 728} 729 730define i32 @test56(i32 %x) { 731 %shr2 = lshr i32 %x, 1 732 %shl = shl i32 %shr2, 4 733 %or = or i32 %shl, 7 734 ret i32 %or 735; CHECK-LABEL: @test56( 736; CHECK: shl i32 %shr2, 4 737} 738 739 740define i32 @test57(i32 %x) { 741 %shr = ashr i32 %x, 1 742 %shl = shl i32 %shr, 4 743 %or = or i32 %shl, 7 744 ret i32 %or 745; CHECK-LABEL: @test57( 746; CHECK: %shl = shl i32 %shr1, 4 747} 748 749 750define i32 @test58(i32 %x) { 751 %shr = ashr i32 %x, 4 752 %shl = shl i32 %shr, 1 753 %or = or i32 %shl, 1 754 ret i32 %or 755; CHECK-LABEL: @test58( 756; CHECK: ashr i32 %x, 3 757} 758 759 760define i32 @test59(i32 %x) { 761 %shr = ashr i32 %x, 4 762 %shl = shl i32 %shr, 1 763 %or = or i32 %shl, 2 764 ret i32 %or 765; CHECK-LABEL: @test59( 766; CHECK: ashr i32 %x, 4 767} 768 769; propagate "exact" trait 770define i32 @test60(i32 %x) { 771 %shr = ashr exact i32 %x, 4 772 %shl = shl i32 %shr, 1 773 %or = or i32 %shl, 1 774 ret i32 %or 775; CHECK-LABEL: @test60( 776; CHECK: ashr exact i32 %x, 3 777} 778 779; PR17026 780; CHECK-LABEL: @test61( 781; CHECK-NOT: sh 782; CHECK: ret 783define void @test61(i128 %arg) { 784bb: 785 br i1 undef, label %bb1, label %bb12 786 787bb1: ; preds = %bb11, %bb 788 br label %bb2 789 790bb2: ; preds = %bb7, %bb1 791 br i1 undef, label %bb3, label %bb7 792 793bb3: ; preds = %bb2 794 %tmp = lshr i128 %arg, 36893488147419103232 795 %tmp4 = shl i128 %tmp, 0 796 %tmp5 = or i128 %tmp4, undef 797 %tmp6 = trunc i128 %tmp5 to i16 798 br label %bb8 799 800bb7: ; preds = %bb2 801 br i1 undef, label %bb8, label %bb2 802 803bb8: ; preds = %bb7, %bb3 804 %tmp9 = phi i16 [ %tmp6, %bb3 ], [ undef, %bb7 ] 805 %tmp10 = icmp eq i16 %tmp9, 0 806 br i1 %tmp10, label %bb11, label %bb12 807 808bb11: ; preds = %bb8 809 br i1 undef, label %bb1, label %bb12 810 811bb12: ; preds = %bb11, %bb8, %bb 812 ret void 813} 814 815define i32 @test62(i32 %a) { 816; CHECK-LABEL: @test62( 817; CHECK-NEXT: ret i32 undef 818 %b = ashr i32 %a, 32 ; shift all bits out 819 ret i32 %b 820} 821 822define <4 x i32> @test62_splat_vector(<4 x i32> %a) { 823; CHECK-LABEL: @test62_splat_vector 824; CHECK-NEXT: ret <4 x i32> undef 825 %b = ashr <4 x i32> %a, <i32 32, i32 32, i32 32, i32 32> ; shift all bits out 826 ret <4 x i32> %b 827} 828 829define <4 x i32> @test62_non_splat_vector(<4 x i32> %a) { 830; CHECK-LABEL: @test62_non_splat_vector 831; CHECK-NOT: ret <4 x i32> undef 832 %b = ashr <4 x i32> %a, <i32 32, i32 0, i32 1, i32 2> ; shift all bits out 833 ret <4 x i32> %b 834} 835 836define <2 x i65> @test_63(<2 x i64> %t) { 837; CHECK-LABEL: @test_63 838 %a = zext <2 x i64> %t to <2 x i65> 839 %sext = shl <2 x i65> %a, <i65 33, i65 33> 840 %b = ashr <2 x i65> %sext, <i65 33, i65 33> 841 ret <2 x i65> %b 842} 843