mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 20:32:21 +00:00
a more graceful fix for test/Other/inline-asm-newline-terminator.ll,
follow on to r103765 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@108390 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5e84e8e52a
commit
b5b73c4c86
@ -178,7 +178,7 @@ bool AsmPrinter::doInitialization(Module &M) {
|
||||
if (!M.getModuleInlineAsm().empty()) {
|
||||
OutStreamer.AddComment("Start of file scope inline assembly");
|
||||
OutStreamer.AddBlankLine();
|
||||
EmitInlineAsm(M.getModuleInlineAsm(), 0/*no loc cookie*/);
|
||||
EmitInlineAsm(M.getModuleInlineAsm()+"\n", 0/*no loc cookie*/);
|
||||
OutStreamer.AddComment("End of file scope inline assembly");
|
||||
OutStreamer.AddBlankLine();
|
||||
}
|
||||
|
@ -53,17 +53,6 @@ void AsmPrinter::EmitInlineAsm(StringRef Str, unsigned LocCookie) const {
|
||||
}
|
||||
|
||||
SourceMgr SrcMgr;
|
||||
|
||||
// Ensure the buffer is newline terminated.
|
||||
char *TmpString = 0;
|
||||
if (Str.back() != '\n') {
|
||||
TmpString = new char[Str.size() + 2];
|
||||
memcpy(TmpString, Str.data(), Str.size());
|
||||
TmpString[Str.size()] = '\n';
|
||||
TmpString[Str.size() + 1] = 0;
|
||||
isNullTerminated = true;
|
||||
Str = TmpString;
|
||||
}
|
||||
|
||||
// If the current LLVMContext has an inline asm handler, set it in SourceMgr.
|
||||
LLVMContext &LLVMCtx = MMI->getModule()->getContext();
|
||||
@ -95,9 +84,6 @@ void AsmPrinter::EmitInlineAsm(StringRef Str, unsigned LocCookie) const {
|
||||
/*NoFinalize*/ true);
|
||||
if (Res && !HasDiagHandler)
|
||||
report_fatal_error("Error parsing inline asm\n");
|
||||
|
||||
if (TmpString)
|
||||
delete[] TmpString;
|
||||
}
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user