From e30bb772cb02a5b523d036eaaa5a402a471d476b Mon Sep 17 00:00:00 2001 From: Richard Kenner Date: Sat, 3 Jul 2004 13:40:47 +0000 Subject: langhooks-def.h (LANG_HOOKS_TYPE_MAX_SIZE): New langhook. * langhooks-def.h (LANG_HOOKS_TYPE_MAX_SIZE): New langhook. * langhooks.h (strct lang_hooks): New field type_max_size. * function.c (assign_temp): Call it. From-SVN: r84053 --- gcc/function.c | 8 ++++++++ 1 file changed, 8 insertions(+) (limited to 'gcc/function.c') diff --git a/gcc/function.c b/gcc/function.c index b6d3789..c3ab96d 100644 --- a/gcc/function.c +++ b/gcc/function.c @@ -914,6 +914,7 @@ assign_temp (tree type_or_decl, int keep, int memory_required, if (mode == BLKmode || memory_required) { HOST_WIDE_INT size = int_size_in_bytes (type); + tree size_tree; rtx tmp; /* Zero sized arrays are GNU C extension. Set size to 1 to avoid @@ -930,6 +931,13 @@ assign_temp (tree type_or_decl, int keep, int memory_required, && host_integerp (TYPE_ARRAY_MAX_SIZE (type), 1)) size = tree_low_cst (TYPE_ARRAY_MAX_SIZE (type), 1); + /* If we still haven't been able to get a size, see if the language + can compute a maximum size. */ + if (size == -1 + && (size_tree = lang_hooks.type_max_size (type)) != 0 + && host_integerp (size_tree, 1)) + size = tree_low_cst (size_tree, 1); + /* The size of the temporary may be too large to fit into an integer. */ /* ??? Not sure this should happen except for user silliness, so limit this to things that aren't compiler-generated temporaries. The -- cgit v1.1