On 9/25/22 09:49, linted via Gcc-patches wrote:
Hello,
I'm just checking to see if anyone has had a chance to look at this.
Thank you
On Wed, Sep 14, 2022 at 2:09 PM linted <linte...@gmail.com> wrote:
Hello,
This patch fixes missing flags when compiling with -static-pie on mips. I
made these modifications based on the previously submitted static pie patch
for arm as well as the working code for aarch64.
I tested with a host of mips-elf and checked with mips-sim. This patch was
also tested and used with uclibc-ng to generate static pie elfs.
This is my first patch for gcc, so please let me know if there is anything
I missed.
Signed-off-by: linted <lin...@users.noreply.github.com>
---
gcc/config/mips/gnu-user.h | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/gcc/config/mips/gnu-user.h b/gcc/config/mips/gnu-user.h
index 6aad7192e69..b1c665b7f37 100644
--- a/gcc/config/mips/gnu-user.h
+++ b/gcc/config/mips/gnu-user.h
@@ -56,11 +56,12 @@ along with GCC; see the file COPYING3. If not see
#define GNU_USER_TARGET_LINK_SPEC "\
%{G*} %{EB} %{EL} %{mips*} %{shared} \
%{!shared: \
- %{!static: \
+ %{!static:%{!static-pie: \
%{rdynamic:-export-dynamic} \
%{mabi=n32: -dynamic-linker " GNU_USER_DYNAMIC_LINKERN32 "} \
%{mabi=64: -dynamic-linker " GNU_USER_DYNAMIC_LINKER64 "} \
- %{mabi=32: -dynamic-linker " GNU_USER_DYNAMIC_LINKER32 "}} \
+ %{mabi=32: -dynamic-linker " GNU_USER_DYNAMIC_LINKER32 "}}} \
+ %{static-pie:-Bstatic -pie --no-dynamic-linker -z text} \
%{static}} \
This is a bit out of my usual areas of expertise. But what I find odd
here is that for -static we essentially do nothing, but for -static-pie
we need "-Bstatic -pie --no-dynamic-linker -z text". Is the -Bstatic
really needed for static-pie And if it is, then wouldn't it be needed
for -static as well? If you look carefully at aarch64, you'll see it
includes -Bstatic for -static.
Jeff