PPCInstrAltivec.td revision 276479
1234353Sdim//===-- PPCInstrAltivec.td - The PowerPC Altivec Extension -*- tablegen -*-===// 2234353Sdim// 3193323Sed// The LLVM Compiler Infrastructure 4193323Sed// 5193323Sed// This file is distributed under the University of Illinois Open Source 6193323Sed// License. See LICENSE.TXT for details. 7234353Sdim// 8193323Sed//===----------------------------------------------------------------------===// 9193323Sed// 10193323Sed// This file describes the Altivec extension to the PowerPC instruction set. 11193323Sed// 12193323Sed//===----------------------------------------------------------------------===// 13193323Sed 14193323Sed//===----------------------------------------------------------------------===// 15193323Sed// Altivec transformation functions and pattern fragments. 16193323Sed// 17193323Sed 18206083Srdivacky// Since we canonicalize buildvectors to v16i8, all vnots "-1" operands will be 19206083Srdivacky// of that type. 20206083Srdivackydef vnot_ppc : PatFrag<(ops node:$in), 21206083Srdivacky (xor node:$in, (bitconvert (v16i8 immAllOnesV)))>; 22193323Sed 23193323Seddef vpkuhum_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 24193323Sed (vector_shuffle node:$lhs, node:$rhs), [{ 25276479Sdim return PPC::isVPKUHUMShuffleMask(cast<ShuffleVectorSDNode>(N), 0, *CurDAG); 26193323Sed}]>; 27193323Seddef vpkuwum_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 28193323Sed (vector_shuffle node:$lhs, node:$rhs), [{ 29276479Sdim return PPC::isVPKUWUMShuffleMask(cast<ShuffleVectorSDNode>(N), 0, *CurDAG); 30193323Sed}]>; 31193323Seddef vpkuhum_unary_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 32193323Sed (vector_shuffle node:$lhs, node:$rhs), [{ 33276479Sdim return PPC::isVPKUHUMShuffleMask(cast<ShuffleVectorSDNode>(N), 1, *CurDAG); 34193323Sed}]>; 35193323Seddef vpkuwum_unary_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 36193323Sed (vector_shuffle node:$lhs, node:$rhs), [{ 37276479Sdim return PPC::isVPKUWUMShuffleMask(cast<ShuffleVectorSDNode>(N), 1, *CurDAG); 38193323Sed}]>; 39193323Sed 40276479Sdim// These fragments are provided for little-endian, where the inputs must be 41276479Sdim// swapped for correct semantics. 42276479Sdimdef vpkuhum_swapped_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 43276479Sdim (vector_shuffle node:$lhs, node:$rhs), [{ 44276479Sdim return PPC::isVPKUHUMShuffleMask(cast<ShuffleVectorSDNode>(N), 2, *CurDAG); 45276479Sdim}]>; 46276479Sdimdef vpkuwum_swapped_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 47276479Sdim (vector_shuffle node:$lhs, node:$rhs), [{ 48276479Sdim return PPC::isVPKUWUMShuffleMask(cast<ShuffleVectorSDNode>(N), 2, *CurDAG); 49276479Sdim}]>; 50193323Sed 51193323Seddef vmrglb_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 52204961Srdivacky (vector_shuffle (v16i8 node:$lhs), node:$rhs), [{ 53276479Sdim return PPC::isVMRGLShuffleMask(cast<ShuffleVectorSDNode>(N), 1, 0, *CurDAG); 54193323Sed}]>; 55193323Seddef vmrglh_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 56204961Srdivacky (vector_shuffle (v16i8 node:$lhs), node:$rhs), [{ 57276479Sdim return PPC::isVMRGLShuffleMask(cast<ShuffleVectorSDNode>(N), 2, 0, *CurDAG); 58193323Sed}]>; 59193323Seddef vmrglw_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 60204961Srdivacky (vector_shuffle (v16i8 node:$lhs), node:$rhs), [{ 61276479Sdim return PPC::isVMRGLShuffleMask(cast<ShuffleVectorSDNode>(N), 4, 0, *CurDAG); 62193323Sed}]>; 63193323Seddef vmrghb_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 64204961Srdivacky (vector_shuffle (v16i8 node:$lhs), node:$rhs), [{ 65276479Sdim return PPC::isVMRGHShuffleMask(cast<ShuffleVectorSDNode>(N), 1, 0, *CurDAG); 66193323Sed}]>; 67193323Seddef vmrghh_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 68204961Srdivacky (vector_shuffle (v16i8 node:$lhs), node:$rhs), [{ 69276479Sdim return PPC::isVMRGHShuffleMask(cast<ShuffleVectorSDNode>(N), 2, 0, *CurDAG); 70193323Sed}]>; 71193323Seddef vmrghw_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 72204961Srdivacky (vector_shuffle (v16i8 node:$lhs), node:$rhs), [{ 73276479Sdim return PPC::isVMRGHShuffleMask(cast<ShuffleVectorSDNode>(N), 4, 0, *CurDAG); 74193323Sed}]>; 75193323Sed 76193323Sed 77193323Seddef vmrglb_unary_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 78204961Srdivacky (vector_shuffle (v16i8 node:$lhs), node:$rhs), [{ 79276479Sdim return PPC::isVMRGLShuffleMask(cast<ShuffleVectorSDNode>(N), 1, 1, *CurDAG); 80193323Sed}]>; 81193323Seddef vmrglh_unary_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 82193323Sed (vector_shuffle node:$lhs, node:$rhs), [{ 83276479Sdim return PPC::isVMRGLShuffleMask(cast<ShuffleVectorSDNode>(N), 2, 1, *CurDAG); 84193323Sed}]>; 85193323Seddef vmrglw_unary_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 86193323Sed (vector_shuffle node:$lhs, node:$rhs), [{ 87276479Sdim return PPC::isVMRGLShuffleMask(cast<ShuffleVectorSDNode>(N), 4, 1, *CurDAG); 88193323Sed}]>; 89193323Seddef vmrghb_unary_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 90193323Sed (vector_shuffle node:$lhs, node:$rhs), [{ 91276479Sdim return PPC::isVMRGHShuffleMask(cast<ShuffleVectorSDNode>(N), 1, 1, *CurDAG); 92193323Sed}]>; 93193323Seddef vmrghh_unary_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 94193323Sed (vector_shuffle node:$lhs, node:$rhs), [{ 95276479Sdim return PPC::isVMRGHShuffleMask(cast<ShuffleVectorSDNode>(N), 2, 1, *CurDAG); 96193323Sed}]>; 97193323Seddef vmrghw_unary_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 98193323Sed (vector_shuffle node:$lhs, node:$rhs), [{ 99276479Sdim return PPC::isVMRGHShuffleMask(cast<ShuffleVectorSDNode>(N), 4, 1, *CurDAG); 100193323Sed}]>; 101193323Sed 102193323Sed 103276479Sdim// These fragments are provided for little-endian, where the inputs must be 104276479Sdim// swapped for correct semantics. 105276479Sdimdef vmrglb_swapped_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 106276479Sdim (vector_shuffle (v16i8 node:$lhs), node:$rhs), [{ 107276479Sdim return PPC::isVMRGLShuffleMask(cast<ShuffleVectorSDNode>(N), 1, 2, *CurDAG); 108276479Sdim}]>; 109276479Sdimdef vmrglh_swapped_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 110276479Sdim (vector_shuffle node:$lhs, node:$rhs), [{ 111276479Sdim return PPC::isVMRGLShuffleMask(cast<ShuffleVectorSDNode>(N), 2, 2, *CurDAG); 112276479Sdim}]>; 113276479Sdimdef vmrglw_swapped_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 114276479Sdim (vector_shuffle node:$lhs, node:$rhs), [{ 115276479Sdim return PPC::isVMRGLShuffleMask(cast<ShuffleVectorSDNode>(N), 4, 2, *CurDAG); 116276479Sdim}]>; 117276479Sdimdef vmrghb_swapped_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 118276479Sdim (vector_shuffle node:$lhs, node:$rhs), [{ 119276479Sdim return PPC::isVMRGHShuffleMask(cast<ShuffleVectorSDNode>(N), 1, 2, *CurDAG); 120276479Sdim}]>; 121276479Sdimdef vmrghh_swapped_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 122276479Sdim (vector_shuffle node:$lhs, node:$rhs), [{ 123276479Sdim return PPC::isVMRGHShuffleMask(cast<ShuffleVectorSDNode>(N), 2, 2, *CurDAG); 124276479Sdim}]>; 125276479Sdimdef vmrghw_swapped_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 126276479Sdim (vector_shuffle node:$lhs, node:$rhs), [{ 127276479Sdim return PPC::isVMRGHShuffleMask(cast<ShuffleVectorSDNode>(N), 4, 2, *CurDAG); 128276479Sdim}]>; 129276479Sdim 130276479Sdim 131193323Seddef VSLDOI_get_imm : SDNodeXForm<vector_shuffle, [{ 132276479Sdim return getI32Imm(PPC::isVSLDOIShuffleMask(N, 0, *CurDAG)); 133193323Sed}]>; 134193323Seddef vsldoi_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 135193323Sed (vector_shuffle node:$lhs, node:$rhs), [{ 136276479Sdim return PPC::isVSLDOIShuffleMask(N, 0, *CurDAG) != -1; 137193323Sed}], VSLDOI_get_imm>; 138193323Sed 139193323Sed 140193323Sed/// VSLDOI_unary* - These are used to match vsldoi(X,X), which is turned into 141193323Sed/// vector_shuffle(X,undef,mask) by the dag combiner. 142193323Seddef VSLDOI_unary_get_imm : SDNodeXForm<vector_shuffle, [{ 143276479Sdim return getI32Imm(PPC::isVSLDOIShuffleMask(N, 1, *CurDAG)); 144193323Sed}]>; 145193323Seddef vsldoi_unary_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 146193323Sed (vector_shuffle node:$lhs, node:$rhs), [{ 147276479Sdim return PPC::isVSLDOIShuffleMask(N, 1, *CurDAG) != -1; 148193323Sed}], VSLDOI_unary_get_imm>; 149193323Sed 150193323Sed 151276479Sdim/// VSLDOI_swapped* - These fragments are provided for little-endian, where 152276479Sdim/// the inputs must be swapped for correct semantics. 153276479Sdimdef VSLDOI_swapped_get_imm : SDNodeXForm<vector_shuffle, [{ 154276479Sdim return getI32Imm(PPC::isVSLDOIShuffleMask(N, 2, *CurDAG)); 155276479Sdim}]>; 156276479Sdimdef vsldoi_swapped_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 157276479Sdim (vector_shuffle node:$lhs, node:$rhs), [{ 158276479Sdim return PPC::isVSLDOIShuffleMask(N, 2, *CurDAG) != -1; 159276479Sdim}], VSLDOI_get_imm>; 160276479Sdim 161276479Sdim 162193323Sed// VSPLT*_get_imm xform function: convert vector_shuffle mask to VSPLT* imm. 163193323Seddef VSPLTB_get_imm : SDNodeXForm<vector_shuffle, [{ 164276479Sdim return getI32Imm(PPC::getVSPLTImmediate(N, 1, *CurDAG)); 165193323Sed}]>; 166193323Seddef vspltb_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 167193323Sed (vector_shuffle node:$lhs, node:$rhs), [{ 168193323Sed return PPC::isSplatShuffleMask(cast<ShuffleVectorSDNode>(N), 1); 169193323Sed}], VSPLTB_get_imm>; 170193323Seddef VSPLTH_get_imm : SDNodeXForm<vector_shuffle, [{ 171276479Sdim return getI32Imm(PPC::getVSPLTImmediate(N, 2, *CurDAG)); 172193323Sed}]>; 173193323Seddef vsplth_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 174193323Sed (vector_shuffle node:$lhs, node:$rhs), [{ 175193323Sed return PPC::isSplatShuffleMask(cast<ShuffleVectorSDNode>(N), 2); 176193323Sed}], VSPLTH_get_imm>; 177193323Seddef VSPLTW_get_imm : SDNodeXForm<vector_shuffle, [{ 178276479Sdim return getI32Imm(PPC::getVSPLTImmediate(N, 4, *CurDAG)); 179193323Sed}]>; 180193323Seddef vspltw_shuffle : PatFrag<(ops node:$lhs, node:$rhs), 181193323Sed (vector_shuffle node:$lhs, node:$rhs), [{ 182193323Sed return PPC::isSplatShuffleMask(cast<ShuffleVectorSDNode>(N), 4); 183193323Sed}], VSPLTW_get_imm>; 184193323Sed 185193323Sed 186193323Sed// VSPLTISB_get_imm xform function: convert build_vector to VSPLTISB imm. 187193323Seddef VSPLTISB_get_imm : SDNodeXForm<build_vector, [{ 188193323Sed return PPC::get_VSPLTI_elt(N, 1, *CurDAG); 189193323Sed}]>; 190193323Seddef vecspltisb : PatLeaf<(build_vector), [{ 191193323Sed return PPC::get_VSPLTI_elt(N, 1, *CurDAG).getNode() != 0; 192193323Sed}], VSPLTISB_get_imm>; 193193323Sed 194193323Sed// VSPLTISH_get_imm xform function: convert build_vector to VSPLTISH imm. 195193323Seddef VSPLTISH_get_imm : SDNodeXForm<build_vector, [{ 196193323Sed return PPC::get_VSPLTI_elt(N, 2, *CurDAG); 197193323Sed}]>; 198193323Seddef vecspltish : PatLeaf<(build_vector), [{ 199193323Sed return PPC::get_VSPLTI_elt(N, 2, *CurDAG).getNode() != 0; 200193323Sed}], VSPLTISH_get_imm>; 201193323Sed 202193323Sed// VSPLTISW_get_imm xform function: convert build_vector to VSPLTISW imm. 203193323Seddef VSPLTISW_get_imm : SDNodeXForm<build_vector, [{ 204193323Sed return PPC::get_VSPLTI_elt(N, 4, *CurDAG); 205193323Sed}]>; 206193323Seddef vecspltisw : PatLeaf<(build_vector), [{ 207193323Sed return PPC::get_VSPLTI_elt(N, 4, *CurDAG).getNode() != 0; 208193323Sed}], VSPLTISW_get_imm>; 209193323Sed 210193323Sed//===----------------------------------------------------------------------===// 211193323Sed// Helpers for defining instructions that directly correspond to intrinsics. 212193323Sed 213249423Sdim// VA1a_Int_Ty - A VAForm_1a intrinsic definition of specific type. 214249423Sdimclass VA1a_Int_Ty<bits<6> xo, string opc, Intrinsic IntID, ValueType Ty> 215251662Sdim : VAForm_1a<xo, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB, vrrc:$vC), 216276479Sdim !strconcat(opc, " $vD, $vA, $vB, $vC"), IIC_VecFP, 217249423Sdim [(set Ty:$vD, (IntID Ty:$vA, Ty:$vB, Ty:$vC))]>; 218193323Sed 219249423Sdim// VA1a_Int_Ty2 - A VAForm_1a intrinsic definition where the type of the 220249423Sdim// inputs doesn't match the type of the output. 221249423Sdimclass VA1a_Int_Ty2<bits<6> xo, string opc, Intrinsic IntID, ValueType OutTy, 222249423Sdim ValueType InTy> 223251662Sdim : VAForm_1a<xo, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB, vrrc:$vC), 224276479Sdim !strconcat(opc, " $vD, $vA, $vB, $vC"), IIC_VecFP, 225249423Sdim [(set OutTy:$vD, (IntID InTy:$vA, InTy:$vB, InTy:$vC))]>; 226249423Sdim 227249423Sdim// VA1a_Int_Ty3 - A VAForm_1a intrinsic definition where there are two 228249423Sdim// input types and an output type. 229249423Sdimclass VA1a_Int_Ty3<bits<6> xo, string opc, Intrinsic IntID, ValueType OutTy, 230249423Sdim ValueType In1Ty, ValueType In2Ty> 231251662Sdim : VAForm_1a<xo, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB, vrrc:$vC), 232276479Sdim !strconcat(opc, " $vD, $vA, $vB, $vC"), IIC_VecFP, 233249423Sdim [(set OutTy:$vD, 234249423Sdim (IntID In1Ty:$vA, In1Ty:$vB, In2Ty:$vC))]>; 235249423Sdim 236249423Sdim// VX1_Int_Ty - A VXForm_1 intrinsic definition of specific type. 237249423Sdimclass VX1_Int_Ty<bits<11> xo, string opc, Intrinsic IntID, ValueType Ty> 238251662Sdim : VXForm_1<xo, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 239276479Sdim !strconcat(opc, " $vD, $vA, $vB"), IIC_VecFP, 240249423Sdim [(set Ty:$vD, (IntID Ty:$vA, Ty:$vB))]>; 241193323Sed 242249423Sdim// VX1_Int_Ty2 - A VXForm_1 intrinsic definition where the type of the 243249423Sdim// inputs doesn't match the type of the output. 244249423Sdimclass VX1_Int_Ty2<bits<11> xo, string opc, Intrinsic IntID, ValueType OutTy, 245249423Sdim ValueType InTy> 246251662Sdim : VXForm_1<xo, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 247276479Sdim !strconcat(opc, " $vD, $vA, $vB"), IIC_VecFP, 248249423Sdim [(set OutTy:$vD, (IntID InTy:$vA, InTy:$vB))]>; 249249423Sdim 250249423Sdim// VX1_Int_Ty3 - A VXForm_1 intrinsic definition where there are two 251249423Sdim// input types and an output type. 252249423Sdimclass VX1_Int_Ty3<bits<11> xo, string opc, Intrinsic IntID, ValueType OutTy, 253249423Sdim ValueType In1Ty, ValueType In2Ty> 254251662Sdim : VXForm_1<xo, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 255276479Sdim !strconcat(opc, " $vD, $vA, $vB"), IIC_VecFP, 256249423Sdim [(set OutTy:$vD, (IntID In1Ty:$vA, In2Ty:$vB))]>; 257249423Sdim 258249423Sdim// VX2_Int_SP - A VXForm_2 intrinsic definition of vector single-precision type. 259249423Sdimclass VX2_Int_SP<bits<11> xo, string opc, Intrinsic IntID> 260251662Sdim : VXForm_2<xo, (outs vrrc:$vD), (ins vrrc:$vB), 261276479Sdim !strconcat(opc, " $vD, $vB"), IIC_VecFP, 262249423Sdim [(set v4f32:$vD, (IntID v4f32:$vB))]>; 263193323Sed 264249423Sdim// VX2_Int_Ty2 - A VXForm_2 intrinsic definition where the type of the 265249423Sdim// inputs doesn't match the type of the output. 266249423Sdimclass VX2_Int_Ty2<bits<11> xo, string opc, Intrinsic IntID, ValueType OutTy, 267249423Sdim ValueType InTy> 268251662Sdim : VXForm_2<xo, (outs vrrc:$vD), (ins vrrc:$vB), 269276479Sdim !strconcat(opc, " $vD, $vB"), IIC_VecFP, 270249423Sdim [(set OutTy:$vD, (IntID InTy:$vB))]>; 271249423Sdim 272193323Sed//===----------------------------------------------------------------------===// 273193323Sed// Instruction Definitions. 274193323Sed 275276479Sdimdef HasAltivec : Predicate<"PPCSubTarget->hasAltivec()">; 276249423Sdimlet Predicates = [HasAltivec] in { 277249423Sdim 278249423Sdimlet isCodeGenOnly = 1 in { 279193323Seddef DSS : DSS_Form<822, (outs), 280193323Sed (ins u5imm:$ZERO0, u5imm:$STRM,u5imm:$ZERO1,u5imm:$ZERO2), 281276479Sdim "dss $STRM", IIC_LdStLoad /*FIXME*/, []>, 282261991Sdim Deprecated<DeprecatedDST>; 283193323Seddef DSSALL : DSS_Form<822, (outs), 284193323Sed (ins u5imm:$ONE, u5imm:$ZERO0,u5imm:$ZERO1,u5imm:$ZERO2), 285276479Sdim "dssall", IIC_LdStLoad /*FIXME*/, []>, 286261991Sdim Deprecated<DeprecatedDST>; 287193323Seddef DST : DSS_Form<342, (outs), 288251662Sdim (ins u5imm:$ZERO, u5imm:$STRM, gprc:$rA, gprc:$rB), 289276479Sdim "dst $rA, $rB, $STRM", IIC_LdStLoad /*FIXME*/, []>, 290261991Sdim Deprecated<DeprecatedDST>; 291193323Seddef DSTT : DSS_Form<342, (outs), 292251662Sdim (ins u5imm:$ONE, u5imm:$STRM, gprc:$rA, gprc:$rB), 293276479Sdim "dstt $rA, $rB, $STRM", IIC_LdStLoad /*FIXME*/, []>, 294261991Sdim Deprecated<DeprecatedDST>; 295193323Seddef DSTST : DSS_Form<374, (outs), 296251662Sdim (ins u5imm:$ZERO, u5imm:$STRM, gprc:$rA, gprc:$rB), 297276479Sdim "dstst $rA, $rB, $STRM", IIC_LdStLoad /*FIXME*/, []>, 298261991Sdim Deprecated<DeprecatedDST>; 299193323Seddef DSTSTT : DSS_Form<374, (outs), 300251662Sdim (ins u5imm:$ONE, u5imm:$STRM, gprc:$rA, gprc:$rB), 301276479Sdim "dststt $rA, $rB, $STRM", IIC_LdStLoad /*FIXME*/, []>, 302261991Sdim Deprecated<DeprecatedDST>; 303193323Sed 304193323Seddef DST64 : DSS_Form<342, (outs), 305251662Sdim (ins u5imm:$ZERO, u5imm:$STRM, g8rc:$rA, gprc:$rB), 306276479Sdim "dst $rA, $rB, $STRM", IIC_LdStLoad /*FIXME*/, []>, 307261991Sdim Deprecated<DeprecatedDST>; 308193323Seddef DSTT64 : DSS_Form<342, (outs), 309251662Sdim (ins u5imm:$ONE, u5imm:$STRM, g8rc:$rA, gprc:$rB), 310276479Sdim "dstt $rA, $rB, $STRM", IIC_LdStLoad /*FIXME*/, []>, 311261991Sdim Deprecated<DeprecatedDST>; 312193323Seddef DSTST64 : DSS_Form<374, (outs), 313251662Sdim (ins u5imm:$ZERO, u5imm:$STRM, g8rc:$rA, gprc:$rB), 314276479Sdim "dstst $rA, $rB, $STRM", IIC_LdStLoad /*FIXME*/, []>, 315261991Sdim Deprecated<DeprecatedDST>; 316193323Seddef DSTSTT64 : DSS_Form<374, (outs), 317251662Sdim (ins u5imm:$ONE, u5imm:$STRM, g8rc:$rA, gprc:$rB), 318276479Sdim "dststt $rA, $rB, $STRM", IIC_LdStLoad /*FIXME*/, []>, 319261991Sdim Deprecated<DeprecatedDST>; 320249423Sdim} 321193323Sed 322251662Sdimdef MFVSCR : VXForm_4<1540, (outs vrrc:$vD), (ins), 323276479Sdim "mfvscr $vD", IIC_LdStStore, 324249423Sdim [(set v8i16:$vD, (int_ppc_altivec_mfvscr))]>; 325251662Sdimdef MTVSCR : VXForm_5<1604, (outs), (ins vrrc:$vB), 326276479Sdim "mtvscr $vB", IIC_LdStLoad, 327249423Sdim [(int_ppc_altivec_mtvscr v4i32:$vB)]>; 328193323Sed 329193323Sedlet canFoldAsLoad = 1, PPC970_Unit = 2 in { // Loads. 330251662Sdimdef LVEBX: XForm_1<31, 7, (outs vrrc:$vD), (ins memrr:$src), 331276479Sdim "lvebx $vD, $src", IIC_LdStLoad, 332249423Sdim [(set v16i8:$vD, (int_ppc_altivec_lvebx xoaddr:$src))]>; 333251662Sdimdef LVEHX: XForm_1<31, 39, (outs vrrc:$vD), (ins memrr:$src), 334276479Sdim "lvehx $vD, $src", IIC_LdStLoad, 335249423Sdim [(set v8i16:$vD, (int_ppc_altivec_lvehx xoaddr:$src))]>; 336251662Sdimdef LVEWX: XForm_1<31, 71, (outs vrrc:$vD), (ins memrr:$src), 337276479Sdim "lvewx $vD, $src", IIC_LdStLoad, 338249423Sdim [(set v4i32:$vD, (int_ppc_altivec_lvewx xoaddr:$src))]>; 339251662Sdimdef LVX : XForm_1<31, 103, (outs vrrc:$vD), (ins memrr:$src), 340276479Sdim "lvx $vD, $src", IIC_LdStLoad, 341249423Sdim [(set v4i32:$vD, (int_ppc_altivec_lvx xoaddr:$src))]>; 342251662Sdimdef LVXL : XForm_1<31, 359, (outs vrrc:$vD), (ins memrr:$src), 343276479Sdim "lvxl $vD, $src", IIC_LdStLoad, 344249423Sdim [(set v4i32:$vD, (int_ppc_altivec_lvxl xoaddr:$src))]>; 345193323Sed} 346193323Sed 347251662Sdimdef LVSL : XForm_1<31, 6, (outs vrrc:$vD), (ins memrr:$src), 348276479Sdim "lvsl $vD, $src", IIC_LdStLoad, 349249423Sdim [(set v16i8:$vD, (int_ppc_altivec_lvsl xoaddr:$src))]>, 350193323Sed PPC970_Unit_LSU; 351251662Sdimdef LVSR : XForm_1<31, 38, (outs vrrc:$vD), (ins memrr:$src), 352276479Sdim "lvsr $vD, $src", IIC_LdStLoad, 353249423Sdim [(set v16i8:$vD, (int_ppc_altivec_lvsr xoaddr:$src))]>, 354193323Sed PPC970_Unit_LSU; 355193323Sed 356193323Sedlet PPC970_Unit = 2 in { // Stores. 357251662Sdimdef STVEBX: XForm_8<31, 135, (outs), (ins vrrc:$rS, memrr:$dst), 358276479Sdim "stvebx $rS, $dst", IIC_LdStStore, 359249423Sdim [(int_ppc_altivec_stvebx v16i8:$rS, xoaddr:$dst)]>; 360251662Sdimdef STVEHX: XForm_8<31, 167, (outs), (ins vrrc:$rS, memrr:$dst), 361276479Sdim "stvehx $rS, $dst", IIC_LdStStore, 362249423Sdim [(int_ppc_altivec_stvehx v8i16:$rS, xoaddr:$dst)]>; 363251662Sdimdef STVEWX: XForm_8<31, 199, (outs), (ins vrrc:$rS, memrr:$dst), 364276479Sdim "stvewx $rS, $dst", IIC_LdStStore, 365249423Sdim [(int_ppc_altivec_stvewx v4i32:$rS, xoaddr:$dst)]>; 366251662Sdimdef STVX : XForm_8<31, 231, (outs), (ins vrrc:$rS, memrr:$dst), 367276479Sdim "stvx $rS, $dst", IIC_LdStStore, 368249423Sdim [(int_ppc_altivec_stvx v4i32:$rS, xoaddr:$dst)]>; 369251662Sdimdef STVXL : XForm_8<31, 487, (outs), (ins vrrc:$rS, memrr:$dst), 370276479Sdim "stvxl $rS, $dst", IIC_LdStStore, 371249423Sdim [(int_ppc_altivec_stvxl v4i32:$rS, xoaddr:$dst)]>; 372193323Sed} 373193323Sed 374193323Sedlet PPC970_Unit = 5 in { // VALU Operations. 375193323Sed// VA-Form instructions. 3-input AltiVec ops. 376276479Sdimlet isCommutable = 1 in { 377251662Sdimdef VMADDFP : VAForm_1<46, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vC, vrrc:$vB), 378276479Sdim "vmaddfp $vD, $vA, $vC, $vB", IIC_VecFP, 379249423Sdim [(set v4f32:$vD, 380249423Sdim (fma v4f32:$vA, v4f32:$vC, v4f32:$vB))]>; 381249423Sdim 382249423Sdim// FIXME: The fma+fneg pattern won't match because fneg is not legal. 383251662Sdimdef VNMSUBFP: VAForm_1<47, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vC, vrrc:$vB), 384276479Sdim "vnmsubfp $vD, $vA, $vC, $vB", IIC_VecFP, 385249423Sdim [(set v4f32:$vD, (fneg (fma v4f32:$vA, v4f32:$vC, 386276479Sdim (fneg v4f32:$vB))))]>; 387193323Sed 388249423Sdimdef VMHADDSHS : VA1a_Int_Ty<32, "vmhaddshs", int_ppc_altivec_vmhaddshs, v8i16>; 389249423Sdimdef VMHRADDSHS : VA1a_Int_Ty<33, "vmhraddshs", int_ppc_altivec_vmhraddshs, 390249423Sdim v8i16>; 391249423Sdimdef VMLADDUHM : VA1a_Int_Ty<34, "vmladduhm", int_ppc_altivec_vmladduhm, v8i16>; 392276479Sdim} // isCommutable 393193323Sed 394249423Sdimdef VPERM : VA1a_Int_Ty3<43, "vperm", int_ppc_altivec_vperm, 395249423Sdim v4i32, v4i32, v16i8>; 396249423Sdimdef VSEL : VA1a_Int_Ty<42, "vsel", int_ppc_altivec_vsel, v4i32>; 397249423Sdim 398193323Sed// Shuffles. 399251662Sdimdef VSLDOI : VAForm_2<44, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB, u5imm:$SH), 400276479Sdim "vsldoi $vD, $vA, $vB, $SH", IIC_VecFP, 401249423Sdim [(set v16i8:$vD, 402249423Sdim (vsldoi_shuffle:$SH v16i8:$vA, v16i8:$vB))]>; 403193323Sed 404193323Sed// VX-Form instructions. AltiVec arithmetic ops. 405276479Sdimlet isCommutable = 1 in { 406251662Sdimdef VADDFP : VXForm_1<10, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 407276479Sdim "vaddfp $vD, $vA, $vB", IIC_VecFP, 408249423Sdim [(set v4f32:$vD, (fadd v4f32:$vA, v4f32:$vB))]>; 409193323Sed 410251662Sdimdef VADDUBM : VXForm_1<0, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 411276479Sdim "vaddubm $vD, $vA, $vB", IIC_VecGeneral, 412249423Sdim [(set v16i8:$vD, (add v16i8:$vA, v16i8:$vB))]>; 413251662Sdimdef VADDUHM : VXForm_1<64, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 414276479Sdim "vadduhm $vD, $vA, $vB", IIC_VecGeneral, 415249423Sdim [(set v8i16:$vD, (add v8i16:$vA, v8i16:$vB))]>; 416251662Sdimdef VADDUWM : VXForm_1<128, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 417276479Sdim "vadduwm $vD, $vA, $vB", IIC_VecGeneral, 418249423Sdim [(set v4i32:$vD, (add v4i32:$vA, v4i32:$vB))]>; 419193323Sed 420249423Sdimdef VADDCUW : VX1_Int_Ty<384, "vaddcuw", int_ppc_altivec_vaddcuw, v4i32>; 421249423Sdimdef VADDSBS : VX1_Int_Ty<768, "vaddsbs", int_ppc_altivec_vaddsbs, v16i8>; 422249423Sdimdef VADDSHS : VX1_Int_Ty<832, "vaddshs", int_ppc_altivec_vaddshs, v8i16>; 423249423Sdimdef VADDSWS : VX1_Int_Ty<896, "vaddsws", int_ppc_altivec_vaddsws, v4i32>; 424249423Sdimdef VADDUBS : VX1_Int_Ty<512, "vaddubs", int_ppc_altivec_vaddubs, v16i8>; 425249423Sdimdef VADDUHS : VX1_Int_Ty<576, "vadduhs", int_ppc_altivec_vadduhs, v8i16>; 426249423Sdimdef VADDUWS : VX1_Int_Ty<640, "vadduws", int_ppc_altivec_vadduws, v4i32>; 427276479Sdim} // isCommutable 428276479Sdim 429276479Sdimlet isCommutable = 1 in 430251662Sdimdef VAND : VXForm_1<1028, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 431276479Sdim "vand $vD, $vA, $vB", IIC_VecFP, 432249423Sdim [(set v4i32:$vD, (and v4i32:$vA, v4i32:$vB))]>; 433251662Sdimdef VANDC : VXForm_1<1092, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 434276479Sdim "vandc $vD, $vA, $vB", IIC_VecFP, 435249423Sdim [(set v4i32:$vD, (and v4i32:$vA, 436249423Sdim (vnot_ppc v4i32:$vB)))]>; 437193323Sed 438251662Sdimdef VCFSX : VXForm_1<842, (outs vrrc:$vD), (ins u5imm:$UIMM, vrrc:$vB), 439276479Sdim "vcfsx $vD, $vB, $UIMM", IIC_VecFP, 440249423Sdim [(set v4f32:$vD, 441249423Sdim (int_ppc_altivec_vcfsx v4i32:$vB, imm:$UIMM))]>; 442251662Sdimdef VCFUX : VXForm_1<778, (outs vrrc:$vD), (ins u5imm:$UIMM, vrrc:$vB), 443276479Sdim "vcfux $vD, $vB, $UIMM", IIC_VecFP, 444249423Sdim [(set v4f32:$vD, 445249423Sdim (int_ppc_altivec_vcfux v4i32:$vB, imm:$UIMM))]>; 446251662Sdimdef VCTSXS : VXForm_1<970, (outs vrrc:$vD), (ins u5imm:$UIMM, vrrc:$vB), 447276479Sdim "vctsxs $vD, $vB, $UIMM", IIC_VecFP, 448249423Sdim [(set v4i32:$vD, 449249423Sdim (int_ppc_altivec_vctsxs v4f32:$vB, imm:$UIMM))]>; 450251662Sdimdef VCTUXS : VXForm_1<906, (outs vrrc:$vD), (ins u5imm:$UIMM, vrrc:$vB), 451276479Sdim "vctuxs $vD, $vB, $UIMM", IIC_VecFP, 452249423Sdim [(set v4i32:$vD, 453249423Sdim (int_ppc_altivec_vctuxs v4f32:$vB, imm:$UIMM))]>; 454243830Sdim 455243830Sdim// Defines with the UIM field set to 0 for floating-point 456243830Sdim// to integer (fp_to_sint/fp_to_uint) conversions and integer 457243830Sdim// to floating-point (sint_to_fp/uint_to_fp) conversions. 458261991Sdimlet isCodeGenOnly = 1, VA = 0 in { 459251662Sdimdef VCFSX_0 : VXForm_1<842, (outs vrrc:$vD), (ins vrrc:$vB), 460276479Sdim "vcfsx $vD, $vB, 0", IIC_VecFP, 461249423Sdim [(set v4f32:$vD, 462249423Sdim (int_ppc_altivec_vcfsx v4i32:$vB, 0))]>; 463251662Sdimdef VCTUXS_0 : VXForm_1<906, (outs vrrc:$vD), (ins vrrc:$vB), 464276479Sdim "vctuxs $vD, $vB, 0", IIC_VecFP, 465249423Sdim [(set v4i32:$vD, 466249423Sdim (int_ppc_altivec_vctuxs v4f32:$vB, 0))]>; 467251662Sdimdef VCFUX_0 : VXForm_1<778, (outs vrrc:$vD), (ins vrrc:$vB), 468276479Sdim "vcfux $vD, $vB, 0", IIC_VecFP, 469249423Sdim [(set v4f32:$vD, 470249423Sdim (int_ppc_altivec_vcfux v4i32:$vB, 0))]>; 471251662Sdimdef VCTSXS_0 : VXForm_1<970, (outs vrrc:$vD), (ins vrrc:$vB), 472276479Sdim "vctsxs $vD, $vB, 0", IIC_VecFP, 473249423Sdim [(set v4i32:$vD, 474249423Sdim (int_ppc_altivec_vctsxs v4f32:$vB, 0))]>; 475243830Sdim} 476249423Sdimdef VEXPTEFP : VX2_Int_SP<394, "vexptefp", int_ppc_altivec_vexptefp>; 477249423Sdimdef VLOGEFP : VX2_Int_SP<458, "vlogefp", int_ppc_altivec_vlogefp>; 478193323Sed 479276479Sdimlet isCommutable = 1 in { 480249423Sdimdef VAVGSB : VX1_Int_Ty<1282, "vavgsb", int_ppc_altivec_vavgsb, v16i8>; 481249423Sdimdef VAVGSH : VX1_Int_Ty<1346, "vavgsh", int_ppc_altivec_vavgsh, v8i16>; 482249423Sdimdef VAVGSW : VX1_Int_Ty<1410, "vavgsw", int_ppc_altivec_vavgsw, v4i32>; 483249423Sdimdef VAVGUB : VX1_Int_Ty<1026, "vavgub", int_ppc_altivec_vavgub, v16i8>; 484249423Sdimdef VAVGUH : VX1_Int_Ty<1090, "vavguh", int_ppc_altivec_vavguh, v8i16>; 485249423Sdimdef VAVGUW : VX1_Int_Ty<1154, "vavguw", int_ppc_altivec_vavguw, v4i32>; 486193323Sed 487249423Sdimdef VMAXFP : VX1_Int_Ty<1034, "vmaxfp", int_ppc_altivec_vmaxfp, v4f32>; 488249423Sdimdef VMAXSB : VX1_Int_Ty< 258, "vmaxsb", int_ppc_altivec_vmaxsb, v16i8>; 489249423Sdimdef VMAXSH : VX1_Int_Ty< 322, "vmaxsh", int_ppc_altivec_vmaxsh, v8i16>; 490249423Sdimdef VMAXSW : VX1_Int_Ty< 386, "vmaxsw", int_ppc_altivec_vmaxsw, v4i32>; 491249423Sdimdef VMAXUB : VX1_Int_Ty< 2, "vmaxub", int_ppc_altivec_vmaxub, v16i8>; 492249423Sdimdef VMAXUH : VX1_Int_Ty< 66, "vmaxuh", int_ppc_altivec_vmaxuh, v8i16>; 493249423Sdimdef VMAXUW : VX1_Int_Ty< 130, "vmaxuw", int_ppc_altivec_vmaxuw, v4i32>; 494249423Sdimdef VMINFP : VX1_Int_Ty<1098, "vminfp", int_ppc_altivec_vminfp, v4f32>; 495249423Sdimdef VMINSB : VX1_Int_Ty< 770, "vminsb", int_ppc_altivec_vminsb, v16i8>; 496249423Sdimdef VMINSH : VX1_Int_Ty< 834, "vminsh", int_ppc_altivec_vminsh, v8i16>; 497249423Sdimdef VMINSW : VX1_Int_Ty< 898, "vminsw", int_ppc_altivec_vminsw, v4i32>; 498249423Sdimdef VMINUB : VX1_Int_Ty< 514, "vminub", int_ppc_altivec_vminub, v16i8>; 499249423Sdimdef VMINUH : VX1_Int_Ty< 578, "vminuh", int_ppc_altivec_vminuh, v8i16>; 500249423Sdimdef VMINUW : VX1_Int_Ty< 642, "vminuw", int_ppc_altivec_vminuw, v4i32>; 501276479Sdim} // isCommutable 502193323Sed 503251662Sdimdef VMRGHB : VXForm_1< 12, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 504276479Sdim "vmrghb $vD, $vA, $vB", IIC_VecFP, 505249423Sdim [(set v16i8:$vD, (vmrghb_shuffle v16i8:$vA, v16i8:$vB))]>; 506251662Sdimdef VMRGHH : VXForm_1< 76, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 507276479Sdim "vmrghh $vD, $vA, $vB", IIC_VecFP, 508249423Sdim [(set v16i8:$vD, (vmrghh_shuffle v16i8:$vA, v16i8:$vB))]>; 509251662Sdimdef VMRGHW : VXForm_1<140, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 510276479Sdim "vmrghw $vD, $vA, $vB", IIC_VecFP, 511249423Sdim [(set v16i8:$vD, (vmrghw_shuffle v16i8:$vA, v16i8:$vB))]>; 512251662Sdimdef VMRGLB : VXForm_1<268, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 513276479Sdim "vmrglb $vD, $vA, $vB", IIC_VecFP, 514249423Sdim [(set v16i8:$vD, (vmrglb_shuffle v16i8:$vA, v16i8:$vB))]>; 515251662Sdimdef VMRGLH : VXForm_1<332, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 516276479Sdim "vmrglh $vD, $vA, $vB", IIC_VecFP, 517249423Sdim [(set v16i8:$vD, (vmrglh_shuffle v16i8:$vA, v16i8:$vB))]>; 518251662Sdimdef VMRGLW : VXForm_1<396, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 519276479Sdim "vmrglw $vD, $vA, $vB", IIC_VecFP, 520249423Sdim [(set v16i8:$vD, (vmrglw_shuffle v16i8:$vA, v16i8:$vB))]>; 521193323Sed 522249423Sdimdef VMSUMMBM : VA1a_Int_Ty3<37, "vmsummbm", int_ppc_altivec_vmsummbm, 523249423Sdim v4i32, v16i8, v4i32>; 524249423Sdimdef VMSUMSHM : VA1a_Int_Ty3<40, "vmsumshm", int_ppc_altivec_vmsumshm, 525249423Sdim v4i32, v8i16, v4i32>; 526249423Sdimdef VMSUMSHS : VA1a_Int_Ty3<41, "vmsumshs", int_ppc_altivec_vmsumshs, 527249423Sdim v4i32, v8i16, v4i32>; 528249423Sdimdef VMSUMUBM : VA1a_Int_Ty3<36, "vmsumubm", int_ppc_altivec_vmsumubm, 529249423Sdim v4i32, v16i8, v4i32>; 530249423Sdimdef VMSUMUHM : VA1a_Int_Ty3<38, "vmsumuhm", int_ppc_altivec_vmsumuhm, 531249423Sdim v4i32, v8i16, v4i32>; 532249423Sdimdef VMSUMUHS : VA1a_Int_Ty3<39, "vmsumuhs", int_ppc_altivec_vmsumuhs, 533249423Sdim v4i32, v8i16, v4i32>; 534193323Sed 535276479Sdimlet isCommutable = 1 in { 536249423Sdimdef VMULESB : VX1_Int_Ty2<776, "vmulesb", int_ppc_altivec_vmulesb, 537249423Sdim v8i16, v16i8>; 538249423Sdimdef VMULESH : VX1_Int_Ty2<840, "vmulesh", int_ppc_altivec_vmulesh, 539249423Sdim v4i32, v8i16>; 540249423Sdimdef VMULEUB : VX1_Int_Ty2<520, "vmuleub", int_ppc_altivec_vmuleub, 541249423Sdim v8i16, v16i8>; 542249423Sdimdef VMULEUH : VX1_Int_Ty2<584, "vmuleuh", int_ppc_altivec_vmuleuh, 543249423Sdim v4i32, v8i16>; 544249423Sdimdef VMULOSB : VX1_Int_Ty2<264, "vmulosb", int_ppc_altivec_vmulosb, 545249423Sdim v8i16, v16i8>; 546249423Sdimdef VMULOSH : VX1_Int_Ty2<328, "vmulosh", int_ppc_altivec_vmulosh, 547249423Sdim v4i32, v8i16>; 548249423Sdimdef VMULOUB : VX1_Int_Ty2< 8, "vmuloub", int_ppc_altivec_vmuloub, 549249423Sdim v8i16, v16i8>; 550249423Sdimdef VMULOUH : VX1_Int_Ty2< 72, "vmulouh", int_ppc_altivec_vmulouh, 551249423Sdim v4i32, v8i16>; 552276479Sdim} // isCommutable 553193323Sed 554249423Sdimdef VREFP : VX2_Int_SP<266, "vrefp", int_ppc_altivec_vrefp>; 555249423Sdimdef VRFIM : VX2_Int_SP<714, "vrfim", int_ppc_altivec_vrfim>; 556249423Sdimdef VRFIN : VX2_Int_SP<522, "vrfin", int_ppc_altivec_vrfin>; 557249423Sdimdef VRFIP : VX2_Int_SP<650, "vrfip", int_ppc_altivec_vrfip>; 558249423Sdimdef VRFIZ : VX2_Int_SP<586, "vrfiz", int_ppc_altivec_vrfiz>; 559249423Sdimdef VRSQRTEFP : VX2_Int_SP<330, "vrsqrtefp", int_ppc_altivec_vrsqrtefp>; 560193323Sed 561251662Sdimdef VSUBCUW : VX1_Int_Ty<1408, "vsubcuw", int_ppc_altivec_vsubcuw, v4i32>; 562193323Sed 563251662Sdimdef VSUBFP : VXForm_1<74, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 564276479Sdim "vsubfp $vD, $vA, $vB", IIC_VecGeneral, 565249423Sdim [(set v4f32:$vD, (fsub v4f32:$vA, v4f32:$vB))]>; 566251662Sdimdef VSUBUBM : VXForm_1<1024, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 567276479Sdim "vsububm $vD, $vA, $vB", IIC_VecGeneral, 568249423Sdim [(set v16i8:$vD, (sub v16i8:$vA, v16i8:$vB))]>; 569251662Sdimdef VSUBUHM : VXForm_1<1088, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 570276479Sdim "vsubuhm $vD, $vA, $vB", IIC_VecGeneral, 571249423Sdim [(set v8i16:$vD, (sub v8i16:$vA, v8i16:$vB))]>; 572251662Sdimdef VSUBUWM : VXForm_1<1152, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 573276479Sdim "vsubuwm $vD, $vA, $vB", IIC_VecGeneral, 574249423Sdim [(set v4i32:$vD, (sub v4i32:$vA, v4i32:$vB))]>; 575193323Sed 576249423Sdimdef VSUBSBS : VX1_Int_Ty<1792, "vsubsbs" , int_ppc_altivec_vsubsbs, v16i8>; 577249423Sdimdef VSUBSHS : VX1_Int_Ty<1856, "vsubshs" , int_ppc_altivec_vsubshs, v8i16>; 578249423Sdimdef VSUBSWS : VX1_Int_Ty<1920, "vsubsws" , int_ppc_altivec_vsubsws, v4i32>; 579249423Sdimdef VSUBUBS : VX1_Int_Ty<1536, "vsububs" , int_ppc_altivec_vsububs, v16i8>; 580249423Sdimdef VSUBUHS : VX1_Int_Ty<1600, "vsubuhs" , int_ppc_altivec_vsubuhs, v8i16>; 581249423Sdimdef VSUBUWS : VX1_Int_Ty<1664, "vsubuws" , int_ppc_altivec_vsubuws, v4i32>; 582193323Sed 583249423Sdimdef VSUMSWS : VX1_Int_Ty<1928, "vsumsws" , int_ppc_altivec_vsumsws, v4i32>; 584249423Sdimdef VSUM2SWS: VX1_Int_Ty<1672, "vsum2sws", int_ppc_altivec_vsum2sws, v4i32>; 585249423Sdim 586251662Sdimdef VSUM4SBS: VX1_Int_Ty3<1800, "vsum4sbs", int_ppc_altivec_vsum4sbs, 587249423Sdim v4i32, v16i8, v4i32>; 588249423Sdimdef VSUM4SHS: VX1_Int_Ty3<1608, "vsum4shs", int_ppc_altivec_vsum4shs, 589249423Sdim v4i32, v8i16, v4i32>; 590249423Sdimdef VSUM4UBS: VX1_Int_Ty3<1544, "vsum4ubs", int_ppc_altivec_vsum4ubs, 591249423Sdim v4i32, v16i8, v4i32>; 592249423Sdim 593251662Sdimdef VNOR : VXForm_1<1284, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 594276479Sdim "vnor $vD, $vA, $vB", IIC_VecFP, 595249423Sdim [(set v4i32:$vD, (vnot_ppc (or v4i32:$vA, 596249423Sdim v4i32:$vB)))]>; 597276479Sdimlet isCommutable = 1 in { 598251662Sdimdef VOR : VXForm_1<1156, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 599276479Sdim "vor $vD, $vA, $vB", IIC_VecFP, 600249423Sdim [(set v4i32:$vD, (or v4i32:$vA, v4i32:$vB))]>; 601251662Sdimdef VXOR : VXForm_1<1220, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 602276479Sdim "vxor $vD, $vA, $vB", IIC_VecFP, 603249423Sdim [(set v4i32:$vD, (xor v4i32:$vA, v4i32:$vB))]>; 604276479Sdim} // isCommutable 605193323Sed 606249423Sdimdef VRLB : VX1_Int_Ty< 4, "vrlb", int_ppc_altivec_vrlb, v16i8>; 607249423Sdimdef VRLH : VX1_Int_Ty< 68, "vrlh", int_ppc_altivec_vrlh, v8i16>; 608249423Sdimdef VRLW : VX1_Int_Ty< 132, "vrlw", int_ppc_altivec_vrlw, v4i32>; 609193323Sed 610249423Sdimdef VSL : VX1_Int_Ty< 452, "vsl" , int_ppc_altivec_vsl, v4i32 >; 611249423Sdimdef VSLO : VX1_Int_Ty<1036, "vslo", int_ppc_altivec_vslo, v4i32>; 612193323Sed 613249423Sdimdef VSLB : VX1_Int_Ty< 260, "vslb", int_ppc_altivec_vslb, v16i8>; 614249423Sdimdef VSLH : VX1_Int_Ty< 324, "vslh", int_ppc_altivec_vslh, v8i16>; 615249423Sdimdef VSLW : VX1_Int_Ty< 388, "vslw", int_ppc_altivec_vslw, v4i32>; 616249423Sdim 617251662Sdimdef VSPLTB : VXForm_1<524, (outs vrrc:$vD), (ins u5imm:$UIMM, vrrc:$vB), 618276479Sdim "vspltb $vD, $vB, $UIMM", IIC_VecPerm, 619249423Sdim [(set v16i8:$vD, 620249423Sdim (vspltb_shuffle:$UIMM v16i8:$vB, (undef)))]>; 621251662Sdimdef VSPLTH : VXForm_1<588, (outs vrrc:$vD), (ins u5imm:$UIMM, vrrc:$vB), 622276479Sdim "vsplth $vD, $vB, $UIMM", IIC_VecPerm, 623249423Sdim [(set v16i8:$vD, 624249423Sdim (vsplth_shuffle:$UIMM v16i8:$vB, (undef)))]>; 625251662Sdimdef VSPLTW : VXForm_1<652, (outs vrrc:$vD), (ins u5imm:$UIMM, vrrc:$vB), 626276479Sdim "vspltw $vD, $vB, $UIMM", IIC_VecPerm, 627249423Sdim [(set v16i8:$vD, 628249423Sdim (vspltw_shuffle:$UIMM v16i8:$vB, (undef)))]>; 629193323Sed 630249423Sdimdef VSR : VX1_Int_Ty< 708, "vsr" , int_ppc_altivec_vsr, v4i32>; 631249423Sdimdef VSRO : VX1_Int_Ty<1100, "vsro" , int_ppc_altivec_vsro, v4i32>; 632193323Sed 633249423Sdimdef VSRAB : VX1_Int_Ty< 772, "vsrab", int_ppc_altivec_vsrab, v16i8>; 634249423Sdimdef VSRAH : VX1_Int_Ty< 836, "vsrah", int_ppc_altivec_vsrah, v8i16>; 635249423Sdimdef VSRAW : VX1_Int_Ty< 900, "vsraw", int_ppc_altivec_vsraw, v4i32>; 636249423Sdimdef VSRB : VX1_Int_Ty< 516, "vsrb" , int_ppc_altivec_vsrb , v16i8>; 637249423Sdimdef VSRH : VX1_Int_Ty< 580, "vsrh" , int_ppc_altivec_vsrh , v8i16>; 638249423Sdimdef VSRW : VX1_Int_Ty< 644, "vsrw" , int_ppc_altivec_vsrw , v4i32>; 639193323Sed 640249423Sdim 641251662Sdimdef VSPLTISB : VXForm_3<780, (outs vrrc:$vD), (ins s5imm:$SIMM), 642276479Sdim "vspltisb $vD, $SIMM", IIC_VecPerm, 643249423Sdim [(set v16i8:$vD, (v16i8 vecspltisb:$SIMM))]>; 644251662Sdimdef VSPLTISH : VXForm_3<844, (outs vrrc:$vD), (ins s5imm:$SIMM), 645276479Sdim "vspltish $vD, $SIMM", IIC_VecPerm, 646249423Sdim [(set v8i16:$vD, (v8i16 vecspltish:$SIMM))]>; 647251662Sdimdef VSPLTISW : VXForm_3<908, (outs vrrc:$vD), (ins s5imm:$SIMM), 648276479Sdim "vspltisw $vD, $SIMM", IIC_VecPerm, 649249423Sdim [(set v4i32:$vD, (v4i32 vecspltisw:$SIMM))]>; 650193323Sed 651193323Sed// Vector Pack. 652249423Sdimdef VPKPX : VX1_Int_Ty2<782, "vpkpx", int_ppc_altivec_vpkpx, 653249423Sdim v8i16, v4i32>; 654249423Sdimdef VPKSHSS : VX1_Int_Ty2<398, "vpkshss", int_ppc_altivec_vpkshss, 655249423Sdim v16i8, v8i16>; 656249423Sdimdef VPKSHUS : VX1_Int_Ty2<270, "vpkshus", int_ppc_altivec_vpkshus, 657249423Sdim v16i8, v8i16>; 658249423Sdimdef VPKSWSS : VX1_Int_Ty2<462, "vpkswss", int_ppc_altivec_vpkswss, 659249423Sdim v16i8, v4i32>; 660249423Sdimdef VPKSWUS : VX1_Int_Ty2<334, "vpkswus", int_ppc_altivec_vpkswus, 661249423Sdim v8i16, v4i32>; 662251662Sdimdef VPKUHUM : VXForm_1<14, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 663276479Sdim "vpkuhum $vD, $vA, $vB", IIC_VecFP, 664249423Sdim [(set v16i8:$vD, 665249423Sdim (vpkuhum_shuffle v16i8:$vA, v16i8:$vB))]>; 666249423Sdimdef VPKUHUS : VX1_Int_Ty2<142, "vpkuhus", int_ppc_altivec_vpkuhus, 667249423Sdim v16i8, v8i16>; 668251662Sdimdef VPKUWUM : VXForm_1<78, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), 669276479Sdim "vpkuwum $vD, $vA, $vB", IIC_VecFP, 670249423Sdim [(set v16i8:$vD, 671249423Sdim (vpkuwum_shuffle v16i8:$vA, v16i8:$vB))]>; 672249423Sdimdef VPKUWUS : VX1_Int_Ty2<206, "vpkuwus", int_ppc_altivec_vpkuwus, 673249423Sdim v8i16, v4i32>; 674193323Sed 675193323Sed// Vector Unpack. 676249423Sdimdef VUPKHPX : VX2_Int_Ty2<846, "vupkhpx", int_ppc_altivec_vupkhpx, 677249423Sdim v4i32, v8i16>; 678249423Sdimdef VUPKHSB : VX2_Int_Ty2<526, "vupkhsb", int_ppc_altivec_vupkhsb, 679249423Sdim v8i16, v16i8>; 680249423Sdimdef VUPKHSH : VX2_Int_Ty2<590, "vupkhsh", int_ppc_altivec_vupkhsh, 681249423Sdim v4i32, v8i16>; 682249423Sdimdef VUPKLPX : VX2_Int_Ty2<974, "vupklpx", int_ppc_altivec_vupklpx, 683249423Sdim v4i32, v8i16>; 684249423Sdimdef VUPKLSB : VX2_Int_Ty2<654, "vupklsb", int_ppc_altivec_vupklsb, 685249423Sdim v8i16, v16i8>; 686249423Sdimdef VUPKLSH : VX2_Int_Ty2<718, "vupklsh", int_ppc_altivec_vupklsh, 687249423Sdim v4i32, v8i16>; 688193323Sed 689193323Sed 690193323Sed// Altivec Comparisons. 691193323Sed 692193323Sedclass VCMP<bits<10> xo, string asmstr, ValueType Ty> 693276479Sdim : VXRForm_1<xo, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), asmstr, 694276479Sdim IIC_VecFPCompare, 695249423Sdim [(set Ty:$vD, (Ty (PPCvcmp Ty:$vA, Ty:$vB, xo)))]>; 696193323Sedclass VCMPo<bits<10> xo, string asmstr, ValueType Ty> 697276479Sdim : VXRForm_1<xo, (outs vrrc:$vD), (ins vrrc:$vA, vrrc:$vB), asmstr, 698276479Sdim IIC_VecFPCompare, 699249423Sdim [(set Ty:$vD, (Ty (PPCvcmp_o Ty:$vA, Ty:$vB, xo)))]> { 700193323Sed let Defs = [CR6]; 701193323Sed let RC = 1; 702193323Sed} 703193323Sed 704193323Sed// f32 element comparisons.0 705193323Seddef VCMPBFP : VCMP <966, "vcmpbfp $vD, $vA, $vB" , v4f32>; 706193323Seddef VCMPBFPo : VCMPo<966, "vcmpbfp. $vD, $vA, $vB" , v4f32>; 707193323Seddef VCMPEQFP : VCMP <198, "vcmpeqfp $vD, $vA, $vB" , v4f32>; 708193323Seddef VCMPEQFPo : VCMPo<198, "vcmpeqfp. $vD, $vA, $vB", v4f32>; 709193323Seddef VCMPGEFP : VCMP <454, "vcmpgefp $vD, $vA, $vB" , v4f32>; 710193323Seddef VCMPGEFPo : VCMPo<454, "vcmpgefp. $vD, $vA, $vB", v4f32>; 711193323Seddef VCMPGTFP : VCMP <710, "vcmpgtfp $vD, $vA, $vB" , v4f32>; 712193323Seddef VCMPGTFPo : VCMPo<710, "vcmpgtfp. $vD, $vA, $vB", v4f32>; 713193323Sed 714193323Sed// i8 element comparisons. 715193323Seddef VCMPEQUB : VCMP < 6, "vcmpequb $vD, $vA, $vB" , v16i8>; 716193323Seddef VCMPEQUBo : VCMPo< 6, "vcmpequb. $vD, $vA, $vB", v16i8>; 717193323Seddef VCMPGTSB : VCMP <774, "vcmpgtsb $vD, $vA, $vB" , v16i8>; 718193323Seddef VCMPGTSBo : VCMPo<774, "vcmpgtsb. $vD, $vA, $vB", v16i8>; 719193323Seddef VCMPGTUB : VCMP <518, "vcmpgtub $vD, $vA, $vB" , v16i8>; 720193323Seddef VCMPGTUBo : VCMPo<518, "vcmpgtub. $vD, $vA, $vB", v16i8>; 721193323Sed 722193323Sed// i16 element comparisons. 723193323Seddef VCMPEQUH : VCMP < 70, "vcmpequh $vD, $vA, $vB" , v8i16>; 724193323Seddef VCMPEQUHo : VCMPo< 70, "vcmpequh. $vD, $vA, $vB", v8i16>; 725193323Seddef VCMPGTSH : VCMP <838, "vcmpgtsh $vD, $vA, $vB" , v8i16>; 726193323Seddef VCMPGTSHo : VCMPo<838, "vcmpgtsh. $vD, $vA, $vB", v8i16>; 727193323Seddef VCMPGTUH : VCMP <582, "vcmpgtuh $vD, $vA, $vB" , v8i16>; 728193323Seddef VCMPGTUHo : VCMPo<582, "vcmpgtuh. $vD, $vA, $vB", v8i16>; 729193323Sed 730193323Sed// i32 element comparisons. 731193323Seddef VCMPEQUW : VCMP <134, "vcmpequw $vD, $vA, $vB" , v4i32>; 732193323Seddef VCMPEQUWo : VCMPo<134, "vcmpequw. $vD, $vA, $vB", v4i32>; 733193323Seddef VCMPGTSW : VCMP <902, "vcmpgtsw $vD, $vA, $vB" , v4i32>; 734193323Seddef VCMPGTSWo : VCMPo<902, "vcmpgtsw. $vD, $vA, $vB", v4i32>; 735193323Seddef VCMPGTUW : VCMP <646, "vcmpgtuw $vD, $vA, $vB" , v4i32>; 736193323Seddef VCMPGTUWo : VCMPo<646, "vcmpgtuw. $vD, $vA, $vB", v4i32>; 737193323Sed 738261991Sdimlet isCodeGenOnly = 1 in { 739261991Sdimdef V_SET0B : VXForm_setzero<1220, (outs vrrc:$vD), (ins), 740276479Sdim "vxor $vD, $vD, $vD", IIC_VecFP, 741261991Sdim [(set v16i8:$vD, (v16i8 immAllZerosV))]>; 742261991Sdimdef V_SET0H : VXForm_setzero<1220, (outs vrrc:$vD), (ins), 743276479Sdim "vxor $vD, $vD, $vD", IIC_VecFP, 744261991Sdim [(set v8i16:$vD, (v8i16 immAllZerosV))]>; 745261991Sdimdef V_SET0 : VXForm_setzero<1220, (outs vrrc:$vD), (ins), 746276479Sdim "vxor $vD, $vD, $vD", IIC_VecFP, 747249423Sdim [(set v4i32:$vD, (v4i32 immAllZerosV))]>; 748261991Sdim 749249423Sdimlet IMM=-1 in { 750261991Sdimdef V_SETALLONESB : VXForm_3<908, (outs vrrc:$vD), (ins), 751276479Sdim "vspltisw $vD, -1", IIC_VecFP, 752261991Sdim [(set v16i8:$vD, (v16i8 immAllOnesV))]>; 753261991Sdimdef V_SETALLONESH : VXForm_3<908, (outs vrrc:$vD), (ins), 754276479Sdim "vspltisw $vD, -1", IIC_VecFP, 755261991Sdim [(set v8i16:$vD, (v8i16 immAllOnesV))]>; 756261991Sdimdef V_SETALLONES : VXForm_3<908, (outs vrrc:$vD), (ins), 757276479Sdim "vspltisw $vD, -1", IIC_VecFP, 758249423Sdim [(set v4i32:$vD, (v4i32 immAllOnesV))]>; 759193323Sed} 760261991Sdim} 761249423Sdim} // VALU Operations. 762193323Sed 763193323Sed//===----------------------------------------------------------------------===// 764193323Sed// Additional Altivec Patterns 765193323Sed// 766193323Sed 767193323Sed// DS* intrinsics 768193323Seddef : Pat<(int_ppc_altivec_dssall), (DSSALL 1, 0, 0, 0)>; 769193323Seddef : Pat<(int_ppc_altivec_dss imm:$STRM), (DSS 0, imm:$STRM, 0, 0)>; 770193323Sed 771193323Sed// * 32-bit 772249423Sdimdef : Pat<(int_ppc_altivec_dst i32:$rA, i32:$rB, imm:$STRM), 773249423Sdim (DST 0, imm:$STRM, $rA, $rB)>; 774249423Sdimdef : Pat<(int_ppc_altivec_dstt i32:$rA, i32:$rB, imm:$STRM), 775249423Sdim (DSTT 1, imm:$STRM, $rA, $rB)>; 776249423Sdimdef : Pat<(int_ppc_altivec_dstst i32:$rA, i32:$rB, imm:$STRM), 777249423Sdim (DSTST 0, imm:$STRM, $rA, $rB)>; 778249423Sdimdef : Pat<(int_ppc_altivec_dststt i32:$rA, i32:$rB, imm:$STRM), 779249423Sdim (DSTSTT 1, imm:$STRM, $rA, $rB)>; 780193323Sed 781193323Sed// * 64-bit 782249423Sdimdef : Pat<(int_ppc_altivec_dst i64:$rA, i32:$rB, imm:$STRM), 783249423Sdim (DST64 0, imm:$STRM, $rA, $rB)>; 784249423Sdimdef : Pat<(int_ppc_altivec_dstt i64:$rA, i32:$rB, imm:$STRM), 785249423Sdim (DSTT64 1, imm:$STRM, $rA, $rB)>; 786249423Sdimdef : Pat<(int_ppc_altivec_dstst i64:$rA, i32:$rB, imm:$STRM), 787249423Sdim (DSTST64 0, imm:$STRM, $rA, $rB)>; 788249423Sdimdef : Pat<(int_ppc_altivec_dststt i64:$rA, i32:$rB, imm:$STRM), 789249423Sdim (DSTSTT64 1, imm:$STRM, $rA, $rB)>; 790193323Sed 791193323Sed// Loads. 792193323Seddef : Pat<(v4i32 (load xoaddr:$src)), (LVX xoaddr:$src)>; 793193323Sed 794193323Sed// Stores. 795249423Sdimdef : Pat<(store v4i32:$rS, xoaddr:$dst), 796249423Sdim (STVX $rS, xoaddr:$dst)>; 797193323Sed 798193323Sed// Bit conversions. 799193323Seddef : Pat<(v16i8 (bitconvert (v8i16 VRRC:$src))), (v16i8 VRRC:$src)>; 800193323Seddef : Pat<(v16i8 (bitconvert (v4i32 VRRC:$src))), (v16i8 VRRC:$src)>; 801193323Seddef : Pat<(v16i8 (bitconvert (v4f32 VRRC:$src))), (v16i8 VRRC:$src)>; 802193323Sed 803193323Seddef : Pat<(v8i16 (bitconvert (v16i8 VRRC:$src))), (v8i16 VRRC:$src)>; 804193323Seddef : Pat<(v8i16 (bitconvert (v4i32 VRRC:$src))), (v8i16 VRRC:$src)>; 805193323Seddef : Pat<(v8i16 (bitconvert (v4f32 VRRC:$src))), (v8i16 VRRC:$src)>; 806193323Sed 807193323Seddef : Pat<(v4i32 (bitconvert (v16i8 VRRC:$src))), (v4i32 VRRC:$src)>; 808193323Seddef : Pat<(v4i32 (bitconvert (v8i16 VRRC:$src))), (v4i32 VRRC:$src)>; 809193323Seddef : Pat<(v4i32 (bitconvert (v4f32 VRRC:$src))), (v4i32 VRRC:$src)>; 810193323Sed 811193323Seddef : Pat<(v4f32 (bitconvert (v16i8 VRRC:$src))), (v4f32 VRRC:$src)>; 812193323Seddef : Pat<(v4f32 (bitconvert (v8i16 VRRC:$src))), (v4f32 VRRC:$src)>; 813193323Seddef : Pat<(v4f32 (bitconvert (v4i32 VRRC:$src))), (v4f32 VRRC:$src)>; 814193323Sed 815193323Sed// Shuffles. 816193323Sed 817193323Sed// Match vsldoi(x,x), vpkuwum(x,x), vpkuhum(x,x) 818249423Sdimdef:Pat<(vsldoi_unary_shuffle:$in v16i8:$vA, undef), 819249423Sdim (VSLDOI $vA, $vA, (VSLDOI_unary_get_imm $in))>; 820249423Sdimdef:Pat<(vpkuwum_unary_shuffle v16i8:$vA, undef), 821249423Sdim (VPKUWUM $vA, $vA)>; 822249423Sdimdef:Pat<(vpkuhum_unary_shuffle v16i8:$vA, undef), 823249423Sdim (VPKUHUM $vA, $vA)>; 824193323Sed 825276479Sdim// Match vsldoi(y,x), vpkuwum(y,x), vpkuhum(y,x), i.e., swapped operands. 826276479Sdim// These fragments are matched for little-endian, where the inputs must 827276479Sdim// be swapped for correct semantics. 828276479Sdimdef:Pat<(vsldoi_swapped_shuffle:$in v16i8:$vA, v16i8:$vB), 829276479Sdim (VSLDOI $vB, $vA, (VSLDOI_swapped_get_imm $in))>; 830276479Sdimdef:Pat<(vpkuwum_swapped_shuffle v16i8:$vA, v16i8:$vB), 831276479Sdim (VPKUWUM $vB, $vA)>; 832276479Sdimdef:Pat<(vpkuhum_swapped_shuffle v16i8:$vA, v16i8:$vB), 833276479Sdim (VPKUHUM $vB, $vA)>; 834276479Sdim 835193323Sed// Match vmrg*(x,x) 836249423Sdimdef:Pat<(vmrglb_unary_shuffle v16i8:$vA, undef), 837249423Sdim (VMRGLB $vA, $vA)>; 838249423Sdimdef:Pat<(vmrglh_unary_shuffle v16i8:$vA, undef), 839249423Sdim (VMRGLH $vA, $vA)>; 840249423Sdimdef:Pat<(vmrglw_unary_shuffle v16i8:$vA, undef), 841249423Sdim (VMRGLW $vA, $vA)>; 842249423Sdimdef:Pat<(vmrghb_unary_shuffle v16i8:$vA, undef), 843249423Sdim (VMRGHB $vA, $vA)>; 844249423Sdimdef:Pat<(vmrghh_unary_shuffle v16i8:$vA, undef), 845249423Sdim (VMRGHH $vA, $vA)>; 846249423Sdimdef:Pat<(vmrghw_unary_shuffle v16i8:$vA, undef), 847249423Sdim (VMRGHW $vA, $vA)>; 848193323Sed 849276479Sdim// Match vmrg*(y,x), i.e., swapped operands. These fragments 850276479Sdim// are matched for little-endian, where the inputs must be 851276479Sdim// swapped for correct semantics. 852276479Sdimdef:Pat<(vmrglb_swapped_shuffle v16i8:$vA, v16i8:$vB), 853276479Sdim (VMRGLB $vB, $vA)>; 854276479Sdimdef:Pat<(vmrglh_swapped_shuffle v16i8:$vA, v16i8:$vB), 855276479Sdim (VMRGLH $vB, $vA)>; 856276479Sdimdef:Pat<(vmrglw_swapped_shuffle v16i8:$vA, v16i8:$vB), 857276479Sdim (VMRGLW $vB, $vA)>; 858276479Sdimdef:Pat<(vmrghb_swapped_shuffle v16i8:$vA, v16i8:$vB), 859276479Sdim (VMRGHB $vB, $vA)>; 860276479Sdimdef:Pat<(vmrghh_swapped_shuffle v16i8:$vA, v16i8:$vB), 861276479Sdim (VMRGHH $vB, $vA)>; 862276479Sdimdef:Pat<(vmrghw_swapped_shuffle v16i8:$vA, v16i8:$vB), 863276479Sdim (VMRGHW $vB, $vA)>; 864276479Sdim 865193323Sed// Logical Operations 866249423Sdimdef : Pat<(vnot_ppc v4i32:$vA), (VNOR $vA, $vA)>; 867193323Sed 868249423Sdimdef : Pat<(vnot_ppc (or v4i32:$A, v4i32:$B)), 869249423Sdim (VNOR $A, $B)>; 870249423Sdimdef : Pat<(and v4i32:$A, (vnot_ppc v4i32:$B)), 871249423Sdim (VANDC $A, $B)>; 872193323Sed 873249423Sdimdef : Pat<(fmul v4f32:$vA, v4f32:$vB), 874249423Sdim (VMADDFP $vA, $vB, 875249423Sdim (v4i32 (VSLW (V_SETALLONES), (V_SETALLONES))))>; 876193323Sed 877193323Sed// Fused multiply add and multiply sub for packed float. These are represented 878193323Sed// separately from the real instructions above, for operations that must have 879193323Sed// the additional precision, such as Newton-Rhapson (used by divide, sqrt) 880249423Sdimdef : Pat<(PPCvmaddfp v4f32:$A, v4f32:$B, v4f32:$C), 881249423Sdim (VMADDFP $A, $B, $C)>; 882249423Sdimdef : Pat<(PPCvnmsubfp v4f32:$A, v4f32:$B, v4f32:$C), 883249423Sdim (VNMSUBFP $A, $B, $C)>; 884193323Sed 885249423Sdimdef : Pat<(int_ppc_altivec_vmaddfp v4f32:$A, v4f32:$B, v4f32:$C), 886249423Sdim (VMADDFP $A, $B, $C)>; 887249423Sdimdef : Pat<(int_ppc_altivec_vnmsubfp v4f32:$A, v4f32:$B, v4f32:$C), 888249423Sdim (VNMSUBFP $A, $B, $C)>; 889193323Sed 890249423Sdimdef : Pat<(PPCvperm v16i8:$vA, v16i8:$vB, v16i8:$vC), 891249423Sdim (VPERM $vA, $vB, $vC)>; 892193630Sed 893249423Sdimdef : Pat<(PPCfre v4f32:$A), (VREFP $A)>; 894249423Sdimdef : Pat<(PPCfrsqrte v4f32:$A), (VRSQRTEFP $A)>; 895249423Sdim 896193630Sed// Vector shifts 897249423Sdimdef : Pat<(v16i8 (shl v16i8:$vA, v16i8:$vB)), 898249423Sdim (v16i8 (VSLB $vA, $vB))>; 899249423Sdimdef : Pat<(v8i16 (shl v8i16:$vA, v8i16:$vB)), 900249423Sdim (v8i16 (VSLH $vA, $vB))>; 901249423Sdimdef : Pat<(v4i32 (shl v4i32:$vA, v4i32:$vB)), 902249423Sdim (v4i32 (VSLW $vA, $vB))>; 903193630Sed 904249423Sdimdef : Pat<(v16i8 (srl v16i8:$vA, v16i8:$vB)), 905249423Sdim (v16i8 (VSRB $vA, $vB))>; 906249423Sdimdef : Pat<(v8i16 (srl v8i16:$vA, v8i16:$vB)), 907249423Sdim (v8i16 (VSRH $vA, $vB))>; 908249423Sdimdef : Pat<(v4i32 (srl v4i32:$vA, v4i32:$vB)), 909249423Sdim (v4i32 (VSRW $vA, $vB))>; 910193630Sed 911249423Sdimdef : Pat<(v16i8 (sra v16i8:$vA, v16i8:$vB)), 912249423Sdim (v16i8 (VSRAB $vA, $vB))>; 913249423Sdimdef : Pat<(v8i16 (sra v8i16:$vA, v8i16:$vB)), 914249423Sdim (v8i16 (VSRAH $vA, $vB))>; 915249423Sdimdef : Pat<(v4i32 (sra v4i32:$vA, v4i32:$vB)), 916249423Sdim (v4i32 (VSRAW $vA, $vB))>; 917243830Sdim 918243830Sdim// Float to integer and integer to float conversions 919249423Sdimdef : Pat<(v4i32 (fp_to_sint v4f32:$vA)), 920249423Sdim (VCTSXS_0 $vA)>; 921249423Sdimdef : Pat<(v4i32 (fp_to_uint v4f32:$vA)), 922249423Sdim (VCTUXS_0 $vA)>; 923249423Sdimdef : Pat<(v4f32 (sint_to_fp v4i32:$vA)), 924249423Sdim (VCFSX_0 $vA)>; 925249423Sdimdef : Pat<(v4f32 (uint_to_fp v4i32:$vA)), 926249423Sdim (VCFUX_0 $vA)>; 927249423Sdim 928249423Sdim// Floating-point rounding 929249423Sdimdef : Pat<(v4f32 (ffloor v4f32:$vA)), 930249423Sdim (VRFIM $vA)>; 931249423Sdimdef : Pat<(v4f32 (fceil v4f32:$vA)), 932249423Sdim (VRFIP $vA)>; 933249423Sdimdef : Pat<(v4f32 (ftrunc v4f32:$vA)), 934249423Sdim (VRFIZ $vA)>; 935249423Sdimdef : Pat<(v4f32 (fnearbyint v4f32:$vA)), 936249423Sdim (VRFIN $vA)>; 937249423Sdim 938249423Sdim} // end HasAltivec 939249423Sdim 940