diff options
author | H.J. Lu <hjl.tools@gmail.com> | 2015-05-16 07:00:21 -0700 |
---|---|---|
committer | H.J. Lu <hjl.tools@gmail.com> | 2015-05-16 07:00:55 -0700 |
commit | 25070364b0ce33eed46aa5d78ebebbec6accec7e (patch) | |
tree | 1430644f09eb8ae60263110353ea34246592e614 /ld | |
parent | 4d18dfad9edf822df205edc2c1fe3fe9f1e467b8 (diff) | |
download | gdb-25070364b0ce33eed46aa5d78ebebbec6accec7e.zip gdb-25070364b0ce33eed46aa5d78ebebbec6accec7e.tar.gz gdb-25070364b0ce33eed46aa5d78ebebbec6accec7e.tar.bz2 |
Don't generate PLT relocations for now binding
There is no need for PLT relocations with -z now. We can use GOT
relocations, which take less space, instead and replace 16-byte .plt
entres with 8-byte .plt.got entries.
bfd/
* elf32-i386.c (elf_i386_check_relocs): Create .plt.got section
for now binding.
(elf_i386_allocate_dynrelocs): Use .plt.got section for now
binding.
* elf64-x86-64.c (elf_x86_64_check_relocs): Create .plt.got
section for now binding.
(elf_x86_64_allocate_dynrelocs): Use .plt.got section for now
binding.
ld/testsuite/
* ld-i386/i386.exp: Run PR ld/17689 tests with -z now.
* ld-x86-64/x86-64.exp: Likewise
* ld-i386/pr17689now.rd: New file.
* ld-x86-64/pr17689now.rd: Likewise
Diffstat (limited to 'ld')
-rw-r--r-- | ld/testsuite/ChangeLog | 7 | ||||
-rw-r--r-- | ld/testsuite/ld-i386/i386.exp | 24 | ||||
-rw-r--r-- | ld/testsuite/ld-i386/pr17689now.rd | 4 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/pr17689now.rd | 4 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/x86-64.exp | 24 |
5 files changed, 63 insertions, 0 deletions
diff --git a/ld/testsuite/ChangeLog b/ld/testsuite/ChangeLog index 43c7c24..e6a551c 100644 --- a/ld/testsuite/ChangeLog +++ b/ld/testsuite/ChangeLog @@ -1,3 +1,10 @@ +2015-05-16 H.J. Lu <hongjiu.lu@intel.com> + + * ld-i386/i386.exp: Run PR ld/17689 tests with -z now. + * ld-x86-64/x86-64.exp: Likewise + * ld-i386/pr17689now.rd: New file. + * ld-x86-64/pr17689now.rd: Likewise + 2015-05-15 H.J. Lu <hongjiu.lu@intel.com> PR binutis/18386 diff --git a/ld/testsuite/ld-i386/i386.exp b/ld/testsuite/ld-i386/i386.exp index bbc6005..a26cffd 100644 --- a/ld/testsuite/ld-i386/i386.exp +++ b/ld/testsuite/ld-i386/i386.exp @@ -406,6 +406,14 @@ if { [isnative] "pr17689.so" \ ] \ [list \ + "Build pr17689.so with -z now" \ + "-shared -Wl,-z,now" \ + "-fPIC" \ + { pr17689a.c } \ + {{readelf {-Wr} pr17689now.rd}} \ + "pr17689now.so" \ + ] \ + [list \ "Build pr17689ver.so" \ "-shared -Wl,--version-script,pr17689a.t" \ "-fPIC" \ @@ -430,6 +438,14 @@ if { [isnative] "pr17689" \ ] \ [list \ + "Build pr17689 with PIE, -z now and GOTOFF" \ + "tmpdir/pr17689b.o tmpdir/pr17689.so -pie -Wl,-z,now" \ + "" \ + { dummy.c } \ + {{readelf {-Wr} pr17689now.rd}} \ + "pr17689now" \ + ] \ + [list \ "Build pr17689ver with PIE and GOTOFF" \ "tmpdir/pr17689b.o tmpdir/pr17689ver.so -pie" \ "" \ @@ -484,6 +500,14 @@ if { [isnative] "pr17689.out" \ ] \ [list \ + "Run pr17689 with PIE, -z now and GOTOFF" \ + "tmpdir/pr17689b.o tmpdir/pr17689.so -pie -z now" \ + "" \ + { dummy.c } \ + "pr17689now" \ + "pr17689.out" \ + ] \ + [list \ "Run pr17689ver with PIE and GOTOFF" \ "tmpdir/pr17689b.o tmpdir/pr17689ver.so -pie" \ "" \ diff --git a/ld/testsuite/ld-i386/pr17689now.rd b/ld/testsuite/ld-i386/pr17689now.rd new file mode 100644 index 0000000..9741df8 --- /dev/null +++ b/ld/testsuite/ld-i386/pr17689now.rd @@ -0,0 +1,4 @@ +#failif +#... +[0-9a-f ]+R_386_JUMP_SLOT +0+.* +#... diff --git a/ld/testsuite/ld-x86-64/pr17689now.rd b/ld/testsuite/ld-x86-64/pr17689now.rd new file mode 100644 index 0000000..8fd9371 --- /dev/null +++ b/ld/testsuite/ld-x86-64/pr17689now.rd @@ -0,0 +1,4 @@ +#failif +#... +[0-9a-f ]+R_X86_64_JUMP_SLOT +0+ +.* +#... diff --git a/ld/testsuite/ld-x86-64/x86-64.exp b/ld/testsuite/ld-x86-64/x86-64.exp index a312271..8281dc4 100644 --- a/ld/testsuite/ld-x86-64/x86-64.exp +++ b/ld/testsuite/ld-x86-64/x86-64.exp @@ -440,6 +440,14 @@ if { [isnative] && [which $CC] != 0 } { "pr17689.so" \ ] \ [list \ + "Build pr17689now.so with -z now" \ + "-shared -Wl,-z,now" \ + "-fPIC" \ + { pr17689a.c } \ + {{readelf {-Wr} pr17689now.rd}} \ + "pr17689now.so" \ + ] \ + [list \ "Build pr17689 with PIE without -fPIE" \ "tmpdir/pr17689.so -pie" \ "" \ @@ -448,6 +456,14 @@ if { [isnative] && [which $CC] != 0 } { "pr17689" \ ] \ [list \ + "Build pr17689 with PIE -z now without -fPIE" \ + "tmpdir/pr17689.so -pie -Wl,-z,now" \ + "" \ + { pr17689b.S } \ + {{readelf {-Wr} pr17689now.rd}} \ + "pr17689now" \ + ] \ + [list \ "Build pr17827 with PIE without -fPIE" \ "tmpdir/pr17689.so -pie" \ "" \ @@ -493,6 +509,14 @@ if { [isnative] && [which $CC] != 0 } { "pr17689" \ "pr17689.out" \ ] \ + [list \ + "Run pr17689 with PIE -z now without -fPIE" \ + "tmpdir/pr17689.so -pie -z now" \ + "" \ + { pr17689b.S } \ + "pr17689now" \ + "pr17689.out" \ + ] \ ] if { [istarget "x86_64-*-linux*"] \ |