mirror of
git://sourceware.org/git/glibc.git
synced 2025-01-30 12:31:53 +08:00
microblaze: Resolve non-relocatable branch in pt-vfork.S (BZ#21779)
The relative branch directly to __libc_vfork results in an relocation that cannot be resolved. Specifically a R_MICROBLAZE_64_PCREL relocation is created for this branch, however for MicroBlaze R_MICROBLAZE_64_PCREL type relocations symbols are not resolved. Additionally due to the branch being located in the .text section the instruction cannot be rewritten as the section is not writable, and causes a segfault at runtime when loading libpthread. To resolve this issue, ensure the branch is done using PLT. This removes the need to modify the instruction and trades the R_MICROBLAZE_64_PCREL for a more common R_MICROBLAZE_JUMP via the PLT. [BZ #21779] * sysdeps/unix/sysv/linux/microblaze/pt-vfork.S: Branch using PLT.
This commit is contained in:
parent
0aab054a92
commit
d95fcb2df4
@ -1,5 +1,8 @@
|
||||
2017-07-23 Nathan Rossi <nathan@nathanrossi.com>
|
||||
|
||||
[BZ #21779]
|
||||
* sysdeps/unix/sysv/linux/microblaze/pt-vfork.S: Branch using PLT.
|
||||
|
||||
* sysdeps/microblaze/libm-test-ulps: Update.
|
||||
|
||||
2017-07-28 Chung-Lin Tang <cltang@codesourcery.com>
|
||||
|
@ -34,7 +34,7 @@
|
||||
|| SHLIB_COMPAT (libpthread, GLIBC_2_1_2, GLIBC_2_20))
|
||||
|
||||
ENTRY (vfork_compat)
|
||||
bri __libc_vfork
|
||||
bri __libc_vfork@PLT
|
||||
END (vfork_compat)
|
||||
|
||||
#endif
|
||||
|
Loading…
Reference in New Issue
Block a user