Commit fc3f36f9 by Michael Meissner Committed by Michael Meissner

re PR target/72717 (ICE: in emit_move_insn, at expr.c:3693 with vector shift @ powerpc64le)

[gcc]
2016-12-07  Michael Meissner  <meissner@linux.vnet.ibm.com>

	PR target/72717
	* config/rs6000/rs6000.c (rs6000_expand_vector_init): If the
	V2DImode elements are SUBREG's convert the result into DImode
	rather than failing in emit_move_insn.

[gcc/testsuite]
2016-12-07  Michael Meissner  <meissner@linux.vnet.ibm.com>

	PR target/72717
	* gcc.target/powerpc/pr72717.c: New test.

From-SVN: r243418
parent 18697a1d
2016-12-07 Michael Meissner <meissner@linux.vnet.ibm.com>
PR target/72717
* config/rs6000/rs6000.c (rs6000_expand_vector_init): If the
V2DImode elements are SUBREG's convert the result into DImode
rather than failing in emit_move_insn.
2016-12-07 Jakub Jelinek <jakub@redhat.com> 2016-12-07 Jakub Jelinek <jakub@redhat.com>
* builtins.c (fold_builtin_strstr): Removed. * builtins.c (fold_builtin_strstr): Removed.
...@@ -6891,25 +6891,43 @@ rs6000_expand_vector_init (rtx target, rtx vals) ...@@ -6891,25 +6891,43 @@ rs6000_expand_vector_init (rtx target, rtx vals)
/* Double word values on VSX can use xxpermdi or lxvdsx. */ /* Double word values on VSX can use xxpermdi or lxvdsx. */
if (VECTOR_MEM_VSX_P (mode) && (mode == V2DFmode || mode == V2DImode)) if (VECTOR_MEM_VSX_P (mode) && (mode == V2DFmode || mode == V2DImode))
{ {
rtx op0 = XVECEXP (vals, 0, 0); rtx op[2];
rtx op1 = XVECEXP (vals, 0, 1); size_t i;
size_t num_elements = all_same ? 1 : 2;
for (i = 0; i < num_elements; i++)
{
op[i] = XVECEXP (vals, 0, i);
/* Just in case there is a SUBREG with a smaller mode, do a
conversion. */
if (GET_MODE (op[i]) != inner_mode)
{
rtx tmp = gen_reg_rtx (inner_mode);
convert_move (tmp, op[i], 0);
op[i] = tmp;
}
/* Allow load with splat double word. */
else if (MEM_P (op[i]))
{
if (!all_same)
op[i] = force_reg (inner_mode, op[i]);
}
else if (!REG_P (op[i]))
op[i] = force_reg (inner_mode, op[i]);
}
if (all_same) if (all_same)
{ {
if (!MEM_P (op0) && !REG_P (op0))
op0 = force_reg (inner_mode, op0);
if (mode == V2DFmode) if (mode == V2DFmode)
emit_insn (gen_vsx_splat_v2df (target, op0)); emit_insn (gen_vsx_splat_v2df (target, op[0]));
else else
emit_insn (gen_vsx_splat_v2di (target, op0)); emit_insn (gen_vsx_splat_v2di (target, op[0]));
} }
else else
{ {
op0 = force_reg (inner_mode, op0);
op1 = force_reg (inner_mode, op1);
if (mode == V2DFmode) if (mode == V2DFmode)
emit_insn (gen_vsx_concat_v2df (target, op0, op1)); emit_insn (gen_vsx_concat_v2df (target, op[0], op[1]));
else else
emit_insn (gen_vsx_concat_v2di (target, op0, op1)); emit_insn (gen_vsx_concat_v2di (target, op[0], op[1]));
} }
return; return;
} }
2016-12-07 Michael Meissner <meissner@linux.vnet.ibm.com>
PR target/72717
* gcc.target/powerpc/pr72717.c: New test.
2016-12-07 Jakub Jelinek <jakub@redhat.com> 2016-12-07 Jakub Jelinek <jakub@redhat.com>
* gcc.dg/builtin-strstr-1.c: New test. * gcc.dg/builtin-strstr-1.c: New test.
......
/* { dg-do compile { target { powerpc*-*-* && lp64 } } } */
/* { dg-skip-if "" { powerpc*-*-darwin* } { "*" } { "" } } */
/* { dg-require-effective-target powerpc_p8vector_ok } */
/* { dg-skip-if "do not override -mcpu" { powerpc*-*-* } { "-mcpu=*" } { "-mcpu=power8" } } */
/* { dg-options "-mcpu=power8 -O2" } */
typedef long V __attribute__((__vector_size__(32)));
extern void foo (V *, V*);
/* This test generated an failure in emit_move_insn. */
void
foo(V *p, V *q)
{
V v = *q;
*p = v << v[0];
}
/* { dg-final { scan-assembler-times "vsld" 2 } } */
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