aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorAlan Modra <amodra@gcc.gnu.org>2011-11-07 11:44:33 +1030
committerAlan Modra <amodra@gcc.gnu.org>2011-11-07 11:44:33 +1030
commitd85087f6a06fa0514a80c2382a73af6d0ed1eef8 (patch)
tree1e386a349ef90287f0902f3f7194d39b95ae8d12 /gcc
parentc5219bb0ec9cfa10d6d59f13145e4c9206aa4b08 (diff)
downloadgcc-d85087f6a06fa0514a80c2382a73af6d0ed1eef8.zip
gcc-d85087f6a06fa0514a80c2382a73af6d0ed1eef8.tar.gz
gcc-d85087f6a06fa0514a80c2382a73af6d0ed1eef8.tar.bz2
re PR target/30282 (Optimization flag -O1 -fschedule-insns2 cause red zone to be used when there is none)
PR target/30282 * config/rs6000/rs6000.c (rs6000_emit_stack_reset): Always emit blockage for ABI_V4. From-SVN: r181056
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog10
-rw-r--r--gcc/config/rs6000/rs6000.c2
2 files changed, 9 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 4ea622e..b3a5be1 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2011-11-07 Alan Modra <amodra@gmail.com>
+
+ PR target/30282
+ * config/rs6000/rs6000.c (rs6000_emit_stack_reset): Always emit
+ blockage for ABI_V4.
+
2011-11-06 Dave Korn <dave.korn.cygwin@gmail.com>
* config/i386/cygwin.h (LIBGCJ_SONAME): Updated to match recent
@@ -147,7 +153,7 @@
* optabs.c (expand_sync_operation, expand_sync_fetch_operation): Remove.
(expand_sync_lock_test_and_set): Remove.
(expand_atomic_load, expand_atomic_store): New.
- (expand_atomic_exchange): New.
+ (expand_atomic_exchange): New.
(expand_atomic_compare_and_swap): New. Implements
atomic_compare_exchange via compare and swap.
(struct atomic_op_functions): Opcode table struct for fetch ops.
@@ -5806,7 +5812,7 @@
* hwint.h (HOST_WIDE_INT_PRINT_HEX_PURE): Add.
* lto-streamer.c (lto_get_section_name): Remove crc32_string.
- Handle numerical random seed.
+ Handle numerical random seed.
* lto-streamer.h (lto_file_decl_data): Change id to
unsigned HOST_WIDE_INT.
* toplev.c (random_seed): Add.
diff --git a/gcc/config/rs6000/rs6000.c b/gcc/config/rs6000/rs6000.c
index 779086a..aa04fdd 100644
--- a/gcc/config/rs6000/rs6000.c
+++ b/gcc/config/rs6000/rs6000.c
@@ -19661,7 +19661,7 @@ rs6000_emit_stack_reset (rs6000_stack_t *info,
{
/* This blockage is needed so that sched doesn't decide to move
the sp change before the register restores. */
- if (frame_reg_rtx != sp_reg_rtx
+ if (DEFAULT_ABI == ABI_V4
|| (TARGET_SPE_ABI
&& info->spe_64bit_regs_used != 0
&& info->first_gp_reg_save != 32))