diff options
author | kenner <kenner@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-06-28 12:01:30 +0000 |
---|---|---|
committer | kenner <kenner@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-06-28 12:01:30 +0000 |
commit | c5bfd6742db2aea145b9536be7664775ec60bb4d (patch) | |
tree | b0ba130dd7c31980e7df064ed1c3f8e0c6893853 /gcc/tree-nested.c | |
parent | 22c62909a2ed2f67ae280c4dbc208a2b482b193c (diff) | |
download | gcc-c5bfd6742db2aea145b9536be7664775ec60bb4d.tar.gz |
* tree-nested.c (create_tmp_var_for): Allow ARRAY_TYPE.
(convert_nonlocal_reference, convert_local_reference): Properly
convert nest of handled component references.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@83781 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/tree-nested.c')
-rw-r--r-- | gcc/tree-nested.c | 115 |
1 files changed, 64 insertions, 51 deletions
diff --git a/gcc/tree-nested.c b/gcc/tree-nested.c index 10bf1ce091c..668861c15b9 100644 --- a/gcc/tree-nested.c +++ b/gcc/tree-nested.c @@ -133,13 +133,12 @@ create_tmp_var_for (struct nesting_info *info, tree type, const char *prefix) tree tmp_var; #if defined ENABLE_CHECKING - /* If the type is an array or a type which must be created by the + /* If the type is of variable size or a type which must be created by the frontend, something is wrong. Note that we explicitly allow incomplete types here, since we create them ourselves here. */ - if (TREE_CODE (type) == ARRAY_TYPE || TREE_ADDRESSABLE (type)) - abort (); - if (TYPE_SIZE_UNIT (type) - && TREE_CODE (TYPE_SIZE_UNIT (type)) != INTEGER_CST) + if (TREE_ADDRESSABLE (type) + || (TYPE_SIZE_UNIT (type) + && TREE_CODE (TYPE_SIZE_UNIT (type)) != INTEGER_CST)) abort (); #endif @@ -797,34 +796,41 @@ convert_nonlocal_reference (tree *tp, int *walk_subtrees, void *data) case REALPART_EXPR: case IMAGPART_EXPR: - wi->val_only = false; - walk_tree (&TREE_OPERAND (t, 0), convert_nonlocal_reference, wi, NULL); - wi->val_only = true; - break; - case COMPONENT_REF: - wi->val_only = false; - walk_tree (&TREE_OPERAND (t, 0), convert_nonlocal_reference, wi, NULL); - wi->val_only = true; - walk_tree (&TREE_OPERAND (t, 2), convert_nonlocal_reference, wi, NULL); - break; - case ARRAY_REF: case ARRAY_RANGE_REF: - wi->val_only = false; - walk_tree (&TREE_OPERAND (t, 0), convert_nonlocal_reference, wi, NULL); - wi->val_only = true; - walk_tree (&TREE_OPERAND (t, 1), convert_nonlocal_reference, wi, NULL); - walk_tree (&TREE_OPERAND (t, 2), convert_nonlocal_reference, wi, NULL); - walk_tree (&TREE_OPERAND (t, 3), convert_nonlocal_reference, wi, NULL); - break; - case BIT_FIELD_REF: - wi->val_only = false; - walk_tree (&TREE_OPERAND (t, 0), convert_nonlocal_reference, wi, NULL); + /* Go down this entire nest and just look at the final prefix and + anything that describes the references. Otherwise, we lose track + of whether a NOP_EXPR or VIEW_CONVERT_EXPR needs a simple value. */ wi->val_only = true; - walk_tree (&TREE_OPERAND (t, 1), convert_nonlocal_reference, wi, NULL); - walk_tree (&TREE_OPERAND (t, 2), convert_nonlocal_reference, wi, NULL); + for (; handled_component_p (t) + || TREE_CODE (t) == REALPART_EXPR || TREE_CODE (t) == IMAGPART_EXPR; + tp = &TREE_OPERAND (t, 0), t = *tp) + { + if (TREE_CODE (t) == COMPONENT_REF) + walk_tree (&TREE_OPERAND (t, 2), convert_nonlocal_reference, wi, + NULL); + else if (TREE_CODE (t) == ARRAY_REF + || TREE_CODE (t) == ARRAY_RANGE_REF) + { + walk_tree (&TREE_OPERAND (t, 1), convert_nonlocal_reference, wi, + NULL); + walk_tree (&TREE_OPERAND (t, 2), convert_nonlocal_reference, wi, + NULL); + walk_tree (&TREE_OPERAND (t, 3), convert_nonlocal_reference, wi, + NULL); + } + else if (TREE_CODE (t) == BIT_FIELD_REF) + { + walk_tree (&TREE_OPERAND (t, 1), convert_nonlocal_reference, wi, + NULL); + walk_tree (&TREE_OPERAND (t, 2), convert_nonlocal_reference, wi, + NULL); + } + } + wi->val_only = false; + walk_tree (tp, convert_nonlocal_reference, wi, NULL); break; default: @@ -938,34 +944,41 @@ convert_local_reference (tree *tp, int *walk_subtrees, void *data) case REALPART_EXPR: case IMAGPART_EXPR: - wi->val_only = false; - walk_tree (&TREE_OPERAND (t, 0), convert_local_reference, wi, NULL); - wi->val_only = true; - break; - case COMPONENT_REF: - wi->val_only = false; - walk_tree (&TREE_OPERAND (t, 0), convert_local_reference, wi, NULL); - wi->val_only = true; - walk_tree (&TREE_OPERAND (t, 2), convert_local_reference, wi, NULL); - break; - case ARRAY_REF: case ARRAY_RANGE_REF: - wi->val_only = false; - walk_tree (&TREE_OPERAND (t, 0), convert_local_reference, wi, NULL); - wi->val_only = true; - walk_tree (&TREE_OPERAND (t, 1), convert_local_reference, wi, NULL); - walk_tree (&TREE_OPERAND (t, 2), convert_local_reference, wi, NULL); - walk_tree (&TREE_OPERAND (t, 3), convert_local_reference, wi, NULL); - break; - case BIT_FIELD_REF: - wi->val_only = false; - walk_tree (&TREE_OPERAND (t, 0), convert_local_reference, wi, NULL); + /* Go down this entire nest and just look at the final prefix and + anything that describes the references. Otherwise, we lose track + of whether a NOP_EXPR or VIEW_CONVERT_EXPR needs a simple value. */ wi->val_only = true; - walk_tree (&TREE_OPERAND (t, 1), convert_local_reference, wi, NULL); - walk_tree (&TREE_OPERAND (t, 2), convert_local_reference, wi, NULL); + for (; handled_component_p (t) + || TREE_CODE (t) == REALPART_EXPR || TREE_CODE (t) == IMAGPART_EXPR; + tp = &TREE_OPERAND (t, 0), t = *tp) + { + if (TREE_CODE (t) == COMPONENT_REF) + walk_tree (&TREE_OPERAND (t, 2), convert_local_reference, wi, + NULL); + else if (TREE_CODE (t) == ARRAY_REF + || TREE_CODE (t) == ARRAY_RANGE_REF) + { + walk_tree (&TREE_OPERAND (t, 1), convert_local_reference, wi, + NULL); + walk_tree (&TREE_OPERAND (t, 2), convert_local_reference, wi, + NULL); + walk_tree (&TREE_OPERAND (t, 3), convert_local_reference, wi, + NULL); + } + else if (TREE_CODE (t) == BIT_FIELD_REF) + { + walk_tree (&TREE_OPERAND (t, 1), convert_local_reference, wi, + NULL); + walk_tree (&TREE_OPERAND (t, 2), convert_local_reference, wi, + NULL); + } + } + wi->val_only = false; + walk_tree (tp, convert_local_reference, wi, NULL); break; default: |