aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlan Modra <amodra@gmail.com>2015-07-31 23:35:42 +0930
committerAlan Modra <amodra@gcc.gnu.org>2015-07-31 23:35:42 +0930
commit9b015c36906089cfbea506d45995350b718bee4a (patch)
tree465a4a15c48e35d8079e8480722311697892cf40
parentec043522ffe0847f1917b5065d3b72c29d601bef (diff)
downloadgcc-9b015c36906089cfbea506d45995350b718bee4a.zip
gcc-9b015c36906089cfbea506d45995350b718bee4a.tar.gz
gcc-9b015c36906089cfbea506d45995350b718bee4a.tar.bz2
re PR go/66870 (split stack issues on ppc64le and ppc64)
PR target/66870 * config/rs6000/rs6000.c (machine_function): Add split_stack_argp_used. (rs6000_emit_prologue): Set it. (rs6000_set_up_by_prologue): Specify r12 when split_stack_argp_used. From-SVN: r226443
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/config/rs6000/rs6000.c4
2 files changed, 11 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 6163e02..daddd9a 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2015-07-31 Alan Modra <amodra@gmail.com>
+
+ PR target/66870
+ * config/rs6000/rs6000.c (machine_function): Add split_stack_argp_used.
+ (rs6000_emit_prologue): Set it.
+ (rs6000_set_up_by_prologue): Specify r12 when split_stack_argp_used.
+
2015-07-31 Richard Biener <rguenther@suse.de>
* fold-const.c (fold_binary_loc): Remove X ^ C1 == C2
diff --git a/gcc/config/rs6000/rs6000.c b/gcc/config/rs6000/rs6000.c
index 2313fad..78de645 100644
--- a/gcc/config/rs6000/rs6000.c
+++ b/gcc/config/rs6000/rs6000.c
@@ -166,6 +166,7 @@ typedef struct GTY(()) machine_function
rtx sdmode_stack_slot;
/* Alternative internal arg pointer for -fsplit-stack. */
rtx split_stack_arg_pointer;
+ bool split_stack_argp_used;
/* Flag if r2 setup is needed with ELFv2 ABI. */
bool r2_setup_needed;
} machine_function;
@@ -24693,6 +24694,7 @@ rs6000_emit_prologue (void)
__morestack was called, it left the arg pointer to the old
stack in r29. Otherwise, the arg pointer is the top of the
current frame. */
+ cfun->machine->split_stack_argp_used = true;
if (sp_adjust)
{
rtx r12 = gen_rtx_REG (Pmode, 12);
@@ -33930,6 +33932,8 @@ rs6000_set_up_by_prologue (struct hard_reg_set_container *set)
&& TARGET_MINIMAL_TOC
&& get_pool_size () != 0)
add_to_hard_reg_set (&set->set, Pmode, RS6000_PIC_OFFSET_TABLE_REGNUM);
+ if (cfun->machine->split_stack_argp_used)
+ add_to_hard_reg_set (&set->set, Pmode, 12);
}