]> sourceware.org Git - glibc.git/commit
S390: Fix build with gcc configured with --enable-default-pie. [BZ #21537]
authorStefan Liebler <stli@linux.vnet.ibm.com>
Mon, 19 Jun 2017 09:06:49 +0000 (11:06 +0200)
committerStefan Liebler <stli@linux.vnet.ibm.com>
Mon, 19 Jun 2017 09:08:58 +0000 (11:08 +0200)
commit5e5b3b886635b52d9baa87414b97965190035e46
tree33536154ee1f8a9bc68d7763e7deb48c7e3b7aee
parent35810f5ccf735d8df0a783bc6ed5fbe455e64876
S390: Fix build with gcc configured with --enable-default-pie. [BZ #21537]

Building glibc with gcc configured with --enable-default-pie failed on s390
due to assembler messages:
../sysdeps/unix/sysv/linux/s390/s390-32/__makecontext_ret.S:44:
Error: junk at end of line, first unrecognized character is `@'

HIDDEN_JUMPTARGET was expanded to exit@PLT@GOTOFF.
If SHARED is not defined, HIDDEN_JUMPTARGET is defined to JUMPTARGET
in sysdeps/s390/s390-32/sysdep.h.  There it expanded to exit@PLT
in non SHARED case as PIC is defined if gcc is configured with
--enable-default-pie. Thus I've changed the "ifdef PIC" to "ifdef SHARED"
as we do not want PLTs in the static obj files.  I've also changed this
in sysdeps/s390/s390-64/sysdep.h.

I've also adjusted sysdeps/unix/sysv/linux/s390/s390-32/__makecontext_ret.S.
If glibc is configured with --disable-hidden-plt, then NO_HIDDEN is defined.
In SHARED case HIDDEN_JUMPTARGET would be expanded to exit@PLT@GOTOFF
instead of __GI_exit@GOTOFF.
Now we jump to:
- __GI_exit if SHARED is defined
- exit@PLT if SHARED and NO_HIDDEN is defined
- exit if both are not defined.
On s390 31bit we have to setup GOT pointer in r12 if we use a PLT stub.
Therefore I use SYSCALL_PIC_SETUP from sysdep.h and added the missing semicolons.

ChangeLog:

[BZ #21537]
* sysdeps/s390/s390-32/sysdep.h (JUMPTARGET, SYSCALL_PIC_SETUP):
Check SHARED instead of PIC.
(SYSCALL_PIC_SETUP): Add missing semicolons.
* sysdeps/s390/s390-64/sysdep.h (JUMPTARGET, SYSCALL_PIC_SETUP):
Check SHARED instead of PIC.
* sysdeps/unix/sysv/linux/s390/s390-32/__makecontext_ret.S
(__makecontext_ret): Adjust code to jump to exit.
ChangeLog
sysdeps/s390/s390-32/sysdep.h
sysdeps/s390/s390-64/sysdep.h
sysdeps/unix/sysv/linux/s390/s390-32/__makecontext_ret.S
This page took 0.040895 seconds and 5 git commands to generate.