aboutsummaryrefslogtreecommitdiffstats
path: root/lib/MC/MCParser
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2010-01-24 01:07:33 +0000
committerChris Lattner <sabre@nondot.org>2010-01-24 01:07:33 +0000
commit75f265fbbbb64ab060bf41c5a4677ce56014ce9f (patch)
tree08f32d5af2ae43aa5dae6b92ca10701fc3de83f5 /lib/MC/MCParser
parentdd7da4f368c7e1139ef78f36ef173a8b8f8f1c61 (diff)
downloadexternal_llvm-75f265fbbbb64ab060bf41c5a4677ce56014ce9f.zip
external_llvm-75f265fbbbb64ab060bf41c5a4677ce56014ce9f.tar.gz
external_llvm-75f265fbbbb64ab060bf41c5a4677ce56014ce9f.tar.bz2
fix a parsing problem on instructions like:
movw $8, (_cost_table_-L97$pb)+66(%eax) After the parens, we could still have a binop. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@94345 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/MC/MCParser')
-rw-r--r--lib/MC/MCParser/AsmParser.cpp7
1 files changed, 3 insertions, 4 deletions
diff --git a/lib/MC/MCParser/AsmParser.cpp b/lib/MC/MCParser/AsmParser.cpp
index dd438b7..077d2df 100644
--- a/lib/MC/MCParser/AsmParser.cpp
+++ b/lib/MC/MCParser/AsmParser.cpp
@@ -331,10 +331,9 @@ bool AsmParser::ParseExpression(const MCExpr *&Res, SMLoc &EndLoc) {
}
bool AsmParser::ParseParenExpression(const MCExpr *&Res, SMLoc &EndLoc) {
- if (ParseParenExpr(Res, EndLoc))
- return true;
-
- return false;
+ Res = 0;
+ return ParseParenExpr(Res, EndLoc) ||
+ ParseBinOpRHS(1, Res, EndLoc);
}
bool AsmParser::ParseAbsoluteExpression(int64_t &Res) {