aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-ssa-operands.c
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2021-05-19 12:36:19 +0200
committerRichard Biener <rguenther@suse.de>2021-05-19 14:53:50 +0200
commit35a16e4b38eb9faf212de9814f17a5215fa5538a (patch)
tree066e20b1a46a20cc5decd53bed51140dbfac3fa8 /gcc/tree-ssa-operands.c
parent2e6ad1ba532fe684633edac766c598be19ad3b59 (diff)
downloadgcc-35a16e4b38eb9faf212de9814f17a5215fa5538a.zip
gcc-35a16e4b38eb9faf212de9814f17a5215fa5538a.tar.gz
gcc-35a16e4b38eb9faf212de9814f17a5215fa5538a.tar.bz2
Avoid marking TARGET_MEM_REF bases addressable
The following does no longer mark TARGET_MEM_REF bases addressable, mimicing MEM_REFs beahvior here. In contrast to the latter, TARGET_MEM_REF RTL expansion expects to always operate on memory though, so make sure we expand them so. 2021-05-19 Richard Biener <rguenther@suse.de> * cfgexpand.c (discover_nonconstant_array_refs_r): Make sure TARGET_MEM_REF bases are expanded as memory. * tree-ssa-operands.c (operands_scanner::get_tmr_operands): Do not mark TARGET_MEM_REF bases addressable. * tree-ssa.c (non_rewritable_mem_ref_base): Handle TARGET_MEM_REF bases as never rewritable. * gimple-walk.c (walk_stmt_load_store_addr_ops): Do not walk TARGET_MEM_REF bases as address-takens. * tree-ssa-dce.c (ref_may_be_aliased): Handle TARGET_MEM_REF.
Diffstat (limited to 'gcc/tree-ssa-operands.c')
-rw-r--r--gcc/tree-ssa-operands.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/gcc/tree-ssa-operands.c b/gcc/tree-ssa-operands.c
index 2fc74d5..c155754 100644
--- a/gcc/tree-ssa-operands.c
+++ b/gcc/tree-ssa-operands.c
@@ -669,7 +669,9 @@ operands_scanner::get_tmr_operands(tree expr, int flags)
gimple_set_has_volatile_ops (stmt, true);
/* First record the real operands. */
- get_expr_operands (&TMR_BASE (expr), opf_use | (flags & opf_no_vops));
+ get_expr_operands (&TMR_BASE (expr),
+ opf_non_addressable | opf_use
+ | (flags & (opf_no_vops|opf_not_non_addressable)));
get_expr_operands (&TMR_INDEX (expr), opf_use | (flags & opf_no_vops));
get_expr_operands (&TMR_INDEX2 (expr), opf_use | (flags & opf_no_vops));