aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Henderson <rth@redhat.com>2004-10-27 20:53:31 -0700
committerRichard Henderson <rth@gcc.gnu.org>2004-10-27 20:53:31 -0700
commit0da34ce409cd62755c3546f40693ee596cffddb2 (patch)
tree01a9cab8c12cb9fbb2c7a60440fb3166ce7f48d0 /gcc
parent744e6f334d1a62657c08aa8ef3b919ba9af808e0 (diff)
downloadgcc-0da34ce409cd62755c3546f40693ee596cffddb2.zip
gcc-0da34ce409cd62755c3546f40693ee596cffddb2.tar.gz
gcc-0da34ce409cd62755c3546f40693ee596cffddb2.tar.bz2
re PR middle-end/18163 (libffi test case ICE's on darwin)
PR middle-end/18163 * expr.c (emit_group_load): Don't go force temporary for memory or concat source. (emit_group_store): Similarly. From-SVN: r89735
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/expr.c6
2 files changed, 11 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 3b4ccf2..59a3794 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2004-10-27 Richard Henderson <rth@redhat.com>
+
+ PR middle-end/18163
+ * expr.c (emit_group_load): Don't go force temporary for memory
+ or concat source.
+ (emit_group_store): Similarly.
+
2004-10-27 Andrew Pinski <pinskia@physics.uc.edu>
PR other/18186
diff --git a/gcc/expr.c b/gcc/expr.c
index f5abce7..bc19bc1 100644
--- a/gcc/expr.c
+++ b/gcc/expr.c
@@ -1571,7 +1571,8 @@ emit_group_load (rtx dst, rtx orig_src, tree type ATTRIBUTE_UNUSED, int ssize)
gcc_assert (GET_CODE (dst) == PARALLEL);
- if (!SCALAR_INT_MODE_P (m) && m != BLKmode)
+ if (!SCALAR_INT_MODE_P (m)
+ && !MEM_P (orig_src) && GET_CODE (orig_src) != CONCAT)
{
enum machine_mode imode = int_mode_for_mode (GET_MODE (orig_src));
if (imode == BLKmode)
@@ -1745,7 +1746,8 @@ emit_group_store (rtx orig_dst, rtx src, tree type ATTRIBUTE_UNUSED, int ssize)
gcc_assert (GET_CODE (src) == PARALLEL);
- if (!SCALAR_INT_MODE_P (m) && m != BLKmode)
+ if (!SCALAR_INT_MODE_P (m)
+ && !MEM_P (orig_dst) && GET_CODE (orig_dst) != CONCAT)
{
enum machine_mode imode = int_mode_for_mode (GET_MODE (orig_dst));
if (imode == BLKmode)