summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChad Rosier <mcrosier@apple.com>2012-10-23 23:42:06 +0000
committerChad Rosier <mcrosier@apple.com>2012-10-23 23:42:06 +0000
commita62352448727b11b03b8d82022f1d77f7df416f4 (patch)
treea6d8fe2de10dba6162091b61de9dac9199103b26
parenteac2b2003e9347aa8014a8793f317f03301d7598 (diff)
downloadbcm5719-llvm-a62352448727b11b03b8d82022f1d77f7df416f4.tar.gz
bcm5719-llvm-a62352448727b11b03b8d82022f1d77f7df416f4.zip
[ms-inline asm] Offset operator - the size should be based on the size of a
pointer, not the size of the variable. Part of rdar://12470317 llvm-svn: 166526
-rw-r--r--llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp4
1 files changed, 4 insertions, 0 deletions
diff --git a/llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp b/llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp
index 1f4e8dae271..b82bbdf9130 100644
--- a/llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp
+++ b/llvm/lib/Target/X86/AsmParser/X86AsmParser.cpp
@@ -774,6 +774,10 @@ X86Operand *X86AsmParser::ParseIntelMemOperand(unsigned SegReg, SMLoc Start) {
Tok.getString() == "OFFSET")) {
OffsetOf = true;
OffsetOfLoc = Parser.getTok().getLoc();
+
+ // Size is based on the size of a pointer, not the size of the variable.
+ assert (!Size && "Unexpected size!");
+ Size = is64BitMode() ? 64 : 32;
Parser.Lex(); // Eat offset.
}
OpenPOWER on IntegriCloud