summaryrefslogtreecommitdiff
path: root/gcc/alias.c
diff options
context:
space:
mode:
authorrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>2004-12-04 00:20:31 +0000
committerrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>2004-12-04 00:20:31 +0000
commit2b02580fd35fe2f9d9b124e2867eb6c7f3228683 (patch)
treec955f6935acd1dde2f9a2c0e759835c083b1cd04 /gcc/alias.c
parenta8d2b0c84dad195a2652a8edd7f68cac0ddf183e (diff)
downloadgcc-2b02580fd35fe2f9d9b124e2867eb6c7f3228683.tar.gz
* alias.c (component_uses_parent_alias_set): Rename from
can_address_p. Return bool. Reverse the sense of the result. Reinstate the check for alias set zero. (get_alias_set): Update to match. * alias.h (component_uses_parent_alias_set): Likewise. * emit-rtl.c (set_mem_attributes_minus_bitpos): Likewise. * expr.c (expand_assignment): Likewise. * expr.h: Remove commented out prototypes that were moved to alias.h. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@91712 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/alias.c')
-rw-r--r--gcc/alias.c29
1 files changed, 19 insertions, 10 deletions
diff --git a/gcc/alias.c b/gcc/alias.c
index 3246082af23..e2b7adf156f 100644
--- a/gcc/alias.c
+++ b/gcc/alias.c
@@ -378,29 +378,36 @@ find_base_decl (tree t)
}
}
-/* Return 1 if all the nested component references handled by
- get_inner_reference in T are such that we can address the object in T. */
+/* Return true if all nested component references handled by
+ get_inner_reference in T are such that we should use the alias set
+ provided by the object at the heart of T.
-int
-can_address_p (tree t)
+ This is true for non-addressable components (which don't have their
+ own alias set), as well as components of objects in alias set zero.
+ This later point is a special case wherein we wish to override the
+ alias set used by the component, but we don't have per-FIELD_DECL
+ assignable alias sets. */
+
+bool
+component_uses_parent_alias_set (tree t)
{
while (1)
{
- /* If we're at the end, it is vacuously addressable. */
+ /* If we're at the end, it vacuously uses its own alias set. */
if (!handled_component_p (t))
- return true;
+ return false;
switch (TREE_CODE (t))
{
case COMPONENT_REF:
if (DECL_NONADDRESSABLE_P (TREE_OPERAND (t, 1)))
- return false;
+ return true;
break;
case ARRAY_REF:
case ARRAY_RANGE_REF:
if (TYPE_NONALIASED_COMPONENT (TREE_TYPE (TREE_OPERAND (t, 0))))
- return false;
+ return true;
break;
case REALPART_EXPR:
@@ -409,10 +416,12 @@ can_address_p (tree t)
default:
/* Bitfields and casts are never addressable. */
- return false;
+ return true;
}
t = TREE_OPERAND (t, 0);
+ if (get_alias_set (TREE_TYPE (t)) == 0)
+ return true;
}
}
@@ -515,7 +524,7 @@ get_alias_set (tree t)
/* Otherwise, pick up the outermost object that we could have a pointer
to, processing conversions as above. */
- while (handled_component_p (t) && ! can_address_p (t))
+ while (component_uses_parent_alias_set (t))
{
t = TREE_OPERAND (t, 0);
STRIP_NOPS (t);