mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-22 11:39:35 +00:00
If a vr is already marked alive in a bb, then it has PHI uses that are visited earlier, then it is not killed in the def block (i.e. not dead).
llvm-svn: 46763
This commit is contained in:
parent
264514cacf
commit
69d5e0fc0f
@ -436,7 +436,8 @@ bool LiveVariables::runOnMachineFunction(MachineFunction &mf) {
|
|||||||
if (MO.isRegister() && MO.isDef() && MO.getReg()) {
|
if (MO.isRegister() && MO.isDef() && MO.getReg()) {
|
||||||
if (MRegisterInfo::isVirtualRegister(MO.getReg())) {
|
if (MRegisterInfo::isVirtualRegister(MO.getReg())) {
|
||||||
VarInfo &VRInfo = getVarInfo(MO.getReg());
|
VarInfo &VRInfo = getVarInfo(MO.getReg());
|
||||||
// Defaults to dead
|
if (VRInfo.AliveBlocks.none())
|
||||||
|
// If vr is not alive in any block, then defaults to dead.
|
||||||
VRInfo.Kills.push_back(MI);
|
VRInfo.Kills.push_back(MI);
|
||||||
} else if (MRegisterInfo::isPhysicalRegister(MO.getReg()) &&
|
} else if (MRegisterInfo::isPhysicalRegister(MO.getReg()) &&
|
||||||
!ReservedRegisters[MO.getReg()]) {
|
!ReservedRegisters[MO.getReg()]) {
|
||||||
|
67
test/CodeGen/PowerPC/2008-02-05-LiveIntervalsAssert.ll
Normal file
67
test/CodeGen/PowerPC/2008-02-05-LiveIntervalsAssert.ll
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
; RUN: llvm-as < %s | llc -mtriple=powerpc-apple-darwin
|
||||||
|
|
||||||
|
%struct.Handle = type { %struct.oopDesc** }
|
||||||
|
%struct.JNI_ArgumentPusher = type { %struct.SignatureIterator, %struct.JavaCallArguments* }
|
||||||
|
%struct.JNI_ArgumentPusherArray = type { %struct.JNI_ArgumentPusher, %struct.JvmtiEventEnabled* }
|
||||||
|
%struct.JavaCallArguments = type { [9 x i32], [9 x i32], i32*, i32*, i32, i32, i32 }
|
||||||
|
%struct.JvmtiEventEnabled = type { i64 }
|
||||||
|
%struct.KlassHandle = type { %struct.Handle }
|
||||||
|
%struct.SignatureIterator = type { i32 (...)**, %struct.KlassHandle, i32, i32, i32 }
|
||||||
|
%struct.instanceOopDesc = type { %struct.oopDesc }
|
||||||
|
%struct.oopDesc = type { %struct.instanceOopDesc*, %struct.instanceOopDesc* }
|
||||||
|
@.str = external constant [44 x i8] ; <[44 x i8]*> [#uses=1]
|
||||||
|
|
||||||
|
define void @_ZN23JNI_ArgumentPusherArray7iterateEy(%struct.JNI_ArgumentPusherArray* %this, i64 %fingerprint) nounwind {
|
||||||
|
entry:
|
||||||
|
br label %bb113
|
||||||
|
|
||||||
|
bb22.preheader: ; preds = %bb113
|
||||||
|
ret void
|
||||||
|
|
||||||
|
bb32.preheader: ; preds = %bb113
|
||||||
|
ret void
|
||||||
|
|
||||||
|
bb42.preheader: ; preds = %bb113
|
||||||
|
ret void
|
||||||
|
|
||||||
|
bb52: ; preds = %bb113
|
||||||
|
br label %bb113
|
||||||
|
|
||||||
|
bb62.preheader: ; preds = %bb113
|
||||||
|
ret void
|
||||||
|
|
||||||
|
bb72.preheader: ; preds = %bb113
|
||||||
|
ret void
|
||||||
|
|
||||||
|
bb82: ; preds = %bb113
|
||||||
|
br label %bb113
|
||||||
|
|
||||||
|
bb93: ; preds = %bb113
|
||||||
|
br label %bb113
|
||||||
|
|
||||||
|
bb103.preheader: ; preds = %bb113
|
||||||
|
ret void
|
||||||
|
|
||||||
|
bb113: ; preds = %bb113, %bb93, %bb82, %bb52, %entry
|
||||||
|
%fingerprint_addr.0.reg2mem.9 = phi i64 [ 0, %entry ], [ 0, %bb52 ], [ 0, %bb82 ], [ 0, %bb93 ], [ %tmp118, %bb113 ] ; <i64> [#uses=1]
|
||||||
|
tail call void @_Z28report_should_not_reach_herePKci( i8* getelementptr ([44 x i8]* @.str, i32 0, i32 0), i32 817 ) nounwind
|
||||||
|
%tmp118 = lshr i64 %fingerprint_addr.0.reg2mem.9, 4 ; <i64> [#uses=2]
|
||||||
|
%tmp21158 = and i64 %tmp118, 15 ; <i64> [#uses=1]
|
||||||
|
switch i64 %tmp21158, label %bb113 [
|
||||||
|
i64 1, label %bb22.preheader
|
||||||
|
i64 2, label %bb52
|
||||||
|
i64 3, label %bb32.preheader
|
||||||
|
i64 4, label %bb42.preheader
|
||||||
|
i64 5, label %bb62.preheader
|
||||||
|
i64 6, label %bb82
|
||||||
|
i64 7, label %bb93
|
||||||
|
i64 8, label %bb103.preheader
|
||||||
|
i64 9, label %bb72.preheader
|
||||||
|
i64 10, label %UnifiedReturnBlock
|
||||||
|
]
|
||||||
|
|
||||||
|
UnifiedReturnBlock: ; preds = %bb113
|
||||||
|
ret void
|
||||||
|
}
|
||||||
|
|
||||||
|
declare void @_Z28report_should_not_reach_herePKci(i8*, i32)
|
Loading…
Reference in New Issue
Block a user