From: Devang Patel Date: Mon, 11 Apr 2005 19:47:44 +0000 (-0700) Subject: rs6000.c (rs6000_emit_vector_select): Fix vector select operand ordering. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=19f1ebc794e936ef25955c0404e6dac505e6e41e;p=gcc.git rs6000.c (rs6000_emit_vector_select): Fix vector select operand ordering. * config/rs6000.c (rs6000_emit_vector_select): Fix vector select operand ordering. From-SVN: r97981 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 5ccf583e483..0818b493467 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2005-04-11 Devang Patel + + * config/rs6000.c (rs6000_emit_vector_select): Fix vector select + operand ordering. + 2005-04-11 Andrew Pinski * fold-const.c (fold_binary_op_with_conditional_arg): diff --git a/gcc/config/rs6000/rs6000.c b/gcc/config/rs6000/rs6000.c index 4bbe70279f7..e3b5cfa14c6 100644 --- a/gcc/config/rs6000/rs6000.c +++ b/gcc/config/rs6000/rs6000.c @@ -10676,9 +10676,11 @@ rs6000_emit_vector_select (rtx dest, rtx op1, rtx op2, rtx mask) temp = gen_reg_rtx (dest_mode); + /* For each vector element, select op1 when mask is 1 otherwise + select op2. */ t = gen_rtx_fmt_ee (SET, VOIDmode, temp, gen_rtx_fmt_Ei (UNSPEC, dest_mode, - gen_rtvec (3, op1, op2, mask), + gen_rtvec (3, op2, op1, mask), vsel_insn_index)); emit_insn (t); emit_move_insn (dest, temp);