Fix initial frame state on powerpc64.

The createPPCMCAsmInfo routine used PPC::R1 as the initial frame
pointer register, but on PPC64 the 32-bit R1 register does not
have a corresponding DWARF number, causing invalid CIE initial
frame state to be emitted.  Fix by using PPC::X1 instead.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@168799 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Ulrich Weigand 2012-11-28 18:21:03 +00:00
parent dacb9a51bd
commit 781dfbd482
2 changed files with 42 additions and 1 deletions

View File

@ -70,7 +70,7 @@ static MCAsmInfo *createPPCMCAsmInfo(const Target &T, StringRef TT) {
// Initial state of the frame pointer is R1.
MachineLocation Dst(MachineLocation::VirtualFP);
MachineLocation Src(PPC::R1, 0);
MachineLocation Src(isPPC64? PPC::X1 : PPC::R1, 0);
MAI->addInitialFrameState(0, Dst, Src);
return MAI;

View File

@ -0,0 +1,41 @@
;; RUN: llc -mtriple=powerpc64-unknown-linux-gnu -filetype=obj %s -o - | \
;; RUN: elf-dump --dump-section-data | FileCheck %s
;; FIXME: this file should be in .s form, change when asm parser is available.
define void @f() {
entry:
ret void
}
;; CHECK: ('sh_name', 0x{{.*}}) # '.eh_frame'
;; CHECK-NEXT: ('sh_type', 0x00000001)
;; CHECK-NEXT: ('sh_flags', 0x0000000000000002)
;; CHECK-NEXT: ('sh_addr', 0x{{.*}})
;; CHECK-NEXT: ('sh_offset', 0x{{.*}})
;; CHECK-NEXT: ('sh_size', 0x0000000000000030)
;; CHECK-NEXT: ('sh_link', 0x00000000)
;; CHECK-NEXT: ('sh_info', 0x00000000)
;; CHECK-NEXT: ('sh_addralign', 0x0000000000000008)
;; CHECK-NEXT: ('sh_entsize', 0x0000000000000000)
;; CHECK-NEXT: ('_section_data', '00000010 00000000 017a5200 01784101 000c0100 00000018 00000018 00000000 00000000 00000000 00000010 00000000')
;; CHECK: ('sh_name', 0x{{.*}}) # '.rela.eh_frame'
;; CHECK-NEXT: ('sh_type', 0x00000004)
;; CHECK-NEXT: ('sh_flags', 0x0000000000000000)
;; CHECK-NEXT: ('sh_addr', 0x{{.*}})
;; CHECK-NEXT: ('sh_offset', 0x{{.*}})
;; CHECK-NEXT: ('sh_size', 0x0000000000000018)
;; CHECK-NEXT: ('sh_link', 0x{{.*}})
;; CHECK-NEXT: ('sh_info', 0x{{.*}})
;; CHECK-NEXT: ('sh_addralign', 0x0000000000000008)
;; CHECK-NEXT: ('sh_entsize', 0x0000000000000018)
;; CHECK-NEXT: ('_relocations', [
;; CHECK-NEXT: # Relocation 0
;; CHECK-NEXT: (('r_offset', 0x000000000000001c)
;; CHECK-NEXT: ('r_sym', 0x{{.*}})
;; CHECK-NEXT: ('r_type', 0x00000026)
;; CHECK-NEXT: ('r_addend', 0x0000000000000000)
;; CHECK-NEXT: ),
;; CHECK-NEXT: ])