diff options
author | Yousong Zhou <yszhou4tech@gmail.com> | 2016-11-24 00:03:39 +0800 |
---|---|---|
committer | Felix Fietkau <nbd@nbd.name> | 2016-11-24 12:53:18 +0100 |
commit | 49703b589ba8a5bfad63762e7fad649ab0097fa9 (patch) | |
tree | 447714ee8fda00a4cc680da0007a7e3936dbf0d5 /toolchain/gcc/patches/5.4.0 | |
parent | 62da60b22032b59a52b0671a40c59105bdee8c55 (diff) | |
download | upstream-49703b589ba8a5bfad63762e7fad649ab0097fa9.tar.gz upstream-49703b589ba8a5bfad63762e7fad649ab0097fa9.tar.bz2 upstream-49703b589ba8a5bfad63762e7fad649ab0097fa9.zip |
toolchain: gcc: disable ifunc on *-musl by default
Otherwise the built binaries may fail with
Error relocating /usr/bin/qemu-system-x86_64: unsupported relocation type 37
Signed-off-by: Yousong Zhou <yszhou4tech@gmail.com>
Diffstat (limited to 'toolchain/gcc/patches/5.4.0')
-rw-r--r-- | toolchain/gcc/patches/5.4.0/280-musl-disable-ifunc-by-default.patch | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/toolchain/gcc/patches/5.4.0/280-musl-disable-ifunc-by-default.patch b/toolchain/gcc/patches/5.4.0/280-musl-disable-ifunc-by-default.patch new file mode 100644 index 0000000000..af5acf8cc9 --- /dev/null +++ b/toolchain/gcc/patches/5.4.0/280-musl-disable-ifunc-by-default.patch @@ -0,0 +1,38 @@ +From 450fb05e2a7510d37744f044009f8237d902f65c Mon Sep 17 00:00:00 2001 +From: nsz <nsz@138bc75d-0d04-0410-961f-82ee72b054a4> +Date: Tue, 30 Aug 2016 10:26:22 +0000 +Subject: [PATCH] disable ifunc on *-musl by default + +gcc/ + * config.gcc (*-*-*musl*): Disable gnu-indirect-function. + + + +git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@239859 138bc75d-0d04-0410-961f-82ee72b054a4 +--- + gcc/ChangeLog | 4 ++++ + gcc/config.gcc | 4 ++-- + 2 files changed, 6 insertions(+), 2 deletions(-) + +diff --git a/gcc/config.gcc b/gcc/config.gcc +index 8827dc8..e544d76 100644 +--- a/gcc/config.gcc ++++ b/gcc/config.gcc +@@ -1465,7 +1465,7 @@ i[34567]86-*-linux* | i[34567]86-*-kfreebsd*-gnu | i[34567]86-*-gnu* | i[34567]8 + extra_options="${extra_options} linux-android.opt" + # Assume modern glibc if not targeting Android nor uclibc. + case ${target} in +- *-*-*android*|*-*-*uclibc*) ++ *-*-*android*|*-*-*uclibc*|*-*-*musl*) + ;; + *) + default_gnu_indirect_function=yes +@@ -1531,7 +1531,7 @@ x86_64-*-linux* | x86_64-*-kfreebsd*-gnu) + extra_options="${extra_options} linux-android.opt" + # Assume modern glibc if not targeting Android nor uclibc. + case ${target} in +- *-*-*android*|*-*-*uclibc*) ++ *-*-*android*|*-*-*uclibc*|*-*-*musl*) + ;; + *) + default_gnu_indirect_function=yes |