re PR target/66033 (rs6000 nops removed by rtl_dce)
authorAlan Modra <amodra@gmail.com>
Wed, 6 May 2015 13:12:19 +0000 (22:42 +0930)
committerAlan Modra <amodra@gcc.gnu.org>
Wed, 6 May 2015 13:12:19 +0000 (22:42 +0930)
PR target/66033
* config/rs6000/rs6000.md (nop): Use an unspec pattern.
(UNSPEC_NOP): Define.
(reload_vsx_from_gpr<mode>): Add missing DONE.
(reload_gpr_from_vsx<mode>): Likewise.
* config/rs6000/vsx.md (vsx_mul_v2di): Likewise.
(vsx_div_v2di, vsx_udiv_v2di): Likewise.

From-SVN: r222851

gcc/ChangeLog
gcc/config/rs6000/rs6000.md
gcc/config/rs6000/vsx.md

index 07ea864db7b8d5c3f046a753a5d0de0cd935942d..24b40750898957657d6982b02ae878e5fcd44828 100644 (file)
@@ -1,3 +1,13 @@
+2015-05-06  Alan Modra  <amodra@gmail.com>
+
+       PR target/66033
+       * config/rs6000/rs6000.md (nop): Use an unspec pattern.
+       (UNSPEC_NOP): Define.
+       (reload_vsx_from_gpr<mode>): Add missing DONE.
+       (reload_gpr_from_vsx<mode>): Likewise.
+       * config/rs6000/vsx.md (vsx_mul_v2di): Likewise.
+       (vsx_div_v2di, vsx_udiv_v2di): Likewise.
+
 2015-05-06  Christian Bruel  <christian.bruel@st.com>
 
        PR target/66015
index 0178bf45b001332456ddd8e5ca895ea46323ab2b..2d15d71cc8881337ea691c19932d486ba91d3111 100644 (file)
    UNSPEC_LFIWAX
    UNSPEC_LFIWZX
    UNSPEC_FCTIWUZ
+   UNSPEC_NOP
    UNSPEC_GRP_END_NOP
    UNSPEC_P8V_FMRGOW
    UNSPEC_P8V_MTVSRWZ
   emit_insn (gen_p8_mtvsrd_1 (tmp, gpr_hi_reg));
   emit_insn (gen_p8_mtvsrd_2 (tmp, gpr_lo_reg));
   emit_insn (gen_p8_xxpermdi_<mode> (dest, tmp));
+  DONE;
 }
   [(set_attr "length" "12")
    (set_attr "type" "three")])
   emit_insn (gen_p8_mfvsrd_3_<mode> (gpr_hi_reg, src));
   emit_insn (gen_vsx_xxpermdi_<mode> (tmp, src, src, GEN_INT (3)));
   emit_insn (gen_p8_mfvsrd_3_<mode> (gpr_lo_reg, tmp));
+  DONE;
 }
   [(set_attr "length" "12")
    (set_attr "type" "three")])
   [(set_attr "type" "jmpreg")])
 
 (define_insn "nop"
-  [(const_int 0)]
+  [(unspec [(const_int 0)] UNSPEC_NOP)]
   ""
   "nop")
 
index 2988c7286465e11cc5f0be3706012187c68fcca8..787f96ae245e38a0e4ec1b53aa7360350da5c953 100644 (file)
   emit_insn (gen_vsx_extract_v2di (op4, op2, GEN_INT (1)));
   emit_insn (gen_muldi3 (op3, op3, op4));
   emit_insn (gen_vsx_concat_v2di (op0, op5, op3));
+  DONE;
 }"
   [(set_attr "type" "mul")])
 
   emit_insn (gen_vsx_extract_v2di (op4, op2, GEN_INT (1)));
   emit_insn (gen_divdi3 (op3, op3, op4));
   emit_insn (gen_vsx_concat_v2di (op0, op5, op3));
+  DONE;
 }"
   [(set_attr "type" "div")])
 
   emit_insn (gen_vsx_extract_v2di (op4, op2, GEN_INT (1)));
   emit_insn (gen_udivdi3 (op3, op3, op4));
   emit_insn (gen_vsx_concat_v2di (op0, op5, op3));
+  DONE;
 }"
   [(set_attr "type" "div")])