forked from OSchip/llvm-project
Fix PR4056. It's possible a physical register def is dead if its implicit use is deleted by two-address pass.
llvm-svn: 70213
This commit is contained in:
parent
a630ce5fff
commit
0f85bd368c
|
@ -627,8 +627,8 @@ void LiveIntervals::handlePhysicalRegisterDef(MachineBasicBlock *MBB,
|
|||
|
||||
// The only case we should have a dead physreg here without a killing or
|
||||
// instruction where we know it's dead is if it is live-in to the function
|
||||
// and never used.
|
||||
assert(!CopyMI && "physreg was not killed in defining block!");
|
||||
// and never used. Another possible case is the implicit use of the
|
||||
// physical register has been deleted by two-address pass.
|
||||
end = start + 1;
|
||||
|
||||
exit:
|
||||
|
|
|
@ -0,0 +1,24 @@
|
|||
; RUN: llvm-as < %s | llc -mtriple=i386-apple-darwin9
|
||||
; PR4056
|
||||
|
||||
define void @int163(i32 %p_4, i32 %p_5) nounwind {
|
||||
entry:
|
||||
%0 = tail call i32 @bar(i32 1) nounwind ; <i32> [#uses=2]
|
||||
%1 = icmp sgt i32 %0, 7 ; <i1> [#uses=1]
|
||||
br i1 %1, label %foo.exit, label %bb.i
|
||||
|
||||
bb.i: ; preds = %entry
|
||||
%2 = lshr i32 1, %0 ; <i32> [#uses=1]
|
||||
%3 = icmp eq i32 %2, 0 ; <i1> [#uses=1]
|
||||
%4 = zext i1 %3 to i32 ; <i32> [#uses=1]
|
||||
%.p_5 = shl i32 %p_5, %4 ; <i32> [#uses=1]
|
||||
br label %foo.exit
|
||||
|
||||
foo.exit: ; preds = %bb.i, %entry
|
||||
%5 = phi i32 [ %.p_5, %bb.i ], [ %p_5, %entry ] ; <i32> [#uses=1]
|
||||
%6 = icmp eq i32 %5, 0 ; <i1> [#uses=0]
|
||||
%7 = tail call i32 @bar(i32 %p_5) nounwind ; <i32> [#uses=0]
|
||||
ret void
|
||||
}
|
||||
|
||||
declare i32 @bar(i32)
|
Loading…
Reference in New Issue