aboutsummaryrefslogtreecommitdiff
path: root/gcc/gimple-fold.c
diff options
context:
space:
mode:
authorRichard Guenther <rguenther@suse.de>2010-11-22 13:18:48 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2010-11-22 13:18:48 +0000
commite9615971330ecdb83b191135075c44a6ee01d091 (patch)
tree9955bf63053ef899a56cecced5b989e2239a8063 /gcc/gimple-fold.c
parent993466f3d18992422941c1a57b53cff04acffce6 (diff)
downloadgcc-e9615971330ecdb83b191135075c44a6ee01d091.zip
gcc-e9615971330ecdb83b191135075c44a6ee01d091.tar.gz
gcc-e9615971330ecdb83b191135075c44a6ee01d091.tar.bz2
gimple-fold.c (maybe_fold_reference): When canonicalizing MEM_REFs, preserve volatileness.
2010-11-22 Richard Guenther <rguenther@suse.de> * gimple-fold.c (maybe_fold_reference): When canonicalizing MEM_REFs, preserve volatileness. * cgraphbuild.c (mark_address): Properly check for FUNCTION_DECL addresses. From-SVN: r167030
Diffstat (limited to 'gcc/gimple-fold.c')
-rw-r--r--gcc/gimple-fold.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/gcc/gimple-fold.c b/gcc/gimple-fold.c
index e561a63..8d0157b 100644
--- a/gcc/gimple-fold.c
+++ b/gcc/gimple-fold.c
@@ -600,15 +600,15 @@ maybe_fold_reference (tree expr, bool is_lhs)
}
/* Canonicalize MEM_REFs invariant address operand. */
else if (TREE_CODE (*t) == MEM_REF
- && TREE_CODE (TREE_OPERAND (*t, 0)) == ADDR_EXPR
- && !DECL_P (TREE_OPERAND (TREE_OPERAND (*t, 0), 0))
- && !CONSTANT_CLASS_P (TREE_OPERAND (TREE_OPERAND (*t, 0), 0)))
+ && !is_gimple_mem_ref_addr (TREE_OPERAND (*t, 0)))
{
+ bool volatile_p = TREE_THIS_VOLATILE (*t);
tree tem = fold_binary (MEM_REF, TREE_TYPE (*t),
TREE_OPERAND (*t, 0),
TREE_OPERAND (*t, 1));
if (tem)
{
+ TREE_THIS_VOLATILE (tem) = volatile_p;
*t = tem;
tem = maybe_fold_reference (expr, is_lhs);
if (tem)