Handle logical shift right (at least I hope so :) )
[llvm/msp430.git] / test / CodeGen / X86 / 2009-03-13-PHIElimBug.ll
blobb01556de4828f6b79b42e72592a3a512850a83ff
1 ; RUN: llvm-as < %s | llc -march=x86 | grep -A 2 {call.*f} | grep movl
2 ; Check the register copy comes after the call to f and before the call to g
3 ; PR3784
5 declare i32 @f()
7 declare i32 @g()
9 define i32 @phi() {
10 entry:
11         %a = call i32 @f()              ; <i32> [#uses=1]
12         %b = invoke i32 @g()
13                         to label %cont unwind label %lpad               ; <i32> [#uses=1]
15 cont:           ; preds = %entry
16         %x = phi i32 [ %b, %entry ]             ; <i32> [#uses=0]
17         %aa = call i32 @g()             ; <i32> [#uses=1]
18         %bb = invoke i32 @g()
19                         to label %cont2 unwind label %lpad              ; <i32> [#uses=1]
21 cont2:          ; preds = %cont
22         %xx = phi i32 [ %bb, %cont ]            ; <i32> [#uses=1]
23         ret i32 %xx
25 lpad:           ; preds = %cont, %entry
26         %y = phi i32 [ %a, %entry ], [ %aa, %cont ]             ; <i32> [#uses=1]
27         ret i32 %y