diff options
author | Adhemerval Zanella <azanella@linux.vnet.ibm.com> | 2013-01-04 19:08:13 +0000 |
---|---|---|
committer | Adhemerval Zanella <azanella@linux.vnet.ibm.com> | 2013-01-04 19:08:13 +0000 |
commit | 7b449889e7886b263718b5103538970f287bc37e (patch) | |
tree | adce081f990c3c199145baac8c42561f51cc5bba /test/MC/PowerPC | |
parent | 13410a11e7247ed9d7841e219fdcdc93427c039e (diff) |
PowerPC: Fix eh_frame relocation for PIC
This patch fixes the PPC eh_frame definitions for the personality and
frame unwinding for PIC objects. It makes PIC build correctly creates
relative relocations in the '.rela.eh_frame' segments and thus avoiding
a text relocation that generates a DT_TEXTREL segments in link phase.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@171506 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/MC/PowerPC')
-rw-r--r-- | test/MC/PowerPC/ppc64-initial-cfa.ll | 103 |
1 files changed, 70 insertions, 33 deletions
diff --git a/test/MC/PowerPC/ppc64-initial-cfa.ll b/test/MC/PowerPC/ppc64-initial-cfa.ll index 3936cf2e81..0e36fb7138 100644 --- a/test/MC/PowerPC/ppc64-initial-cfa.ll +++ b/test/MC/PowerPC/ppc64-initial-cfa.ll @@ -1,41 +1,78 @@ -;; RUN: llc -mtriple=powerpc64-unknown-linux-gnu -filetype=obj %s -o - | \ -;; RUN: elf-dump --dump-section-data | FileCheck %s +; RUN: llc -mtriple=powerpc64-unknown-linux-gnu -filetype=obj -relocation-model=static %s -o - | \ +; RUN: elf-dump --dump-section-data | FileCheck %s -check-prefix=STATIC +; RUN: llc -mtriple=powerpc64-unknown-linux-gnu -filetype=obj -relocation-model=pic %s -o - | \ +; RUN: elf-dump --dump-section-data | FileCheck %s -check-prefix=PIC -;; FIXME: this file should be in .s form, change when asm parser is available. +; 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: ]) +; STATIC: ('sh_name', 0x{{.*}}) # '.eh_frame' +; STATIC-NEXT: ('sh_type', 0x00000001) +; STATIC-NEXT: ('sh_flags', 0x0000000000000002) +; STATIC-NEXT: ('sh_addr', 0x{{.*}}) +; STATIC-NEXT: ('sh_offset', 0x{{.*}}) +; STATIC-NEXT: ('sh_size', 0x0000000000000028) +; STATIC-NEXT: ('sh_link', 0x00000000) +; STATIC-NEXT: ('sh_info', 0x00000000) +; STATIC-NEXT: ('sh_addralign', 0x0000000000000008) +; STATIC-NEXT: ('sh_entsize', 0x0000000000000000) +; STATIC-NEXT: ('_section_data', '00000010 00000000 017a5200 01784101 0b0c0100 00000010 00000018 00000000 00000010 00000000') +; STATIC: ('sh_name', 0x{{.*}}) # '.rela.eh_frame' +; STATIC-NEXT: ('sh_type', 0x00000004) +; STATIC-NEXT: ('sh_flags', 0x0000000000000000) +; STATIC-NEXT: ('sh_addr', 0x{{.*}}) +; STATIC-NEXT: ('sh_offset', 0x{{.*}}) +; STATIC-NEXT: ('sh_size', 0x0000000000000018) +; STATIC-NEXT: ('sh_link', 0x{{.*}}) +; STATIC-NEXT: ('sh_info', 0x{{.*}}) +; STATIC-NEXT: ('sh_addralign', 0x0000000000000008) +; STATIC-NEXT: ('sh_entsize', 0x0000000000000018) +; STATIC-NEXT: ('_relocations', [ + +; Static build should create R_PPC64_ADDR32 relocations +; STATIC-NEXT: # Relocation 0 +; STATIC-NEXT: (('r_offset', 0x000000000000001c) +; STATIC-NEXT: ('r_sym', 0x{{.*}}) +; STATIC-NEXT: ('r_type', 0x00000001) +; STATIC-NEXT: ('r_addend', 0x0000000000000000) +; STATIC-NEXT: ), +; STATIC-NEXT: ]) + + +; PIC: ('sh_name', 0x{{.*}}) # '.eh_frame' +; PIC-NEXT: ('sh_type', 0x00000001) +; PIC-NEXT: ('sh_flags', 0x0000000000000002) +; PIC-NEXT: ('sh_addr', 0x{{.*}}) +; PIC-NEXT: ('sh_offset', 0x{{.*}}) +; PIC-NEXT: ('sh_size', 0x0000000000000028) +; PIC-NEXT: ('sh_link', 0x00000000) +; PIC-NEXT: ('sh_info', 0x00000000) +; PIC-NEXT: ('sh_addralign', 0x0000000000000008) +; PIC-NEXT: ('sh_entsize', 0x0000000000000000) +; PIC-NEXT: ('_section_data', '00000010 00000000 017a5200 01784101 1b0c0100 00000010 00000018 00000000 00000010 00000000') + +; PIC: ('sh_name', 0x{{.*}}) # '.rela.eh_frame' +; PIC-NEXT: ('sh_type', 0x00000004) +; PIC-NEXT: ('sh_flags', 0x0000000000000000) +; PIC-NEXT: ('sh_addr', 0x{{.*}}) +; PIC-NEXT: ('sh_offset', 0x{{.*}}) +; PIC-NEXT: ('sh_size', 0x0000000000000018) +; PIC-NEXT: ('sh_link', 0x{{.*}}) +; PIC-NEXT: ('sh_info', 0x{{.*}}) +; PIC-NEXT: ('sh_addralign', 0x0000000000000008) +; PIC-NEXT: ('sh_entsize', 0x0000000000000018) +; PIC-NEXT: ('_relocations', [ + +; PIC build should create R_PPC64_REL32 relocations +; PIC-NEXT: # Relocation 0 +; PIC-NEXT: (('r_offset', 0x000000000000001c) +; PIC-NEXT: ('r_sym', 0x{{.*}}) +; PIC-NEXT: ('r_type', 0x0000001a) +; PIC-NEXT: ('r_addend', 0x0000000000000000) +; PIC-NEXT: ), +; PIC-NEXT: ]) |