[RISCV] Add shrinkwrap test cases showing gaps in current impl
[llvm-project.git] / llvm / test / CodeGen / X86 / 2009-04-25-CoalescerBug.ll
blob1dd30e82630992558ef5254d0a51bcea72c71248
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=x86_64-- | FileCheck %s
3 ; rdar://6806252
5 define i64 @test(ptr %tmp13) nounwind {
6 ; CHECK-LABEL: test:
7 ; CHECK:       # %bb.0: # %entry
8 ; CHECK-NEXT:    movl (%rdi), %ecx
9 ; CHECK-NEXT:    movl %ecx, %eax
10 ; CHECK-NEXT:    shrl %eax
11 ; CHECK-NEXT:    .p2align 4
12 ; CHECK-NEXT:  .LBB0_1: # %while.cond
13 ; CHECK-NEXT:    # =>This Inner Loop Header: Depth=1
14 ; CHECK-NEXT:    testb $1, %cl
15 ; CHECK-NEXT:    jne .LBB0_1
16 ; CHECK-NEXT:  # %bb.2: # %while.end
17 ; CHECK-NEXT:    retq
18 entry:
19         br label %while.cond
21 while.cond:             ; preds = %while.cond, %entry
22         %tmp15 = load i32, ptr %tmp13           ; <i32> [#uses=2]
23         %bf.lo = lshr i32 %tmp15, 1             ; <i32> [#uses=1]
24         %bf.lo.cleared = and i32 %bf.lo, 2147483647             ; <i32> [#uses=1]
25         %conv = zext i32 %bf.lo.cleared to i64          ; <i64> [#uses=1]
26         %bf.lo.cleared25 = and i32 %tmp15, 1            ; <i32> [#uses=1]
27         %tobool = icmp ne i32 %bf.lo.cleared25, 0               ; <i1> [#uses=1]
28         br i1 %tobool, label %while.cond, label %while.end
30 while.end:              ; preds = %while.cond
31         ret i64 %conv