aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAldy Hernandez <aldyh@redhat.com>2004-10-26 23:17:57 +0000
committerAldy Hernandez <aldyh@gcc.gnu.org>2004-10-26 23:17:57 +0000
commit7ef7000b5fa205310cebf717088fd021370365c3 (patch)
tree969be6cdf8e58e2b1c6464d76816b2d8aa1ad641
parenta6cb7068eb8b15fc807aeb5051ede637e92d033b (diff)
downloadgcc-7ef7000b5fa205310cebf717088fd021370365c3.zip
gcc-7ef7000b5fa205310cebf717088fd021370365c3.tar.gz
gcc-7ef7000b5fa205310cebf717088fd021370365c3.tar.bz2
expr.c (emit_group_store): Do not treat floats as BLKmode.
* expr.c (emit_group_store): Do not treat floats as BLKmode. (emit_group_load): Same. From-SVN: r89612
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/expr.c6
2 files changed, 9 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 2851099..ae5616c 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2004-10-26 Aldy Hernandez <aldyh@redhat.com>
+
+ * expr.c (emit_group_store): Do not treat floats as BLKmode.
+ (emit_group_load): Same.
+
2004-10-26 Joseph S. Myers <jsm@polyomino.org.uk>
* c-parse.in (datadef): Use pedwarn rather than error and warning
diff --git a/gcc/expr.c b/gcc/expr.c
index e71c22f..f5abce7 100644
--- a/gcc/expr.c
+++ b/gcc/expr.c
@@ -1567,10 +1567,11 @@ emit_group_load (rtx dst, rtx orig_src, tree type ATTRIBUTE_UNUSED, int ssize)
{
rtx *tmps, src;
int start, i;
+ enum machine_mode m = GET_MODE (orig_src);
gcc_assert (GET_CODE (dst) == PARALLEL);
- if (!SCALAR_INT_MODE_P (GET_MODE (orig_src)))
+ if (!SCALAR_INT_MODE_P (m) && m != BLKmode)
{
enum machine_mode imode = int_mode_for_mode (GET_MODE (orig_src));
if (imode == BLKmode)
@@ -1740,10 +1741,11 @@ emit_group_store (rtx orig_dst, rtx src, tree type ATTRIBUTE_UNUSED, int ssize)
{
rtx *tmps, dst;
int start, i;
+ enum machine_mode m = GET_MODE (orig_dst);
gcc_assert (GET_CODE (src) == PARALLEL);
- if (!SCALAR_INT_MODE_P (GET_MODE (orig_dst)))
+ if (!SCALAR_INT_MODE_P (m) && m != BLKmode)
{
enum machine_mode imode = int_mode_for_mode (GET_MODE (orig_dst));
if (imode == BLKmode)