aboutsummaryrefslogtreecommitdiffstats
path: root/toolchain/gcc/patches/5.3.0/020-no-plt-backport.patch
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2016-02-29 20:09:45 +0000
committerFelix Fietkau <nbd@openwrt.org>2016-02-29 20:09:45 +0000
commit5168d43b16658db0bf17db9798715e4363fdf2bc (patch)
tree7b066ae98de3e213c632b3e934ead02d60af4efa /toolchain/gcc/patches/5.3.0/020-no-plt-backport.patch
parent64fc5264cc4ee23fbf663e0658372eb4536bfce1 (diff)
downloadupstream-5168d43b16658db0bf17db9798715e4363fdf2bc.tar.gz
upstream-5168d43b16658db0bf17db9798715e4363fdf2bc.tar.bz2
upstream-5168d43b16658db0bf17db9798715e4363fdf2bc.zip
gcc: update gcc 5 to version 5.3.0
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de> SVN-Revision: 48826
Diffstat (limited to 'toolchain/gcc/patches/5.3.0/020-no-plt-backport.patch')
-rw-r--r--toolchain/gcc/patches/5.3.0/020-no-plt-backport.patch28
1 files changed, 28 insertions, 0 deletions
diff --git a/toolchain/gcc/patches/5.3.0/020-no-plt-backport.patch b/toolchain/gcc/patches/5.3.0/020-no-plt-backport.patch
new file mode 100644
index 0000000000..b9702c9520
--- /dev/null
+++ b/toolchain/gcc/patches/5.3.0/020-no-plt-backport.patch
@@ -0,0 +1,28 @@
+--- a/gcc/calls.c
++++ b/gcc/calls.c
+@@ -225,6 +225,12 @@ prepare_call_address (tree fndecl_or_typ
+ && targetm.small_register_classes_for_mode_p (FUNCTION_MODE))
+ ? force_not_mem (memory_address (FUNCTION_MODE, funexp))
+ : memory_address (FUNCTION_MODE, funexp));
++ else if (flag_pic && !flag_plt && fndecl_or_type
++ && TREE_CODE (fndecl_or_type) == FUNCTION_DECL
++ && !targetm.binds_local_p (fndecl_or_type))
++ {
++ funexp = force_reg (Pmode, funexp);
++ }
+ else if (! sibcallp)
+ {
+ #ifndef NO_FUNCTION_CSE
+--- a/gcc/common.opt
++++ b/gcc/common.opt
+@@ -1779,6 +1779,10 @@ fpie
+ Common Report Var(flag_pie,1) Negative(fPIC)
+ Generate position-independent code for executables if possible (small mode)
+
++fplt
++Common Report Var(flag_plt) Init(1)
++Use PLT for PIC calls (-fno-plt: load the address from GOT at call site)
++
+ fplugin=
+ Common Joined RejectNegative Var(common_deferred_options) Defer
+ Specify a plugin to load