Commit 9c0631a7 by Aldy Hernandez Committed by Aldy Hernandez

expr.c (emit_group_load): Dump parallels of simd types to memory.

2003-04-29  Aldy Hernandez  <aldyh@redhat.com>

        * expr.c (emit_group_load): Dump parallels of simd types to
        memory.

From-SVN: r66280
parent 95b588cf
2003-04-29 Aldy Hernandez <aldyh@redhat.com>
* expr.c (emit_group_load): Dump parallels of simd types to
memory.
2003-04-29 Vladimir Makarov <vmakarov@redhat.com> 2003-04-29 Vladimir Makarov <vmakarov@redhat.com>
* genautomata.c (add_vect): Check undefined value for range type * genautomata.c (add_vect): Check undefined value for range type
......
...@@ -2363,6 +2363,19 @@ emit_group_load (dst, orig_src, ssize) ...@@ -2363,6 +2363,19 @@ emit_group_load (dst, orig_src, ssize)
else else
abort (); abort ();
} }
/* FIXME: A SIMD parallel will eventually lead to a subreg of a
SIMD register, which is currently broken. While we get GCC
to emit proper RTL for these cases, let's dump to memory. */
else if (VECTOR_MODE_P (GET_MODE (dst))
&& GET_CODE (src) == REG)
{
int slen = GET_MODE_SIZE (GET_MODE (src));
rtx mem;
mem = assign_stack_temp (GET_MODE (src), slen, 0);
emit_move_insn (mem, src);
tmps[i] = adjust_address (mem, mode, (int) bytepos);
}
else if (CONSTANT_P (src) else if (CONSTANT_P (src)
|| (GET_CODE (src) == REG && GET_MODE (src) == mode)) || (GET_CODE (src) == REG && GET_MODE (src) == mode))
tmps[i] = src; tmps[i] = src;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment