aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Henderson <rth@redhat.com>2005-01-26 15:21:45 -0800
committerRichard Henderson <rth@gcc.gnu.org>2005-01-26 15:21:45 -0800
commiteec6bb06c65297a56eeff3c6bd8e4b31fec554bb (patch)
treec828ac0ac89a98ec49d783702a5abcc79e0be758
parent78ef1e3d9fbe214ead3c117ec54a5c10da91a0df (diff)
downloadgcc-eec6bb06c65297a56eeff3c6bd8e4b31fec554bb.zip
gcc-eec6bb06c65297a56eeff3c6bd8e4b31fec554bb.tar.gz
gcc-eec6bb06c65297a56eeff3c6bd8e4b31fec554bb.tar.bz2
Revert last change.
From-SVN: r94291
-rw-r--r--gcc/ChangeLog4
-rw-r--r--gcc/c-decl.c7
-rw-r--r--gcc/expmed.c2
-rw-r--r--gcc/expr.c16
4 files changed, 8 insertions, 21 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 7b5f4dc..2885274 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,9 @@
2005-01-26 Richard Henderson <rth@redhat.com>
+ * c-decl.c, expmed.c, expr.c: Revert last change.
+
+2005-01-26 Richard Henderson <rth@redhat.com>
+
PR middle-end/18008
* c-decl.c (finish_struct): Set DECL_MODE after resetting a
field's type.
diff --git a/gcc/c-decl.c b/gcc/c-decl.c
index 61521e8..6673927 100644
--- a/gcc/c-decl.c
+++ b/gcc/c-decl.c
@@ -5301,11 +5301,8 @@ finish_struct (tree t, tree fieldlist, tree attributes)
= tree_low_cst (DECL_INITIAL (*fieldlistp), 1);
tree type = TREE_TYPE (*fieldlistp);
if (width != TYPE_PRECISION (type))
- {
- TREE_TYPE (*fieldlistp)
- = build_nonstandard_integer_type (width, TYPE_UNSIGNED (type));
- DECL_MODE (*fieldlistp) = TYPE_MODE (TREE_TYPE (*fieldlistp));
- }
+ TREE_TYPE (*fieldlistp)
+ = build_nonstandard_integer_type (width, TYPE_UNSIGNED (type));
DECL_INITIAL (*fieldlistp) = 0;
}
else
diff --git a/gcc/expmed.c b/gcc/expmed.c
index 084a987..1091c45 100644
--- a/gcc/expmed.c
+++ b/gcc/expmed.c
@@ -878,7 +878,7 @@ store_fixed_bit_field (rtx op0, unsigned HOST_WIDE_INT offset,
if (GET_MODE (value) != mode)
{
if ((REG_P (value) || GET_CODE (value) == SUBREG)
- && GET_MODE_SIZE (GET_MODE (value)) <= bitsize)
+ && GET_MODE_SIZE (mode) < GET_MODE_SIZE (GET_MODE (value)))
value = gen_lowpart (mode, value);
else
value = convert_to_mode (mode, value, 1);
diff --git a/gcc/expr.c b/gcc/expr.c
index 1f82b1d..ed693a3 100644
--- a/gcc/expr.c
+++ b/gcc/expr.c
@@ -5215,21 +5215,7 @@ store_field (rtx target, HOST_WIDE_INT bitsize, HOST_WIDE_INT bitpos,
&& TREE_CODE (TYPE_SIZE (TREE_TYPE (exp))) == INTEGER_CST
&& compare_tree_int (TYPE_SIZE (TREE_TYPE (exp)), bitsize) != 0))
{
- rtx temp;
-
- /* If EXP is a NOP_EXPR of precision less than its mode, then that
- implies a mask operation. If the precision is the same size as
- the field we're storing into, that mask is redundant. This is
- particularly common with bit field assignments generated by the
- C front end. */
- if (TREE_CODE (exp) == NOP_EXPR
- && INTEGRAL_TYPE_P (TREE_TYPE (exp))
- && (TYPE_PRECISION (TREE_TYPE (exp))
- < GET_MODE_BITSIZE (TYPE_MODE (TREE_TYPE (exp))))
- && bitsize == TYPE_PRECISION (TREE_TYPE (exp)))
- exp = TREE_OPERAND (exp, 0);
-
- temp = expand_expr (exp, NULL_RTX, VOIDmode, 0);
+ rtx temp = expand_expr (exp, NULL_RTX, VOIDmode, 0);
/* If BITSIZE is narrower than the size of the type of EXP
we will be narrowing TEMP. Normally, what's wanted are the