diff options
author | Eric Christopher <echristo@apple.com> | 2010-10-17 01:51:42 +0000 |
---|---|---|
committer | Eric Christopher <echristo@apple.com> | 2010-10-17 01:51:42 +0000 |
commit | d56d61af0190ee8024eb71dd4138ed7861f20adc (patch) | |
tree | c99b4939ddef658d1c99565847a646dd6efeb701 | |
parent | 7208dbf2d58a8eeff755907494d77af052db207b (diff) | |
download | external_llvm-d56d61af0190ee8024eb71dd4138ed7861f20adc.zip external_llvm-d56d61af0190ee8024eb71dd4138ed7861f20adc.tar.gz external_llvm-d56d61af0190ee8024eb71dd4138ed7861f20adc.tar.bz2 |
Optimize GEP off of intermediate allocas.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@116681 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Target/ARM/ARMFastISel.cpp | 60 |
1 files changed, 46 insertions, 14 deletions
diff --git a/lib/Target/ARM/ARMFastISel.cpp b/lib/Target/ARM/ARMFastISel.cpp index 11ef6c2..d1f3aed 100644 --- a/lib/Target/ARM/ARMFastISel.cpp +++ b/lib/Target/ARM/ARMFastISel.cpp @@ -33,7 +33,9 @@ #include "llvm/CodeGen/MachineModuleInfo.h" #include "llvm/CodeGen/MachineConstantPool.h" #include "llvm/CodeGen/MachineFrameInfo.h" +#include "llvm/CodeGen/MachineMemOperand.h" #include "llvm/CodeGen/MachineRegisterInfo.h" +#include "llvm/CodeGen/PseudoSourceValue.h" #include "llvm/Support/CallSite.h" #include "llvm/Support/CommandLine.h" #include "llvm/Support/ErrorHandling.h" @@ -658,21 +660,13 @@ bool ARMFastISel::ARMComputeRegOffset(const Value *Obj, AddrBase &Base, break; } case Instruction::Alloca: { - // TODO: Fix this to do intermediate loads, etc. - if (Offset != 0) return false; - const AllocaInst *AI = cast<AllocaInst>(Obj); - DenseMap<const AllocaInst*, int>::iterator SI = - FuncInfo.StaticAllocaMap.find(AI); - if (SI != FuncInfo.StaticAllocaMap.end()) { - Base.Reg = ARM::SP; - Base.FrameIndex = SI->second; - return true; - } - // Don't handle dynamic allocas. - assert(!FuncInfo.StaticAllocaMap.count(cast<AllocaInst>(Obj)) && - "Alloca should have been handled earlier!"); - return false; + unsigned Reg = TargetMaterializeAlloca(AI); + + if (Reg == 0) return false; + + Base.Reg = Reg; + return true; } } @@ -766,6 +760,24 @@ bool ARMFastISel::ARMEmitLoad(EVT VT, unsigned &ResultReg, TII.loadRegFromStackSlot(*FuncInfo.MBB, *FuncInfo.InsertPt, ResultReg, Base.FrameIndex, RC, TM.getRegisterInfo()); + else if (Base.Reg == ARM::SP) { + // TODO: This won't work for NEON. + unsigned FI = Base.FrameIndex; + MachineMemOperand *MMO = + FuncInfo.MF->getMachineMemOperand( + MachinePointerInfo::getFixedStack(FI, Offset), + MachineMemOperand::MOLoad, + MFI.getObjectSize(FI), + MFI.getObjectAlignment(FI)); + if (isFloat || isThumb) + AddOptionalDefs(BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt, DL, + TII.get(Opc), ResultReg) + .addFrameIndex(FI).addImm(Offset).addMemOperand(MMO)); + else + AddOptionalDefs(BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt, DL, + TII.get(Opc), ResultReg) + .addFrameIndex(FI).addReg(0).addImm(Offset).addMemOperand(MMO)); + } // The thumb and floating point instructions both take 2 operands, ARM takes // another register. else if (isFloat || isThumb) @@ -838,6 +850,26 @@ bool ARMFastISel::ARMEmitStore(EVT VT, unsigned SrcReg, TII.storeRegToStackSlot(*FuncInfo.MBB, *FuncInfo.InsertPt, SrcReg, true /*isKill*/, Base.FrameIndex, TLI.getRegClassFor(VT), TM.getRegisterInfo()); + else if (Base.Reg == ARM::SP) { + // TODO: This won't work for NEON. + unsigned FI = Base.FrameIndex; + MachineMemOperand *MMO = + FuncInfo.MF->getMachineMemOperand( + MachinePointerInfo::getFixedStack(FI, Offset), + MachineMemOperand::MOStore, + MFI.getObjectSize(FI), + MFI.getObjectAlignment(FI)); + if (isFloat || isThumb) + AddOptionalDefs(BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt, DL, + TII.get(StrOpc)) + .addReg(SrcReg, getKillRegState(true)) + .addFrameIndex(FI).addImm(Offset).addMemOperand(MMO)); + else + AddOptionalDefs(BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt, DL, + TII.get(StrOpc)) + .addReg(SrcReg, getKillRegState(true)) + .addFrameIndex(FI).addReg(0).addImm(Offset).addMemOperand(MMO)); + } // The thumb addressing mode has operands swapped from the arm addressing // mode, the floating point one only has two operands. else if (isFloat || isThumb) |