diff options
author | Evan Cheng <evan.cheng@apple.com> | 2008-04-01 23:26:12 +0000 |
---|---|---|
committer | Evan Cheng <evan.cheng@apple.com> | 2008-04-01 23:26:12 +0000 |
commit | c87df6568a1e224f6faa9e5a5f40a08f69aa67e9 (patch) | |
tree | a908bcc600e2fa093b4579ee00856af9296514cb /lib/Target | |
parent | f850073ddb0f5f248e1f9ed6aefb8b9cb8992521 (diff) | |
download | external_llvm-c87df6568a1e224f6faa9e5a5f40a08f69aa67e9.zip external_llvm-c87df6568a1e224f6faa9e5a5f40a08f69aa67e9.tar.gz external_llvm-c87df6568a1e224f6faa9e5a5f40a08f69aa67e9.tar.bz2 |
ReMat of load from stub in pic mode extends the life of pic base. Currently spiller doesn't do a good job of estimating the impact. Disable for now.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@49059 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target')
-rw-r--r-- | lib/Target/X86/X86InstrInfo.cpp | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/lib/Target/X86/X86InstrInfo.cpp b/lib/Target/X86/X86InstrInfo.cpp index ffe2083..c9de586 100644 --- a/lib/Target/X86/X86InstrInfo.cpp +++ b/lib/Target/X86/X86InstrInfo.cpp @@ -37,6 +37,10 @@ namespace { cl::desc("Print instructions that the allocator wants to" " fuse, but the X86 backend currently can't"), cl::Hidden); + cl::opt<bool> + ReMatPICStubLoad("remat-pic-stub-load", + cl::desc("Re-materialize load from stub in PIC mode"), + cl::init(false), cl::Hidden); } X86InstrInfo::X86InstrInfo(X86TargetMachine &tm) @@ -782,6 +786,8 @@ bool X86InstrInfo::isReallyTriviallyReMaterializable(MachineInstr *MI) const { if (BaseReg == 0) return true; // Allow re-materialization of PIC load. + if (!ReMatPICStubLoad && MI->getOperand(4).isGlobal()) + return false; MachineRegisterInfo &MRI = MI->getParent()->getParent()->getRegInfo(); bool isPICBase = false; for (MachineRegisterInfo::def_iterator I = MRI.def_begin(BaseReg), |