aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorKaz Kojima <kkojima@gcc.gnu.org>2007-06-03 04:38:52 +0000
committerKaz Kojima <kkojima@gcc.gnu.org>2007-06-03 04:38:52 +0000
commit439211a08df810d61028b6325cdbe3f4c69f0b16 (patch)
tree970266bbd98f540f4cf9c254578f7d68633ae244 /gcc
parent2bccb817ce335a130252ceabd55524ce1b5ffa93 (diff)
downloadgcc-439211a08df810d61028b6325cdbe3f4c69f0b16.zip
gcc-439211a08df810d61028b6325cdbe3f4c69f0b16.tar.gz
gcc-439211a08df810d61028b6325cdbe3f4c69f0b16.tar.bz2
re PR target/32163 (Compiling with stack protector causes reigster spill failure)
PR target/32163 * config/sh/sh.md (symGOT_load): Don't schedule insns when the symbol is generated with the stack protector. From-SVN: r125292
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/config/sh/sh.md14
2 files changed, 20 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 3f67139..c1b2d93 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2007-06-03 Kaz Kojima <kkojima@gcc.gnu.org>
+
+ PR target/32163
+ * config/sh/sh.md (symGOT_load): Don't schedule insns when
+ the symbol is generated with the stack protector.
+
2007-06-03 Kazu Hirata <kazu@codesourcery.com>
* config/m68k/m68k.c (m68k_attribute_table): Add "interrupt".
diff --git a/gcc/config/sh/sh.md b/gcc/config/sh/sh.md
index 2c81792..9cc42b4 100644
--- a/gcc/config/sh/sh.md
+++ b/gcc/config/sh/sh.md
@@ -8502,6 +8502,20 @@ label:
operands[2],
gen_rtx_REG (Pmode, PIC_REG)));
+ /* When stack protector inserts codes after the result is set to
+ R0, @(rX, r12) will cause a spill failure for R0. Don't schedule
+ insns to avoid combining (set A (plus rX r12)) and (set op0 (mem A))
+ when rX is a GOT address for the guard symbol. Ugly but doesn't
+ matter because this is a rare situation. */
+ if (!TARGET_SHMEDIA
+ && flag_stack_protect
+ && GET_CODE (operands[1]) == CONST
+ && GET_CODE (XEXP (operands[1], 0)) == UNSPEC
+ && GET_CODE (XVECEXP (XEXP (operands[1], 0), 0, 0)) == SYMBOL_REF
+ && strcmp (XSTR (XVECEXP (XEXP (operands[1], 0), 0, 0), 0),
+ \"__stack_chk_guard\") == 0)
+ emit_insn (gen_blockage ());
+
/* N.B. This is not constant for a GOTPLT relocation. */
mem = gen_rtx_MEM (Pmode, operands[3]);
MEM_NOTRAP_P (mem) = 1;