[PATCH] fix corruption in X86AsmParser
Maarten Lankhorst
maarten.lankhorst at canonical.com
Thu Aug 15 04:30:00 PDT 2013
This fixes the failing x86_errors.s test.
Signed-off-by: Maarten Lankhorst <maarten.lankhorst at canonical.com>
---
diff -ru test/lib/Target/X86/AsmParser/X86AsmParser.cpp llvm-toolchain-3.3-3.3/lib/Target/X86/AsmParser/X86AsmParser.cpp
--- test/lib/Target/X86/AsmParser/X86AsmParser.cpp 2013-05-05 02:40:33.000000000 +0200
+++ llvm-toolchain-3.3-3.3/lib/Target/X86/AsmParser/X86AsmParser.cpp 2013-08-14 16:26:44.721547396 +0200
@@ -2382,8 +2382,10 @@
if (!WasOriginallyInvalidOperand) {
ArrayRef<SMRange> Ranges = MatchingInlineAsm ? EmptyRanges :
Op->getLocRange();
- return Error(IDLoc, "invalid instruction mnemonic '" + Base + "'",
- Ranges, MatchingInlineAsm);
+ SmallString<126> Msg;
+ raw_svector_ostream OS(Msg);
+ OS << "invalid instruction mnemonic '" << Base << "'";
+ return Error(IDLoc, OS.str(), Ranges, MatchingInlineAsm);
}
// Recover location info for the operand if we know which was the problem.
More information about the llvm-commits
mailing list