aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-ssa-pre.c
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2016-09-29 12:31:02 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2016-09-29 12:31:02 +0000
commit0ce1ecc7be817f0f96354b26f0d80f5bf53df764 (patch)
tree10160a742e289a4c4b2274325ea25c7de8d22d9b /gcc/tree-ssa-pre.c
parentda186c1f433028066a476955a36ce48647b13c6b (diff)
downloadgcc-0ce1ecc7be817f0f96354b26f0d80f5bf53df764.zip
gcc-0ce1ecc7be817f0f96354b26f0d80f5bf53df764.tar.gz
gcc-0ce1ecc7be817f0f96354b26f0d80f5bf53df764.tar.bz2
re PR bootstrap/77768 (LTO/PGO -O3 bootstrap broken: tree-vrp.c:11053:0: internal compiler error: Segmentation fault)
2016-09-29 Richard Biener <rguenther@suse.de> PR tree-optimization/77768 * tree-ssa-pre.c (eliminate_dom_walker::before_dom_children): Handle stores to readonly memory when removing redundant stores. * gcc.dg/torture/pr77768.c: New testcase. From-SVN: r240617
Diffstat (limited to 'gcc/tree-ssa-pre.c')
-rw-r--r--gcc/tree-ssa-pre.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/gcc/tree-ssa-pre.c b/gcc/tree-ssa-pre.c
index 3675fb9..39bc254 100644
--- a/gcc/tree-ssa-pre.c
+++ b/gcc/tree-ssa-pre.c
@@ -4443,9 +4443,11 @@ eliminate_dom_walker::before_dom_children (basic_block b)
&& operand_equal_p (val, rhs, 0))
{
/* We can only remove the later store if the former aliases
- at least all accesses the later one does. */
+ at least all accesses the later one does or if the store
+ was to readonly memory storing the same value. */
alias_set_type set = get_alias_set (lhs);
- if (vnresult->set == set
+ if (! vnresult
+ || vnresult->set == set
|| alias_set_subset_of (set, vnresult->set))
{
if (dump_file && (dump_flags & TDF_DETAILS))