From: Jakob Stoklund Olesen Date: Fri, 22 Jun 2012 18:51:35 +0000 (+0000) Subject: Don't depend on live ranges being present. X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=b150930910a254377a62ed74af981c37eafe8fcb;p=oota-llvm.git Don't depend on live ranges being present. DBG_VALUE instructions could be referring to non-existing virtual registers. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@159020 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/LiveDebugVariables.cpp b/lib/CodeGen/LiveDebugVariables.cpp index dd28252e53f..c32ce2df780 100644 --- a/lib/CodeGen/LiveDebugVariables.cpp +++ b/lib/CodeGen/LiveDebugVariables.cpp @@ -642,11 +642,16 @@ UserValue::computeIntervals(MachineRegisterInfo &MRI, // Register locations are constrained to where the register value is live. if (TargetRegisterInfo::isVirtualRegister(Loc.getReg())) { - LiveInterval *LI = &LIS.getInterval(Loc.getReg()); - const VNInfo *VNI = LI->getVNInfoAt(Idx); + LiveInterval *LI = 0; + const VNInfo *VNI = 0; + if (LIS.hasInterval(Loc.getReg())) { + LI = &LIS.getInterval(Loc.getReg()); + VNI = LI->getVNInfoAt(Idx); + } SmallVector Kills; extendDef(Idx, LocNo, LI, VNI, &Kills, LIS, MDT, UVS); - addDefsFromCopies(LI, LocNo, Kills, Defs, MRI, LIS); + if (LI) + addDefsFromCopies(LI, LocNo, Kills, Defs, MRI, LIS); continue; }