aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/ARM
diff options
context:
space:
mode:
authorMihai Popa <mihail.popa@gmail.com>2013-06-11 09:48:35 +0000
committerMihai Popa <mihail.popa@gmail.com>2013-06-11 09:48:35 +0000
commit55ab7315d04ce4f25a15e5cd50f6a23d950a00cf (patch)
tree8aa576a45ed168ba3f7dd4c76d15df65ef29aa86 /lib/Target/ARM
parent16ad92ad3cd0cbbaa4d0524d9f201dd5dbefa15a (diff)
downloadexternal_llvm-55ab7315d04ce4f25a15e5cd50f6a23d950a00cf.zip
external_llvm-55ab7315d04ce4f25a15e5cd50f6a23d950a00cf.tar.gz
external_llvm-55ab7315d04ce4f25a15e5cd50f6a23d950a00cf.tar.bz2
It adds support for negative zero offsets for loads and stores.
Negative zero is returned by the primary expression parser as INT32_MIN, so all that the method needs to do is to accept this value. Behavior already present for Thumb2. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@183734 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/ARM')
-rw-r--r--lib/Target/ARM/AsmParser/ARMAsmParser.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/lib/Target/ARM/AsmParser/ARMAsmParser.cpp b/lib/Target/ARM/AsmParser/ARMAsmParser.cpp
index 314d37d..c59ca64 100644
--- a/lib/Target/ARM/AsmParser/ARMAsmParser.cpp
+++ b/lib/Target/ARM/AsmParser/ARMAsmParser.cpp
@@ -994,7 +994,7 @@ public:
const MCConstantExpr *CE = dyn_cast<MCConstantExpr>(getImm());
if (!CE) return false;
int64_t Val = CE->getValue();
- return Val > -4096 && Val < 4096;
+ return (Val == INT32_MIN) || (Val > -4096 && Val < 4096);
}
bool isAddrMode3() const {
// If we have an immediate that's not a constant, treat it as a label