From e5f9d91646f6ee51ab0e029dc315abc29716397a Mon Sep 17 00:00:00 2001 From: Aldy Hernandez Date: Mon, 15 Nov 2004 20:20:09 +0000 Subject: [PATCH] altivec.md ("altivec_vsplth"): Rewrite with vec_duplicate. * config/rs6000/altivec.md ("altivec_vsplth"): Rewrite with vec_duplicate. (altivec_vspltb): Same. (altivec_vspltw): Same. (altivec_vspltisb): Same. (altivec_vspltish): Same. (altivec_vspltisw): Same. (altivec_vspltisw_v4sf): Same. (define_constants): Remove UNSPEC_VSPLTISB, UNSPEC_VSPLTISW, UNSPEC_VSPLTISH. Move "End of vector xor's" comment to the right place. From-SVN: r90683 --- gcc/ChangeLog | 14 ++++++++++++ gcc/config/rs6000/altivec.md | 41 ++++++++++++++++++++---------------- 2 files changed, 37 insertions(+), 18 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index b418029ef28..ccb32736fec 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,17 @@ +2004-11-15 Aldy Hernandez + + * config/rs6000/altivec.md ("altivec_vsplth"): Rewrite with + vec_duplicate. + (altivec_vspltb): Same. + (altivec_vspltw): Same. + (altivec_vspltisb): Same. + (altivec_vspltish): Same. + (altivec_vspltisw): Same. + (altivec_vspltisw_v4sf): Same. + (define_constants): Remove UNSPEC_VSPLTISB, UNSPEC_VSPLTISW, + UNSPEC_VSPLTISH. + Move "End of vector xor's" comment to the right place. + 2004-11-15 Steve Ellcey * config/ia64/ia64.md (*movtf_internal): Use destination_operand diff --git a/gcc/config/rs6000/altivec.md b/gcc/config/rs6000/altivec.md index 17866a9131e..8a76681a38b 100644 --- a/gcc/config/rs6000/altivec.md +++ b/gcc/config/rs6000/altivec.md @@ -20,10 +20,7 @@ ;; MA 02111-1307, USA. (define_constants - [(UNSPEC_VSPLTISW 141) - (UNSPEC_VSPLTISH 140) - (UNSPEC_VSPLTISB 139) - (UNSPEC_VCMPBFP 50) + [(UNSPEC_VCMPBFP 50) (UNSPEC_VCMPEQUB 51) (UNSPEC_VCMPEQUH 52) (UNSPEC_VCMPEQUW 53) @@ -1494,59 +1491,67 @@ "TARGET_ALTIVEC" "vxor %0,%1,%2" [(set_attr "type" "vecsimple")]) +;; End of vector xor's (define_insn "altivec_vspltb" [(set (match_operand:V16QI 0 "register_operand" "=v") - (unspec:V16QI [(match_operand:V16QI 1 "register_operand" "v") - (match_operand:QI 2 "immediate_operand" "i")] 136))] + (vec_duplicate:V16QI + (vec_select:QI (match_operand:V16QI 1 "register_operand" "v") + (parallel + [(match_operand:QI 2 "immediate_operand" "i")]))))] "TARGET_ALTIVEC" "vspltb %0,%1,%2" [(set_attr "type" "vecperm")]) -;; End of vector xor's (define_insn "altivec_vsplth" [(set (match_operand:V8HI 0 "register_operand" "=v") - (unspec:V8HI [(match_operand:V8HI 1 "register_operand" "v") - (match_operand:QI 2 "immediate_operand" "i")] 137))] + (vec_duplicate:V8HI + (vec_select:HI (match_operand:V8HI 1 "register_operand" "v") + (parallel + [(match_operand:QI 2 "immediate_operand" "i")]))))] "TARGET_ALTIVEC" "vsplth %0,%1,%2" [(set_attr "type" "vecperm")]) (define_insn "altivec_vspltw" [(set (match_operand:V4SI 0 "register_operand" "=v") - (unspec:V4SI [(match_operand:V4SI 1 "register_operand" "v") - (match_operand:QI 2 "immediate_operand" "i")] 138))] + (vec_duplicate:V4SI + (vec_select:SI (match_operand:V4SI 1 "register_operand" "v") + (parallel + [(match_operand:QI 2 "immediate_operand" "i")]))))] "TARGET_ALTIVEC" "vspltw %0,%1,%2" [(set_attr "type" "vecperm")]) (define_insn "altivec_vspltisb" [(set (match_operand:V16QI 0 "register_operand" "=v") - (unspec:V16QI [(match_operand:QI 1 "immediate_operand" "i")] - UNSPEC_VSPLTISB))] + (vec_duplicate:V16QI + (match_operand:QI 1 "immediate_operand" "i")))] "TARGET_ALTIVEC" "vspltisb %0,%1" [(set_attr "type" "vecperm")]) (define_insn "altivec_vspltish" [(set (match_operand:V8HI 0 "register_operand" "=v") - (unspec:V8HI [(match_operand:QI 1 "immediate_operand" "i")] - UNSPEC_VSPLTISH))] + (vec_duplicate:V8HI + (sign_extend:HI (match_operand:QI 1 "immediate_operand" "i"))))] "TARGET_ALTIVEC" "vspltish %0,%1" [(set_attr "type" "vecperm")]) (define_insn "altivec_vspltisw" [(set (match_operand:V4SI 0 "register_operand" "=v") - (unspec:V4SI [(match_operand:QI 1 "immediate_operand" "i")] - UNSPEC_VSPLTISW))] + (vec_duplicate:V4SI + (sign_extend:SI (match_operand:QI 1 "immediate_operand" "i"))))] "TARGET_ALTIVEC" "vspltisw %0,%1" [(set_attr "type" "vecperm")]) (define_insn "altivec_vspltisw_v4sf" [(set (match_operand:V4SF 0 "register_operand" "=v") - (unspec:V4SF [(match_operand:QI 1 "immediate_operand" "i")] 142))] + (vec_duplicate:V4SF + (float:SF (sign_extend:SI + (match_operand:QI 1 "immediate_operand" "i")))))] "TARGET_ALTIVEC" "vspltisw %0,%1" [(set_attr "type" "vecperm")]) -- 2.30.2