From c0fad4d9fdb1aebe029bcb54311fad7059b1a9e5 Mon Sep 17 00:00:00 2001 From: Vladimir Medic Date: Wed, 13 Nov 2013 13:18:04 +0000 Subject: [PATCH] Fix bug in .gpword directive parsing. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@194570 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/Mips/AsmParser/MipsAsmParser.cpp | 6 ++---- test/MC/Mips/mips_directives.s | 3 ++- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/lib/Target/Mips/AsmParser/MipsAsmParser.cpp b/lib/Target/Mips/AsmParser/MipsAsmParser.cpp index 7b93d751e00..89e2b3b0227 100644 --- a/lib/Target/Mips/AsmParser/MipsAsmParser.cpp +++ b/lib/Target/Mips/AsmParser/MipsAsmParser.cpp @@ -2379,13 +2379,11 @@ bool MipsAsmParser::parseDirectiveGpWord() { // 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/test/MC/Mips/mips_directives.s b/test/MC/Mips/mips_directives.s index 6bd690aad60..44e707c8945 100644 --- a/test/MC/Mips/mips_directives.s +++ b/test/MC/Mips/mips_directives.s @@ -19,10 +19,11 @@ $BB0_2: .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] -- 2.34.1