aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/X86
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2007-08-01 23:46:47 +0000
committerEvan Cheng <evan.cheng@apple.com>2007-08-01 23:46:47 +0000
commit5278784621bd6f77cad3c6b8388290aa5c5870ec (patch)
treea7813aa0e1bba7ff4fd597658f751353271cb1a7 /lib/Target/X86
parent0db079e2e69dd349d9f0fb88ea57da0fbc7d016e (diff)
downloadexternal_llvm-5278784621bd6f77cad3c6b8388290aa5c5870ec.zip
external_llvm-5278784621bd6f77cad3c6b8388290aa5c5870ec.tar.gz
external_llvm-5278784621bd6f77cad3c6b8388290aa5c5870ec.tar.bz2
Can't handle offset and scale if rip-relative addressing is to be used.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@40703 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/X86')
-rw-r--r--lib/Target/X86/X86ISelLowering.cpp16
1 files changed, 10 insertions, 6 deletions
diff --git a/lib/Target/X86/X86ISelLowering.cpp b/lib/Target/X86/X86ISelLowering.cpp
index 939ddf8..91da4c0 100644
--- a/lib/Target/X86/X86ISelLowering.cpp
+++ b/lib/Target/X86/X86ISelLowering.cpp
@@ -4449,14 +4449,18 @@ bool X86TargetLowering::isLegalAddressingMode(const AddrMode &AM,
return false;
if (AM.BaseGV) {
- // X86-64 only supports addr of globals in small code model.
- if (Subtarget->is64Bit() &&
- getTargetMachine().getCodeModel() != CodeModel::Small)
- return false;
-
- // We can only fold this if we don't need a load either.
+ // We can only fold this if we don't need an extra load.
if (Subtarget->GVRequiresExtraLoad(AM.BaseGV, getTargetMachine(), false))
return false;
+
+ // X86-64 only supports addr of globals in small code model.
+ if (Subtarget->is64Bit()) {
+ if (getTargetMachine().getCodeModel() != CodeModel::Small)
+ return false;
+ // If lower 4G is not available, then we must use rip-relative addressing.
+ if (AM.BaseOffs || AM.Scale > 1)
+ return false;
+ }
}
switch (AM.Scale) {