Emit word of zeroes after the last instruction as a start of the mandatory

traceback table on PowerPC64. This helps gdb handle exceptions. The other
mandatory fields are ignored by gdb and harder to implement so just add
there a FIXME.

Patch by Bill Schmidt. PR13641.

llvm-svn: 162778
This commit is contained in:
Roman Divacky 2012-08-28 19:06:55 +00:00
parent 206cefe66c
commit 8c4b6a307e
2 changed files with 25 additions and 0 deletions

View File

@ -109,6 +109,8 @@ namespace {
bool doFinalization(Module &M);
virtual void EmitFunctionEntryLabel();
void EmitFunctionBodyEnd();
};
/// PPCDarwinAsmPrinter - PowerPC assembly printer, customized for Darwin/Mac
@ -450,6 +452,19 @@ bool PPCLinuxAsmPrinter::doFinalization(Module &M) {
return AsmPrinter::doFinalization(M);
}
/// EmitFunctionBodyEnd - Print the traceback table before the .size
/// directive.
///
void PPCLinuxAsmPrinter::EmitFunctionBodyEnd() {
// Only the 64-bit target requires a traceback table. For now,
// we only emit the word of zeroes that GDB requires to find
// the end of the function.
// FIXME: Eventually we should add the eight-byte mandatory fields
// described in the PPC64 ELF ABI.
if (Subtarget.isPPC64())
OutStreamer.EmitIntValue(0, 4/*size*/);
}
void PPCDarwinAsmPrinter::EmitStartOfAsmFile(Module &M) {
static const char *const CPUDirectives[] = {
"",

View File

@ -0,0 +1,10 @@
; RUN: llc < %s | FileCheck %s
target datalayout = "E-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v128:128:128-n32:64"
target triple = "powerpc64-unknown-linux-gnu"
define void @foo() nounwind {
ret void
}
; CHECK: blr
; CHECK-NEXT: .long 0