+2004-12-21 Richard Henderson <rth@redhat.com>
+
+ * gimplify.c (eval_save_expr): New.
+ (gimplify_one_sizepos): Use it.
+ * stor-layout.c (layout_type): Unshare TYPE_MIN/MAX_VALUE.
+
2004-12-21 Nathan Sidwell <nathan@codesourcery.com>
* system.c (IN_RANGE): Use plain unsigned, not unsigned
gimplify_one_sizepos (&TYPE_SIZE_UNIT (type), list_p);
}
-/* Subroutine of the above to gimplify one size or position, *EXPR_P.
+/* A subroutine of gimplify_one_sizepos, called via walk_tree. Evaluate
+ the expression if it's a SAVE_EXPR and add it to the statement list
+ in DATA. */
+
+static tree
+eval_save_expr (tree *tp, int *walk_subtrees, void *data)
+{
+ if (TREE_CODE (*tp) == SAVE_EXPR)
+ {
+ *walk_subtrees = 0;
+ gimplify_and_add (*tp, (tree *) data);
+ }
+ else if (TYPE_P (*tp) || DECL_P (*tp))
+ *walk_subtrees = 0;
+ return NULL;
+}
+
+/* A subroutine of gimplify_type_sizes to make sure that *EXPR_P,
+ a size or position, has had all of its SAVE_EXPRs evaluated.
We add any required statements to STMT_P. */
void
|| CONTAINS_PLACEHOLDER_P (*expr_p))
return;
- gimplify_expr (expr_p, stmt_p, NULL, is_gimple_val, fb_rvalue);
+ walk_tree (expr_p, eval_save_expr, stmt_p, NULL);
}
\f
#ifdef ENABLE_CHECKING
if (index && TYPE_MAX_VALUE (index) && TYPE_MIN_VALUE (index)
&& TYPE_SIZE (element))
{
- tree ub = TYPE_MAX_VALUE (index);
- tree lb = TYPE_MIN_VALUE (index);
+ tree ub = unshare_expr (TYPE_MAX_VALUE (index));
+ tree lb = unshare_expr (TYPE_MIN_VALUE (index));
tree length;
tree element_size;