diff options
| author | Jim Grosbach <grosbach@apple.com> | 2010-03-10 00:13:42 +0000 | 
|---|---|---|
| committer | Jim Grosbach <grosbach@apple.com> | 2010-03-10 00:13:42 +0000 | 
| commit | 7c617b5e53987d786451dd668b5113f2e2b983f8 (patch) | |
| tree | 27adde717bc1ab01b7309247616a9f3ac9cef9c0 | |
| parent | 7dda453410eb957cd52cff4f8fa8d5a9c09e28df (diff) | |
| download | external_llvm-7c617b5e53987d786451dd668b5113f2e2b983f8.zip external_llvm-7c617b5e53987d786451dd668b5113f2e2b983f8.tar.gz external_llvm-7c617b5e53987d786451dd668b5113f2e2b983f8.tar.bz2 | |
Clear up the last (famous last words) frame index value reuse issues for Thumb1.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@98109 91177308-0d34-0410-b5e6-96231b3b80d8
| -rw-r--r-- | lib/CodeGen/PrologEpilogInserter.cpp | 15 | ||||
| -rw-r--r-- | lib/CodeGen/PrologEpilogInserter.h | 3 | ||||
| -rw-r--r-- | lib/Target/ARM/Thumb1RegisterInfo.cpp | 2 | 
3 files changed, 12 insertions, 8 deletions
| diff --git a/lib/CodeGen/PrologEpilogInserter.cpp b/lib/CodeGen/PrologEpilogInserter.cpp index f50fd5a..2d54cd4 100644 --- a/lib/CodeGen/PrologEpilogInserter.cpp +++ b/lib/CodeGen/PrologEpilogInserter.cpp @@ -57,6 +57,7 @@ bool PEI::runOnMachineFunction(MachineFunction &Fn) {    const TargetRegisterInfo *TRI = Fn.getTarget().getRegisterInfo();    RS = TRI->requiresRegisterScavenging(Fn) ? new RegScavenger() : NULL;    FrameIndexVirtualScavenging = TRI->requiresFrameIndexScavenging(Fn); +  FrameConstantRegMap.clear();    // Get MachineModuleInfo so that we can track the construction of the    // frame. @@ -693,8 +694,7 @@ void PEI::replaceFrameIndices(MachineFunction &Fn) {              assert (FrameIndexVirtualScavenging &&                      "Not scavenging, but virtual returned from "                      "eliminateFrameIndex()!"); -            FrameConstantRegMap[VReg] = FrameConstantEntry(Value.second, -                                                           SPAdj); +            FrameConstantRegMap[VReg] = FrameConstantEntry(Value, SPAdj);            }            // Reset the iterator if we were at the beginning of the BB. @@ -765,12 +765,12 @@ void PEI::scavengeFrameVirtualRegs(MachineFunction &Fn) {      unsigned CurrentVirtReg = 0;      unsigned CurrentScratchReg = 0;      bool havePrevValue = false; -    int PrevValue = 0; +    TargetRegisterInfo::FrameIndexValue PrevValue(0,0); +    TargetRegisterInfo::FrameIndexValue Value(0,0);      MachineInstr *PrevLastUseMI = NULL;      unsigned PrevLastUseOp = 0;      bool trackingCurrentValue = false;      int SPAdj = 0; -    int Value = 0;      // The instruction stream may change in the loop, so check BB->end()      // directly. @@ -827,8 +827,11 @@ void PEI::scavengeFrameVirtualRegs(MachineFunction &Fn) {              if (trackingCurrentValue) {                SPAdj = (*Entry).second.second;                Value = (*Entry).second.first; -            } else -              SPAdj = Value = 0; +            } else { +              SPAdj = 0; +              Value.first = 0; +              Value.second = 0; +            }              // If the scratch register from the last allocation is still              // available, see if the value matches. If it does, just re-use it. diff --git a/lib/CodeGen/PrologEpilogInserter.h b/lib/CodeGen/PrologEpilogInserter.h index 931f1eb..aa95773 100644 --- a/lib/CodeGen/PrologEpilogInserter.h +++ b/lib/CodeGen/PrologEpilogInserter.h @@ -102,7 +102,8 @@ namespace llvm {      // When using the scavenger post-pass to resolve frame reference      // materialization registers, maintain a map of the registers to      // the constant value and SP adjustment associated with it. -    typedef std::pair<int, int> FrameConstantEntry; +    typedef std::pair<TargetRegisterInfo::FrameIndexValue, int> +      FrameConstantEntry;      DenseMap<unsigned, FrameConstantEntry> FrameConstantRegMap;  #ifndef NDEBUG diff --git a/lib/Target/ARM/Thumb1RegisterInfo.cpp b/lib/Target/ARM/Thumb1RegisterInfo.cpp index a4070bd..6215d2f 100644 --- a/lib/Target/ARM/Thumb1RegisterInfo.cpp +++ b/lib/Target/ARM/Thumb1RegisterInfo.cpp @@ -642,7 +642,7 @@ Thumb1RegisterInfo::eliminateFrameIndex(MachineBasicBlock::iterator II,        VReg = MF.getRegInfo().createVirtualRegister(ARM::tGPRRegisterClass);        assert (Value && "Frame index virtual allocated, but Value arg is NULL!");        bool UseRR = false; -      bool TrackVReg = FrameReg == ARM::SP; +      bool TrackVReg = true;        Value->first = FrameReg; // use the frame register as a kind indicator        Value->second = Offset; | 
