rs6000.c (rs6000_emit_vector_select): Fix vector select operand ordering.
authorDevang Patel <dpatel@apple.com>
Mon, 11 Apr 2005 19:47:44 +0000 (12:47 -0700)
committerDevang Patel <dpatel@gcc.gnu.org>
Mon, 11 Apr 2005 19:47:44 +0000 (12:47 -0700)
       * config/rs6000.c (rs6000_emit_vector_select): Fix vector select
       operand ordering.

From-SVN: r97981

gcc/ChangeLog
gcc/config/rs6000/rs6000.c

index 5ccf583..0818b49 100644 (file)
@@ -1,3 +1,8 @@
+2005-04-11  Devang Patel  <dpatel@apple.com>
+
+       * config/rs6000.c (rs6000_emit_vector_select): Fix vector select
+       operand ordering.
+       
 2005-04-11  Andrew Pinski  <pinskia@physics.uc.edu>
 
        * fold-const.c (fold_binary_op_with_conditional_arg):
index 4bbe702..e3b5cfa 100644 (file)
@@ -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);