summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorzack <zack@138bc75d-0d04-0410-961f-82ee72b054a4>2000-05-06 17:29:59 +0000
committerzack <zack@138bc75d-0d04-0410-961f-82ee72b054a4>2000-05-06 17:29:59 +0000
commitb08026c3c2ae119a54863b35c588bb2926b06c4e (patch)
tree48b84eb692491d6afc688da0f6de4f0619bc5fc4
parente19a3988fb08fbd14d20c712dc3193826d022430 (diff)
downloadgcc-b08026c3c2ae119a54863b35c588bb2926b06c4e.tar.gz
* com.c (ffecom_overlap_): Set source_offset to
bitsize_zero_node. (ffecom_tree_canonize_ptr_): Use size_binop. Convert to bitsizetype before multiplying by TYPE_SIZE. (ffecom_tree_canonize_ref_) [case ARRAY_REF]: Break up offset calculation. Convert to bitsizetype before multiplying by TYPE_SIZE. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@33730 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/f/ChangeLog10
-rw-r--r--gcc/f/com.c31
2 files changed, 25 insertions, 16 deletions
diff --git a/gcc/f/ChangeLog b/gcc/f/ChangeLog
index 854802cf206..5c95ba177e6 100644
--- a/gcc/f/ChangeLog
+++ b/gcc/f/ChangeLog
@@ -1,3 +1,13 @@
+2000-05-06 Zack Weinberg <zack@wolery.cumb.org>
+
+ * com.c (ffecom_overlap_): Set source_offset to
+ bitsize_zero_node.
+ (ffecom_tree_canonize_ptr_): Use size_binop. Convert to
+ bitsizetype before multiplying by TYPE_SIZE.
+ (ffecom_tree_canonize_ref_) [case ARRAY_REF]: Break up offset
+ calculation. Convert to bitsizetype before multiplying by
+ TYPE_SIZE.
+
2000-04-18 Zack Weinberg <zack@wolery.cumb.org>
* lex.c: Remove references to cccp.c.
diff --git a/gcc/f/com.c b/gcc/f/com.c
index 5fd24823012..d1ddd622dec 100644
--- a/gcc/f/com.c
+++ b/gcc/f/com.c
@@ -1712,7 +1712,7 @@ ffecom_overlap_ (tree dest_decl, tree dest_offset, tree dest_size,
return TRUE;
source_decl = source_tree;
- source_offset = size_zero_node;
+ source_offset = bitsize_zero_node;
source_size = TYPE_SIZE (TREE_TYPE (TREE_TYPE (source_tree)));
break;
@@ -9086,9 +9086,9 @@ ffecom_tree_canonize_ptr_ (tree *decl, tree *offset,
*offset, TREE_OPERAND (t, 1)));
/* Convert offset (presumably in bytes) into canonical units
(presumably bits). */
- *offset = fold (build (MULT_EXPR, TREE_TYPE (*offset),
- TYPE_SIZE (TREE_TYPE (TREE_TYPE (t))),
- *offset));
+ *offset = size_binop (MULT_EXPR,
+ convert (bitsizetype, *offset),
+ TYPE_SIZE (TREE_TYPE (TREE_TYPE (t))));
break;
}
/* Not a COMMON reference, so an unrecognized pattern. */
@@ -9249,18 +9249,17 @@ ffecom_tree_canonize_ref_ (tree *decl, tree *offset,
|| (*decl == error_mark_node))
return;
- *offset
- = size_binop (MULT_EXPR,
- TYPE_SIZE (TREE_TYPE (TREE_TYPE (array))),
- convert (sizetype,
- fold (build (MINUS_EXPR, TREE_TYPE (element),
- element,
- TYPE_MIN_VALUE
- (TYPE_DOMAIN
- (TREE_TYPE (array)))))));;
-
- *offset = size_binop (PLUS_EXPR, convert (sizetype, init_offset),
- *offset);
+ /* Calculate ((element - base) * NBBY) + init_offset. */
+ *offset = fold (build (MINUS_EXPR, TREE_TYPE (element),
+ element,
+ TYPE_MIN_VALUE (TYPE_DOMAIN
+ (TREE_TYPE (array)))));
+
+ *offset = size_binop (MULT_EXPR,
+ convert (bitsizetype, *offset),
+ TYPE_SIZE (TREE_TYPE (TREE_TYPE (array))));
+
+ *offset = size_binop (PLUS_EXPR, init_offset, *offset);
*size = TYPE_SIZE (TREE_TYPE (t));
return;