diff options
author | Stefan Liebler <stli@linux.vnet.ibm.com> | 2016-05-11 15:51:25 +0200 |
---|---|---|
committer | Stefan Liebler <stli@linux.vnet.ibm.com> | 2016-05-11 15:51:25 +0200 |
commit | c64a10e54441db7df85592b009348a919a7259d7 (patch) | |
tree | 4ec3c3c4e88b4ba4c8b9b2d720e650995107d8fb | |
parent | 2a1f15b1a9d51c2ba3f217641ea3af96ea208061 (diff) | |
download | glibc-c64a10e54441db7df85592b009348a919a7259d7.tar.gz glibc-c64a10e54441db7df85592b009348a919a7259d7.tar.xz glibc-c64a10e54441db7df85592b009348a919a7259d7.zip |
S390: Use fPIC to avoid R_390_GOT12 relocation in gcrt1.o.
if glibc is build with -march=z900 | -march=z990, the startup file gcrt1.o (used if you link with gcc -pg) contains R_390_GOT12 | R_390_GOT20 relocations. Thus, an entry in the GOT can be addressed relative to the GOT pointer with a 12 | 20 bit displacement value. The startup files should not contain R_390_GOT12, R_390_GOT20 relocations, but R_390_GOTENT ones. This patch removes the overrides of pic-ccflag and the default pic-ccflag = -fPIC in Makeconfig is used instead to get the R_390_GOTENT relocations in gcrt1.o. ChangeLog: * sysdeps/s390/s390-32/Makefile (pic-ccflag): Remove. * sysdeps/s390/s390-64/Makefile: Likewise.
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | sysdeps/s390/s390-32/Makefile | 2 | ||||
-rw-r--r-- | sysdeps/s390/s390-64/Makefile | 2 |
3 files changed, 5 insertions, 4 deletions
diff --git a/ChangeLog b/ChangeLog index 8958a06d2a..7533a3d9de 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2016-05-11 Stefan Liebler <stli@linux.vnet.ibm.com> + + * sysdeps/s390/s390-32/Makefile (pic-ccflag): Remove. + * sysdeps/s390/s390-64/Makefile: Likewise. + 2016-05-11 H.J. Lu <hongjiu.lu@intel.com> * sysdeps/i386/i686/multiarch/Makefile (gen-as-const-headers): diff --git a/sysdeps/s390/s390-32/Makefile b/sysdeps/s390/s390-32/Makefile index 057862d91b..a07f2986ae 100644 --- a/sysdeps/s390/s390-32/Makefile +++ b/sysdeps/s390/s390-32/Makefile @@ -1,5 +1,3 @@ -pic-ccflag = -fpic - ifeq ($(subdir),gmon) sysdep_routines += s390-mcount endif diff --git a/sysdeps/s390/s390-64/Makefile b/sysdeps/s390/s390-64/Makefile index ce4f0c5c88..5909d1f7aa 100644 --- a/sysdeps/s390/s390-64/Makefile +++ b/sysdeps/s390/s390-64/Makefile @@ -1,5 +1,3 @@ -pic-ccflag = -fpic - ifeq ($(subdir),gmon) sysdep_routines += s390x-mcount endif |