summaryrefslogtreecommitdiff
path: root/user/openjdk7/gcc-207-static-pie.patch
diff options
context:
space:
mode:
authorZach van Rijn <me@zv.io>2022-10-31 22:39:57 -0500
committerZach van Rijn <me@zv.io>2022-11-02 16:01:24 -0500
commitc5b882546f831beffaec290c7b5c6ee3b4efc258 (patch)
treeab443a31f04ce8e2a8d8d3b5bb177910641a7fa0 /user/openjdk7/gcc-207-static-pie.patch
parentf501eba1775d96f4438e2086e4b66966f2ec06a8 (diff)
downloadpackages-c5b882546f831beffaec290c7b5c6ee3b4efc258.tar.gz
packages-c5b882546f831beffaec290c7b5c6ee3b4efc258.tar.bz2
packages-c5b882546f831beffaec290c7b5c6ee3b4efc258.tar.xz
packages-c5b882546f831beffaec290c7b5c6ee3b4efc258.zip
[WIP] import from ppc64 test tree.
Diffstat (limited to 'user/openjdk7/gcc-207-static-pie.patch')
-rw-r--r--user/openjdk7/gcc-207-static-pie.patch40
1 files changed, 40 insertions, 0 deletions
diff --git a/user/openjdk7/gcc-207-static-pie.patch b/user/openjdk7/gcc-207-static-pie.patch
new file mode 100644
index 000000000..9355c584b
--- /dev/null
+++ b/user/openjdk7/gcc-207-static-pie.patch
@@ -0,0 +1,40 @@
+diff --git a/gcc/config/gnu-user.h b/gcc/config/gnu-user.h
+index b0bf40a..d4b56fe 100644
+--- a/gcc/config/gnu-user.h
++++ b/gcc/config/gnu-user.h
+@@ -51,10 +51,10 @@ see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
+ #if defined HAVE_LD_PIE
+ #define GNU_USER_TARGET_STARTFILE_SPEC \
+ "%{!shared: %{pg|p|profile:gcrt1.o%s;: \
+- %{" PIE_SPEC ":Scrt1.o%s} %{" NO_PIE_SPEC ":crt1.o%s}}} \
+- crti.o%s %{static:crtbeginT.o%s;: %{shared:crtbeginS.o%s} \
++ %{" PIE_SPEC ":%{static:rcrt1.o%s;:Scrt1.o%s}} %{" NO_PIE_SPEC ":crt1.o%s}}} \
++ crti.o%s %{shared:crtbeginS.o%s;: \
+ %{" PIE_SPEC ":crtbeginS.o%s} \
+- %{" NO_PIE_SPEC ":crtbegin.o%s}} \
++ %{" NO_PIE_SPEC ":%{static:crtbeginT.o%s;:crtbegin.o%s}}} \
+ %{fvtable-verify=none:%s; \
+ fvtable-verify=preinit:vtv_start_preinit.o%s; \
+ fvtable-verify=std:vtv_start.o%s} \
+diff --git a/gcc/gcc.c b/gcc/gcc.c
+index 0208d61..731564e 100644
+--- a/gcc/gcc.c
++++ b/gcc/gcc.c
+@@ -870,7 +870,7 @@ proper position among the other output files. */
+ #endif
+
+ #ifdef ENABLE_DEFAULT_PIE
+-#define NO_PIE_SPEC "no-pie|static"
++#define NO_PIE_SPEC "no-pie"
+ #define PIE_SPEC NO_PIE_SPEC "|r|shared:;"
+ #define NO_FPIE1_SPEC "fno-pie"
+ #define FPIE1_SPEC NO_FPIE1_SPEC ":;"
+@@ -916,7 +916,7 @@ proper position among the other output files. */
+ #ifndef LINK_PIE_SPEC
+ #ifdef HAVE_LD_PIE
+ #ifndef LD_PIE_SPEC
+-#define LD_PIE_SPEC "-pie"
++#define LD_PIE_SPEC "-pie %{static:--no-dynamic-linker -Bsymbolic}"
+ #endif
+ #else
+ #define LD_PIE_SPEC ""