aboutsummaryrefslogtreecommitdiff
path: root/gcc/emit-rtl.c
diff options
context:
space:
mode:
authorRichard Guenther <rguenther@suse.de>2010-04-07 10:13:25 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2010-04-07 10:13:25 +0000
commit56c47f227103ba589fc246c6bee47d0fca8afaaf (patch)
tree73257bbd69a5a06f1b84a4d755f735c5fa36e36c /gcc/emit-rtl.c
parenta42f12170922d13a8ecb5b0d9043c0b929bec957 (diff)
downloadgcc-56c47f227103ba589fc246c6bee47d0fca8afaaf.zip
gcc-56c47f227103ba589fc246c6bee47d0fca8afaaf.tar.gz
gcc-56c47f227103ba589fc246c6bee47d0fca8afaaf.tar.bz2
re PR rtl-optimization/42617 (TARGET_MEM_REF and plain INDIRECT_REFs are not handled by the RTL oracle)
2010-04-07 Richard Guenther <rguenther@suse.de> PR middle-end/42617 * emit-rtl.c (set_mem_attributes_minus_bitpos): Do not discard plain indirect references. * fold-const.c (operand_equal_p): Guard against NULL_TREE type. * tree.c (tree_nop_conversion): Likewise. From-SVN: r158045
Diffstat (limited to 'gcc/emit-rtl.c')
-rw-r--r--gcc/emit-rtl.c19
1 files changed, 19 insertions, 0 deletions
diff --git a/gcc/emit-rtl.c b/gcc/emit-rtl.c
index 6e1f949..dda2b0f 100644
--- a/gcc/emit-rtl.c
+++ b/gcc/emit-rtl.c
@@ -1750,6 +1750,7 @@ set_mem_attributes_minus_bitpos (rtx ref, tree t, int objectp,
/* ??? Any reason the field size would be different than
the size we got from the type? */
}
+
else if (flag_argument_noalias > 1
&& (INDIRECT_REF_P (t2))
&& TREE_CODE (TREE_OPERAND (t2, 0)) == PARM_DECL)
@@ -1757,6 +1758,15 @@ set_mem_attributes_minus_bitpos (rtx ref, tree t, int objectp,
expr = t2;
offset = NULL;
}
+
+ /* If this is an indirect reference, record it. */
+ else if (TREE_CODE (t) == INDIRECT_REF
+ || TREE_CODE (t) == MISALIGNED_INDIRECT_REF)
+ {
+ expr = t;
+ offset = const0_rtx;
+ apply_bitpos = bitpos;
+ }
}
/* If this is a Fortran indirect argument reference, record the
@@ -1769,6 +1779,15 @@ set_mem_attributes_minus_bitpos (rtx ref, tree t, int objectp,
offset = NULL;
}
+ /* If this is an indirect reference, record it. */
+ else if (TREE_CODE (t) == INDIRECT_REF
+ || TREE_CODE (t) == MISALIGNED_INDIRECT_REF)
+ {
+ expr = t;
+ offset = const0_rtx;
+ apply_bitpos = bitpos;
+ }
+
if (!align_computed && !INDIRECT_REF_P (t))
{
unsigned int obj_align