|
|
85359c |
commit 8a1b46d59d6c3e1e5eb606cd44689c8557612257
|
|
|
85359c |
Author: law <law@138bc75d-0d04-0410-961f-82ee72b054a4>
|
|
|
85359c |
Date: Wed Sep 20 05:21:09 2017 +0000
|
|
|
85359c |
|
|
|
85359c |
* config/alpha/alpha.c (alpha_expand_prologue): Also check
|
|
|
85359c |
flag_stack_clash_protection.
|
|
|
85359c |
* config/ia64/ia64.c (ia64_compute_frame_size): Likewise.
|
|
|
85359c |
(ia64_expand_prologue): Likewise.
|
|
|
85359c |
* config/mips/mips.c (mips_expand_prologue): Likewise.
|
|
|
85359c |
* config/sparc/sparc.c (sparc_expand_prologue): Likewise.
|
|
|
85359c |
(sparc_flat_expand_prologue): Likewise.
|
|
|
85359c |
* config/spu/spu.c (spu_expand_prologue): Likewise.
|
|
|
85359c |
|
|
|
85359c |
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@252996 138bc75d-0d04-0410-961f-82ee72b054a4
|
|
|
85359c |
|
|
|
85359c |
diff --git a/gcc/config/alpha/alpha.c b/gcc/config/alpha/alpha.c
|
|
|
85359c |
index 5402f5213d6..c46c843e462 100644
|
|
|
85359c |
--- a/gcc/config/alpha/alpha.c
|
|
|
85359c |
+++ b/gcc/config/alpha/alpha.c
|
|
|
85359c |
@@ -7624,7 +7624,7 @@ alpha_expand_prologue (void)
|
|
|
85359c |
Note that we are only allowed to adjust sp once in the prologue. */
|
|
|
85359c |
|
|
|
85359c |
probed_size = frame_size;
|
|
|
85359c |
- if (flag_stack_check)
|
|
|
85359c |
+ if (flag_stack_check || flag_stack_clash_protection)
|
|
|
85359c |
probed_size += get_stack_check_protect ();
|
|
|
85359c |
|
|
|
85359c |
if (probed_size <= 32768)
|
|
|
85359c |
@@ -7639,7 +7639,7 @@ alpha_expand_prologue (void)
|
|
|
85359c |
/* We only have to do this probe if we aren't saving registers or
|
|
|
85359c |
if we are probing beyond the frame because of -fstack-check. */
|
|
|
85359c |
if ((sa_size == 0 && probed_size > probed - 4096)
|
|
|
85359c |
- || flag_stack_check)
|
|
|
85359c |
+ || flag_stack_check || flag_stack_clash_protection)
|
|
|
85359c |
emit_insn (gen_probe_stack (GEN_INT (-probed_size)));
|
|
|
85359c |
}
|
|
|
85359c |
|
|
|
85359c |
@@ -7669,7 +7669,8 @@ alpha_expand_prologue (void)
|
|
|
85359c |
late in the compilation, generate the loop as a single insn. */
|
|
|
85359c |
emit_insn (gen_prologue_stack_probe_loop (count, ptr));
|
|
|
85359c |
|
|
|
85359c |
- if ((leftover > 4096 && sa_size == 0) || flag_stack_check)
|
|
|
85359c |
+ if ((leftover > 4096 && sa_size == 0)
|
|
|
85359c |
+ || flag_stack_check || flag_stack_clash_protection)
|
|
|
85359c |
{
|
|
|
85359c |
rtx last = gen_rtx_MEM (DImode,
|
|
|
85359c |
plus_constant (Pmode, ptr, -leftover));
|
|
|
85359c |
@@ -7677,7 +7678,7 @@ alpha_expand_prologue (void)
|
|
|
85359c |
emit_move_insn (last, const0_rtx);
|
|
|
85359c |
}
|
|
|
85359c |
|
|
|
85359c |
- if (flag_stack_check)
|
|
|
85359c |
+ if (flag_stack_check || flag_stack_clash_protection)
|
|
|
85359c |
{
|
|
|
85359c |
/* If -fstack-check is specified we have to load the entire
|
|
|
85359c |
constant into a register and subtract from the sp in one go,
|
|
|
85359c |
diff --git a/gcc/config/ia64/ia64.c b/gcc/config/ia64/ia64.c
|
|
|
85359c |
index 390983936e8..5bf7046cf15 100644
|
|
|
85359c |
--- a/gcc/config/ia64/ia64.c
|
|
|
85359c |
+++ b/gcc/config/ia64/ia64.c
|
|
|
85359c |
@@ -2638,7 +2638,8 @@ ia64_compute_frame_size (HOST_WIDE_INT size)
|
|
|
85359c |
mark_reg_gr_used_mask (cfun->machine->ia64_eh_epilogue_bsp, NULL);
|
|
|
85359c |
|
|
|
85359c |
/* Static stack checking uses r2 and r3. */
|
|
|
85359c |
- if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK)
|
|
|
85359c |
+ if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK
|
|
|
85359c |
+ || flag_stack_clash_protection)
|
|
|
85359c |
current_frame_info.gr_used_mask |= 0xc;
|
|
|
85359c |
|
|
|
85359c |
/* Find the size of the register stack frame. We have only 80 local
|
|
|
85359c |
@@ -3434,7 +3435,8 @@ ia64_expand_prologue (void)
|
|
|
85359c |
if (flag_stack_usage_info)
|
|
|
85359c |
current_function_static_stack_size = current_frame_info.total_size;
|
|
|
85359c |
|
|
|
85359c |
- if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK)
|
|
|
85359c |
+ if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK
|
|
|
85359c |
+ || flag_stack_clash_protection)
|
|
|
85359c |
ia64_emit_probe_stack_range (get_stack_check_protect (),
|
|
|
85359c |
current_frame_info.total_size,
|
|
|
85359c |
current_frame_info.n_input_regs
|
|
|
85359c |
diff --git a/gcc/config/mips/mips.c b/gcc/config/mips/mips.c
|
|
|
85359c |
index 9b7eb678f19..da17f94b4f9 100644
|
|
|
85359c |
--- a/gcc/config/mips/mips.c
|
|
|
85359c |
+++ b/gcc/config/mips/mips.c
|
|
|
85359c |
@@ -10745,7 +10745,9 @@ mips_expand_prologue (void)
|
|
|
85359c |
if (flag_stack_usage_info)
|
|
|
85359c |
current_function_static_stack_size = size;
|
|
|
85359c |
|
|
|
85359c |
- if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK && size)
|
|
|
85359c |
+ if ((flag_stack_check == STATIC_BUILTIN_STACK_CHECK
|
|
|
85359c |
+ || flag_stack_clash_protection)
|
|
|
85359c |
+ && size)
|
|
|
85359c |
mips_emit_probe_stack_range (get_stack_check_protect (), size);
|
|
|
85359c |
|
|
|
85359c |
/* Save the registers. Allocate up to MIPS_MAX_FIRST_STACK_STEP
|
|
|
85359c |
diff --git a/gcc/config/sparc/sparc.c b/gcc/config/sparc/sparc.c
|
|
|
85359c |
index e5e93c80261..617aa617208 100644
|
|
|
85359c |
--- a/gcc/config/sparc/sparc.c
|
|
|
85359c |
+++ b/gcc/config/sparc/sparc.c
|
|
|
85359c |
@@ -5430,7 +5430,9 @@ sparc_expand_prologue (void)
|
|
|
85359c |
if (flag_stack_usage_info)
|
|
|
85359c |
current_function_static_stack_size = size;
|
|
|
85359c |
|
|
|
85359c |
- if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK && size)
|
|
|
85359c |
+ if ((flag_stack_check == STATIC_BUILTIN_STACK_CHECK
|
|
|
85359c |
+ || flag_stack_clash_protection)
|
|
|
85359c |
+ && size)
|
|
|
85359c |
sparc_emit_probe_stack_range (get_stack_check_protect (), size);
|
|
|
85359c |
|
|
|
85359c |
if (size == 0)
|
|
|
85359c |
@@ -5532,7 +5534,9 @@ sparc_flat_expand_prologue (void)
|
|
|
85359c |
if (flag_stack_usage_info)
|
|
|
85359c |
current_function_static_stack_size = size;
|
|
|
85359c |
|
|
|
85359c |
- if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK && size)
|
|
|
85359c |
+ if ((flag_stack_check == STATIC_BUILTIN_STACK_CHECK
|
|
|
85359c |
+ || flag_stack_clash_protection)
|
|
|
85359c |
+ && size)
|
|
|
85359c |
sparc_emit_probe_stack_range (get_stack_check_protect (), size);
|
|
|
85359c |
|
|
|
85359c |
if (sparc_save_local_in_regs_p)
|
|
|
85359c |
diff --git a/gcc/config/spu/spu.c b/gcc/config/spu/spu.c
|
|
|
85359c |
index 328bd5bd2ae..5541a3cd243 100644
|
|
|
85359c |
--- a/gcc/config/spu/spu.c
|
|
|
85359c |
+++ b/gcc/config/spu/spu.c
|
|
|
85359c |
@@ -1761,7 +1761,7 @@ spu_expand_prologue (void)
|
|
|
85359c |
|
|
|
85359c |
if (total_size > 0)
|
|
|
85359c |
{
|
|
|
85359c |
- if (flag_stack_check)
|
|
|
85359c |
+ if (flag_stack_check || flag_stack_clash_protection)
|
|
|
85359c |
{
|
|
|
85359c |
/* We compare against total_size-1 because
|
|
|
85359c |
($sp >= total_size) <=> ($sp > total_size-1) */
|
|
|
85359c |
@@ -5366,7 +5366,7 @@ spu_allocate_stack (rtx op0, rtx op1)
|
|
|
85359c |
emit_insn (gen_spu_convert (sp, stack_pointer_rtx));
|
|
|
85359c |
emit_insn (gen_subv4si3 (sp, sp, splatted));
|
|
|
85359c |
|
|
|
85359c |
- if (flag_stack_check)
|
|
|
85359c |
+ if (flag_stack_check || flag_stack_clash_protection)
|
|
|
85359c |
{
|
|
|
85359c |
rtx avail = gen_reg_rtx(SImode);
|
|
|
85359c |
rtx result = gen_reg_rtx(SImode);
|