diff options
| author | Jakob Stoklund Olesen <stoklund@2pi.dk> | 2012-03-28 21:20:32 +0000 | 
|---|---|---|
| committer | Jakob Stoklund Olesen <stoklund@2pi.dk> | 2012-03-28 21:20:32 +0000 | 
| commit | 9e512120b76e273d7de644b1149f6ed96f363b3a (patch) | |
| tree | b8912ec4173eb9f1f5c404f93081fa7774731f7a /llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp | |
| parent | e798ba4b6797c5ae6dbb3047ffa3121d9ba3a04f (diff) | |
| download | bcm5719-llvm-9e512120b76e273d7de644b1149f6ed96f363b3a.tar.gz bcm5719-llvm-9e512120b76e273d7de644b1149f6ed96f363b3a.zip | |
Spill DPair registers, not just QPR.
The arm_neon intrinsics can create virtual registers from the DPair
register class which allows both even-odd and odd-even D-register pairs.
This fixes PR12389.
llvm-svn: 153603
Diffstat (limited to 'llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp')
| -rw-r--r-- | llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp | 4 | 
1 files changed, 2 insertions, 2 deletions
| diff --git a/llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp b/llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp index 17ff7192b1e..ccb6b16d3ac 100644 --- a/llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp +++ b/llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp @@ -757,7 +757,7 @@ storeRegToStackSlot(MachineBasicBlock &MBB, MachineBasicBlock::iterator I,          llvm_unreachable("Unknown reg class!");        break;      case 16: -      if (ARM::QPRRegClass.hasSubClassEq(RC)) { +      if (ARM::DPairRegClass.hasSubClassEq(RC)) {          // Use aligned spills if the stack can be realigned.          if (Align >= 16 && getRegisterInfo().canRealignStack(MF)) {            AddDefaultPred(BuildMI(MBB, I, DL, get(ARM::VST1q64)) @@ -907,7 +907,7 @@ loadRegFromStackSlot(MachineBasicBlock &MBB, MachineBasicBlock::iterator I,        llvm_unreachable("Unknown reg class!");      break;    case 16: -    if (ARM::QPRRegClass.hasSubClassEq(RC)) { +    if (ARM::DPairRegClass.hasSubClassEq(RC)) {        if (Align >= 16 && getRegisterInfo().canRealignStack(MF)) {          AddDefaultPred(BuildMI(MBB, I, DL, get(ARM::VLD1q64), DestReg)                       .addFrameIndex(FI).addImm(16) | 

