summaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>2007-09-11 19:43:02 +0000
committerebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>2007-09-11 19:43:02 +0000
commit9ba1ed5a8ff65cefe456fbdd48b7244800de1f87 (patch)
tree6794bfdde0fa3a761d0a915bf86007b0ca87d7e2 /gcc
parentd2d8f66232a3fcc744de1107058fc3075769f795 (diff)
downloadgcc-9ba1ed5a8ff65cefe456fbdd48b7244800de1f87.tar.gz
* tree-ssa-structalias.c (push_fields_onto_fieldstack): Deal with
TYPE_NONALIASED_COMPONENT like with DECL_NONADDRESSABLE_P. ada/ * decl.c (array_type_has_nonaliased_component): New predicate. (gnat_to_gnu_field) <E_Array_Type>: Invoke the above predicate to set the TYPE_NONALIASED_COMPONENT flag on the type. <E_Array_Subtype>: Likewise. * gigi.h (type_for_nonaliased_component_p): Declare. * utils.c (type_for_nonaliased_component_p): New predicate. (create_field_decl): Invoke the above predicate to set the DECL_NONADDRESSABLE_P flag on the field. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@128391 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/ada/ChangeLog11
-rw-r--r--gcc/ada/decl.c41
-rw-r--r--gcc/ada/gigi.h4
-rw-r--r--gcc/ada/utils.c31
-rw-r--r--gcc/tree-ssa-structalias.c9
6 files changed, 70 insertions, 31 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index ac74a0e54c6..3fff25df9b0 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2007-09-11 Eric Botcazou <ebotcazou@adacore.com>
+
+ * tree-ssa-structalias.c (push_fields_onto_fieldstack): Deal with
+ TYPE_NONALIASED_COMPONENT like with DECL_NONADDRESSABLE_P.
+
2007-09-11 Jason Merrill <jason@redhat.com>
PR middle-end/27945
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog
index 1ad4a404e8e..6951351c64f 100644
--- a/gcc/ada/ChangeLog
+++ b/gcc/ada/ChangeLog
@@ -1,3 +1,14 @@
+2007-09-11 Eric Botcazou <ebotcazou@adacore.com>
+
+ * decl.c (array_type_has_nonaliased_component): New predicate.
+ (gnat_to_gnu_field) <E_Array_Type>: Invoke the above predicate to
+ set the TYPE_NONALIASED_COMPONENT flag on the type.
+ <E_Array_Subtype>: Likewise.
+ * gigi.h (type_for_nonaliased_component_p): Declare.
+ * utils.c (type_for_nonaliased_component_p): New predicate.
+ (create_field_decl): Invoke the above predicate to set the
+ DECL_NONADDRESSABLE_P flag on the field.
+
2007-09-11 Javier Miranda <miranda@adacore.com>
* einfo.ads, einfo.adb (Dispatch_Table_Wrapper): New attribute. Present
diff --git a/gcc/ada/decl.c b/gcc/ada/decl.c
index 5aa4bc8dd37..3d7c849fa71 100644
--- a/gcc/ada/decl.c
+++ b/gcc/ada/decl.c
@@ -103,6 +103,7 @@ static tree gnat_to_gnu_field (Entity_Id, tree, int, bool);
static tree gnat_to_gnu_param (Entity_Id, Mechanism_Type, Entity_Id, bool,
bool *);
static bool same_discriminant_p (Entity_Id, Entity_Id);
+static bool array_type_has_nonaliased_component (Entity_Id, tree);
static void components_to_record (tree, Node_Id, tree, int, bool, tree *,
bool, bool, bool, bool);
static Uint annotate_value (tree);
@@ -1788,16 +1789,7 @@ gnat_to_gnu_entity (Entity_Id gnat_entity, tree gnu_expr, int definition)
{
tem = build_array_type (tem, gnu_index_types[index]);
TYPE_MULTI_ARRAY_P (tem) = (index > 0);
-
- /* If the type below this is a multi-array type, then this
- does not have aliased components. But we have to make
- them addressable if it must be passed by reference or
- if that is the default. */
- if ((TREE_CODE (TREE_TYPE (tem)) == ARRAY_TYPE
- && TYPE_MULTI_ARRAY_P (TREE_TYPE (tem)))
- || (!Has_Aliased_Components (gnat_entity)
- && !must_pass_by_ref (TREE_TYPE (tem))
- && !default_pass_by_ref (TREE_TYPE (tem))))
+ if (array_type_has_nonaliased_component (gnat_entity, tem))
TYPE_NONALIASED_COMPONENT (tem) = 1;
}
@@ -2123,16 +2115,7 @@ gnat_to_gnu_entity (Entity_Id gnat_entity, tree gnu_expr, int definition)
{
gnu_type = build_array_type (gnu_type, gnu_index_type[index]);
TYPE_MULTI_ARRAY_P (gnu_type) = (index > 0);
-
- /* If the type below this is a multi-array type, then this
- does not have aliased components. But we have to make
- them addressable if it must be passed by reference or
- if that is the default. */
- if ((TREE_CODE (TREE_TYPE (gnu_type)) == ARRAY_TYPE
- && TYPE_MULTI_ARRAY_P (TREE_TYPE (gnu_type)))
- || (!Has_Aliased_Components (gnat_entity)
- && !must_pass_by_ref (TREE_TYPE (gnu_type))
- && !default_pass_by_ref (TREE_TYPE (gnu_type))))
+ if (array_type_has_nonaliased_component (gnat_entity, gnu_type))
TYPE_NONALIASED_COMPONENT (gnu_type) = 1;
}
@@ -4625,6 +4608,24 @@ same_discriminant_p (Entity_Id discr1, Entity_Id discr2)
return
Original_Record_Component (discr1) == Original_Record_Component (discr2);
}
+
+/* Return true if the array type specified by GNAT_TYPE and GNU_TYPE has
+ a non-aliased component in the back-end sense. */
+
+static bool
+array_type_has_nonaliased_component (Entity_Id gnat_type, tree gnu_type)
+{
+ /* If the type below this is a multi-array type, then
+ this does not have aliased components. */
+ if (TREE_CODE (TREE_TYPE (gnu_type)) == ARRAY_TYPE
+ && TYPE_MULTI_ARRAY_P (TREE_TYPE (gnu_type)))
+ return true;
+
+ if (Has_Aliased_Components (gnat_type))
+ return false;
+
+ return type_for_nonaliased_component_p (TREE_TYPE (gnu_type));
+}
/* Given GNAT_ENTITY, elaborate all expressions that are required to
be elaborated at the point of its definition, but do nothing else. */
diff --git a/gcc/ada/gigi.h b/gcc/ada/gigi.h
index 42e923391b5..97a1862a268 100644
--- a/gcc/ada/gigi.h
+++ b/gcc/ada/gigi.h
@@ -704,6 +704,10 @@ extern tree unchecked_convert (tree type, tree expr, bool notrunc_p);
the latter being a record type as predicated by Is_Record_Type. */
extern enum tree_code tree_code_for_record_type (Entity_Id);
+/* Return true if GNU_TYPE is suitable as the type of a non-aliased
+ component of an aggregate type. */
+extern bool type_for_nonaliased_component_p (tree);
+
/* Prepare expr to be an argument of a TRUTH_NOT_EXPR or other logical
operation.
diff --git a/gcc/ada/utils.c b/gcc/ada/utils.c
index 6a4cc3c7669..56d490073c4 100644
--- a/gcc/ada/utils.c
+++ b/gcc/ada/utils.c
@@ -1625,21 +1625,14 @@ create_field_decl (tree field_name, tree field_type, tree record_type,
}
/* In addition to what our caller says, claim the field is addressable if we
- know we might ever attempt to take its address, then mark the decl as
- nonaddressable accordingly.
+ know that its type is not suitable.
The field may also be "technically" nonaddressable, meaning that even if
we attempt to take the field's address we will actually get the address
of a copy. This is the case for true bitfields, but the DECL_BIT_FIELD
value we have at this point is not accurate enough, so we don't account
for this here and let finish_record_type decide. */
-
- /* We will take the address in any argument passing sequence if the field
- type is passed by reference, and we might need the address for any array
- type, even if normally passed by-copy, to construct a fat pointer if the
- field is used as an actual for an unconstrained formal. */
- if (TREE_CODE (field_type) == ARRAY_TYPE
- || must_pass_by_ref (field_type) || default_pass_by_ref (field_type))
+ if (!type_for_nonaliased_component_p (field_type))
addressable = 1;
DECL_NONADDRESSABLE_P (field_decl) = !addressable;
@@ -4004,6 +3997,26 @@ tree_code_for_record_type (Entity_Id gnat_type)
return UNION_TYPE;
}
+/* Return true if GNU_TYPE is suitable as the type of a non-aliased
+ component of an aggregate type. */
+
+bool
+type_for_nonaliased_component_p (tree gnu_type)
+{
+ /* If the type is passed by reference, we may have pointers to the
+ component so it cannot be made non-aliased. */
+ if (must_pass_by_ref (gnu_type) || default_pass_by_ref (gnu_type))
+ return false;
+
+ /* We might need the address for any array type, even if normally
+ passed by copy, to construct a fat pointer if the component is
+ used as an actual for an unconstrained formal. */
+ if (TREE_CODE (gnu_type) == ARRAY_TYPE)
+ return false;
+
+ return true;
+}
+
/* Perform final processing on global variables. */
void
diff --git a/gcc/tree-ssa-structalias.c b/gcc/tree-ssa-structalias.c
index a379e7e2a8d..3e588bdfcdb 100644
--- a/gcc/tree-ssa-structalias.c
+++ b/gcc/tree-ssa-structalias.c
@@ -4114,7 +4114,9 @@ push_fields_onto_fieldstack (tree type, VEC(fieldoff_s,heap) **fieldstack,
else if (!(pushed = push_fields_onto_fieldstack
(TREE_TYPE (type), fieldstack,
offset + i * TREE_INT_CST_LOW (elsz), has_union,
- TREE_TYPE (type))))
+ (TYPE_NONALIASED_COMPONENT (type)
+ ? addressable_type
+ : TREE_TYPE (type)))))
/* Empty structures may have actual size, like in C++. So
see if we didn't push any subfields and the size is
nonzero, push the field onto the stack */
@@ -4129,7 +4131,10 @@ push_fields_onto_fieldstack (tree type, VEC(fieldoff_s,heap) **fieldstack,
pair->size = elsz;
pair->decl = NULL_TREE;
pair->offset = offset + i * TREE_INT_CST_LOW (elsz);
- pair->alias_set = -1;
+ if (TYPE_NONALIASED_COMPONENT (type))
+ pair->alias_set = get_alias_set (addressable_type);
+ else
+ pair->alias_set = -1;
count++;
}
else