Fix bug in .gpword directive parsing.
llvm-svn: 194570
diff --git a/llvm/lib/Target/Mips/AsmParser/MipsAsmParser.cpp b/llvm/lib/Target/Mips/AsmParser/MipsAsmParser.cpp
index 7b93d75..89e2b3b 100644
--- a/llvm/lib/Target/Mips/AsmParser/MipsAsmParser.cpp
+++ b/llvm/lib/Target/Mips/AsmParser/MipsAsmParser.cpp
@@ -2379,13 +2379,11 @@
// method to evaluate the expression.
if (getParser().parseExpression(Value))
return true;
-
getParser().getStreamer().EmitGPRel32Value(Value);
- Parser.Lex(); // Eat last token.
- if (getLexer().is(AsmToken::EndOfStatement))
+ if (getLexer().isNot(AsmToken::EndOfStatement))
return Error(getLexer().getLoc(), "unexpected token in directive");
-
+ Parser.Lex(); // Eat EndOfStatement token.
return false;
}
diff --git a/llvm/test/MC/Mips/mips_directives.s b/llvm/test/MC/Mips/mips_directives.s
index 6bd690a..44e707c 100644
--- a/llvm/test/MC/Mips/mips_directives.s
+++ b/llvm/test/MC/Mips/mips_directives.s
@@ -19,10 +19,11 @@
.set noat
$JTI0_0:
.gpword ($BB0_2)
+
.word 0x77fffffc
# CHECK: $JTI0_0:
# CHECK: .gpword ($BB0_2)
-# CHECK-NEXT: .4byte 2013265916
+# CHECK: .4byte 2013265916
.set at=$12
.set macro
# CHECK: b 1332 # encoding: [0x10,0x00,0x01,0x4d]