summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSergei Trofimovich <slyfox@gentoo.org>2017-12-18 10:00:39 +0000
committerSergei Trofimovich <slyfox@gentoo.org>2017-12-18 10:00:39 +0000
commit0fc2d0869357532ff25be11c71487a995d954963 (patch)
tree9019ed132926f3de304cea8204e3fc8a302dd936
parentgcc/7.2.0: copy all patches from 7.1.0 as we are using unmodified patchset (diff)
downloadgentoo-0fc2d0869357532ff25be11c71487a995d954963.tar.gz
gentoo-0fc2d0869357532ff25be11c71487a995d954963.tar.bz2
gentoo-0fc2d0869357532ff25be11c71487a995d954963.zip
gcc/6.4.0, gcc/7.2.0: fix --default-pie to use proper startup files, bug #641474
The change adds two patches to patchset: - gentoo/95_all_static_override_pie.patch - gentoo/96_all_powerpc_pie.patch First fixes -static handling for --default-pie compiler. Second fixes to use proper startup files for --default-pie on powerpc. Otherwise binutils-2.27 and upper generates invalid ELF files. Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=22626 Bug: https://bugs.gentoo.org/641474
-rw-r--r--src/patchsets/gcc/6.4.0/gentoo/95_all_static_override_pie.patch188
-rw-r--r--src/patchsets/gcc/6.4.0/gentoo/96_all_powerpc_pie.patch84
-rw-r--r--src/patchsets/gcc/6.4.0/gentoo/README.history3
-rw-r--r--src/patchsets/gcc/7.2.0/gentoo/95_all_static_override_pie.patch188
-rw-r--r--src/patchsets/gcc/7.2.0/gentoo/96_all_powerpc_pie.patch84
-rw-r--r--src/patchsets/gcc/7.2.0/gentoo/README.history3
6 files changed, 550 insertions, 0 deletions
diff --git a/src/patchsets/gcc/6.4.0/gentoo/95_all_static_override_pie.patch b/src/patchsets/gcc/6.4.0/gentoo/95_all_static_override_pie.patch
new file mode 100644
index 0000000000..13c06a16b7
--- /dev/null
+++ b/src/patchsets/gcc/6.4.0/gentoo/95_all_static_override_pie.patch
@@ -0,0 +1,188 @@
+https://bugs.gentoo.org/641474
+
+From d59d277cd2562766313583261750a3d84863a27d Mon Sep 17 00:00:00 2001
+From: amodra <amodra@138bc75d-0d04-0410-961f-82ee72b054a4>
+Date: Tue, 29 Aug 2017 08:25:17 +0000
+Subject: [PATCH] PR driver/81523: Make -static override -pie
+
+-static and -pie together behave differently depending on whether GCC is
+configured with --enable-default-pie. On x86, "-static -pie" fails to
+create executable when --enable-default-pie isn't used, but creates a
+static executable when --enable-default-pie is used. This patch makes
+-static completely override -pie to create a static executable, regardless
+if --enable-default-pie is used to configure GCC.
+
+ PR target/81170
+ PR target/81295
+ PR driver/81523
+ * gcc.c (NO_PIE_SPEC): Delete.
+ (PIE_SPEC): Define as !no-pie/pie. Move static|shared|r
+ exclusion..
+ (LINK_PIE_SPEC): ..to here.
+ (LINK_COMMAND_SPEC): Support -no-pie.
+ * config/gnu-user.h (GNU_USER_TARGET_STARTFILE_SPEC): Correct
+ chain of crtbegin*.o selection, update for PIE_SPEC changes and
+ format.
+ (GNU_USER_TARGET_ENDFILE_SPEC): Similarly.
+ * config/sol2.h (STARTFILE_CRTBEGIN_SPEC): Similarly.
+ (ENDFILE_CRTEND_SPEC): Similarly.
+
+
+git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-6-branch@251404 138bc75d-0d04-0410-961f-82ee72b054a4
+---
+ gcc/ChangeLog | 20 ++++++++++++++++++++
+ gcc/config/gnu-user.h | 34 ++++++++++++++++++++++++----------
+ gcc/config/sol2.h | 12 ++++++------
+ gcc/gcc.c | 14 +++++++-------
+ 4 files changed, 57 insertions(+), 23 deletions(-)
+
+diff --git a/gcc/config/gnu-user.h b/gcc/config/gnu-user.h
+index b0bf40a954f..8c579aac3f6 100644
+--- a/gcc/config/gnu-user.h
++++ b/gcc/config/gnu-user.h
+@@ -50,19 +50,28 @@ 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 ":crtbeginS.o%s} \
+- %{" NO_PIE_SPEC ":crtbegin.o%s}} \
++ "%{shared:; \
++ pg|p|profile:gcrt1.o%s; \
++ static:crt1.o%s; \
++ " PIE_SPEC ":Scrt1.o%s; \
++ :crt1.o%s} \
++ crti.o%s \
++ %{static:crtbeginT.o%s; \
++ shared|" PIE_SPEC ":crtbeginS.o%s; \
++ :crtbegin.o%s} \
+ %{fvtable-verify=none:%s; \
+ fvtable-verify=preinit:vtv_start_preinit.o%s; \
+ fvtable-verify=std:vtv_start.o%s} \
+ " CRTOFFLOADBEGIN
+ #else
+ #define GNU_USER_TARGET_STARTFILE_SPEC \
+- "%{!shared: %{pg|p|profile:gcrt1.o%s;:crt1.o%s}} \
+- crti.o%s %{static:crtbeginT.o%s;shared|pie:crtbeginS.o%s;:crtbegin.o%s} \
++ "%{shared:; \
++ pg|p|profile:gcrt1.o%s; \
++ :crt1.o%s} \
++ crti.o%s \
++ %{static:crtbeginT.o%s; \
++ shared|pie:crtbeginS.o%s; \
++ :crtbegin.o%s} \
+ %{fvtable-verify=none:%s; \
+ fvtable-verify=preinit:vtv_start_preinit.o%s; \
+ fvtable-verify=std:vtv_start.o%s} \
+@@ -82,15 +91,20 @@ see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
+ "%{fvtable-verify=none:%s; \
+ fvtable-verify=preinit:vtv_end_preinit.o%s; \
+ fvtable-verify=std:vtv_end.o%s} \
+- %{shared:crtendS.o%s;: %{" PIE_SPEC ":crtendS.o%s} \
+- %{" NO_PIE_SPEC ":crtend.o%s}} crtn.o%s \
++ %{static:crtend.o%s; \
++ shared|" PIE_SPEC ":crtendS.o%s; \
++ :crtend.o%s} \
++ crtn.o%s \
+ " CRTOFFLOADEND
+ #else
+ #define GNU_USER_TARGET_ENDFILE_SPEC \
+ "%{fvtable-verify=none:%s; \
+ fvtable-verify=preinit:vtv_end_preinit.o%s; \
+ fvtable-verify=std:vtv_end.o%s} \
+- %{shared|pie:crtendS.o%s;:crtend.o%s} crtn.o%s \
++ %{static:crtend.o%s; \
++ shared|pie:crtendS.o%s; \
++ :crtend.o%s} \
++ crtn.o%s \
+ " CRTOFFLOADEND
+ #endif
+ #undef ENDFILE_SPEC
+diff --git a/gcc/config/sol2.h b/gcc/config/sol2.h
+index 5160e1fda18..78764c4e556 100644
+--- a/gcc/config/sol2.h
++++ b/gcc/config/sol2.h
+@@ -159,9 +159,9 @@ along with GCC; see the file COPYING3. If not see
+ %{!ansi:values-Xa.o%s}"
+
+ #if defined(HAVE_LD_PIE) && defined(HAVE_SOLARIS_CRTS)
+-#define STARTFILE_CRTBEGIN_SPEC "%{shared:crtbeginS.o%s} \
+- %{" PIE_SPEC ":crtbeginS.o%s} \
+- %{" NO_PIE_SPEC ":crtbegin.o%s}"
++#define STARTFILE_CRTBEGIN_SPEC "%{static:crtbegin.o%s; \
++ shared|" PIE_SPEC ":crtbeginS.o%s; \
++ :crtbegin.o%s}"
+ #else
+ #define STARTFILE_CRTBEGIN_SPEC "crtbegin.o%s"
+ #endif
+@@ -204,9 +204,9 @@ along with GCC; see the file COPYING3. If not see
+ #endif
+
+ #if defined(HAVE_LD_PIE) && defined(HAVE_SOLARIS_CRTS)
+-#define ENDFILE_CRTEND_SPEC "%{shared:crtendS.o%s;: \
+- %{" PIE_SPEC ":crtendS.o%s} \
+- %{" NO_PIE_SPEC ":crtend.o%s}}"
++#define ENDFILE_CRTEND_SPEC "%{static:crtend.o%s; \
++ shared|" PIE_SPEC ":crtendS.o%s; \
++ :crtend.o%s}"
+ #else
+ #define ENDFILE_CRTEND_SPEC "crtend.o%s"
+ #endif
+diff --git a/gcc/gcc.c b/gcc/gcc.c
+index cfa074d4e43..896d9af4acb 100644
+--- a/gcc/gcc.c
++++ b/gcc/gcc.c
+@@ -869,8 +869,7 @@ proper position among the other output files. */
+ #endif
+
+ #ifdef ENABLE_DEFAULT_PIE
+-#define NO_PIE_SPEC "no-pie|static"
+-#define PIE_SPEC NO_PIE_SPEC "|r|shared:;"
++#define PIE_SPEC "!no-pie"
+ #define NO_FPIE1_SPEC "fno-pie"
+ #define FPIE1_SPEC NO_FPIE1_SPEC ":;"
+ #define NO_FPIE2_SPEC "fno-PIE"
+@@ -891,7 +890,6 @@ proper position among the other output files. */
+ #define FPIE_OR_FPIC_SPEC NO_FPIE_AND_FPIC_SPEC ":;"
+ #else
+ #define PIE_SPEC "pie"
+-#define NO_PIE_SPEC PIE_SPEC "|r|shared:;"
+ #define FPIE1_SPEC "fpie"
+ #define NO_FPIE1_SPEC FPIE1_SPEC ":;"
+ #define FPIE2_SPEC "fPIE"
+@@ -920,7 +918,7 @@ proper position among the other output files. */
+ #else
+ #define LD_PIE_SPEC ""
+ #endif
+-#define LINK_PIE_SPEC "%{no-pie:} " "%{" PIE_SPEC ":" LD_PIE_SPEC "} "
++#define LINK_PIE_SPEC "%{static|shared|r:;" PIE_SPEC ":" LD_PIE_SPEC "} "
+ #endif
+
+ #ifndef LINK_BUILDID_SPEC
+@@ -999,8 +997,10 @@ proper position among the other output files. */
+ #endif
+
+ /* -u* was put back because both BSD and SysV seem to support it. */
+-/* %{static:} simply prevents an error message if the target machine
+- doesn't handle -static. */
++/* %{static|no-pie:} simply prevents an error message:
++ 1. If the target machine doesn't handle -static.
++ 2. If PIE isn't enabled by default.
++ */
+ /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
+ scripts which exist in user specified directories, or in standard
+ directories. */
+@@ -1017,7 +1017,7 @@ proper position among the other output files. */
+ "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
+ "%X %{o*} %{e*} %{N} %{n} %{r}\
+ %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} \
+- %{static:} %{L*} %(mfwrap) %(link_libgcc) " \
++ %{static|no-pie:} %{L*} %(mfwrap) %(link_libgcc) " \
+ VTABLE_VERIFICATION_SPEC " " SANITIZER_EARLY_SPEC " %o " CHKP_SPEC " \
+ %{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1):\
+ %:include(libgomp.spec)%(link_gomp)}\
+--
+2.15.1
+
diff --git a/src/patchsets/gcc/6.4.0/gentoo/96_all_powerpc_pie.patch b/src/patchsets/gcc/6.4.0/gentoo/96_all_powerpc_pie.patch
new file mode 100644
index 0000000000..55cf5d60f8
--- /dev/null
+++ b/src/patchsets/gcc/6.4.0/gentoo/96_all_powerpc_pie.patch
@@ -0,0 +1,84 @@
+https://bugs.gentoo.org/641474
+
+From e764842a5c6ae3aa81be7c8c2b710d92404b9590 Mon Sep 17 00:00:00 2001
+From: amodra <amodra@138bc75d-0d04-0410-961f-82ee72b054a4>
+Date: Tue, 29 Aug 2017 08:27:02 +0000
+Subject: [PATCH] [RS6000] linux startfile/endfile
+
+These need to match the gnu-user.h definitions to support
+--enable-default-pie. Otherwise we end up linking the wrong startup
+files when defaulting to PIE.
+
+ PR target/81170
+ PR target/81295
+ * config/rs6000/sysv4.h (STARTFILE_LINUX_SPEC): Upgrade to
+ match gnu-user.h startfile.
+ (ENDFILE_LINUX_SPEC): Similarly.
+
+
+git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-6-branch@251405 138bc75d-0d04-0410-961f-82ee72b054a4
+---
+ gcc/ChangeLog | 7 +++++++
+ gcc/config/rs6000/sysv4.h | 46 ++++++++++++++++++++++++++++------------------
+ 2 files changed, 35 insertions(+), 18 deletions(-)
+
+diff --git a/gcc/config/rs6000/sysv4.h b/gcc/config/rs6000/sysv4.h
+index ba35fd27d0f..f81ba6d1514 100644
+--- a/gcc/config/rs6000/sysv4.h
++++ b/gcc/config/rs6000/sysv4.h
+@@ -752,24 +752,34 @@ ENDIAN_SELECT(" -mbig", " -mlittle", DEFAULT_ASM_ENDIAN)
+ #define CRTOFFLOADEND ""
+ #endif
+
+-#ifdef HAVE_LD_PIE
+-#define STARTFILE_LINUX_SPEC "\
+-%{!shared: %{pg|p|profile:gcrt1.o%s;pie:Scrt1.o%s;:crt1.o%s}} \
+-%{mnewlib:ecrti.o%s;:crti.o%s} \
+-%{static:crtbeginT.o%s;shared|pie:crtbeginS.o%s;:crtbegin.o%s} \
+-" CRTOFFLOADBEGIN
+-#else
+-#define STARTFILE_LINUX_SPEC "\
+-%{!shared: %{pg|p|profile:gcrt1.o%s;:crt1.o%s}} \
+-%{mnewlib:ecrti.o%s;:crti.o%s} \
+-%{static:crtbeginT.o%s;shared|pie:crtbeginS.o%s;:crtbegin.o%s} \
+-" CRTOFFLOADBEGIN
+-#endif
+-
+-#define ENDFILE_LINUX_SPEC "\
+-%{shared|pie:crtendS.o%s;:crtend.o%s} \
+-%{mnewlib:ecrtn.o%s;:crtn.o%s} \
+-" CRTOFFLOADEND
++/* STARTFILE_LINUX_SPEC should be the same as GNU_USER_TARGET_STARTFILE_SPEC
++ but with the mnewlib ecrti.o%s selection substituted for crti.o%s. */
++#define STARTFILE_LINUX_SPEC \
++ "%{shared:; \
++ pg|p|profile:gcrt1.o%s; \
++ static:crt1.o%s; \
++ " PIE_SPEC ":Scrt1.o%s; \
++ :crt1.o%s} \
++ %{mnewlib:ecrti.o%s;:crti.o%s} \
++ %{static:crtbeginT.o%s; \
++ shared|" PIE_SPEC ":crtbeginS.o%s; \
++ :crtbegin.o%s} \
++ %{fvtable-verify=none:%s; \
++ fvtable-verify=preinit:vtv_start_preinit.o%s; \
++ fvtable-verify=std:vtv_start.o%s} \
++ " CRTOFFLOADBEGIN
++
++/* ENDFILE_LINUX_SPEC should be the same as GNU_USER_TARGET_ENDFILE_SPEC
++ but with the mnewlib ecrtn.o%s selection substituted for crtn.o%s. */
++#define ENDFILE_LINUX_SPEC \
++ "%{fvtable-verify=none:%s; \
++ fvtable-verify=preinit:vtv_end_preinit.o%s; \
++ fvtable-verify=std:vtv_end.o%s} \
++ %{static:crtend.o%s; \
++ shared|" PIE_SPEC ":crtendS.o%s; \
++ :crtend.o%s} \
++ %{mnewlib:ecrtn.o%s;:crtn.o%s} \
++ " CRTOFFLOADEND
+
+ #define LINK_START_LINUX_SPEC ""
+
+--
+2.15.1
+
diff --git a/src/patchsets/gcc/6.4.0/gentoo/README.history b/src/patchsets/gcc/6.4.0/gentoo/README.history
index 181f356501..832f7cdba1 100644
--- a/src/patchsets/gcc/6.4.0/gentoo/README.history
+++ b/src/patchsets/gcc/6.4.0/gentoo/README.history
@@ -1,3 +1,6 @@
+1.2 TODO
+ + 95_all_static_override_pie.patch
+ + 96_all_powerpc_pie.patch
1.1 27 Nov 2017
+ 92_all_asan-signal_h.patch
+ 93_all_ucontext-to-ucontext_t.patch
diff --git a/src/patchsets/gcc/7.2.0/gentoo/95_all_static_override_pie.patch b/src/patchsets/gcc/7.2.0/gentoo/95_all_static_override_pie.patch
new file mode 100644
index 0000000000..13c06a16b7
--- /dev/null
+++ b/src/patchsets/gcc/7.2.0/gentoo/95_all_static_override_pie.patch
@@ -0,0 +1,188 @@
+https://bugs.gentoo.org/641474
+
+From d59d277cd2562766313583261750a3d84863a27d Mon Sep 17 00:00:00 2001
+From: amodra <amodra@138bc75d-0d04-0410-961f-82ee72b054a4>
+Date: Tue, 29 Aug 2017 08:25:17 +0000
+Subject: [PATCH] PR driver/81523: Make -static override -pie
+
+-static and -pie together behave differently depending on whether GCC is
+configured with --enable-default-pie. On x86, "-static -pie" fails to
+create executable when --enable-default-pie isn't used, but creates a
+static executable when --enable-default-pie is used. This patch makes
+-static completely override -pie to create a static executable, regardless
+if --enable-default-pie is used to configure GCC.
+
+ PR target/81170
+ PR target/81295
+ PR driver/81523
+ * gcc.c (NO_PIE_SPEC): Delete.
+ (PIE_SPEC): Define as !no-pie/pie. Move static|shared|r
+ exclusion..
+ (LINK_PIE_SPEC): ..to here.
+ (LINK_COMMAND_SPEC): Support -no-pie.
+ * config/gnu-user.h (GNU_USER_TARGET_STARTFILE_SPEC): Correct
+ chain of crtbegin*.o selection, update for PIE_SPEC changes and
+ format.
+ (GNU_USER_TARGET_ENDFILE_SPEC): Similarly.
+ * config/sol2.h (STARTFILE_CRTBEGIN_SPEC): Similarly.
+ (ENDFILE_CRTEND_SPEC): Similarly.
+
+
+git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-6-branch@251404 138bc75d-0d04-0410-961f-82ee72b054a4
+---
+ gcc/ChangeLog | 20 ++++++++++++++++++++
+ gcc/config/gnu-user.h | 34 ++++++++++++++++++++++++----------
+ gcc/config/sol2.h | 12 ++++++------
+ gcc/gcc.c | 14 +++++++-------
+ 4 files changed, 57 insertions(+), 23 deletions(-)
+
+diff --git a/gcc/config/gnu-user.h b/gcc/config/gnu-user.h
+index b0bf40a954f..8c579aac3f6 100644
+--- a/gcc/config/gnu-user.h
++++ b/gcc/config/gnu-user.h
+@@ -50,19 +50,28 @@ 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 ":crtbeginS.o%s} \
+- %{" NO_PIE_SPEC ":crtbegin.o%s}} \
++ "%{shared:; \
++ pg|p|profile:gcrt1.o%s; \
++ static:crt1.o%s; \
++ " PIE_SPEC ":Scrt1.o%s; \
++ :crt1.o%s} \
++ crti.o%s \
++ %{static:crtbeginT.o%s; \
++ shared|" PIE_SPEC ":crtbeginS.o%s; \
++ :crtbegin.o%s} \
+ %{fvtable-verify=none:%s; \
+ fvtable-verify=preinit:vtv_start_preinit.o%s; \
+ fvtable-verify=std:vtv_start.o%s} \
+ " CRTOFFLOADBEGIN
+ #else
+ #define GNU_USER_TARGET_STARTFILE_SPEC \
+- "%{!shared: %{pg|p|profile:gcrt1.o%s;:crt1.o%s}} \
+- crti.o%s %{static:crtbeginT.o%s;shared|pie:crtbeginS.o%s;:crtbegin.o%s} \
++ "%{shared:; \
++ pg|p|profile:gcrt1.o%s; \
++ :crt1.o%s} \
++ crti.o%s \
++ %{static:crtbeginT.o%s; \
++ shared|pie:crtbeginS.o%s; \
++ :crtbegin.o%s} \
+ %{fvtable-verify=none:%s; \
+ fvtable-verify=preinit:vtv_start_preinit.o%s; \
+ fvtable-verify=std:vtv_start.o%s} \
+@@ -82,15 +91,20 @@ see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
+ "%{fvtable-verify=none:%s; \
+ fvtable-verify=preinit:vtv_end_preinit.o%s; \
+ fvtable-verify=std:vtv_end.o%s} \
+- %{shared:crtendS.o%s;: %{" PIE_SPEC ":crtendS.o%s} \
+- %{" NO_PIE_SPEC ":crtend.o%s}} crtn.o%s \
++ %{static:crtend.o%s; \
++ shared|" PIE_SPEC ":crtendS.o%s; \
++ :crtend.o%s} \
++ crtn.o%s \
+ " CRTOFFLOADEND
+ #else
+ #define GNU_USER_TARGET_ENDFILE_SPEC \
+ "%{fvtable-verify=none:%s; \
+ fvtable-verify=preinit:vtv_end_preinit.o%s; \
+ fvtable-verify=std:vtv_end.o%s} \
+- %{shared|pie:crtendS.o%s;:crtend.o%s} crtn.o%s \
++ %{static:crtend.o%s; \
++ shared|pie:crtendS.o%s; \
++ :crtend.o%s} \
++ crtn.o%s \
+ " CRTOFFLOADEND
+ #endif
+ #undef ENDFILE_SPEC
+diff --git a/gcc/config/sol2.h b/gcc/config/sol2.h
+index 5160e1fda18..78764c4e556 100644
+--- a/gcc/config/sol2.h
++++ b/gcc/config/sol2.h
+@@ -159,9 +159,9 @@ along with GCC; see the file COPYING3. If not see
+ %{!ansi:values-Xa.o%s}"
+
+ #if defined(HAVE_LD_PIE) && defined(HAVE_SOLARIS_CRTS)
+-#define STARTFILE_CRTBEGIN_SPEC "%{shared:crtbeginS.o%s} \
+- %{" PIE_SPEC ":crtbeginS.o%s} \
+- %{" NO_PIE_SPEC ":crtbegin.o%s}"
++#define STARTFILE_CRTBEGIN_SPEC "%{static:crtbegin.o%s; \
++ shared|" PIE_SPEC ":crtbeginS.o%s; \
++ :crtbegin.o%s}"
+ #else
+ #define STARTFILE_CRTBEGIN_SPEC "crtbegin.o%s"
+ #endif
+@@ -204,9 +204,9 @@ along with GCC; see the file COPYING3. If not see
+ #endif
+
+ #if defined(HAVE_LD_PIE) && defined(HAVE_SOLARIS_CRTS)
+-#define ENDFILE_CRTEND_SPEC "%{shared:crtendS.o%s;: \
+- %{" PIE_SPEC ":crtendS.o%s} \
+- %{" NO_PIE_SPEC ":crtend.o%s}}"
++#define ENDFILE_CRTEND_SPEC "%{static:crtend.o%s; \
++ shared|" PIE_SPEC ":crtendS.o%s; \
++ :crtend.o%s}"
+ #else
+ #define ENDFILE_CRTEND_SPEC "crtend.o%s"
+ #endif
+diff --git a/gcc/gcc.c b/gcc/gcc.c
+index cfa074d4e43..896d9af4acb 100644
+--- a/gcc/gcc.c
++++ b/gcc/gcc.c
+@@ -869,8 +869,7 @@ proper position among the other output files. */
+ #endif
+
+ #ifdef ENABLE_DEFAULT_PIE
+-#define NO_PIE_SPEC "no-pie|static"
+-#define PIE_SPEC NO_PIE_SPEC "|r|shared:;"
++#define PIE_SPEC "!no-pie"
+ #define NO_FPIE1_SPEC "fno-pie"
+ #define FPIE1_SPEC NO_FPIE1_SPEC ":;"
+ #define NO_FPIE2_SPEC "fno-PIE"
+@@ -891,7 +890,6 @@ proper position among the other output files. */
+ #define FPIE_OR_FPIC_SPEC NO_FPIE_AND_FPIC_SPEC ":;"
+ #else
+ #define PIE_SPEC "pie"
+-#define NO_PIE_SPEC PIE_SPEC "|r|shared:;"
+ #define FPIE1_SPEC "fpie"
+ #define NO_FPIE1_SPEC FPIE1_SPEC ":;"
+ #define FPIE2_SPEC "fPIE"
+@@ -920,7 +918,7 @@ proper position among the other output files. */
+ #else
+ #define LD_PIE_SPEC ""
+ #endif
+-#define LINK_PIE_SPEC "%{no-pie:} " "%{" PIE_SPEC ":" LD_PIE_SPEC "} "
++#define LINK_PIE_SPEC "%{static|shared|r:;" PIE_SPEC ":" LD_PIE_SPEC "} "
+ #endif
+
+ #ifndef LINK_BUILDID_SPEC
+@@ -999,8 +997,10 @@ proper position among the other output files. */
+ #endif
+
+ /* -u* was put back because both BSD and SysV seem to support it. */
+-/* %{static:} simply prevents an error message if the target machine
+- doesn't handle -static. */
++/* %{static|no-pie:} simply prevents an error message:
++ 1. If the target machine doesn't handle -static.
++ 2. If PIE isn't enabled by default.
++ */
+ /* We want %{T*} after %{L*} and %D so that it can be used to specify linker
+ scripts which exist in user specified directories, or in standard
+ directories. */
+@@ -1017,7 +1017,7 @@ proper position among the other output files. */
+ "%{fuse-ld=*:-fuse-ld=%*} " LINK_COMPRESS_DEBUG_SPEC \
+ "%X %{o*} %{e*} %{N} %{n} %{r}\
+ %{s} %{t} %{u*} %{z} %{Z} %{!nostdlib:%{!nostartfiles:%S}} \
+- %{static:} %{L*} %(mfwrap) %(link_libgcc) " \
++ %{static|no-pie:} %{L*} %(mfwrap) %(link_libgcc) " \
+ VTABLE_VERIFICATION_SPEC " " SANITIZER_EARLY_SPEC " %o " CHKP_SPEC " \
+ %{fopenacc|fopenmp|%:gt(%{ftree-parallelize-loops=*:%*} 1):\
+ %:include(libgomp.spec)%(link_gomp)}\
+--
+2.15.1
+
diff --git a/src/patchsets/gcc/7.2.0/gentoo/96_all_powerpc_pie.patch b/src/patchsets/gcc/7.2.0/gentoo/96_all_powerpc_pie.patch
new file mode 100644
index 0000000000..55cf5d60f8
--- /dev/null
+++ b/src/patchsets/gcc/7.2.0/gentoo/96_all_powerpc_pie.patch
@@ -0,0 +1,84 @@
+https://bugs.gentoo.org/641474
+
+From e764842a5c6ae3aa81be7c8c2b710d92404b9590 Mon Sep 17 00:00:00 2001
+From: amodra <amodra@138bc75d-0d04-0410-961f-82ee72b054a4>
+Date: Tue, 29 Aug 2017 08:27:02 +0000
+Subject: [PATCH] [RS6000] linux startfile/endfile
+
+These need to match the gnu-user.h definitions to support
+--enable-default-pie. Otherwise we end up linking the wrong startup
+files when defaulting to PIE.
+
+ PR target/81170
+ PR target/81295
+ * config/rs6000/sysv4.h (STARTFILE_LINUX_SPEC): Upgrade to
+ match gnu-user.h startfile.
+ (ENDFILE_LINUX_SPEC): Similarly.
+
+
+git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-6-branch@251405 138bc75d-0d04-0410-961f-82ee72b054a4
+---
+ gcc/ChangeLog | 7 +++++++
+ gcc/config/rs6000/sysv4.h | 46 ++++++++++++++++++++++++++++------------------
+ 2 files changed, 35 insertions(+), 18 deletions(-)
+
+diff --git a/gcc/config/rs6000/sysv4.h b/gcc/config/rs6000/sysv4.h
+index ba35fd27d0f..f81ba6d1514 100644
+--- a/gcc/config/rs6000/sysv4.h
++++ b/gcc/config/rs6000/sysv4.h
+@@ -752,24 +752,34 @@ ENDIAN_SELECT(" -mbig", " -mlittle", DEFAULT_ASM_ENDIAN)
+ #define CRTOFFLOADEND ""
+ #endif
+
+-#ifdef HAVE_LD_PIE
+-#define STARTFILE_LINUX_SPEC "\
+-%{!shared: %{pg|p|profile:gcrt1.o%s;pie:Scrt1.o%s;:crt1.o%s}} \
+-%{mnewlib:ecrti.o%s;:crti.o%s} \
+-%{static:crtbeginT.o%s;shared|pie:crtbeginS.o%s;:crtbegin.o%s} \
+-" CRTOFFLOADBEGIN
+-#else
+-#define STARTFILE_LINUX_SPEC "\
+-%{!shared: %{pg|p|profile:gcrt1.o%s;:crt1.o%s}} \
+-%{mnewlib:ecrti.o%s;:crti.o%s} \
+-%{static:crtbeginT.o%s;shared|pie:crtbeginS.o%s;:crtbegin.o%s} \
+-" CRTOFFLOADBEGIN
+-#endif
+-
+-#define ENDFILE_LINUX_SPEC "\
+-%{shared|pie:crtendS.o%s;:crtend.o%s} \
+-%{mnewlib:ecrtn.o%s;:crtn.o%s} \
+-" CRTOFFLOADEND
++/* STARTFILE_LINUX_SPEC should be the same as GNU_USER_TARGET_STARTFILE_SPEC
++ but with the mnewlib ecrti.o%s selection substituted for crti.o%s. */
++#define STARTFILE_LINUX_SPEC \
++ "%{shared:; \
++ pg|p|profile:gcrt1.o%s; \
++ static:crt1.o%s; \
++ " PIE_SPEC ":Scrt1.o%s; \
++ :crt1.o%s} \
++ %{mnewlib:ecrti.o%s;:crti.o%s} \
++ %{static:crtbeginT.o%s; \
++ shared|" PIE_SPEC ":crtbeginS.o%s; \
++ :crtbegin.o%s} \
++ %{fvtable-verify=none:%s; \
++ fvtable-verify=preinit:vtv_start_preinit.o%s; \
++ fvtable-verify=std:vtv_start.o%s} \
++ " CRTOFFLOADBEGIN
++
++/* ENDFILE_LINUX_SPEC should be the same as GNU_USER_TARGET_ENDFILE_SPEC
++ but with the mnewlib ecrtn.o%s selection substituted for crtn.o%s. */
++#define ENDFILE_LINUX_SPEC \
++ "%{fvtable-verify=none:%s; \
++ fvtable-verify=preinit:vtv_end_preinit.o%s; \
++ fvtable-verify=std:vtv_end.o%s} \
++ %{static:crtend.o%s; \
++ shared|" PIE_SPEC ":crtendS.o%s; \
++ :crtend.o%s} \
++ %{mnewlib:ecrtn.o%s;:crtn.o%s} \
++ " CRTOFFLOADEND
+
+ #define LINK_START_LINUX_SPEC ""
+
+--
+2.15.1
+
diff --git a/src/patchsets/gcc/7.2.0/gentoo/README.history b/src/patchsets/gcc/7.2.0/gentoo/README.history
index 20b95f6172..239e4fd21c 100644
--- a/src/patchsets/gcc/7.2.0/gentoo/README.history
+++ b/src/patchsets/gcc/7.2.0/gentoo/README.history
@@ -1,3 +1,6 @@
+1.1 TODO
+ + 95_all_static_override_pie.patch
+ + 96_all_powerpc_pie.patch
1.0 08 May 2017
+ 10_all_default-fortify-source.patch
+ 11_all_default-warn-format-security.patch