blob: d6f260d9fbd39bae3cd093e7ad37eb39cc7e2f84 [file] [log] [blame]
Hal Finkel27774d92014-03-13 07:58:58 +00001//===- PPCInstrVSX.td - The PowerPC VSX Extension --*- tablegen -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This file describes the VSX extension to the PowerPC instruction set.
11//
12//===----------------------------------------------------------------------===//
13
Bill Schmidtfe723b92015-04-27 19:57:34 +000014// *********************************** NOTE ***********************************
15// ** For POWER8 Little Endian, the VSX swap optimization relies on knowing **
16// ** which VMX and VSX instructions are lane-sensitive and which are not. **
17// ** A lane-sensitive instruction relies, implicitly or explicitly, on **
18// ** whether lanes are numbered from left to right. An instruction like **
19// ** VADDFP is not lane-sensitive, because each lane of the result vector **
20// ** relies only on the corresponding lane of the source vectors. However, **
21// ** an instruction like VMULESB is lane-sensitive, because "even" and **
22// ** "odd" lanes are different for big-endian and little-endian numbering. **
23// ** **
24// ** When adding new VMX and VSX instructions, please consider whether they **
25// ** are lane-sensitive. If so, they must be added to a switch statement **
26// ** in PPCVSXSwapRemoval::gatherVectorInstructions(). **
27// ****************************************************************************
28
Hal Finkel27774d92014-03-13 07:58:58 +000029def PPCRegVSRCAsmOperand : AsmOperandClass {
30 let Name = "RegVSRC"; let PredicateMethod = "isVSRegNumber";
31}
32def vsrc : RegisterOperand<VSRC> {
33 let ParserMatchClass = PPCRegVSRCAsmOperand;
34}
35
Hal Finkel19be5062014-03-29 05:29:01 +000036def PPCRegVSFRCAsmOperand : AsmOperandClass {
37 let Name = "RegVSFRC"; let PredicateMethod = "isVSRegNumber";
38}
39def vsfrc : RegisterOperand<VSFRC> {
40 let ParserMatchClass = PPCRegVSFRCAsmOperand;
41}
42
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +000043def PPCRegVSSRCAsmOperand : AsmOperandClass {
44 let Name = "RegVSSRC"; let PredicateMethod = "isVSRegNumber";
45}
46def vssrc : RegisterOperand<VSSRC> {
47 let ParserMatchClass = PPCRegVSSRCAsmOperand;
48}
49
Zaara Syedafcd96972017-09-21 16:12:33 +000050def PPCRegSPILLTOVSRRCAsmOperand : AsmOperandClass {
51 let Name = "RegSPILLTOVSRRC"; let PredicateMethod = "isVSRegNumber";
52}
53
54def spilltovsrrc : RegisterOperand<SPILLTOVSRRC> {
55 let ParserMatchClass = PPCRegSPILLTOVSRRCAsmOperand;
56}
Bill Schmidtfae5d712014-12-09 16:35:51 +000057// Little-endian-specific nodes.
58def SDT_PPClxvd2x : SDTypeProfile<1, 1, [
59 SDTCisVT<0, v2f64>, SDTCisPtrTy<1>
60]>;
61def SDT_PPCstxvd2x : SDTypeProfile<0, 2, [
62 SDTCisVT<0, v2f64>, SDTCisPtrTy<1>
63]>;
64def SDT_PPCxxswapd : SDTypeProfile<1, 1, [
65 SDTCisSameAs<0, 1>
66]>;
Nemanja Ivanovic44513e52016-07-05 09:22:29 +000067def SDTVecConv : SDTypeProfile<1, 2, [
68 SDTCisVec<0>, SDTCisVec<1>, SDTCisPtrTy<2>
69]>;
Bill Schmidtfae5d712014-12-09 16:35:51 +000070
71def PPClxvd2x : SDNode<"PPCISD::LXVD2X", SDT_PPClxvd2x,
Sean Fertile3c8c3852017-01-26 18:59:15 +000072 [SDNPHasChain, SDNPMayLoad, SDNPMemOperand]>;
Bill Schmidtfae5d712014-12-09 16:35:51 +000073def PPCstxvd2x : SDNode<"PPCISD::STXVD2X", SDT_PPCstxvd2x,
74 [SDNPHasChain, SDNPMayStore]>;
75def PPCxxswapd : SDNode<"PPCISD::XXSWAPD", SDT_PPCxxswapd, [SDNPHasChain]>;
Nemanja Ivanovicc38b5312015-04-11 10:40:42 +000076def PPCmfvsr : SDNode<"PPCISD::MFVSR", SDTUnaryOp, []>;
77def PPCmtvsra : SDNode<"PPCISD::MTVSRA", SDTUnaryOp, []>;
78def PPCmtvsrz : SDNode<"PPCISD::MTVSRZ", SDTUnaryOp, []>;
Nemanja Ivanovic44513e52016-07-05 09:22:29 +000079def PPCsvec2fp : SDNode<"PPCISD::SINT_VEC_TO_FP", SDTVecConv, []>;
80def PPCuvec2fp: SDNode<"PPCISD::UINT_VEC_TO_FP", SDTVecConv, []>;
Nemanja Ivanoviceebbcb62016-07-12 12:16:27 +000081def PPCswapNoChain : SDNode<"PPCISD::SWAP_NO_CHAIN", SDT_PPCxxswapd>;
Bill Schmidtfae5d712014-12-09 16:35:51 +000082
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +000083multiclass XX3Form_Rcr<bits<6> opcode, bits<7> xo, string asmbase,
84 string asmstr, InstrItinClass itin, Intrinsic Int,
85 ValueType OutTy, ValueType InTy> {
Hal Finkel27774d92014-03-13 07:58:58 +000086 let BaseName = asmbase in {
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +000087 def NAME : XX3Form_Rc<opcode, xo, (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +000088 !strconcat(asmbase, !strconcat(" ", asmstr)), itin,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +000089 [(set OutTy:$XT, (Int InTy:$XA, InTy:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +000090 let Defs = [CR6] in
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +000091 def o : XX3Form_Rc<opcode, xo, (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +000092 !strconcat(asmbase, !strconcat(". ", asmstr)), itin,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +000093 [(set InTy:$XT,
94 (InTy (PPCvcmp_o InTy:$XA, InTy:$XB, xo)))]>,
95 isDOT;
Hal Finkel27774d92014-03-13 07:58:58 +000096 }
97}
98
Nemanja Ivanovic11049f82016-10-04 06:59:23 +000099// Instruction form with a single input register for instructions such as
100// XXPERMDI. The reason for defining this is that specifying multiple chained
101// operands (such as loads) to an instruction will perform both chained
102// operations rather than coalescing them into a single register - even though
103// the source memory location is the same. This simply forces the instruction
104// to use the same register for both inputs.
105// For example, an output DAG such as this:
106// (XXPERMDI (LXSIBZX xoaddr:$src), (LXSIBZX xoaddr:$src ), 0))
107// would result in two load instructions emitted and used as separate inputs
108// to the XXPERMDI instruction.
109class XX3Form_2s<bits<6> opcode, bits<5> xo, dag OOL, dag IOL, string asmstr,
110 InstrItinClass itin, list<dag> pattern>
111 : XX3Form_2<opcode, xo, OOL, IOL, asmstr, itin, pattern> {
112 let XB = XA;
113}
114
Eric Christopher1b8e7632014-05-22 01:07:24 +0000115def HasVSX : Predicate<"PPCSubTarget->hasVSX()">;
Bill Schmidtfae5d712014-12-09 16:35:51 +0000116def IsLittleEndian : Predicate<"PPCSubTarget->isLittleEndian()">;
117def IsBigEndian : Predicate<"!PPCSubTarget->isLittleEndian()">;
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +0000118def HasOnlySwappingMemOps : Predicate<"!PPCSubTarget->hasP9Vector()">;
Bill Schmidtfae5d712014-12-09 16:35:51 +0000119
Hal Finkel27774d92014-03-13 07:58:58 +0000120let Predicates = [HasVSX] in {
121let AddedComplexity = 400 in { // Prefer VSX patterns over non-VSX patterns.
Nemanja Ivanovic11049f82016-10-04 06:59:23 +0000122let UseVSXReg = 1 in {
Craig Topperc50d64b2014-11-26 00:46:26 +0000123let hasSideEffects = 0 in { // VSX instructions don't have side effects.
Hal Finkel27774d92014-03-13 07:58:58 +0000124let Uses = [RM] in {
125
126 // Load indexed instructions
Sean Fertile3c8c3852017-01-26 18:59:15 +0000127 let mayLoad = 1, mayStore = 0 in {
Nemanja Ivanovic6354d232016-10-04 11:25:52 +0000128 let CodeSize = 3 in
Stefan Pintilie26d4f922018-03-26 17:39:18 +0000129 def LXSDX : XX1Form_memOp<31, 588,
Hal Finkel19be5062014-03-29 05:29:01 +0000130 (outs vsfrc:$XT), (ins memrr:$src),
Hal Finkel27774d92014-03-13 07:58:58 +0000131 "lxsdx $XT, $src", IIC_LdStLFD,
Lei Huangf4ec6782018-05-24 03:20:28 +0000132 []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000133
Tony Jiang438bf4a2017-11-20 14:38:30 +0000134 // Pseudo instruction XFLOADf64 will be expanded to LXSDX or LFDX later
135 let isPseudo = 1, CodeSize = 3 in
Stefan Pintilie26d4f922018-03-26 17:39:18 +0000136 def XFLOADf64 : PseudoXFormMemOp<(outs vsfrc:$XT), (ins memrr:$src),
Tony Jiang438bf4a2017-11-20 14:38:30 +0000137 "#XFLOADf64",
138 [(set f64:$XT, (load xoaddr:$src))]>;
139
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +0000140 let Predicates = [HasVSX, HasOnlySwappingMemOps] in
Stefan Pintilie26d4f922018-03-26 17:39:18 +0000141 def LXVD2X : XX1Form_memOp<31, 844,
Hal Finkel27774d92014-03-13 07:58:58 +0000142 (outs vsrc:$XT), (ins memrr:$src),
143 "lxvd2x $XT, $src", IIC_LdStLFD,
Bill Schmidt72954782014-11-12 04:19:40 +0000144 [(set v2f64:$XT, (int_ppc_vsx_lxvd2x xoaddr:$src))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000145
Stefan Pintilie26d4f922018-03-26 17:39:18 +0000146 def LXVDSX : XX1Form_memOp<31, 332,
Hal Finkel27774d92014-03-13 07:58:58 +0000147 (outs vsrc:$XT), (ins memrr:$src),
148 "lxvdsx $XT, $src", IIC_LdStLFD, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000149
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +0000150 let Predicates = [HasVSX, HasOnlySwappingMemOps] in
Stefan Pintilie26d4f922018-03-26 17:39:18 +0000151 def LXVW4X : XX1Form_memOp<31, 780,
Hal Finkel27774d92014-03-13 07:58:58 +0000152 (outs vsrc:$XT), (ins memrr:$src),
Bill Schmidt2d1128a2014-10-17 15:13:38 +0000153 "lxvw4x $XT, $src", IIC_LdStLFD,
Nemanja Ivanovicb89c27f2017-05-02 01:47:34 +0000154 []>;
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +0000155 } // mayLoad
Hal Finkel27774d92014-03-13 07:58:58 +0000156
157 // Store indexed instructions
Sean Fertile3c8c3852017-01-26 18:59:15 +0000158 let mayStore = 1, mayLoad = 0 in {
Nemanja Ivanovic6354d232016-10-04 11:25:52 +0000159 let CodeSize = 3 in
Stefan Pintilie26d4f922018-03-26 17:39:18 +0000160 def STXSDX : XX1Form_memOp<31, 716,
Hal Finkel19be5062014-03-29 05:29:01 +0000161 (outs), (ins vsfrc:$XT, memrr:$dst),
Hal Finkel27774d92014-03-13 07:58:58 +0000162 "stxsdx $XT, $dst", IIC_LdStSTFD,
Lei Huangf4ec6782018-05-24 03:20:28 +0000163 []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000164
Tony Jiang438bf4a2017-11-20 14:38:30 +0000165 // Pseudo instruction XFSTOREf64 will be expanded to STXSDX or STFDX later
166 let isPseudo = 1, CodeSize = 3 in
Stefan Pintilie26d4f922018-03-26 17:39:18 +0000167 def XFSTOREf64 : PseudoXFormMemOp<(outs), (ins vsfrc:$XT, memrr:$dst),
Tony Jiang438bf4a2017-11-20 14:38:30 +0000168 "#XFSTOREf64",
169 [(store f64:$XT, xoaddr:$dst)]>;
170
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +0000171 let Predicates = [HasVSX, HasOnlySwappingMemOps] in {
Nemanja Ivanovice78ffed2016-09-22 10:32:03 +0000172 // The behaviour of this instruction is endianness-specific so we provide no
173 // pattern to match it without considering endianness.
Stefan Pintilie26d4f922018-03-26 17:39:18 +0000174 def STXVD2X : XX1Form_memOp<31, 972,
Hal Finkel27774d92014-03-13 07:58:58 +0000175 (outs), (ins vsrc:$XT, memrr:$dst),
176 "stxvd2x $XT, $dst", IIC_LdStSTFD,
Nemanja Ivanovice78ffed2016-09-22 10:32:03 +0000177 []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000178
Stefan Pintilie26d4f922018-03-26 17:39:18 +0000179 def STXVW4X : XX1Form_memOp<31, 908,
Hal Finkel27774d92014-03-13 07:58:58 +0000180 (outs), (ins vsrc:$XT, memrr:$dst),
Bill Schmidt2d1128a2014-10-17 15:13:38 +0000181 "stxvw4x $XT, $dst", IIC_LdStSTFD,
Nemanja Ivanovicb89c27f2017-05-02 01:47:34 +0000182 []>;
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +0000183 }
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +0000184 } // mayStore
Hal Finkel27774d92014-03-13 07:58:58 +0000185
186 // Add/Mul Instructions
187 let isCommutable = 1 in {
188 def XSADDDP : XX3Form<60, 32,
Hal Finkel19be5062014-03-29 05:29:01 +0000189 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000190 "xsadddp $XT, $XA, $XB", IIC_VecFP,
191 [(set f64:$XT, (fadd f64:$XA, f64:$XB))]>;
192 def XSMULDP : XX3Form<60, 48,
Hal Finkel19be5062014-03-29 05:29:01 +0000193 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000194 "xsmuldp $XT, $XA, $XB", IIC_VecFP,
195 [(set f64:$XT, (fmul f64:$XA, f64:$XB))]>;
196
197 def XVADDDP : XX3Form<60, 96,
198 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
199 "xvadddp $XT, $XA, $XB", IIC_VecFP,
200 [(set v2f64:$XT, (fadd v2f64:$XA, v2f64:$XB))]>;
201
202 def XVADDSP : XX3Form<60, 64,
203 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
204 "xvaddsp $XT, $XA, $XB", IIC_VecFP,
205 [(set v4f32:$XT, (fadd v4f32:$XA, v4f32:$XB))]>;
206
207 def XVMULDP : XX3Form<60, 112,
208 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
209 "xvmuldp $XT, $XA, $XB", IIC_VecFP,
210 [(set v2f64:$XT, (fmul v2f64:$XA, v2f64:$XB))]>;
211
212 def XVMULSP : XX3Form<60, 80,
213 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
214 "xvmulsp $XT, $XA, $XB", IIC_VecFP,
215 [(set v4f32:$XT, (fmul v4f32:$XA, v4f32:$XB))]>;
216 }
217
218 // Subtract Instructions
219 def XSSUBDP : XX3Form<60, 40,
Hal Finkel19be5062014-03-29 05:29:01 +0000220 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000221 "xssubdp $XT, $XA, $XB", IIC_VecFP,
222 [(set f64:$XT, (fsub f64:$XA, f64:$XB))]>;
223
224 def XVSUBDP : XX3Form<60, 104,
225 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
226 "xvsubdp $XT, $XA, $XB", IIC_VecFP,
227 [(set v2f64:$XT, (fsub v2f64:$XA, v2f64:$XB))]>;
228 def XVSUBSP : XX3Form<60, 72,
229 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
230 "xvsubsp $XT, $XA, $XB", IIC_VecFP,
231 [(set v4f32:$XT, (fsub v4f32:$XA, v4f32:$XB))]>;
232
233 // FMA Instructions
Hal Finkel25e04542014-03-25 18:55:11 +0000234 let BaseName = "XSMADDADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000235 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000236 def XSMADDADP : XX3Form<60, 33,
Hal Finkel19be5062014-03-29 05:29:01 +0000237 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000238 "xsmaddadp $XT, $XA, $XB", IIC_VecFP,
239 [(set f64:$XT, (fma f64:$XA, f64:$XB, f64:$XTi))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000240 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
241 AltVSXFMARel;
242 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000243 def XSMADDMDP : XX3Form<60, 41,
Hal Finkel19be5062014-03-29 05:29:01 +0000244 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000245 "xsmaddmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000246 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
247 AltVSXFMARel;
248 }
Hal Finkel27774d92014-03-13 07:58:58 +0000249
Hal Finkel25e04542014-03-25 18:55:11 +0000250 let BaseName = "XSMSUBADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000251 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000252 def XSMSUBADP : XX3Form<60, 49,
Hal Finkel19be5062014-03-29 05:29:01 +0000253 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000254 "xsmsubadp $XT, $XA, $XB", IIC_VecFP,
255 [(set f64:$XT, (fma f64:$XA, f64:$XB, (fneg f64:$XTi)))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000256 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
257 AltVSXFMARel;
258 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000259 def XSMSUBMDP : XX3Form<60, 57,
Hal Finkel19be5062014-03-29 05:29:01 +0000260 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000261 "xsmsubmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000262 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
263 AltVSXFMARel;
264 }
Hal Finkel27774d92014-03-13 07:58:58 +0000265
Hal Finkel25e04542014-03-25 18:55:11 +0000266 let BaseName = "XSNMADDADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000267 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000268 def XSNMADDADP : XX3Form<60, 161,
Hal Finkel19be5062014-03-29 05:29:01 +0000269 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000270 "xsnmaddadp $XT, $XA, $XB", IIC_VecFP,
271 [(set f64:$XT, (fneg (fma f64:$XA, f64:$XB, f64:$XTi)))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000272 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
273 AltVSXFMARel;
274 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000275 def XSNMADDMDP : XX3Form<60, 169,
Hal Finkel19be5062014-03-29 05:29:01 +0000276 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000277 "xsnmaddmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000278 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
279 AltVSXFMARel;
280 }
Hal Finkel27774d92014-03-13 07:58:58 +0000281
Hal Finkel25e04542014-03-25 18:55:11 +0000282 let BaseName = "XSNMSUBADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000283 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000284 def XSNMSUBADP : XX3Form<60, 177,
Hal Finkel19be5062014-03-29 05:29:01 +0000285 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000286 "xsnmsubadp $XT, $XA, $XB", IIC_VecFP,
287 [(set f64:$XT, (fneg (fma f64:$XA, f64:$XB, (fneg f64:$XTi))))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000288 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
289 AltVSXFMARel;
290 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000291 def XSNMSUBMDP : XX3Form<60, 185,
Hal Finkel19be5062014-03-29 05:29:01 +0000292 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000293 "xsnmsubmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000294 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
295 AltVSXFMARel;
296 }
Hal Finkel27774d92014-03-13 07:58:58 +0000297
Hal Finkel25e04542014-03-25 18:55:11 +0000298 let BaseName = "XVMADDADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000299 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000300 def XVMADDADP : XX3Form<60, 97,
301 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
302 "xvmaddadp $XT, $XA, $XB", IIC_VecFP,
303 [(set v2f64:$XT, (fma v2f64:$XA, v2f64:$XB, v2f64:$XTi))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000304 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
305 AltVSXFMARel;
306 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000307 def XVMADDMDP : XX3Form<60, 105,
308 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
309 "xvmaddmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000310 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
311 AltVSXFMARel;
312 }
Hal Finkel27774d92014-03-13 07:58:58 +0000313
Hal Finkel25e04542014-03-25 18:55:11 +0000314 let BaseName = "XVMADDASP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000315 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000316 def XVMADDASP : XX3Form<60, 65,
317 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
318 "xvmaddasp $XT, $XA, $XB", IIC_VecFP,
319 [(set v4f32:$XT, (fma v4f32:$XA, v4f32:$XB, v4f32:$XTi))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000320 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
321 AltVSXFMARel;
322 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000323 def XVMADDMSP : XX3Form<60, 73,
324 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
325 "xvmaddmsp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000326 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
327 AltVSXFMARel;
328 }
Hal Finkel27774d92014-03-13 07:58:58 +0000329
Hal Finkel25e04542014-03-25 18:55:11 +0000330 let BaseName = "XVMSUBADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000331 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000332 def XVMSUBADP : XX3Form<60, 113,
333 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
334 "xvmsubadp $XT, $XA, $XB", IIC_VecFP,
335 [(set v2f64:$XT, (fma v2f64:$XA, v2f64:$XB, (fneg v2f64:$XTi)))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000336 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
337 AltVSXFMARel;
338 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000339 def XVMSUBMDP : XX3Form<60, 121,
340 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
341 "xvmsubmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000342 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
343 AltVSXFMARel;
344 }
Hal Finkel27774d92014-03-13 07:58:58 +0000345
Hal Finkel25e04542014-03-25 18:55:11 +0000346 let BaseName = "XVMSUBASP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000347 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000348 def XVMSUBASP : XX3Form<60, 81,
349 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
350 "xvmsubasp $XT, $XA, $XB", IIC_VecFP,
351 [(set v4f32:$XT, (fma v4f32:$XA, v4f32:$XB, (fneg v4f32:$XTi)))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000352 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
353 AltVSXFMARel;
354 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000355 def XVMSUBMSP : XX3Form<60, 89,
356 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
357 "xvmsubmsp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000358 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
359 AltVSXFMARel;
360 }
Hal Finkel27774d92014-03-13 07:58:58 +0000361
Hal Finkel25e04542014-03-25 18:55:11 +0000362 let BaseName = "XVNMADDADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000363 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000364 def XVNMADDADP : XX3Form<60, 225,
365 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
366 "xvnmaddadp $XT, $XA, $XB", IIC_VecFP,
367 [(set v2f64:$XT, (fneg (fma v2f64:$XA, v2f64:$XB, v2f64:$XTi)))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000368 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
369 AltVSXFMARel;
370 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000371 def XVNMADDMDP : XX3Form<60, 233,
372 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
373 "xvnmaddmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000374 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
375 AltVSXFMARel;
376 }
Hal Finkel27774d92014-03-13 07:58:58 +0000377
Hal Finkel25e04542014-03-25 18:55:11 +0000378 let BaseName = "XVNMADDASP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000379 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000380 def XVNMADDASP : XX3Form<60, 193,
381 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
382 "xvnmaddasp $XT, $XA, $XB", IIC_VecFP,
383 [(set v4f32:$XT, (fneg (fma v4f32:$XA, v4f32:$XB, v4f32:$XTi)))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000384 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
385 AltVSXFMARel;
386 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000387 def XVNMADDMSP : XX3Form<60, 201,
388 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
389 "xvnmaddmsp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000390 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
391 AltVSXFMARel;
392 }
Hal Finkel27774d92014-03-13 07:58:58 +0000393
Hal Finkel25e04542014-03-25 18:55:11 +0000394 let BaseName = "XVNMSUBADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000395 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000396 def XVNMSUBADP : XX3Form<60, 241,
397 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
398 "xvnmsubadp $XT, $XA, $XB", IIC_VecFP,
399 [(set v2f64:$XT, (fneg (fma v2f64:$XA, v2f64:$XB, (fneg v2f64:$XTi))))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000400 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
401 AltVSXFMARel;
402 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000403 def XVNMSUBMDP : XX3Form<60, 249,
404 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
405 "xvnmsubmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000406 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
407 AltVSXFMARel;
408 }
Hal Finkel27774d92014-03-13 07:58:58 +0000409
Hal Finkel25e04542014-03-25 18:55:11 +0000410 let BaseName = "XVNMSUBASP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000411 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000412 def XVNMSUBASP : XX3Form<60, 209,
413 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
414 "xvnmsubasp $XT, $XA, $XB", IIC_VecFP,
415 [(set v4f32:$XT, (fneg (fma v4f32:$XA, v4f32:$XB, (fneg v4f32:$XTi))))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000416 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
417 AltVSXFMARel;
418 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000419 def XVNMSUBMSP : XX3Form<60, 217,
420 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
421 "xvnmsubmsp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000422 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
423 AltVSXFMARel;
424 }
Hal Finkel27774d92014-03-13 07:58:58 +0000425
426 // Division Instructions
427 def XSDIVDP : XX3Form<60, 56,
Hal Finkel19be5062014-03-29 05:29:01 +0000428 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000429 "xsdivdp $XT, $XA, $XB", IIC_FPDivD,
Hal Finkel27774d92014-03-13 07:58:58 +0000430 [(set f64:$XT, (fdiv f64:$XA, f64:$XB))]>;
431 def XSSQRTDP : XX2Form<60, 75,
Hal Finkel19be5062014-03-29 05:29:01 +0000432 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000433 "xssqrtdp $XT, $XB", IIC_FPSqrtD,
Hal Finkel27774d92014-03-13 07:58:58 +0000434 [(set f64:$XT, (fsqrt f64:$XB))]>;
435
436 def XSREDP : XX2Form<60, 90,
Hal Finkel19be5062014-03-29 05:29:01 +0000437 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000438 "xsredp $XT, $XB", IIC_VecFP,
439 [(set f64:$XT, (PPCfre f64:$XB))]>;
440 def XSRSQRTEDP : XX2Form<60, 74,
Hal Finkel19be5062014-03-29 05:29:01 +0000441 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000442 "xsrsqrtedp $XT, $XB", IIC_VecFP,
443 [(set f64:$XT, (PPCfrsqrte f64:$XB))]>;
444
445 def XSTDIVDP : XX3Form_1<60, 61,
Hal Finkel19be5062014-03-29 05:29:01 +0000446 (outs crrc:$crD), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000447 "xstdivdp $crD, $XA, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000448 def XSTSQRTDP : XX2Form_1<60, 106,
Hal Finkel19be5062014-03-29 05:29:01 +0000449 (outs crrc:$crD), (ins vsfrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000450 "xstsqrtdp $crD, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000451
452 def XVDIVDP : XX3Form<60, 120,
453 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000454 "xvdivdp $XT, $XA, $XB", IIC_FPDivD,
Hal Finkel27774d92014-03-13 07:58:58 +0000455 [(set v2f64:$XT, (fdiv v2f64:$XA, v2f64:$XB))]>;
456 def XVDIVSP : XX3Form<60, 88,
457 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000458 "xvdivsp $XT, $XA, $XB", IIC_FPDivS,
Hal Finkel27774d92014-03-13 07:58:58 +0000459 [(set v4f32:$XT, (fdiv v4f32:$XA, v4f32:$XB))]>;
460
461 def XVSQRTDP : XX2Form<60, 203,
462 (outs vsrc:$XT), (ins vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000463 "xvsqrtdp $XT, $XB", IIC_FPSqrtD,
Hal Finkel27774d92014-03-13 07:58:58 +0000464 [(set v2f64:$XT, (fsqrt v2f64:$XB))]>;
465 def XVSQRTSP : XX2Form<60, 139,
466 (outs vsrc:$XT), (ins vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000467 "xvsqrtsp $XT, $XB", IIC_FPSqrtS,
Hal Finkel27774d92014-03-13 07:58:58 +0000468 [(set v4f32:$XT, (fsqrt v4f32:$XB))]>;
469
470 def XVTDIVDP : XX3Form_1<60, 125,
471 (outs crrc:$crD), (ins vsrc:$XA, vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000472 "xvtdivdp $crD, $XA, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000473 def XVTDIVSP : XX3Form_1<60, 93,
474 (outs crrc:$crD), (ins vsrc:$XA, vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000475 "xvtdivsp $crD, $XA, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000476
477 def XVTSQRTDP : XX2Form_1<60, 234,
478 (outs crrc:$crD), (ins vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000479 "xvtsqrtdp $crD, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000480 def XVTSQRTSP : XX2Form_1<60, 170,
481 (outs crrc:$crD), (ins vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000482 "xvtsqrtsp $crD, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000483
484 def XVREDP : XX2Form<60, 218,
485 (outs vsrc:$XT), (ins vsrc:$XB),
486 "xvredp $XT, $XB", IIC_VecFP,
487 [(set v2f64:$XT, (PPCfre v2f64:$XB))]>;
488 def XVRESP : XX2Form<60, 154,
489 (outs vsrc:$XT), (ins vsrc:$XB),
490 "xvresp $XT, $XB", IIC_VecFP,
491 [(set v4f32:$XT, (PPCfre v4f32:$XB))]>;
492
493 def XVRSQRTEDP : XX2Form<60, 202,
494 (outs vsrc:$XT), (ins vsrc:$XB),
495 "xvrsqrtedp $XT, $XB", IIC_VecFP,
496 [(set v2f64:$XT, (PPCfrsqrte v2f64:$XB))]>;
497 def XVRSQRTESP : XX2Form<60, 138,
498 (outs vsrc:$XT), (ins vsrc:$XB),
499 "xvrsqrtesp $XT, $XB", IIC_VecFP,
500 [(set v4f32:$XT, (PPCfrsqrte v4f32:$XB))]>;
501
502 // Compare Instructions
503 def XSCMPODP : XX3Form_1<60, 43,
Hal Finkel19be5062014-03-29 05:29:01 +0000504 (outs crrc:$crD), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000505 "xscmpodp $crD, $XA, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000506 def XSCMPUDP : XX3Form_1<60, 35,
Hal Finkel19be5062014-03-29 05:29:01 +0000507 (outs crrc:$crD), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000508 "xscmpudp $crD, $XA, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000509
510 defm XVCMPEQDP : XX3Form_Rcr<60, 99,
Nemanja Ivanovicf502a422015-06-26 19:26:53 +0000511 "xvcmpeqdp", "$XT, $XA, $XB", IIC_VecFPCompare,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +0000512 int_ppc_vsx_xvcmpeqdp, v2i64, v2f64>;
Hal Finkel27774d92014-03-13 07:58:58 +0000513 defm XVCMPEQSP : XX3Form_Rcr<60, 67,
Nemanja Ivanovicf502a422015-06-26 19:26:53 +0000514 "xvcmpeqsp", "$XT, $XA, $XB", IIC_VecFPCompare,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +0000515 int_ppc_vsx_xvcmpeqsp, v4i32, v4f32>;
Hal Finkel27774d92014-03-13 07:58:58 +0000516 defm XVCMPGEDP : XX3Form_Rcr<60, 115,
Nemanja Ivanovicf502a422015-06-26 19:26:53 +0000517 "xvcmpgedp", "$XT, $XA, $XB", IIC_VecFPCompare,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +0000518 int_ppc_vsx_xvcmpgedp, v2i64, v2f64>;
Hal Finkel27774d92014-03-13 07:58:58 +0000519 defm XVCMPGESP : XX3Form_Rcr<60, 83,
Nemanja Ivanovicf502a422015-06-26 19:26:53 +0000520 "xvcmpgesp", "$XT, $XA, $XB", IIC_VecFPCompare,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +0000521 int_ppc_vsx_xvcmpgesp, v4i32, v4f32>;
Hal Finkel27774d92014-03-13 07:58:58 +0000522 defm XVCMPGTDP : XX3Form_Rcr<60, 107,
Nemanja Ivanovicf502a422015-06-26 19:26:53 +0000523 "xvcmpgtdp", "$XT, $XA, $XB", IIC_VecFPCompare,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +0000524 int_ppc_vsx_xvcmpgtdp, v2i64, v2f64>;
Hal Finkel27774d92014-03-13 07:58:58 +0000525 defm XVCMPGTSP : XX3Form_Rcr<60, 75,
Nemanja Ivanovicf502a422015-06-26 19:26:53 +0000526 "xvcmpgtsp", "$XT, $XA, $XB", IIC_VecFPCompare,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +0000527 int_ppc_vsx_xvcmpgtsp, v4i32, v4f32>;
Hal Finkel27774d92014-03-13 07:58:58 +0000528
529 // Move Instructions
530 def XSABSDP : XX2Form<60, 345,
Hal Finkel19be5062014-03-29 05:29:01 +0000531 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000532 "xsabsdp $XT, $XB", IIC_VecFP,
533 [(set f64:$XT, (fabs f64:$XB))]>;
534 def XSNABSDP : XX2Form<60, 361,
Hal Finkel19be5062014-03-29 05:29:01 +0000535 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000536 "xsnabsdp $XT, $XB", IIC_VecFP,
537 [(set f64:$XT, (fneg (fabs f64:$XB)))]>;
538 def XSNEGDP : XX2Form<60, 377,
Hal Finkel19be5062014-03-29 05:29:01 +0000539 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000540 "xsnegdp $XT, $XB", IIC_VecFP,
541 [(set f64:$XT, (fneg f64:$XB))]>;
542 def XSCPSGNDP : XX3Form<60, 176,
Hal Finkel19be5062014-03-29 05:29:01 +0000543 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000544 "xscpsgndp $XT, $XA, $XB", IIC_VecFP,
545 [(set f64:$XT, (fcopysign f64:$XB, f64:$XA))]>;
546
547 def XVABSDP : XX2Form<60, 473,
548 (outs vsrc:$XT), (ins vsrc:$XB),
549 "xvabsdp $XT, $XB", IIC_VecFP,
550 [(set v2f64:$XT, (fabs v2f64:$XB))]>;
551
552 def XVABSSP : XX2Form<60, 409,
553 (outs vsrc:$XT), (ins vsrc:$XB),
554 "xvabssp $XT, $XB", IIC_VecFP,
555 [(set v4f32:$XT, (fabs v4f32:$XB))]>;
556
557 def XVCPSGNDP : XX3Form<60, 240,
558 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
559 "xvcpsgndp $XT, $XA, $XB", IIC_VecFP,
560 [(set v2f64:$XT, (fcopysign v2f64:$XB, v2f64:$XA))]>;
561 def XVCPSGNSP : XX3Form<60, 208,
562 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
563 "xvcpsgnsp $XT, $XA, $XB", IIC_VecFP,
564 [(set v4f32:$XT, (fcopysign v4f32:$XB, v4f32:$XA))]>;
565
566 def XVNABSDP : XX2Form<60, 489,
567 (outs vsrc:$XT), (ins vsrc:$XB),
568 "xvnabsdp $XT, $XB", IIC_VecFP,
569 [(set v2f64:$XT, (fneg (fabs v2f64:$XB)))]>;
570 def XVNABSSP : XX2Form<60, 425,
571 (outs vsrc:$XT), (ins vsrc:$XB),
572 "xvnabssp $XT, $XB", IIC_VecFP,
573 [(set v4f32:$XT, (fneg (fabs v4f32:$XB)))]>;
574
575 def XVNEGDP : XX2Form<60, 505,
576 (outs vsrc:$XT), (ins vsrc:$XB),
577 "xvnegdp $XT, $XB", IIC_VecFP,
578 [(set v2f64:$XT, (fneg v2f64:$XB))]>;
579 def XVNEGSP : XX2Form<60, 441,
580 (outs vsrc:$XT), (ins vsrc:$XB),
581 "xvnegsp $XT, $XB", IIC_VecFP,
582 [(set v4f32:$XT, (fneg v4f32:$XB))]>;
583
584 // Conversion Instructions
585 def XSCVDPSP : XX2Form<60, 265,
Hal Finkel19be5062014-03-29 05:29:01 +0000586 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000587 "xscvdpsp $XT, $XB", IIC_VecFP, []>;
588 def XSCVDPSXDS : XX2Form<60, 344,
Hal Finkel19be5062014-03-29 05:29:01 +0000589 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel4a912252014-03-23 05:35:00 +0000590 "xscvdpsxds $XT, $XB", IIC_VecFP,
591 [(set f64:$XT, (PPCfctidz f64:$XB))]>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +0000592 let isCodeGenOnly = 1 in
593 def XSCVDPSXDSs : XX2Form<60, 344,
594 (outs vssrc:$XT), (ins vssrc:$XB),
595 "xscvdpsxds $XT, $XB", IIC_VecFP,
596 [(set f32:$XT, (PPCfctidz f32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000597 def XSCVDPSXWS : XX2Form<60, 88,
Hal Finkel19be5062014-03-29 05:29:01 +0000598 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel4a912252014-03-23 05:35:00 +0000599 "xscvdpsxws $XT, $XB", IIC_VecFP,
600 [(set f64:$XT, (PPCfctiwz f64:$XB))]>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +0000601 let isCodeGenOnly = 1 in
602 def XSCVDPSXWSs : XX2Form<60, 88,
603 (outs vssrc:$XT), (ins vssrc:$XB),
604 "xscvdpsxws $XT, $XB", IIC_VecFP,
605 [(set f32:$XT, (PPCfctiwz f32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000606 def XSCVDPUXDS : XX2Form<60, 328,
Hal Finkel19be5062014-03-29 05:29:01 +0000607 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel4a912252014-03-23 05:35:00 +0000608 "xscvdpuxds $XT, $XB", IIC_VecFP,
609 [(set f64:$XT, (PPCfctiduz f64:$XB))]>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +0000610 let isCodeGenOnly = 1 in
611 def XSCVDPUXDSs : XX2Form<60, 328,
612 (outs vssrc:$XT), (ins vssrc:$XB),
613 "xscvdpuxds $XT, $XB", IIC_VecFP,
614 [(set f32:$XT, (PPCfctiduz f32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000615 def XSCVDPUXWS : XX2Form<60, 72,
Hal Finkel19be5062014-03-29 05:29:01 +0000616 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel4a912252014-03-23 05:35:00 +0000617 "xscvdpuxws $XT, $XB", IIC_VecFP,
618 [(set f64:$XT, (PPCfctiwuz f64:$XB))]>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +0000619 let isCodeGenOnly = 1 in
620 def XSCVDPUXWSs : XX2Form<60, 72,
621 (outs vssrc:$XT), (ins vssrc:$XB),
622 "xscvdpuxws $XT, $XB", IIC_VecFP,
623 [(set f32:$XT, (PPCfctiwuz f32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000624 def XSCVSPDP : XX2Form<60, 329,
Hal Finkel19be5062014-03-29 05:29:01 +0000625 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000626 "xscvspdp $XT, $XB", IIC_VecFP, []>;
627 def XSCVSXDDP : XX2Form<60, 376,
Hal Finkel19be5062014-03-29 05:29:01 +0000628 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel4a912252014-03-23 05:35:00 +0000629 "xscvsxddp $XT, $XB", IIC_VecFP,
630 [(set f64:$XT, (PPCfcfid f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000631 def XSCVUXDDP : XX2Form<60, 360,
Hal Finkel19be5062014-03-29 05:29:01 +0000632 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel4a912252014-03-23 05:35:00 +0000633 "xscvuxddp $XT, $XB", IIC_VecFP,
634 [(set f64:$XT, (PPCfcfidu f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000635
636 def XVCVDPSP : XX2Form<60, 393,
637 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000638 "xvcvdpsp $XT, $XB", IIC_VecFP,
639 [(set v4f32:$XT, (int_ppc_vsx_xvcvdpsp v2f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000640 def XVCVDPSXDS : XX2Form<60, 472,
641 (outs vsrc:$XT), (ins vsrc:$XB),
Hal Finkel7279f4b2014-03-26 19:13:54 +0000642 "xvcvdpsxds $XT, $XB", IIC_VecFP,
643 [(set v2i64:$XT, (fp_to_sint v2f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000644 def XVCVDPSXWS : XX2Form<60, 216,
645 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000646 "xvcvdpsxws $XT, $XB", IIC_VecFP,
647 [(set v4i32:$XT, (int_ppc_vsx_xvcvdpsxws v2f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000648 def XVCVDPUXDS : XX2Form<60, 456,
649 (outs vsrc:$XT), (ins vsrc:$XB),
Hal Finkel7279f4b2014-03-26 19:13:54 +0000650 "xvcvdpuxds $XT, $XB", IIC_VecFP,
651 [(set v2i64:$XT, (fp_to_uint v2f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000652 def XVCVDPUXWS : XX2Form<60, 200,
653 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000654 "xvcvdpuxws $XT, $XB", IIC_VecFP,
655 [(set v4i32:$XT, (int_ppc_vsx_xvcvdpuxws v2f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000656
657 def XVCVSPDP : XX2Form<60, 457,
658 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000659 "xvcvspdp $XT, $XB", IIC_VecFP,
660 [(set v2f64:$XT, (int_ppc_vsx_xvcvspdp v4f32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000661 def XVCVSPSXDS : XX2Form<60, 408,
662 (outs vsrc:$XT), (ins vsrc:$XB),
663 "xvcvspsxds $XT, $XB", IIC_VecFP, []>;
664 def XVCVSPSXWS : XX2Form<60, 152,
665 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +0000666 "xvcvspsxws $XT, $XB", IIC_VecFP,
667 [(set v4i32:$XT, (fp_to_sint v4f32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000668 def XVCVSPUXDS : XX2Form<60, 392,
669 (outs vsrc:$XT), (ins vsrc:$XB),
670 "xvcvspuxds $XT, $XB", IIC_VecFP, []>;
671 def XVCVSPUXWS : XX2Form<60, 136,
672 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +0000673 "xvcvspuxws $XT, $XB", IIC_VecFP,
674 [(set v4i32:$XT, (fp_to_uint v4f32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000675 def XVCVSXDDP : XX2Form<60, 504,
676 (outs vsrc:$XT), (ins vsrc:$XB),
Hal Finkel7279f4b2014-03-26 19:13:54 +0000677 "xvcvsxddp $XT, $XB", IIC_VecFP,
678 [(set v2f64:$XT, (sint_to_fp v2i64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000679 def XVCVSXDSP : XX2Form<60, 440,
680 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000681 "xvcvsxdsp $XT, $XB", IIC_VecFP,
682 [(set v4f32:$XT, (int_ppc_vsx_xvcvsxdsp v2i64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000683 def XVCVSXWDP : XX2Form<60, 248,
684 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000685 "xvcvsxwdp $XT, $XB", IIC_VecFP,
686 [(set v2f64:$XT, (int_ppc_vsx_xvcvsxwdp v4i32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000687 def XVCVSXWSP : XX2Form<60, 184,
688 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic44513e52016-07-05 09:22:29 +0000689 "xvcvsxwsp $XT, $XB", IIC_VecFP,
690 [(set v4f32:$XT, (sint_to_fp v4i32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000691 def XVCVUXDDP : XX2Form<60, 488,
692 (outs vsrc:$XT), (ins vsrc:$XB),
Hal Finkel7279f4b2014-03-26 19:13:54 +0000693 "xvcvuxddp $XT, $XB", IIC_VecFP,
694 [(set v2f64:$XT, (uint_to_fp v2i64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000695 def XVCVUXDSP : XX2Form<60, 424,
696 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000697 "xvcvuxdsp $XT, $XB", IIC_VecFP,
698 [(set v4f32:$XT, (int_ppc_vsx_xvcvuxdsp v2i64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000699 def XVCVUXWDP : XX2Form<60, 232,
700 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000701 "xvcvuxwdp $XT, $XB", IIC_VecFP,
702 [(set v2f64:$XT, (int_ppc_vsx_xvcvuxwdp v4i32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000703 def XVCVUXWSP : XX2Form<60, 168,
704 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +0000705 "xvcvuxwsp $XT, $XB", IIC_VecFP,
706 [(set v4f32:$XT, (uint_to_fp v4i32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000707
708 // Rounding Instructions
709 def XSRDPI : XX2Form<60, 73,
Hal Finkel19be5062014-03-29 05:29:01 +0000710 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000711 "xsrdpi $XT, $XB", IIC_VecFP,
Michael Kuperstein2bc3d4d2016-08-18 20:08:15 +0000712 [(set f64:$XT, (fround f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000713 def XSRDPIC : XX2Form<60, 107,
Hal Finkel19be5062014-03-29 05:29:01 +0000714 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000715 "xsrdpic $XT, $XB", IIC_VecFP,
716 [(set f64:$XT, (fnearbyint f64:$XB))]>;
717 def XSRDPIM : XX2Form<60, 121,
Hal Finkel19be5062014-03-29 05:29:01 +0000718 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000719 "xsrdpim $XT, $XB", IIC_VecFP,
720 [(set f64:$XT, (ffloor f64:$XB))]>;
721 def XSRDPIP : XX2Form<60, 105,
Hal Finkel19be5062014-03-29 05:29:01 +0000722 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000723 "xsrdpip $XT, $XB", IIC_VecFP,
724 [(set f64:$XT, (fceil f64:$XB))]>;
725 def XSRDPIZ : XX2Form<60, 89,
Hal Finkel19be5062014-03-29 05:29:01 +0000726 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000727 "xsrdpiz $XT, $XB", IIC_VecFP,
728 [(set f64:$XT, (ftrunc f64:$XB))]>;
729
730 def XVRDPI : XX2Form<60, 201,
731 (outs vsrc:$XT), (ins vsrc:$XB),
732 "xvrdpi $XT, $XB", IIC_VecFP,
Michael Kuperstein2bc3d4d2016-08-18 20:08:15 +0000733 [(set v2f64:$XT, (fround v2f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000734 def XVRDPIC : XX2Form<60, 235,
735 (outs vsrc:$XT), (ins vsrc:$XB),
736 "xvrdpic $XT, $XB", IIC_VecFP,
737 [(set v2f64:$XT, (fnearbyint v2f64:$XB))]>;
738 def XVRDPIM : XX2Form<60, 249,
739 (outs vsrc:$XT), (ins vsrc:$XB),
740 "xvrdpim $XT, $XB", IIC_VecFP,
741 [(set v2f64:$XT, (ffloor v2f64:$XB))]>;
742 def XVRDPIP : XX2Form<60, 233,
743 (outs vsrc:$XT), (ins vsrc:$XB),
744 "xvrdpip $XT, $XB", IIC_VecFP,
745 [(set v2f64:$XT, (fceil v2f64:$XB))]>;
746 def XVRDPIZ : XX2Form<60, 217,
747 (outs vsrc:$XT), (ins vsrc:$XB),
748 "xvrdpiz $XT, $XB", IIC_VecFP,
749 [(set v2f64:$XT, (ftrunc v2f64:$XB))]>;
750
751 def XVRSPI : XX2Form<60, 137,
752 (outs vsrc:$XT), (ins vsrc:$XB),
753 "xvrspi $XT, $XB", IIC_VecFP,
Michael Kuperstein2bc3d4d2016-08-18 20:08:15 +0000754 [(set v4f32:$XT, (fround v4f32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000755 def XVRSPIC : XX2Form<60, 171,
756 (outs vsrc:$XT), (ins vsrc:$XB),
757 "xvrspic $XT, $XB", IIC_VecFP,
758 [(set v4f32:$XT, (fnearbyint v4f32:$XB))]>;
759 def XVRSPIM : XX2Form<60, 185,
760 (outs vsrc:$XT), (ins vsrc:$XB),
761 "xvrspim $XT, $XB", IIC_VecFP,
762 [(set v4f32:$XT, (ffloor v4f32:$XB))]>;
763 def XVRSPIP : XX2Form<60, 169,
764 (outs vsrc:$XT), (ins vsrc:$XB),
765 "xvrspip $XT, $XB", IIC_VecFP,
766 [(set v4f32:$XT, (fceil v4f32:$XB))]>;
767 def XVRSPIZ : XX2Form<60, 153,
768 (outs vsrc:$XT), (ins vsrc:$XB),
769 "xvrspiz $XT, $XB", IIC_VecFP,
770 [(set v4f32:$XT, (ftrunc v4f32:$XB))]>;
771
772 // Max/Min Instructions
Hal Finkele01d3212014-03-24 15:07:28 +0000773 let isCommutable = 1 in {
Hal Finkel27774d92014-03-13 07:58:58 +0000774 def XSMAXDP : XX3Form<60, 160,
Hal Finkel19be5062014-03-29 05:29:01 +0000775 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
Bill Schmidt1ca69fa2014-10-31 19:19:07 +0000776 "xsmaxdp $XT, $XA, $XB", IIC_VecFP,
777 [(set vsfrc:$XT,
778 (int_ppc_vsx_xsmaxdp vsfrc:$XA, vsfrc:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000779 def XSMINDP : XX3Form<60, 168,
Hal Finkel19be5062014-03-29 05:29:01 +0000780 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
Bill Schmidt1ca69fa2014-10-31 19:19:07 +0000781 "xsmindp $XT, $XA, $XB", IIC_VecFP,
782 [(set vsfrc:$XT,
783 (int_ppc_vsx_xsmindp vsfrc:$XA, vsfrc:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000784
785 def XVMAXDP : XX3Form<60, 224,
786 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Bill Schmidt1ca69fa2014-10-31 19:19:07 +0000787 "xvmaxdp $XT, $XA, $XB", IIC_VecFP,
788 [(set vsrc:$XT,
789 (int_ppc_vsx_xvmaxdp vsrc:$XA, vsrc:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000790 def XVMINDP : XX3Form<60, 232,
791 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Bill Schmidt1ca69fa2014-10-31 19:19:07 +0000792 "xvmindp $XT, $XA, $XB", IIC_VecFP,
793 [(set vsrc:$XT,
794 (int_ppc_vsx_xvmindp vsrc:$XA, vsrc:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000795
796 def XVMAXSP : XX3Form<60, 192,
797 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Bill Schmidt1ca69fa2014-10-31 19:19:07 +0000798 "xvmaxsp $XT, $XA, $XB", IIC_VecFP,
799 [(set vsrc:$XT,
800 (int_ppc_vsx_xvmaxsp vsrc:$XA, vsrc:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000801 def XVMINSP : XX3Form<60, 200,
802 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Bill Schmidt1ca69fa2014-10-31 19:19:07 +0000803 "xvminsp $XT, $XA, $XB", IIC_VecFP,
804 [(set vsrc:$XT,
805 (int_ppc_vsx_xvminsp vsrc:$XA, vsrc:$XB))]>;
Hal Finkele01d3212014-03-24 15:07:28 +0000806 } // isCommutable
Hal Finkel27774d92014-03-13 07:58:58 +0000807} // Uses = [RM]
808
809 // Logical Instructions
Hal Finkele01d3212014-03-24 15:07:28 +0000810 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000811 def XXLAND : XX3Form<60, 130,
812 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkelbd4de9d2014-03-26 04:55:40 +0000813 "xxland $XT, $XA, $XB", IIC_VecGeneral,
814 [(set v4i32:$XT, (and v4i32:$XA, v4i32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000815 def XXLANDC : XX3Form<60, 138,
816 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkelbd4de9d2014-03-26 04:55:40 +0000817 "xxlandc $XT, $XA, $XB", IIC_VecGeneral,
818 [(set v4i32:$XT, (and v4i32:$XA,
819 (vnot_ppc v4i32:$XB)))]>;
Hal Finkele01d3212014-03-24 15:07:28 +0000820 let isCommutable = 1 in {
Hal Finkel27774d92014-03-13 07:58:58 +0000821 def XXLNOR : XX3Form<60, 162,
822 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkelbd4de9d2014-03-26 04:55:40 +0000823 "xxlnor $XT, $XA, $XB", IIC_VecGeneral,
824 [(set v4i32:$XT, (vnot_ppc (or v4i32:$XA,
825 v4i32:$XB)))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000826 def XXLOR : XX3Form<60, 146,
827 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkelbd4de9d2014-03-26 04:55:40 +0000828 "xxlor $XT, $XA, $XB", IIC_VecGeneral,
829 [(set v4i32:$XT, (or v4i32:$XA, v4i32:$XB))]>;
Hal Finkel19be5062014-03-29 05:29:01 +0000830 let isCodeGenOnly = 1 in
831 def XXLORf: XX3Form<60, 146,
832 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
833 "xxlor $XT, $XA, $XB", IIC_VecGeneral, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000834 def XXLXOR : XX3Form<60, 154,
835 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkelbd4de9d2014-03-26 04:55:40 +0000836 "xxlxor $XT, $XA, $XB", IIC_VecGeneral,
837 [(set v4i32:$XT, (xor v4i32:$XA, v4i32:$XB))]>;
Hal Finkele01d3212014-03-24 15:07:28 +0000838 } // isCommutable
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +0000839 let isCodeGenOnly = 1 in
840 def XXLXORz : XX3Form_Zero<60, 154, (outs vsrc:$XT), (ins),
841 "xxlxor $XT, $XT, $XT", IIC_VecGeneral,
842 [(set v4i32:$XT, (v4i32 immAllZerosV))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000843
Ehsan Amiric90b02c2016-10-24 17:31:09 +0000844 let isCodeGenOnly = 1 in {
845 def XXLXORdpz : XX3Form_SetZero<60, 154,
846 (outs vsfrc:$XT), (ins),
847 "xxlxor $XT, $XT, $XT", IIC_VecGeneral,
848 [(set f64:$XT, (fpimm0))]>;
849 def XXLXORspz : XX3Form_SetZero<60, 154,
850 (outs vssrc:$XT), (ins),
851 "xxlxor $XT, $XT, $XT", IIC_VecGeneral,
852 [(set f32:$XT, (fpimm0))]>;
853 }
854
Hal Finkel27774d92014-03-13 07:58:58 +0000855 // Permutation Instructions
856 def XXMRGHW : XX3Form<60, 18,
857 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
858 "xxmrghw $XT, $XA, $XB", IIC_VecPerm, []>;
859 def XXMRGLW : XX3Form<60, 50,
860 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
861 "xxmrglw $XT, $XA, $XB", IIC_VecPerm, []>;
862
863 def XXPERMDI : XX3Form_2<60, 10,
864 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB, u2imm:$DM),
Tony Jiang60c247d2017-05-31 13:09:57 +0000865 "xxpermdi $XT, $XA, $XB, $DM", IIC_VecPerm,
866 [(set v2i64:$XT, (PPCxxpermdi v2i64:$XA, v2i64:$XB,
867 imm32SExt16:$DM))]>;
Nemanja Ivanovic15748f42016-12-06 11:47:14 +0000868 let isCodeGenOnly = 1 in
869 def XXPERMDIs : XX3Form_2s<60, 10, (outs vsrc:$XT), (ins vsfrc:$XA, u2imm:$DM),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +0000870 "xxpermdi $XT, $XA, $XA, $DM", IIC_VecPerm, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000871 def XXSEL : XX4Form<60, 3,
872 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB, vsrc:$XC),
Nemanja Ivanovic5d06f172018-08-27 13:20:42 +0000873 "xxsel $XT, $XA, $XB, $XC", IIC_VecPerm, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000874
875 def XXSLDWI : XX3Form_2<60, 2,
876 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB, u2imm:$SHW),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +0000877 "xxsldwi $XT, $XA, $XB, $SHW", IIC_VecPerm,
878 [(set v4i32:$XT, (PPCvecshl v4i32:$XA, v4i32:$XB,
879 imm32SExt16:$SHW))]>;
Zaara Syedab2595b92018-08-08 15:20:43 +0000880
881 let isCodeGenOnly = 1 in
882 def XXSLDWIs : XX3Form_2s<60, 2,
883 (outs vsrc:$XT), (ins vsfrc:$XA, u2imm:$SHW),
884 "xxsldwi $XT, $XA, $XA, $SHW", IIC_VecPerm, []>;
885
Hal Finkel27774d92014-03-13 07:58:58 +0000886 def XXSPLTW : XX2Form_2<60, 164,
887 (outs vsrc:$XT), (ins vsrc:$XB, u2imm:$UIM),
Nemanja Ivanovic1a2b2f02016-05-04 16:04:02 +0000888 "xxspltw $XT, $XB, $UIM", IIC_VecPerm,
889 [(set v4i32:$XT,
890 (PPCxxsplt v4i32:$XB, imm32SExt16:$UIM))]>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +0000891 let isCodeGenOnly = 1 in
892 def XXSPLTWs : XX2Form_2<60, 164,
893 (outs vsrc:$XT), (ins vfrc:$XB, u2imm:$UIM),
894 "xxspltw $XT, $XB, $UIM", IIC_VecPerm, []>;
Zaara Syedab2595b92018-08-08 15:20:43 +0000895
Craig Topperc50d64b2014-11-26 00:46:26 +0000896} // hasSideEffects
Nemanja Ivanovic11049f82016-10-04 06:59:23 +0000897} // UseVSXReg = 1
Hal Finkel27774d92014-03-13 07:58:58 +0000898
Bill Schmidt61e65232014-10-22 13:13:40 +0000899// SELECT_CC_* - Used to implement the SELECT_CC DAG operation. Expanded after
900// instruction selection into a branch sequence.
901let usesCustomInserter = 1, // Expanded after instruction selection.
902 PPC970_Single = 1 in {
903
904 def SELECT_CC_VSRC: Pseudo<(outs vsrc:$dst),
905 (ins crrc:$cond, vsrc:$T, vsrc:$F, i32imm:$BROPC),
906 "#SELECT_CC_VSRC",
907 []>;
Bill Schmidt9c54bbd2014-10-22 16:58:20 +0000908 def SELECT_VSRC: Pseudo<(outs vsrc:$dst),
909 (ins crbitrc:$cond, vsrc:$T, vsrc:$F),
910 "#SELECT_VSRC",
Bill Schmidt61e65232014-10-22 13:13:40 +0000911 [(set v2f64:$dst,
912 (select i1:$cond, v2f64:$T, v2f64:$F))]>;
Bill Schmidt9c54bbd2014-10-22 16:58:20 +0000913 def SELECT_CC_VSFRC: Pseudo<(outs f8rc:$dst),
914 (ins crrc:$cond, f8rc:$T, f8rc:$F,
915 i32imm:$BROPC), "#SELECT_CC_VSFRC",
916 []>;
917 def SELECT_VSFRC: Pseudo<(outs f8rc:$dst),
918 (ins crbitrc:$cond, f8rc:$T, f8rc:$F),
919 "#SELECT_VSFRC",
920 [(set f64:$dst,
921 (select i1:$cond, f64:$T, f64:$F))]>;
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +0000922 def SELECT_CC_VSSRC: Pseudo<(outs f4rc:$dst),
923 (ins crrc:$cond, f4rc:$T, f4rc:$F,
924 i32imm:$BROPC), "#SELECT_CC_VSSRC",
925 []>;
926 def SELECT_VSSRC: Pseudo<(outs f4rc:$dst),
927 (ins crbitrc:$cond, f4rc:$T, f4rc:$F),
928 "#SELECT_VSSRC",
929 [(set f32:$dst,
930 (select i1:$cond, f32:$T, f32:$F))]>;
Bill Schmidt9c54bbd2014-10-22 16:58:20 +0000931} // usesCustomInserter
932} // AddedComplexity
Bill Schmidt61e65232014-10-22 13:13:40 +0000933
Hal Finkel27774d92014-03-13 07:58:58 +0000934def : InstAlias<"xvmovdp $XT, $XB",
935 (XVCPSGNDP vsrc:$XT, vsrc:$XB, vsrc:$XB)>;
936def : InstAlias<"xvmovsp $XT, $XB",
937 (XVCPSGNSP vsrc:$XT, vsrc:$XB, vsrc:$XB)>;
938
939def : InstAlias<"xxspltd $XT, $XB, 0",
940 (XXPERMDI vsrc:$XT, vsrc:$XB, vsrc:$XB, 0)>;
941def : InstAlias<"xxspltd $XT, $XB, 1",
942 (XXPERMDI vsrc:$XT, vsrc:$XB, vsrc:$XB, 3)>;
943def : InstAlias<"xxmrghd $XT, $XA, $XB",
944 (XXPERMDI vsrc:$XT, vsrc:$XA, vsrc:$XB, 0)>;
945def : InstAlias<"xxmrgld $XT, $XA, $XB",
946 (XXPERMDI vsrc:$XT, vsrc:$XA, vsrc:$XB, 3)>;
947def : InstAlias<"xxswapd $XT, $XB",
948 (XXPERMDI vsrc:$XT, vsrc:$XB, vsrc:$XB, 2)>;
Nemanja Ivanovic15748f42016-12-06 11:47:14 +0000949def : InstAlias<"xxspltd $XT, $XB, 0",
950 (XXPERMDIs vsrc:$XT, vsfrc:$XB, 0)>;
951def : InstAlias<"xxspltd $XT, $XB, 1",
952 (XXPERMDIs vsrc:$XT, vsfrc:$XB, 3)>;
953def : InstAlias<"xxswapd $XT, $XB",
954 (XXPERMDIs vsrc:$XT, vsfrc:$XB, 2)>;
Hal Finkel27774d92014-03-13 07:58:58 +0000955
956let AddedComplexity = 400 in { // Prefer VSX patterns over non-VSX patterns.
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000957
Nemanja Ivanovic6f22b412016-09-27 08:42:12 +0000958def : Pat<(v4i32 (vnot_ppc v4i32:$A)),
959 (v4i32 (XXLNOR $A, $A))>;
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000960let Predicates = [IsBigEndian] in {
Hal Finkel27774d92014-03-13 07:58:58 +0000961def : Pat<(v2f64 (scalar_to_vector f64:$A)),
Hal Finkel19be5062014-03-29 05:29:01 +0000962 (v2f64 (SUBREG_TO_REG (i64 1), $A, sub_64))>;
Hal Finkel27774d92014-03-13 07:58:58 +0000963
Matt Arsenaultfbd9bbf2015-12-11 19:20:16 +0000964def : Pat<(f64 (extractelt v2f64:$S, 0)),
Hal Finkel19be5062014-03-29 05:29:01 +0000965 (f64 (EXTRACT_SUBREG $S, sub_64))>;
Matt Arsenaultfbd9bbf2015-12-11 19:20:16 +0000966def : Pat<(f64 (extractelt v2f64:$S, 1)),
Hal Finkel19be5062014-03-29 05:29:01 +0000967 (f64 (EXTRACT_SUBREG (XXPERMDI $S, $S, 2), sub_64))>;
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000968}
969
970let Predicates = [IsLittleEndian] in {
971def : Pat<(v2f64 (scalar_to_vector f64:$A)),
972 (v2f64 (XXPERMDI (SUBREG_TO_REG (i64 1), $A, sub_64),
973 (SUBREG_TO_REG (i64 1), $A, sub_64), 0))>;
974
Matt Arsenaultfbd9bbf2015-12-11 19:20:16 +0000975def : Pat<(f64 (extractelt v2f64:$S, 0)),
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000976 (f64 (EXTRACT_SUBREG (XXPERMDI $S, $S, 2), sub_64))>;
Matt Arsenaultfbd9bbf2015-12-11 19:20:16 +0000977def : Pat<(f64 (extractelt v2f64:$S, 1)),
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000978 (f64 (EXTRACT_SUBREG $S, sub_64))>;
979}
Hal Finkel27774d92014-03-13 07:58:58 +0000980
981// Additional fnmsub patterns: -a*c + b == -(a*c - b)
982def : Pat<(fma (fneg f64:$A), f64:$C, f64:$B),
983 (XSNMSUBADP $B, $C, $A)>;
984def : Pat<(fma f64:$A, (fneg f64:$C), f64:$B),
985 (XSNMSUBADP $B, $C, $A)>;
986
987def : Pat<(fma (fneg v2f64:$A), v2f64:$C, v2f64:$B),
988 (XVNMSUBADP $B, $C, $A)>;
989def : Pat<(fma v2f64:$A, (fneg v2f64:$C), v2f64:$B),
990 (XVNMSUBADP $B, $C, $A)>;
991
992def : Pat<(fma (fneg v4f32:$A), v4f32:$C, v4f32:$B),
993 (XVNMSUBASP $B, $C, $A)>;
994def : Pat<(fma v4f32:$A, (fneg v4f32:$C), v4f32:$B),
995 (XVNMSUBASP $B, $C, $A)>;
996
Hal Finkel9e0baa62014-04-01 19:24:27 +0000997def : Pat<(v2f64 (bitconvert v4f32:$A)),
998 (COPY_TO_REGCLASS $A, VSRC)>;
Hal Finkel27774d92014-03-13 07:58:58 +0000999def : Pat<(v2f64 (bitconvert v4i32:$A)),
1000 (COPY_TO_REGCLASS $A, VSRC)>;
1001def : Pat<(v2f64 (bitconvert v8i16:$A)),
1002 (COPY_TO_REGCLASS $A, VSRC)>;
1003def : Pat<(v2f64 (bitconvert v16i8:$A)),
1004 (COPY_TO_REGCLASS $A, VSRC)>;
1005
Hal Finkel9e0baa62014-04-01 19:24:27 +00001006def : Pat<(v4f32 (bitconvert v2f64:$A)),
1007 (COPY_TO_REGCLASS $A, VRRC)>;
Hal Finkel27774d92014-03-13 07:58:58 +00001008def : Pat<(v4i32 (bitconvert v2f64:$A)),
1009 (COPY_TO_REGCLASS $A, VRRC)>;
1010def : Pat<(v8i16 (bitconvert v2f64:$A)),
1011 (COPY_TO_REGCLASS $A, VRRC)>;
1012def : Pat<(v16i8 (bitconvert v2f64:$A)),
1013 (COPY_TO_REGCLASS $A, VRRC)>;
1014
Hal Finkel9e0baa62014-04-01 19:24:27 +00001015def : Pat<(v2i64 (bitconvert v4f32:$A)),
1016 (COPY_TO_REGCLASS $A, VSRC)>;
Hal Finkela6c8b512014-03-26 16:12:58 +00001017def : Pat<(v2i64 (bitconvert v4i32:$A)),
1018 (COPY_TO_REGCLASS $A, VSRC)>;
1019def : Pat<(v2i64 (bitconvert v8i16:$A)),
1020 (COPY_TO_REGCLASS $A, VSRC)>;
1021def : Pat<(v2i64 (bitconvert v16i8:$A)),
1022 (COPY_TO_REGCLASS $A, VSRC)>;
1023
Hal Finkel9e0baa62014-04-01 19:24:27 +00001024def : Pat<(v4f32 (bitconvert v2i64:$A)),
1025 (COPY_TO_REGCLASS $A, VRRC)>;
Hal Finkela6c8b512014-03-26 16:12:58 +00001026def : Pat<(v4i32 (bitconvert v2i64:$A)),
1027 (COPY_TO_REGCLASS $A, VRRC)>;
1028def : Pat<(v8i16 (bitconvert v2i64:$A)),
1029 (COPY_TO_REGCLASS $A, VRRC)>;
1030def : Pat<(v16i8 (bitconvert v2i64:$A)),
1031 (COPY_TO_REGCLASS $A, VRRC)>;
1032
Hal Finkel9281c9a2014-03-26 18:26:30 +00001033def : Pat<(v2f64 (bitconvert v2i64:$A)),
1034 (COPY_TO_REGCLASS $A, VRRC)>;
1035def : Pat<(v2i64 (bitconvert v2f64:$A)),
1036 (COPY_TO_REGCLASS $A, VRRC)>;
1037
Kit Bartond4eb73c2015-05-05 16:10:44 +00001038def : Pat<(v2f64 (bitconvert v1i128:$A)),
1039 (COPY_TO_REGCLASS $A, VRRC)>;
1040def : Pat<(v1i128 (bitconvert v2f64:$A)),
1041 (COPY_TO_REGCLASS $A, VRRC)>;
1042
Stefan Pintilie927e8bf2018-10-23 17:11:36 +00001043def : Pat<(v2i64 (bitconvert f128:$A)),
1044 (COPY_TO_REGCLASS $A, VRRC)>;
1045def : Pat<(v4i32 (bitconvert f128:$A)),
1046 (COPY_TO_REGCLASS $A, VRRC)>;
1047def : Pat<(v8i16 (bitconvert f128:$A)),
1048 (COPY_TO_REGCLASS $A, VRRC)>;
1049def : Pat<(v16i8 (bitconvert f128:$A)),
1050 (COPY_TO_REGCLASS $A, VRRC)>;
1051
Nemanja Ivanovic44513e52016-07-05 09:22:29 +00001052def : Pat<(v2f64 (PPCsvec2fp v4i32:$C, 0)),
1053 (v2f64 (XVCVSXWDP (v2i64 (XXMRGHW $C, $C))))>;
1054def : Pat<(v2f64 (PPCsvec2fp v4i32:$C, 1)),
1055 (v2f64 (XVCVSXWDP (v2i64 (XXMRGLW $C, $C))))>;
1056
1057def : Pat<(v2f64 (PPCuvec2fp v4i32:$C, 0)),
1058 (v2f64 (XVCVUXWDP (v2i64 (XXMRGHW $C, $C))))>;
1059def : Pat<(v2f64 (PPCuvec2fp v4i32:$C, 1)),
1060 (v2f64 (XVCVUXWDP (v2i64 (XXMRGLW $C, $C))))>;
1061
Bill Schmidt2d1128a2014-10-17 15:13:38 +00001062// Loads.
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00001063let Predicates = [HasVSX, HasOnlySwappingMemOps] in {
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00001064 def : Pat<(v2f64 (PPClxvd2x xoaddr:$src)), (LXVD2X xoaddr:$src)>;
Bill Schmidt2d1128a2014-10-17 15:13:38 +00001065
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00001066 // Stores.
1067 def : Pat<(int_ppc_vsx_stxvd2x v2f64:$rS, xoaddr:$dst),
1068 (STXVD2X $rS, xoaddr:$dst)>;
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00001069 def : Pat<(PPCstxvd2x v2f64:$rS, xoaddr:$dst), (STXVD2X $rS, xoaddr:$dst)>;
1070}
Nemanja Ivanovice78ffed2016-09-22 10:32:03 +00001071let Predicates = [IsBigEndian, HasVSX, HasOnlySwappingMemOps] in {
1072 def : Pat<(v2f64 (load xoaddr:$src)), (LXVD2X xoaddr:$src)>;
1073 def : Pat<(v2i64 (load xoaddr:$src)), (LXVD2X xoaddr:$src)>;
1074 def : Pat<(v4i32 (load xoaddr:$src)), (LXVW4X xoaddr:$src)>;
Nemanja Ivanovicb89c27f2017-05-02 01:47:34 +00001075 def : Pat<(v4i32 (int_ppc_vsx_lxvw4x xoaddr:$src)), (LXVW4X xoaddr:$src)>;
Nemanja Ivanovice78ffed2016-09-22 10:32:03 +00001076 def : Pat<(store v2f64:$rS, xoaddr:$dst), (STXVD2X $rS, xoaddr:$dst)>;
1077 def : Pat<(store v2i64:$rS, xoaddr:$dst), (STXVD2X $rS, xoaddr:$dst)>;
Nemanja Ivanovicb89c27f2017-05-02 01:47:34 +00001078 def : Pat<(store v4i32:$XT, xoaddr:$dst), (STXVW4X $XT, xoaddr:$dst)>;
1079 def : Pat<(int_ppc_vsx_stxvw4x v4i32:$rS, xoaddr:$dst),
1080 (STXVW4X $rS, xoaddr:$dst)>;
Nemanja Ivanovice78ffed2016-09-22 10:32:03 +00001081}
Bill Schmidtfae5d712014-12-09 16:35:51 +00001082
1083// Permutes.
1084def : Pat<(v2f64 (PPCxxswapd v2f64:$src)), (XXPERMDI $src, $src, 2)>;
1085def : Pat<(v2i64 (PPCxxswapd v2i64:$src)), (XXPERMDI $src, $src, 2)>;
1086def : Pat<(v4f32 (PPCxxswapd v4f32:$src)), (XXPERMDI $src, $src, 2)>;
1087def : Pat<(v4i32 (PPCxxswapd v4i32:$src)), (XXPERMDI $src, $src, 2)>;
Nemanja Ivanoviceebbcb62016-07-12 12:16:27 +00001088def : Pat<(v2f64 (PPCswapNoChain v2f64:$src)), (XXPERMDI $src, $src, 2)>;
Bill Schmidt2d1128a2014-10-17 15:13:38 +00001089
Tony Jiang0a429f02017-05-24 23:48:29 +00001090// PPCvecshl XT, XA, XA, 2 can be selected to both XXSLDWI XT,XA,XA,2 and
1091// XXSWAPD XT,XA (i.e. XXPERMDI XT,XA,XA,2), the later one is more profitable.
1092def : Pat<(v4i32 (PPCvecshl v4i32:$src, v4i32:$src, 2)), (XXPERMDI $src, $src, 2)>;
1093
Bill Schmidt61e65232014-10-22 13:13:40 +00001094// Selects.
1095def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETLT)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001096 (SELECT_VSRC (CRANDC $lhs, $rhs), $tval, $fval)>;
1097def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETULT)),
Bill Schmidt61e65232014-10-22 13:13:40 +00001098 (SELECT_VSRC (CRANDC $rhs, $lhs), $tval, $fval)>;
1099def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETLE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001100 (SELECT_VSRC (CRORC $lhs, $rhs), $tval, $fval)>;
1101def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETULE)),
Bill Schmidt61e65232014-10-22 13:13:40 +00001102 (SELECT_VSRC (CRORC $rhs, $lhs), $tval, $fval)>;
1103def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETEQ)),
1104 (SELECT_VSRC (CREQV $lhs, $rhs), $tval, $fval)>;
1105def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETGE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001106 (SELECT_VSRC (CRORC $rhs, $lhs), $tval, $fval)>;
1107def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETUGE)),
Bill Schmidt61e65232014-10-22 13:13:40 +00001108 (SELECT_VSRC (CRORC $lhs, $rhs), $tval, $fval)>;
1109def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETGT)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001110 (SELECT_VSRC (CRANDC $rhs, $lhs), $tval, $fval)>;
1111def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETUGT)),
Bill Schmidt61e65232014-10-22 13:13:40 +00001112 (SELECT_VSRC (CRANDC $lhs, $rhs), $tval, $fval)>;
1113def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETNE)),
1114 (SELECT_VSRC (CRXOR $lhs, $rhs), $tval, $fval)>;
1115
Bill Schmidt9c54bbd2014-10-22 16:58:20 +00001116def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETLT)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001117 (SELECT_VSFRC (CRANDC $lhs, $rhs), $tval, $fval)>;
1118def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETULT)),
Bill Schmidt9c54bbd2014-10-22 16:58:20 +00001119 (SELECT_VSFRC (CRANDC $rhs, $lhs), $tval, $fval)>;
1120def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETLE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001121 (SELECT_VSFRC (CRORC $lhs, $rhs), $tval, $fval)>;
1122def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETULE)),
Bill Schmidt9c54bbd2014-10-22 16:58:20 +00001123 (SELECT_VSFRC (CRORC $rhs, $lhs), $tval, $fval)>;
1124def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETEQ)),
1125 (SELECT_VSFRC (CREQV $lhs, $rhs), $tval, $fval)>;
1126def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETGE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001127 (SELECT_VSFRC (CRORC $rhs, $lhs), $tval, $fval)>;
1128def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETUGE)),
Bill Schmidt9c54bbd2014-10-22 16:58:20 +00001129 (SELECT_VSFRC (CRORC $lhs, $rhs), $tval, $fval)>;
1130def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETGT)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001131 (SELECT_VSFRC (CRANDC $rhs, $lhs), $tval, $fval)>;
1132def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETUGT)),
Bill Schmidt9c54bbd2014-10-22 16:58:20 +00001133 (SELECT_VSFRC (CRANDC $lhs, $rhs), $tval, $fval)>;
1134def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETNE)),
1135 (SELECT_VSFRC (CRXOR $lhs, $rhs), $tval, $fval)>;
1136
Bill Schmidt76746922014-11-14 12:10:40 +00001137// Divides.
1138def : Pat<(int_ppc_vsx_xvdivsp v4f32:$A, v4f32:$B),
1139 (XVDIVSP $A, $B)>;
1140def : Pat<(int_ppc_vsx_xvdivdp v2f64:$A, v2f64:$B),
1141 (XVDIVDP $A, $B)>;
1142
Nemanja Ivanovic984a3612015-07-14 17:25:20 +00001143// Reciprocal estimate
1144def : Pat<(int_ppc_vsx_xvresp v4f32:$A),
1145 (XVRESP $A)>;
1146def : Pat<(int_ppc_vsx_xvredp v2f64:$A),
1147 (XVREDP $A)>;
1148
Nemanja Ivanovicd358b8f2015-07-05 06:03:51 +00001149// Recip. square root estimate
1150def : Pat<(int_ppc_vsx_xvrsqrtesp v4f32:$A),
1151 (XVRSQRTESP $A)>;
1152def : Pat<(int_ppc_vsx_xvrsqrtedp v2f64:$A),
1153 (XVRSQRTEDP $A)>;
1154
Zi Xuan Wu6a3c2792018-11-14 02:34:45 +00001155// Vector selection
1156def : Pat<(v16i8 (vselect v16i8:$vA, v16i8:$vB, v16i8:$vC)),
1157 (COPY_TO_REGCLASS
1158 (XXSEL (COPY_TO_REGCLASS $vC, VSRC),
1159 (COPY_TO_REGCLASS $vB, VSRC),
1160 (COPY_TO_REGCLASS $vA, VSRC)), VRRC)>;
1161def : Pat<(v8i16 (vselect v8i16:$vA, v8i16:$vB, v8i16:$vC)),
1162 (COPY_TO_REGCLASS
1163 (XXSEL (COPY_TO_REGCLASS $vC, VSRC),
1164 (COPY_TO_REGCLASS $vB, VSRC),
1165 (COPY_TO_REGCLASS $vA, VSRC)), VRRC)>;
1166def : Pat<(vselect v4i32:$vA, v4i32:$vB, v4i32:$vC),
1167 (XXSEL $vC, $vB, $vA)>;
1168def : Pat<(vselect v2i64:$vA, v2i64:$vB, v2i64:$vC),
1169 (XXSEL $vC, $vB, $vA)>;
1170def : Pat<(vselect v4i32:$vA, v4f32:$vB, v4f32:$vC),
1171 (XXSEL $vC, $vB, $vA)>;
1172def : Pat<(vselect v2i64:$vA, v2f64:$vB, v2f64:$vC),
1173 (XXSEL $vC, $vB, $vA)>;
1174
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001175let Predicates = [IsLittleEndian] in {
1176def : Pat<(f64 (PPCfcfid (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1177 (f64 (XSCVSXDDP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1178def : Pat<(f64 (PPCfcfid (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1179 (f64 (XSCVSXDDP (COPY_TO_REGCLASS (f64 (COPY_TO_REGCLASS $S, VSRC)), VSFRC)))>;
1180def : Pat<(f64 (PPCfcfidu (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1181 (f64 (XSCVUXDDP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1182def : Pat<(f64 (PPCfcfidu (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1183 (f64 (XSCVUXDDP (COPY_TO_REGCLASS (f64 (COPY_TO_REGCLASS $S, VSRC)), VSFRC)))>;
1184} // IsLittleEndian
1185
1186let Predicates = [IsBigEndian] in {
1187def : Pat<(f64 (PPCfcfid (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1188 (f64 (XSCVSXDDP (COPY_TO_REGCLASS $S, VSFRC)))>;
1189def : Pat<(f64 (PPCfcfid (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1190 (f64 (XSCVSXDDP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1191def : Pat<(f64 (PPCfcfidu (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1192 (f64 (XSCVUXDDP (COPY_TO_REGCLASS $S, VSFRC)))>;
1193def : Pat<(f64 (PPCfcfidu (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1194 (f64 (XSCVUXDDP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1195} // IsBigEndian
1196
Hal Finkel27774d92014-03-13 07:58:58 +00001197} // AddedComplexity
1198} // HasVSX
1199
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001200def ScalarLoads {
1201 dag Li8 = (i32 (extloadi8 xoaddr:$src));
1202 dag ZELi8 = (i32 (zextloadi8 xoaddr:$src));
1203 dag ZELi8i64 = (i64 (zextloadi8 xoaddr:$src));
1204 dag SELi8 = (i32 (sext_inreg (extloadi8 xoaddr:$src), i8));
1205 dag SELi8i64 = (i64 (sext_inreg (extloadi8 xoaddr:$src), i8));
1206
1207 dag Li16 = (i32 (extloadi16 xoaddr:$src));
1208 dag ZELi16 = (i32 (zextloadi16 xoaddr:$src));
1209 dag ZELi16i64 = (i64 (zextloadi16 xoaddr:$src));
1210 dag SELi16 = (i32 (sextloadi16 xoaddr:$src));
1211 dag SELi16i64 = (i64 (sextloadi16 xoaddr:$src));
1212
1213 dag Li32 = (i32 (load xoaddr:$src));
1214}
1215
Kit Barton298beb52015-02-18 16:21:46 +00001216// The following VSX instructions were introduced in Power ISA 2.07
1217/* FIXME: if the operands are v2i64, these patterns will not match.
1218 we should define new patterns or otherwise match the same patterns
1219 when the elements are larger than i32.
1220*/
1221def HasP8Vector : Predicate<"PPCSubTarget->hasP8Vector()">;
Nemanja Ivanovicc38b5312015-04-11 10:40:42 +00001222def HasDirectMove : Predicate<"PPCSubTarget->hasDirectMove()">;
Lei Huangc29229a2018-05-08 17:36:40 +00001223def NoP9Vector : Predicate<"!PPCSubTarget->hasP9Vector()">;
Kit Barton298beb52015-02-18 16:21:46 +00001224let Predicates = [HasP8Vector] in {
1225let AddedComplexity = 400 in { // Prefer VSX patterns over non-VSX patterns.
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001226 let isCommutable = 1, UseVSXReg = 1 in {
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001227 def XXLEQV : XX3Form<60, 186,
1228 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
1229 "xxleqv $XT, $XA, $XB", IIC_VecGeneral,
1230 [(set v4i32:$XT, (vnot_ppc (xor v4i32:$XA, v4i32:$XB)))]>;
1231 def XXLNAND : XX3Form<60, 178,
1232 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
1233 "xxlnand $XT, $XA, $XB", IIC_VecGeneral,
1234 [(set v4i32:$XT, (vnot_ppc (and v4i32:$XA,
Kit Barton298beb52015-02-18 16:21:46 +00001235 v4i32:$XB)))]>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001236 } // isCommutable, UseVSXReg
Nemanja Ivanovicd9e4b4f2015-07-10 14:25:17 +00001237
Nemanja Ivanovic5655fb32015-07-10 12:38:08 +00001238 def : Pat<(int_ppc_vsx_xxleqv v4i32:$A, v4i32:$B),
1239 (XXLEQV $A, $B)>;
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001240
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001241 let UseVSXReg = 1 in {
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001242 def XXLORC : XX3Form<60, 170,
1243 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
1244 "xxlorc $XT, $XA, $XB", IIC_VecGeneral,
1245 [(set v4i32:$XT, (or v4i32:$XA, (vnot_ppc v4i32:$XB)))]>;
1246
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +00001247 // VSX scalar loads introduced in ISA 2.07
Sean Fertile3c8c3852017-01-26 18:59:15 +00001248 let mayLoad = 1, mayStore = 0 in {
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00001249 let CodeSize = 3 in
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001250 def LXSSPX : XX1Form_memOp<31, 524, (outs vssrc:$XT), (ins memrr:$src),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001251 "lxsspx $XT, $src", IIC_LdStLFD, []>;
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001252 def LXSIWAX : XX1Form_memOp<31, 76, (outs vsfrc:$XT), (ins memrr:$src),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001253 "lxsiwax $XT, $src", IIC_LdStLFD, []>;
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001254 def LXSIWZX : XX1Form_memOp<31, 12, (outs vsfrc:$XT), (ins memrr:$src),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001255 "lxsiwzx $XT, $src", IIC_LdStLFD, []>;
1256
1257 // Please note let isPseudo = 1 is not part of class Pseudo<>. Missing it
1258 // would cause these Pseudos are not expanded in expandPostRAPseudos()
1259 let isPseudo = 1 in {
1260 // Pseudo instruction XFLOADf32 will be expanded to LXSSPX or LFSX later
1261 let CodeSize = 3 in
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001262 def XFLOADf32 : PseudoXFormMemOp<(outs vssrc:$XT), (ins memrr:$src),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001263 "#XFLOADf32",
1264 [(set f32:$XT, (load xoaddr:$src))]>;
1265 // Pseudo instruction LIWAX will be expanded to LXSIWAX or LFIWAX later
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001266 def LIWAX : PseudoXFormMemOp<(outs vsfrc:$XT), (ins memrr:$src),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001267 "#LIWAX",
1268 [(set f64:$XT, (PPClfiwax xoaddr:$src))]>;
1269 // Pseudo instruction LIWZX will be expanded to LXSIWZX or LFIWZX later
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001270 def LIWZX : PseudoXFormMemOp<(outs vsfrc:$XT), (ins memrr:$src),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001271 "#LIWZX",
1272 [(set f64:$XT, (PPClfiwzx xoaddr:$src))]>;
1273 }
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +00001274 } // mayLoad
1275
1276 // VSX scalar stores introduced in ISA 2.07
Sean Fertile3c8c3852017-01-26 18:59:15 +00001277 let mayStore = 1, mayLoad = 0 in {
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00001278 let CodeSize = 3 in
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001279 def STXSSPX : XX1Form_memOp<31, 652, (outs), (ins vssrc:$XT, memrr:$dst),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001280 "stxsspx $XT, $dst", IIC_LdStSTFD, []>;
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001281 def STXSIWX : XX1Form_memOp<31, 140, (outs), (ins vsfrc:$XT, memrr:$dst),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001282 "stxsiwx $XT, $dst", IIC_LdStSTFD, []>;
1283
1284 // Please note let isPseudo = 1 is not part of class Pseudo<>. Missing it
1285 // would cause these Pseudos are not expanded in expandPostRAPseudos()
1286 let isPseudo = 1 in {
1287 // Pseudo instruction XFSTOREf32 will be expanded to STXSSPX or STFSX later
1288 let CodeSize = 3 in
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001289 def XFSTOREf32 : PseudoXFormMemOp<(outs), (ins vssrc:$XT, memrr:$dst),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001290 "#XFSTOREf32",
1291 [(store f32:$XT, xoaddr:$dst)]>;
1292 // Pseudo instruction STIWX will be expanded to STXSIWX or STFIWX later
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001293 def STIWX : PseudoXFormMemOp<(outs), (ins vsfrc:$XT, memrr:$dst),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001294 "#STIWX",
1295 [(PPCstfiwx f64:$XT, xoaddr:$dst)]>;
1296 }
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +00001297 } // mayStore
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001298 } // UseVSXReg = 1
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001299
1300 def : Pat<(f64 (extloadf32 xoaddr:$src)),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001301 (COPY_TO_REGCLASS (XFLOADf32 xoaddr:$src), VSFRC)>;
Lei Huangcd4f3852018-03-12 19:26:18 +00001302 def : Pat<(f32 (fpround (f64 (extloadf32 xoaddr:$src)))),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001303 (f32 (XFLOADf32 xoaddr:$src))>;
Michael Kuperstein2bc3d4d2016-08-18 20:08:15 +00001304 def : Pat<(f64 (fpextend f32:$src)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001305 (COPY_TO_REGCLASS $src, VSFRC)>;
Hal Finkela2cdbce2015-08-30 22:12:50 +00001306
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001307 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETLT)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001308 (SELECT_VSSRC (CRANDC $lhs, $rhs), $tval, $fval)>;
1309 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETULT)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001310 (SELECT_VSSRC (CRANDC $rhs, $lhs), $tval, $fval)>;
1311 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETLE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001312 (SELECT_VSSRC (CRORC $lhs, $rhs), $tval, $fval)>;
1313 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETULE)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001314 (SELECT_VSSRC (CRORC $rhs, $lhs), $tval, $fval)>;
1315 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETEQ)),
1316 (SELECT_VSSRC (CREQV $lhs, $rhs), $tval, $fval)>;
1317 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETGE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001318 (SELECT_VSSRC (CRORC $rhs, $lhs), $tval, $fval)>;
1319 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETUGE)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001320 (SELECT_VSSRC (CRORC $lhs, $rhs), $tval, $fval)>;
1321 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETGT)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001322 (SELECT_VSSRC (CRANDC $rhs, $lhs), $tval, $fval)>;
1323 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETUGT)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001324 (SELECT_VSSRC (CRANDC $lhs, $rhs), $tval, $fval)>;
1325 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETNE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001326 (SELECT_VSSRC (CRXOR $lhs, $rhs), $tval, $fval)>;
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001327
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001328 let UseVSXReg = 1 in {
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001329 // VSX Elementary Scalar FP arithmetic (SP)
1330 let isCommutable = 1 in {
1331 def XSADDSP : XX3Form<60, 0,
1332 (outs vssrc:$XT), (ins vssrc:$XA, vssrc:$XB),
1333 "xsaddsp $XT, $XA, $XB", IIC_VecFP,
1334 [(set f32:$XT, (fadd f32:$XA, f32:$XB))]>;
1335 def XSMULSP : XX3Form<60, 16,
1336 (outs vssrc:$XT), (ins vssrc:$XA, vssrc:$XB),
1337 "xsmulsp $XT, $XA, $XB", IIC_VecFP,
1338 [(set f32:$XT, (fmul f32:$XA, f32:$XB))]>;
1339 } // isCommutable
1340
1341 def XSDIVSP : XX3Form<60, 24,
1342 (outs vssrc:$XT), (ins vssrc:$XA, vssrc:$XB),
1343 "xsdivsp $XT, $XA, $XB", IIC_FPDivS,
1344 [(set f32:$XT, (fdiv f32:$XA, f32:$XB))]>;
1345 def XSRESP : XX2Form<60, 26,
1346 (outs vssrc:$XT), (ins vssrc:$XB),
1347 "xsresp $XT, $XB", IIC_VecFP,
1348 [(set f32:$XT, (PPCfre f32:$XB))]>;
Lei Huang6270ab62018-07-04 21:59:16 +00001349 def XSRSP : XX2Form<60, 281,
1350 (outs vssrc:$XT), (ins vsfrc:$XB),
1351 "xsrsp $XT, $XB", IIC_VecFP, []>;
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001352 def XSSQRTSP : XX2Form<60, 11,
1353 (outs vssrc:$XT), (ins vssrc:$XB),
1354 "xssqrtsp $XT, $XB", IIC_FPSqrtS,
1355 [(set f32:$XT, (fsqrt f32:$XB))]>;
1356 def XSRSQRTESP : XX2Form<60, 10,
1357 (outs vssrc:$XT), (ins vssrc:$XB),
1358 "xsrsqrtesp $XT, $XB", IIC_VecFP,
1359 [(set f32:$XT, (PPCfrsqrte f32:$XB))]>;
1360 def XSSUBSP : XX3Form<60, 8,
1361 (outs vssrc:$XT), (ins vssrc:$XA, vssrc:$XB),
1362 "xssubsp $XT, $XA, $XB", IIC_VecFP,
1363 [(set f32:$XT, (fsub f32:$XA, f32:$XB))]>;
Nemanja Ivanovic376e1732015-05-29 17:13:25 +00001364
1365 // FMA Instructions
1366 let BaseName = "XSMADDASP" in {
1367 let isCommutable = 1 in
1368 def XSMADDASP : XX3Form<60, 1,
1369 (outs vssrc:$XT),
1370 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1371 "xsmaddasp $XT, $XA, $XB", IIC_VecFP,
1372 [(set f32:$XT, (fma f32:$XA, f32:$XB, f32:$XTi))]>,
1373 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1374 AltVSXFMARel;
1375 let IsVSXFMAAlt = 1 in
1376 def XSMADDMSP : XX3Form<60, 9,
1377 (outs vssrc:$XT),
1378 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1379 "xsmaddmsp $XT, $XA, $XB", IIC_VecFP, []>,
1380 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1381 AltVSXFMARel;
1382 }
1383
1384 let BaseName = "XSMSUBASP" in {
1385 let isCommutable = 1 in
1386 def XSMSUBASP : XX3Form<60, 17,
1387 (outs vssrc:$XT),
1388 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1389 "xsmsubasp $XT, $XA, $XB", IIC_VecFP,
1390 [(set f32:$XT, (fma f32:$XA, f32:$XB,
1391 (fneg f32:$XTi)))]>,
1392 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1393 AltVSXFMARel;
1394 let IsVSXFMAAlt = 1 in
1395 def XSMSUBMSP : XX3Form<60, 25,
1396 (outs vssrc:$XT),
1397 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1398 "xsmsubmsp $XT, $XA, $XB", IIC_VecFP, []>,
1399 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1400 AltVSXFMARel;
1401 }
1402
1403 let BaseName = "XSNMADDASP" in {
1404 let isCommutable = 1 in
1405 def XSNMADDASP : XX3Form<60, 129,
1406 (outs vssrc:$XT),
1407 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1408 "xsnmaddasp $XT, $XA, $XB", IIC_VecFP,
1409 [(set f32:$XT, (fneg (fma f32:$XA, f32:$XB,
1410 f32:$XTi)))]>,
1411 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1412 AltVSXFMARel;
1413 let IsVSXFMAAlt = 1 in
1414 def XSNMADDMSP : XX3Form<60, 137,
1415 (outs vssrc:$XT),
1416 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1417 "xsnmaddmsp $XT, $XA, $XB", IIC_VecFP, []>,
1418 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1419 AltVSXFMARel;
1420 }
1421
1422 let BaseName = "XSNMSUBASP" in {
1423 let isCommutable = 1 in
1424 def XSNMSUBASP : XX3Form<60, 145,
1425 (outs vssrc:$XT),
1426 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1427 "xsnmsubasp $XT, $XA, $XB", IIC_VecFP,
1428 [(set f32:$XT, (fneg (fma f32:$XA, f32:$XB,
1429 (fneg f32:$XTi))))]>,
1430 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1431 AltVSXFMARel;
1432 let IsVSXFMAAlt = 1 in
1433 def XSNMSUBMSP : XX3Form<60, 153,
1434 (outs vssrc:$XT),
1435 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1436 "xsnmsubmsp $XT, $XA, $XB", IIC_VecFP, []>,
1437 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1438 AltVSXFMARel;
1439 }
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001440
1441 // Single Precision Conversions (FP <-> INT)
1442 def XSCVSXDSP : XX2Form<60, 312,
1443 (outs vssrc:$XT), (ins vsfrc:$XB),
1444 "xscvsxdsp $XT, $XB", IIC_VecFP,
1445 [(set f32:$XT, (PPCfcfids f64:$XB))]>;
1446 def XSCVUXDSP : XX2Form<60, 296,
1447 (outs vssrc:$XT), (ins vsfrc:$XB),
1448 "xscvuxdsp $XT, $XB", IIC_VecFP,
1449 [(set f32:$XT, (PPCfcfidus f64:$XB))]>;
1450
1451 // Conversions between vector and scalar single precision
1452 def XSCVDPSPN : XX2Form<60, 267, (outs vsrc:$XT), (ins vssrc:$XB),
1453 "xscvdpspn $XT, $XB", IIC_VecFP, []>;
1454 def XSCVSPDPN : XX2Form<60, 331, (outs vssrc:$XT), (ins vsrc:$XB),
1455 "xscvspdpn $XT, $XB", IIC_VecFP, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001456 } // UseVSXReg = 1
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001457
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001458 let Predicates = [IsLittleEndian] in {
Lei Huangcd4f3852018-03-12 19:26:18 +00001459 def : Pat<(f32 (PPCfcfids
1460 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 0)))))),
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001461 (f32 (XSCVSXDSP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00001462 def : Pat<(f32 (PPCfcfids
1463 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 1)))))),
1464 (f32 (XSCVSXDSP (COPY_TO_REGCLASS
1465 (f64 (COPY_TO_REGCLASS $S, VSRC)), VSFRC)))>;
1466 def : Pat<(f32 (PPCfcfidus
1467 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 0)))))),
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001468 (f32 (XSCVUXDSP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00001469 def : Pat<(f32 (PPCfcfidus
1470 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 1)))))),
1471 (f32 (XSCVUXDSP (COPY_TO_REGCLASS
1472 (f64 (COPY_TO_REGCLASS $S, VSRC)), VSFRC)))>;
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001473 }
1474
1475 let Predicates = [IsBigEndian] in {
Lei Huangcd4f3852018-03-12 19:26:18 +00001476 def : Pat<(f32 (PPCfcfids
1477 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 0)))))),
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001478 (f32 (XSCVSXDSP (COPY_TO_REGCLASS $S, VSFRC)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00001479 def : Pat<(f32 (PPCfcfids
1480 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 1)))))),
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001481 (f32 (XSCVSXDSP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00001482 def : Pat<(f32 (PPCfcfidus
1483 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 0)))))),
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001484 (f32 (XSCVUXDSP (COPY_TO_REGCLASS $S, VSFRC)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00001485 def : Pat<(f32 (PPCfcfidus
1486 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 1)))))),
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001487 (f32 (XSCVUXDSP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1488 }
Lei Huangc29229a2018-05-08 17:36:40 +00001489
1490 // Instructions for converting float to i64 feeding a store.
1491 let Predicates = [NoP9Vector] in {
1492 def : Pat<(PPCstore_scal_int_from_vsr
1493 (f64 (PPCcv_fp_to_sint_in_vsr f64:$src)), xoaddr:$dst, 8),
1494 (STXSDX (XSCVDPSXDS f64:$src), xoaddr:$dst)>;
1495 def : Pat<(PPCstore_scal_int_from_vsr
1496 (f64 (PPCcv_fp_to_uint_in_vsr f64:$src)), xoaddr:$dst, 8),
1497 (STXSDX (XSCVDPUXDS f64:$src), xoaddr:$dst)>;
1498 }
1499
1500 // Instructions for converting float to i32 feeding a store.
1501 def : Pat<(PPCstore_scal_int_from_vsr
1502 (f64 (PPCcv_fp_to_sint_in_vsr f64:$src)), xoaddr:$dst, 4),
1503 (STIWX (XSCVDPSXWS f64:$src), xoaddr:$dst)>;
1504 def : Pat<(PPCstore_scal_int_from_vsr
1505 (f64 (PPCcv_fp_to_uint_in_vsr f64:$src)), xoaddr:$dst, 4),
1506 (STIWX (XSCVDPUXWS f64:$src), xoaddr:$dst)>;
1507
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +00001508} // AddedComplexity = 400
Kit Barton298beb52015-02-18 16:21:46 +00001509} // HasP8Vector
Nemanja Ivanovicc38b5312015-04-11 10:40:42 +00001510
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00001511let UseVSXReg = 1, AddedComplexity = 400 in {
Ehsan Amiri99b017a2016-03-31 17:47:17 +00001512let Predicates = [HasDirectMove] in {
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001513 // VSX direct move instructions
1514 def MFVSRD : XX1_RS6_RD5_XO<31, 51, (outs g8rc:$rA), (ins vsfrc:$XT),
1515 "mfvsrd $rA, $XT", IIC_VecGeneral,
1516 [(set i64:$rA, (PPCmfvsr f64:$XT))]>,
1517 Requires<[In64BitMode]>;
Nemanja Ivanovicffcf0fb2017-03-15 16:04:53 +00001518 let isCodeGenOnly = 1 in
1519 def MFVRD : XX1_RS6_RD5_XO<31, 51, (outs g8rc:$rA), (ins vrrc:$XT),
1520 "mfvsrd $rA, $XT", IIC_VecGeneral,
1521 []>,
1522 Requires<[In64BitMode]>;
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001523 def MFVSRWZ : XX1_RS6_RD5_XO<31, 115, (outs gprc:$rA), (ins vsfrc:$XT),
1524 "mfvsrwz $rA, $XT", IIC_VecGeneral,
1525 [(set i32:$rA, (PPCmfvsr f64:$XT))]>;
1526 def MTVSRD : XX1_RS6_RD5_XO<31, 179, (outs vsfrc:$XT), (ins g8rc:$rA),
1527 "mtvsrd $XT, $rA", IIC_VecGeneral,
1528 [(set f64:$XT, (PPCmtvsra i64:$rA))]>,
1529 Requires<[In64BitMode]>;
1530 def MTVSRWA : XX1_RS6_RD5_XO<31, 211, (outs vsfrc:$XT), (ins gprc:$rA),
1531 "mtvsrwa $XT, $rA", IIC_VecGeneral,
1532 [(set f64:$XT, (PPCmtvsra i32:$rA))]>;
1533 def MTVSRWZ : XX1_RS6_RD5_XO<31, 243, (outs vsfrc:$XT), (ins gprc:$rA),
1534 "mtvsrwz $XT, $rA", IIC_VecGeneral,
1535 [(set f64:$XT, (PPCmtvsrz i32:$rA))]>;
Ehsan Amiri99b017a2016-03-31 17:47:17 +00001536} // HasDirectMove
1537
1538let Predicates = [IsISA3_0, HasDirectMove] in {
1539 def MTVSRWS: XX1_RS6_RD5_XO<31, 403, (outs vsrc:$XT), (ins gprc:$rA),
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00001540 "mtvsrws $XT, $rA", IIC_VecGeneral, []>;
Ehsan Amiri99b017a2016-03-31 17:47:17 +00001541
Guozhi Wei22e7da92017-05-11 22:17:35 +00001542 def MTVSRDD: XX1Form<31, 435, (outs vsrc:$XT), (ins g8rc_nox0:$rA, g8rc:$rB),
Ehsan Amiri99b017a2016-03-31 17:47:17 +00001543 "mtvsrdd $XT, $rA, $rB", IIC_VecGeneral,
1544 []>, Requires<[In64BitMode]>;
1545
1546 def MFVSRLD: XX1_RS6_RD5_XO<31, 307, (outs g8rc:$rA), (ins vsrc:$XT),
1547 "mfvsrld $rA, $XT", IIC_VecGeneral,
1548 []>, Requires<[In64BitMode]>;
1549
1550} // IsISA3_0, HasDirectMove
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001551} // UseVSXReg = 1
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001552
Nemanja Ivanovicffcf0fb2017-03-15 16:04:53 +00001553// We want to parse this from asm, but we don't want to emit this as it would
1554// be emitted with a VSX reg. So leave Emit = 0 here.
1555def : InstAlias<"mfvrd $rA, $XT",
1556 (MFVRD g8rc:$rA, vrrc:$XT), 0>;
1557def : InstAlias<"mffprd $rA, $src",
1558 (MFVSRD g8rc:$rA, f8rc:$src)>;
1559
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001560/* Direct moves of various widths from GPR's into VSR's. Each move lines
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001561 the value up into element 0 (both BE and LE). Namely, entities smaller than
1562 a doubleword are shifted left and moved for BE. For LE, they're moved, then
1563 swapped to go into the least significant element of the VSR.
1564*/
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001565def MovesToVSR {
1566 dag BE_BYTE_0 =
1567 (MTVSRD
1568 (RLDICR
1569 (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $A, sub_32), 56, 7));
1570 dag BE_HALF_0 =
1571 (MTVSRD
1572 (RLDICR
1573 (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $A, sub_32), 48, 15));
1574 dag BE_WORD_0 =
1575 (MTVSRD
1576 (RLDICR
1577 (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $A, sub_32), 32, 31));
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001578 dag BE_DWORD_0 = (MTVSRD $A);
1579
1580 dag LE_MTVSRW = (MTVSRD (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $A, sub_32));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001581 dag LE_WORD_1 = (v2i64 (INSERT_SUBREG (v2i64 (IMPLICIT_DEF)),
1582 LE_MTVSRW, sub_64));
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001583 dag LE_WORD_0 = (XXPERMDI LE_WORD_1, LE_WORD_1, 2);
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001584 dag LE_DWORD_1 = (v2i64 (INSERT_SUBREG (v2i64 (IMPLICIT_DEF)),
1585 BE_DWORD_0, sub_64));
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001586 dag LE_DWORD_0 = (XXPERMDI LE_DWORD_1, LE_DWORD_1, 2);
1587}
1588
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001589/* Patterns for extracting elements out of vectors. Integer elements are
1590 extracted using direct move operations. Patterns for extracting elements
1591 whose indices are not available at compile time are also provided with
1592 various _VARIABLE_ patterns.
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001593 The numbering for the DAG's is for LE, but when used on BE, the correct
1594 LE element can just be used (i.e. LE_BYTE_2 == BE_BYTE_13).
1595*/
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001596def VectorExtractions {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001597 // Doubleword extraction
1598 dag LE_DWORD_0 =
1599 (MFVSRD
1600 (EXTRACT_SUBREG
1601 (XXPERMDI (COPY_TO_REGCLASS $S, VSRC),
1602 (COPY_TO_REGCLASS $S, VSRC), 2), sub_64));
1603 dag LE_DWORD_1 = (MFVSRD
1604 (EXTRACT_SUBREG
1605 (v2i64 (COPY_TO_REGCLASS $S, VSRC)), sub_64));
1606
1607 // Word extraction
Nemanja Ivanoviceebbcb62016-07-12 12:16:27 +00001608 dag LE_WORD_0 = (MFVSRWZ (EXTRACT_SUBREG (XXPERMDI $S, $S, 2), sub_64));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001609 dag LE_WORD_1 = (MFVSRWZ (EXTRACT_SUBREG (XXSLDWI $S, $S, 1), sub_64));
1610 dag LE_WORD_2 = (MFVSRWZ (EXTRACT_SUBREG
1611 (v2i64 (COPY_TO_REGCLASS $S, VSRC)), sub_64));
1612 dag LE_WORD_3 = (MFVSRWZ (EXTRACT_SUBREG (XXSLDWI $S, $S, 3), sub_64));
1613
1614 // Halfword extraction
1615 dag LE_HALF_0 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 0, 48), sub_32));
1616 dag LE_HALF_1 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 48, 48), sub_32));
1617 dag LE_HALF_2 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 32, 48), sub_32));
1618 dag LE_HALF_3 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 16, 48), sub_32));
1619 dag LE_HALF_4 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 0, 48), sub_32));
1620 dag LE_HALF_5 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 48, 48), sub_32));
1621 dag LE_HALF_6 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 32, 48), sub_32));
1622 dag LE_HALF_7 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 16, 48), sub_32));
1623
1624 // Byte extraction
1625 dag LE_BYTE_0 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 0, 56), sub_32));
1626 dag LE_BYTE_1 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 56, 56), sub_32));
1627 dag LE_BYTE_2 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 48, 56), sub_32));
1628 dag LE_BYTE_3 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 40, 56), sub_32));
1629 dag LE_BYTE_4 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 32, 56), sub_32));
1630 dag LE_BYTE_5 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 24, 56), sub_32));
1631 dag LE_BYTE_6 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 16, 56), sub_32));
1632 dag LE_BYTE_7 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 8, 56), sub_32));
1633 dag LE_BYTE_8 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 0, 56), sub_32));
1634 dag LE_BYTE_9 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 56, 56), sub_32));
1635 dag LE_BYTE_10 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 48, 56), sub_32));
1636 dag LE_BYTE_11 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 40, 56), sub_32));
1637 dag LE_BYTE_12 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 32, 56), sub_32));
1638 dag LE_BYTE_13 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 24, 56), sub_32));
1639 dag LE_BYTE_14 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 16, 56), sub_32));
1640 dag LE_BYTE_15 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 8, 56), sub_32));
1641
1642 /* Variable element number (BE and LE patterns must be specified separately)
1643 This is a rather involved process.
1644
1645 Conceptually, this is how the move is accomplished:
1646 1. Identify which doubleword contains the element
1647 2. Shift in the VMX register so that the correct doubleword is correctly
1648 lined up for the MFVSRD
1649 3. Perform the move so that the element (along with some extra stuff)
1650 is in the GPR
1651 4. Right shift within the GPR so that the element is right-justified
1652
1653 Of course, the index is an element number which has a different meaning
1654 on LE/BE so the patterns have to be specified separately.
1655
1656 Note: The final result will be the element right-justified with high
1657 order bits being arbitrarily defined (namely, whatever was in the
1658 vector register to the left of the value originally).
1659 */
1660
1661 /* LE variable byte
1662 Number 1. above:
1663 - For elements 0-7, we shift left by 8 bytes since they're on the right
1664 - For elements 8-15, we need not shift (shift left by zero bytes)
1665 This is accomplished by inverting the bits of the index and AND-ing
1666 with 0x8 (i.e. clearing all bits of the index and inverting bit 60).
1667 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001668 dag LE_VBYTE_PERM_VEC = (v16i8 (LVSL ZERO8, (ANDC8 (LI8 8), $Idx)));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001669
1670 // Number 2. above:
1671 // - Now that we set up the shift amount, we shift in the VMX register
Lei Huangcd4f3852018-03-12 19:26:18 +00001672 dag LE_VBYTE_PERMUTE = (v16i8 (VPERM $S, $S, LE_VBYTE_PERM_VEC));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001673
1674 // Number 3. above:
1675 // - The doubleword containing our element is moved to a GPR
1676 dag LE_MV_VBYTE = (MFVSRD
1677 (EXTRACT_SUBREG
1678 (v2i64 (COPY_TO_REGCLASS LE_VBYTE_PERMUTE, VSRC)),
1679 sub_64));
1680
1681 /* Number 4. above:
1682 - Truncate the element number to the range 0-7 (8-15 are symmetrical
1683 and out of range values are truncated accordingly)
1684 - Multiply by 8 as we need to shift right by the number of bits, not bytes
1685 - Shift right in the GPR by the calculated value
1686 */
1687 dag LE_VBYTE_SHIFT = (EXTRACT_SUBREG (RLDICR (AND8 (LI8 7), $Idx), 3, 60),
1688 sub_32);
1689 dag LE_VARIABLE_BYTE = (EXTRACT_SUBREG (SRD LE_MV_VBYTE, LE_VBYTE_SHIFT),
1690 sub_32);
1691
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001692 /* LE variable halfword
1693 Number 1. above:
1694 - For elements 0-3, we shift left by 8 since they're on the right
1695 - For elements 4-7, we need not shift (shift left by zero bytes)
1696 Similarly to the byte pattern, we invert the bits of the index, but we
1697 AND with 0x4 (i.e. clear all bits of the index and invert bit 61).
1698 Of course, the shift is still by 8 bytes, so we must multiply by 2.
1699 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001700 dag LE_VHALF_PERM_VEC =
1701 (v16i8 (LVSL ZERO8, (RLDICR (ANDC8 (LI8 4), $Idx), 1, 62)));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001702
1703 // Number 2. above:
1704 // - Now that we set up the shift amount, we shift in the VMX register
Lei Huangcd4f3852018-03-12 19:26:18 +00001705 dag LE_VHALF_PERMUTE = (v16i8 (VPERM $S, $S, LE_VHALF_PERM_VEC));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001706
1707 // Number 3. above:
1708 // - The doubleword containing our element is moved to a GPR
1709 dag LE_MV_VHALF = (MFVSRD
1710 (EXTRACT_SUBREG
1711 (v2i64 (COPY_TO_REGCLASS LE_VHALF_PERMUTE, VSRC)),
1712 sub_64));
1713
1714 /* Number 4. above:
1715 - Truncate the element number to the range 0-3 (4-7 are symmetrical
1716 and out of range values are truncated accordingly)
1717 - Multiply by 16 as we need to shift right by the number of bits
1718 - Shift right in the GPR by the calculated value
1719 */
1720 dag LE_VHALF_SHIFT = (EXTRACT_SUBREG (RLDICR (AND8 (LI8 3), $Idx), 4, 59),
1721 sub_32);
1722 dag LE_VARIABLE_HALF = (EXTRACT_SUBREG (SRD LE_MV_VHALF, LE_VHALF_SHIFT),
1723 sub_32);
1724
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001725 /* LE variable word
1726 Number 1. above:
1727 - For elements 0-1, we shift left by 8 since they're on the right
1728 - For elements 2-3, we need not shift
1729 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001730 dag LE_VWORD_PERM_VEC = (v16i8 (LVSL ZERO8,
1731 (RLDICR (ANDC8 (LI8 2), $Idx), 2, 61)));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001732
1733 // Number 2. above:
1734 // - Now that we set up the shift amount, we shift in the VMX register
Lei Huangcd4f3852018-03-12 19:26:18 +00001735 dag LE_VWORD_PERMUTE = (v16i8 (VPERM $S, $S, LE_VWORD_PERM_VEC));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001736
1737 // Number 3. above:
1738 // - The doubleword containing our element is moved to a GPR
1739 dag LE_MV_VWORD = (MFVSRD
1740 (EXTRACT_SUBREG
1741 (v2i64 (COPY_TO_REGCLASS LE_VWORD_PERMUTE, VSRC)),
1742 sub_64));
1743
1744 /* Number 4. above:
1745 - Truncate the element number to the range 0-1 (2-3 are symmetrical
1746 and out of range values are truncated accordingly)
1747 - Multiply by 32 as we need to shift right by the number of bits
1748 - Shift right in the GPR by the calculated value
1749 */
1750 dag LE_VWORD_SHIFT = (EXTRACT_SUBREG (RLDICR (AND8 (LI8 1), $Idx), 5, 58),
1751 sub_32);
1752 dag LE_VARIABLE_WORD = (EXTRACT_SUBREG (SRD LE_MV_VWORD, LE_VWORD_SHIFT),
1753 sub_32);
1754
1755 /* LE variable doubleword
1756 Number 1. above:
1757 - For element 0, we shift left by 8 since it's on the right
1758 - For element 1, we need not shift
1759 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001760 dag LE_VDWORD_PERM_VEC = (v16i8 (LVSL ZERO8,
1761 (RLDICR (ANDC8 (LI8 1), $Idx), 3, 60)));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001762
1763 // Number 2. above:
1764 // - Now that we set up the shift amount, we shift in the VMX register
Lei Huangcd4f3852018-03-12 19:26:18 +00001765 dag LE_VDWORD_PERMUTE = (v16i8 (VPERM $S, $S, LE_VDWORD_PERM_VEC));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001766
1767 // Number 3. above:
1768 // - The doubleword containing our element is moved to a GPR
1769 // - Number 4. is not needed for the doubleword as the value is 64-bits
1770 dag LE_VARIABLE_DWORD =
1771 (MFVSRD (EXTRACT_SUBREG
1772 (v2i64 (COPY_TO_REGCLASS LE_VDWORD_PERMUTE, VSRC)),
1773 sub_64));
1774
1775 /* LE variable float
1776 - Shift the vector to line up the desired element to BE Word 0
1777 - Convert 32-bit float to a 64-bit single precision float
1778 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001779 dag LE_VFLOAT_PERM_VEC = (v16i8 (LVSL ZERO8,
1780 (RLDICR (XOR8 (LI8 3), $Idx), 2, 61)));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001781 dag LE_VFLOAT_PERMUTE = (VPERM $S, $S, LE_VFLOAT_PERM_VEC);
1782 dag LE_VARIABLE_FLOAT = (XSCVSPDPN LE_VFLOAT_PERMUTE);
1783
1784 /* LE variable double
1785 Same as the LE doubleword except there is no move.
1786 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001787 dag LE_VDOUBLE_PERMUTE = (v16i8 (VPERM (v16i8 (COPY_TO_REGCLASS $S, VRRC)),
1788 (v16i8 (COPY_TO_REGCLASS $S, VRRC)),
1789 LE_VDWORD_PERM_VEC));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001790 dag LE_VARIABLE_DOUBLE = (COPY_TO_REGCLASS LE_VDOUBLE_PERMUTE, VSRC);
1791
1792 /* BE variable byte
1793 The algorithm here is the same as the LE variable byte except:
1794 - The shift in the VMX register is by 0/8 for opposite element numbers so
1795 we simply AND the element number with 0x8
1796 - The order of elements after the move to GPR is reversed, so we invert
1797 the bits of the index prior to truncating to the range 0-7
1798 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001799 dag BE_VBYTE_PERM_VEC = (v16i8 (LVSL ZERO8, (ANDIo8 $Idx, 8)));
1800 dag BE_VBYTE_PERMUTE = (v16i8 (VPERM $S, $S, BE_VBYTE_PERM_VEC));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001801 dag BE_MV_VBYTE = (MFVSRD
1802 (EXTRACT_SUBREG
1803 (v2i64 (COPY_TO_REGCLASS BE_VBYTE_PERMUTE, VSRC)),
1804 sub_64));
1805 dag BE_VBYTE_SHIFT = (EXTRACT_SUBREG (RLDICR (ANDC8 (LI8 7), $Idx), 3, 60),
1806 sub_32);
1807 dag BE_VARIABLE_BYTE = (EXTRACT_SUBREG (SRD BE_MV_VBYTE, BE_VBYTE_SHIFT),
1808 sub_32);
1809
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001810 /* BE variable halfword
1811 The algorithm here is the same as the LE variable halfword except:
1812 - The shift in the VMX register is by 0/8 for opposite element numbers so
1813 we simply AND the element number with 0x4 and multiply by 2
1814 - The order of elements after the move to GPR is reversed, so we invert
1815 the bits of the index prior to truncating to the range 0-3
1816 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001817 dag BE_VHALF_PERM_VEC = (v16i8 (LVSL ZERO8,
1818 (RLDICR (ANDIo8 $Idx, 4), 1, 62)));
1819 dag BE_VHALF_PERMUTE = (v16i8 (VPERM $S, $S, BE_VHALF_PERM_VEC));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001820 dag BE_MV_VHALF = (MFVSRD
1821 (EXTRACT_SUBREG
1822 (v2i64 (COPY_TO_REGCLASS BE_VHALF_PERMUTE, VSRC)),
1823 sub_64));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001824 dag BE_VHALF_SHIFT = (EXTRACT_SUBREG (RLDICR (ANDC8 (LI8 3), $Idx), 4, 59),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001825 sub_32);
1826 dag BE_VARIABLE_HALF = (EXTRACT_SUBREG (SRD BE_MV_VHALF, BE_VHALF_SHIFT),
1827 sub_32);
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001828
1829 /* BE variable word
1830 The algorithm is the same as the LE variable word except:
1831 - The shift in the VMX register happens for opposite element numbers
1832 - The order of elements after the move to GPR is reversed, so we invert
1833 the bits of the index prior to truncating to the range 0-1
1834 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001835 dag BE_VWORD_PERM_VEC = (v16i8 (LVSL ZERO8,
1836 (RLDICR (ANDIo8 $Idx, 2), 2, 61)));
1837 dag BE_VWORD_PERMUTE = (v16i8 (VPERM $S, $S, BE_VWORD_PERM_VEC));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001838 dag BE_MV_VWORD = (MFVSRD
1839 (EXTRACT_SUBREG
1840 (v2i64 (COPY_TO_REGCLASS BE_VWORD_PERMUTE, VSRC)),
1841 sub_64));
1842 dag BE_VWORD_SHIFT = (EXTRACT_SUBREG (RLDICR (ANDC8 (LI8 1), $Idx), 5, 58),
1843 sub_32);
1844 dag BE_VARIABLE_WORD = (EXTRACT_SUBREG (SRD BE_MV_VWORD, BE_VWORD_SHIFT),
1845 sub_32);
1846
1847 /* BE variable doubleword
1848 Same as the LE doubleword except we shift in the VMX register for opposite
1849 element indices.
1850 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001851 dag BE_VDWORD_PERM_VEC = (v16i8 (LVSL ZERO8,
1852 (RLDICR (ANDIo8 $Idx, 1), 3, 60)));
1853 dag BE_VDWORD_PERMUTE = (v16i8 (VPERM $S, $S, BE_VDWORD_PERM_VEC));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001854 dag BE_VARIABLE_DWORD =
1855 (MFVSRD (EXTRACT_SUBREG
1856 (v2i64 (COPY_TO_REGCLASS BE_VDWORD_PERMUTE, VSRC)),
1857 sub_64));
1858
1859 /* BE variable float
1860 - Shift the vector to line up the desired element to BE Word 0
1861 - Convert 32-bit float to a 64-bit single precision float
1862 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001863 dag BE_VFLOAT_PERM_VEC = (v16i8 (LVSL ZERO8, (RLDICR $Idx, 2, 61)));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001864 dag BE_VFLOAT_PERMUTE = (VPERM $S, $S, BE_VFLOAT_PERM_VEC);
1865 dag BE_VARIABLE_FLOAT = (XSCVSPDPN BE_VFLOAT_PERMUTE);
1866
1867 /* BE variable double
1868 Same as the BE doubleword except there is no move.
1869 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001870 dag BE_VDOUBLE_PERMUTE = (v16i8 (VPERM (v16i8 (COPY_TO_REGCLASS $S, VRRC)),
1871 (v16i8 (COPY_TO_REGCLASS $S, VRRC)),
1872 BE_VDWORD_PERM_VEC));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001873 dag BE_VARIABLE_DOUBLE = (COPY_TO_REGCLASS BE_VDOUBLE_PERMUTE, VSRC);
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001874}
1875
Zaara Syeda48cb3c12017-11-27 17:11:03 +00001876def NoP9Altivec : Predicate<"!PPCSubTarget->hasP9Altivec()">;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00001877let AddedComplexity = 400 in {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001878// v4f32 scalar <-> vector conversions (BE)
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001879let Predicates = [IsBigEndian, HasP8Vector] in {
1880 def : Pat<(v4f32 (scalar_to_vector f32:$A)),
1881 (v4f32 (XSCVDPSPN $A))>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001882 def : Pat<(f32 (vector_extract v4f32:$S, 0)),
1883 (f32 (XSCVSPDPN $S))>;
1884 def : Pat<(f32 (vector_extract v4f32:$S, 1)),
1885 (f32 (XSCVSPDPN (XXSLDWI $S, $S, 1)))>;
1886 def : Pat<(f32 (vector_extract v4f32:$S, 2)),
Nemanja Ivanoviceebbcb62016-07-12 12:16:27 +00001887 (f32 (XSCVSPDPN (XXPERMDI $S, $S, 2)))>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001888 def : Pat<(f32 (vector_extract v4f32:$S, 3)),
1889 (f32 (XSCVSPDPN (XXSLDWI $S, $S, 3)))>;
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001890 def : Pat<(f32 (vector_extract v4f32:$S, i64:$Idx)),
1891 (f32 VectorExtractions.BE_VARIABLE_FLOAT)>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001892} // IsBigEndian, HasP8Vector
1893
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001894// Variable index vector_extract for v2f64 does not require P8Vector
1895let Predicates = [IsBigEndian, HasVSX] in
1896 def : Pat<(f64 (vector_extract v2f64:$S, i64:$Idx)),
1897 (f64 VectorExtractions.BE_VARIABLE_DOUBLE)>;
1898
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001899let Predicates = [IsBigEndian, HasDirectMove] in {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001900 // v16i8 scalar <-> vector conversions (BE)
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001901 def : Pat<(v16i8 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001902 (v16i8 (SUBREG_TO_REG (i64 1), MovesToVSR.BE_BYTE_0, sub_64))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001903 def : Pat<(v8i16 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001904 (v8i16 (SUBREG_TO_REG (i64 1), MovesToVSR.BE_HALF_0, sub_64))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001905 def : Pat<(v4i32 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001906 (v4i32 (SUBREG_TO_REG (i64 1), MovesToVSR.BE_WORD_0, sub_64))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001907 def : Pat<(v2i64 (scalar_to_vector i64:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001908 (v2i64 (SUBREG_TO_REG (i64 1), MovesToVSR.BE_DWORD_0, sub_64))>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00001909
1910 // v2i64 scalar <-> vector conversions (BE)
1911 def : Pat<(i64 (vector_extract v2i64:$S, 0)),
1912 (i64 VectorExtractions.LE_DWORD_1)>;
1913 def : Pat<(i64 (vector_extract v2i64:$S, 1)),
1914 (i64 VectorExtractions.LE_DWORD_0)>;
1915 def : Pat<(i64 (vector_extract v2i64:$S, i64:$Idx)),
1916 (i64 VectorExtractions.BE_VARIABLE_DWORD)>;
1917} // IsBigEndian, HasDirectMove
1918
1919let Predicates = [IsBigEndian, HasDirectMove, NoP9Altivec] in {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001920 def : Pat<(i32 (vector_extract v16i8:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001921 (i32 VectorExtractions.LE_BYTE_15)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001922 def : Pat<(i32 (vector_extract v16i8:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001923 (i32 VectorExtractions.LE_BYTE_14)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001924 def : Pat<(i32 (vector_extract v16i8:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001925 (i32 VectorExtractions.LE_BYTE_13)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001926 def : Pat<(i32 (vector_extract v16i8:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001927 (i32 VectorExtractions.LE_BYTE_12)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001928 def : Pat<(i32 (vector_extract v16i8:$S, 4)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001929 (i32 VectorExtractions.LE_BYTE_11)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001930 def : Pat<(i32 (vector_extract v16i8:$S, 5)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001931 (i32 VectorExtractions.LE_BYTE_10)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001932 def : Pat<(i32 (vector_extract v16i8:$S, 6)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001933 (i32 VectorExtractions.LE_BYTE_9)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001934 def : Pat<(i32 (vector_extract v16i8:$S, 7)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001935 (i32 VectorExtractions.LE_BYTE_8)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001936 def : Pat<(i32 (vector_extract v16i8:$S, 8)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001937 (i32 VectorExtractions.LE_BYTE_7)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001938 def : Pat<(i32 (vector_extract v16i8:$S, 9)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001939 (i32 VectorExtractions.LE_BYTE_6)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001940 def : Pat<(i32 (vector_extract v16i8:$S, 10)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001941 (i32 VectorExtractions.LE_BYTE_5)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001942 def : Pat<(i32 (vector_extract v16i8:$S, 11)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001943 (i32 VectorExtractions.LE_BYTE_4)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001944 def : Pat<(i32 (vector_extract v16i8:$S, 12)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001945 (i32 VectorExtractions.LE_BYTE_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001946 def : Pat<(i32 (vector_extract v16i8:$S, 13)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001947 (i32 VectorExtractions.LE_BYTE_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001948 def : Pat<(i32 (vector_extract v16i8:$S, 14)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001949 (i32 VectorExtractions.LE_BYTE_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001950 def : Pat<(i32 (vector_extract v16i8:$S, 15)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001951 (i32 VectorExtractions.LE_BYTE_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001952 def : Pat<(i32 (vector_extract v16i8:$S, i64:$Idx)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001953 (i32 VectorExtractions.BE_VARIABLE_BYTE)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001954
1955 // v8i16 scalar <-> vector conversions (BE)
1956 def : Pat<(i32 (vector_extract v8i16:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001957 (i32 VectorExtractions.LE_HALF_7)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001958 def : Pat<(i32 (vector_extract v8i16:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001959 (i32 VectorExtractions.LE_HALF_6)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001960 def : Pat<(i32 (vector_extract v8i16:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001961 (i32 VectorExtractions.LE_HALF_5)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001962 def : Pat<(i32 (vector_extract v8i16:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001963 (i32 VectorExtractions.LE_HALF_4)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001964 def : Pat<(i32 (vector_extract v8i16:$S, 4)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001965 (i32 VectorExtractions.LE_HALF_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001966 def : Pat<(i32 (vector_extract v8i16:$S, 5)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001967 (i32 VectorExtractions.LE_HALF_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001968 def : Pat<(i32 (vector_extract v8i16:$S, 6)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001969 (i32 VectorExtractions.LE_HALF_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001970 def : Pat<(i32 (vector_extract v8i16:$S, 7)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001971 (i32 VectorExtractions.LE_HALF_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001972 def : Pat<(i32 (vector_extract v8i16:$S, i64:$Idx)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001973 (i32 VectorExtractions.BE_VARIABLE_HALF)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001974
1975 // v4i32 scalar <-> vector conversions (BE)
1976 def : Pat<(i32 (vector_extract v4i32:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001977 (i32 VectorExtractions.LE_WORD_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001978 def : Pat<(i32 (vector_extract v4i32:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001979 (i32 VectorExtractions.LE_WORD_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001980 def : Pat<(i32 (vector_extract v4i32:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001981 (i32 VectorExtractions.LE_WORD_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001982 def : Pat<(i32 (vector_extract v4i32:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001983 (i32 VectorExtractions.LE_WORD_0)>;
1984 def : Pat<(i32 (vector_extract v4i32:$S, i64:$Idx)),
1985 (i32 VectorExtractions.BE_VARIABLE_WORD)>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00001986} // IsBigEndian, HasDirectMove, NoP9Altivec
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001987
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001988// v4f32 scalar <-> vector conversions (LE)
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001989let Predicates = [IsLittleEndian, HasP8Vector] in {
1990 def : Pat<(v4f32 (scalar_to_vector f32:$A)),
1991 (v4f32 (XXSLDWI (XSCVDPSPN $A), (XSCVDPSPN $A), 1))>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001992 def : Pat<(f32 (vector_extract v4f32:$S, 0)),
1993 (f32 (XSCVSPDPN (XXSLDWI $S, $S, 3)))>;
1994 def : Pat<(f32 (vector_extract v4f32:$S, 1)),
Nemanja Ivanoviceebbcb62016-07-12 12:16:27 +00001995 (f32 (XSCVSPDPN (XXPERMDI $S, $S, 2)))>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001996 def : Pat<(f32 (vector_extract v4f32:$S, 2)),
1997 (f32 (XSCVSPDPN (XXSLDWI $S, $S, 1)))>;
1998 def : Pat<(f32 (vector_extract v4f32:$S, 3)),
1999 (f32 (XSCVSPDPN $S))>;
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002000 def : Pat<(f32 (vector_extract v4f32:$S, i64:$Idx)),
2001 (f32 VectorExtractions.LE_VARIABLE_FLOAT)>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00002002} // IsLittleEndian, HasP8Vector
2003
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002004// Variable index vector_extract for v2f64 does not require P8Vector
2005let Predicates = [IsLittleEndian, HasVSX] in
2006 def : Pat<(f64 (vector_extract v2f64:$S, i64:$Idx)),
2007 (f64 VectorExtractions.LE_VARIABLE_DOUBLE)>;
2008
Zaara Syeda75098802018-11-05 17:31:26 +00002009def : Pat<(int_ppc_vsx_stxvd2x_be v2f64:$rS, xoaddr:$dst),
2010 (STXVD2X $rS, xoaddr:$dst)>;
2011def : Pat<(int_ppc_vsx_stxvw4x_be v4i32:$rS, xoaddr:$dst),
2012 (STXVW4X $rS, xoaddr:$dst)>;
Nemanja Ivanovicb89c27f2017-05-02 01:47:34 +00002013def : Pat<(v4i32 (int_ppc_vsx_lxvw4x_be xoaddr:$src)), (LXVW4X xoaddr:$src)>;
2014def : Pat<(v2f64 (int_ppc_vsx_lxvd2x_be xoaddr:$src)), (LXVD2X xoaddr:$src)>;
Tony Jiang5f850cd2016-11-15 14:25:56 +00002015
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002016// Variable index unsigned vector_extract on Power9
2017let Predicates = [HasP9Altivec, IsLittleEndian] in {
2018 def : Pat<(i64 (anyext (i32 (vector_extract v16i8:$S, i64:$Idx)))),
2019 (VEXTUBRX $Idx, $S)>;
2020
2021 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, i64:$Idx)))),
2022 (VEXTUHRX (RLWINM8 $Idx, 1, 28, 30), $S)>;
2023 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 0)))),
2024 (VEXTUHRX (LI8 0), $S)>;
2025 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 1)))),
2026 (VEXTUHRX (LI8 2), $S)>;
2027 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 2)))),
2028 (VEXTUHRX (LI8 4), $S)>;
2029 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 3)))),
2030 (VEXTUHRX (LI8 6), $S)>;
2031 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 4)))),
2032 (VEXTUHRX (LI8 8), $S)>;
2033 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 5)))),
2034 (VEXTUHRX (LI8 10), $S)>;
2035 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 6)))),
2036 (VEXTUHRX (LI8 12), $S)>;
2037 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 7)))),
2038 (VEXTUHRX (LI8 14), $S)>;
2039
2040 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, i64:$Idx)))),
2041 (VEXTUWRX (RLWINM8 $Idx, 2, 28, 29), $S)>;
2042 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 0)))),
2043 (VEXTUWRX (LI8 0), $S)>;
2044 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 1)))),
2045 (VEXTUWRX (LI8 4), $S)>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002046 // For extracting LE word 2, MFVSRWZ is better than VEXTUWRX
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002047 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 2)))),
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002048 (INSERT_SUBREG (i64 (IMPLICIT_DEF)),
2049 (i32 VectorExtractions.LE_WORD_2), sub_32)>;
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002050 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 3)))),
2051 (VEXTUWRX (LI8 12), $S)>;
2052
2053 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, i64:$Idx)))),
2054 (EXTSW (VEXTUWRX (RLWINM8 $Idx, 2, 28, 29), $S))>;
2055 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 0)))),
2056 (EXTSW (VEXTUWRX (LI8 0), $S))>;
2057 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 1)))),
2058 (EXTSW (VEXTUWRX (LI8 4), $S))>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002059 // For extracting LE word 2, MFVSRWZ is better than VEXTUWRX
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002060 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 2)))),
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002061 (EXTSW (INSERT_SUBREG (i64 (IMPLICIT_DEF)),
2062 (i32 VectorExtractions.LE_WORD_2), sub_32))>;
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002063 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 3)))),
2064 (EXTSW (VEXTUWRX (LI8 12), $S))>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002065
2066 def : Pat<(i32 (vector_extract v16i8:$S, i64:$Idx)),
2067 (i32 (EXTRACT_SUBREG (VEXTUBRX $Idx, $S), sub_32))>;
2068 def : Pat<(i32 (vector_extract v16i8:$S, 0)),
2069 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 0), $S), sub_32))>;
2070 def : Pat<(i32 (vector_extract v16i8:$S, 1)),
2071 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 1), $S), sub_32))>;
2072 def : Pat<(i32 (vector_extract v16i8:$S, 2)),
2073 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 2), $S), sub_32))>;
2074 def : Pat<(i32 (vector_extract v16i8:$S, 3)),
2075 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 3), $S), sub_32))>;
2076 def : Pat<(i32 (vector_extract v16i8:$S, 4)),
2077 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 4), $S), sub_32))>;
2078 def : Pat<(i32 (vector_extract v16i8:$S, 5)),
2079 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 5), $S), sub_32))>;
2080 def : Pat<(i32 (vector_extract v16i8:$S, 6)),
2081 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 6), $S), sub_32))>;
2082 def : Pat<(i32 (vector_extract v16i8:$S, 7)),
2083 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 7), $S), sub_32))>;
2084 def : Pat<(i32 (vector_extract v16i8:$S, 8)),
2085 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 8), $S), sub_32))>;
2086 def : Pat<(i32 (vector_extract v16i8:$S, 9)),
2087 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 9), $S), sub_32))>;
2088 def : Pat<(i32 (vector_extract v16i8:$S, 10)),
2089 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 10), $S), sub_32))>;
2090 def : Pat<(i32 (vector_extract v16i8:$S, 11)),
2091 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 11), $S), sub_32))>;
2092 def : Pat<(i32 (vector_extract v16i8:$S, 12)),
2093 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 12), $S), sub_32))>;
2094 def : Pat<(i32 (vector_extract v16i8:$S, 13)),
2095 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 13), $S), sub_32))>;
2096 def : Pat<(i32 (vector_extract v16i8:$S, 14)),
2097 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 14), $S), sub_32))>;
2098 def : Pat<(i32 (vector_extract v16i8:$S, 15)),
2099 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 15), $S), sub_32))>;
2100
2101 def : Pat<(i32 (vector_extract v8i16:$S, i64:$Idx)),
2102 (i32 (EXTRACT_SUBREG (VEXTUHRX
2103 (RLWINM8 $Idx, 1, 28, 30), $S), sub_32))>;
2104 def : Pat<(i32 (vector_extract v8i16:$S, 0)),
2105 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 0), $S), sub_32))>;
2106 def : Pat<(i32 (vector_extract v8i16:$S, 1)),
2107 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 2), $S), sub_32))>;
2108 def : Pat<(i32 (vector_extract v8i16:$S, 2)),
2109 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 4), $S), sub_32))>;
2110 def : Pat<(i32 (vector_extract v8i16:$S, 3)),
2111 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 6), $S), sub_32))>;
2112 def : Pat<(i32 (vector_extract v8i16:$S, 4)),
2113 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 8), $S), sub_32))>;
2114 def : Pat<(i32 (vector_extract v8i16:$S, 5)),
2115 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 10), $S), sub_32))>;
2116 def : Pat<(i32 (vector_extract v8i16:$S, 6)),
2117 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 12), $S), sub_32))>;
2118 def : Pat<(i32 (vector_extract v8i16:$S, 6)),
2119 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 14), $S), sub_32))>;
2120
2121 def : Pat<(i32 (vector_extract v4i32:$S, i64:$Idx)),
2122 (i32 (EXTRACT_SUBREG (VEXTUWRX
2123 (RLWINM8 $Idx, 2, 28, 29), $S), sub_32))>;
2124 def : Pat<(i32 (vector_extract v4i32:$S, 0)),
2125 (i32 (EXTRACT_SUBREG (VEXTUWRX (LI8 0), $S), sub_32))>;
2126 def : Pat<(i32 (vector_extract v4i32:$S, 1)),
2127 (i32 (EXTRACT_SUBREG (VEXTUWRX (LI8 4), $S), sub_32))>;
2128 // For extracting LE word 2, MFVSRWZ is better than VEXTUWRX
2129 def : Pat<(i32 (vector_extract v4i32:$S, 2)),
2130 (i32 VectorExtractions.LE_WORD_2)>;
2131 def : Pat<(i32 (vector_extract v4i32:$S, 3)),
2132 (i32 (EXTRACT_SUBREG (VEXTUWRX (LI8 12), $S), sub_32))>;
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002133}
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002134
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002135let Predicates = [HasP9Altivec, IsBigEndian] in {
2136 def : Pat<(i64 (anyext (i32 (vector_extract v16i8:$S, i64:$Idx)))),
2137 (VEXTUBLX $Idx, $S)>;
2138
2139 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, i64:$Idx)))),
2140 (VEXTUHLX (RLWINM8 $Idx, 1, 28, 30), $S)>;
2141 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 0)))),
2142 (VEXTUHLX (LI8 0), $S)>;
2143 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 1)))),
2144 (VEXTUHLX (LI8 2), $S)>;
2145 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 2)))),
2146 (VEXTUHLX (LI8 4), $S)>;
2147 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 3)))),
2148 (VEXTUHLX (LI8 6), $S)>;
2149 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 4)))),
2150 (VEXTUHLX (LI8 8), $S)>;
2151 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 5)))),
2152 (VEXTUHLX (LI8 10), $S)>;
2153 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 6)))),
2154 (VEXTUHLX (LI8 12), $S)>;
2155 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 7)))),
2156 (VEXTUHLX (LI8 14), $S)>;
2157
2158 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, i64:$Idx)))),
2159 (VEXTUWLX (RLWINM8 $Idx, 2, 28, 29), $S)>;
2160 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 0)))),
2161 (VEXTUWLX (LI8 0), $S)>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002162
2163 // For extracting BE word 1, MFVSRWZ is better than VEXTUWLX
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002164 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 1)))),
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002165 (INSERT_SUBREG (i64 (IMPLICIT_DEF)),
2166 (i32 VectorExtractions.LE_WORD_2), sub_32)>;
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002167 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 2)))),
2168 (VEXTUWLX (LI8 8), $S)>;
2169 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 3)))),
2170 (VEXTUWLX (LI8 12), $S)>;
2171
2172 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, i64:$Idx)))),
2173 (EXTSW (VEXTUWLX (RLWINM8 $Idx, 2, 28, 29), $S))>;
2174 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 0)))),
2175 (EXTSW (VEXTUWLX (LI8 0), $S))>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002176 // For extracting BE word 1, MFVSRWZ is better than VEXTUWLX
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002177 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 1)))),
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002178 (EXTSW (INSERT_SUBREG (i64 (IMPLICIT_DEF)),
2179 (i32 VectorExtractions.LE_WORD_2), sub_32))>;
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002180 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 2)))),
2181 (EXTSW (VEXTUWLX (LI8 8), $S))>;
2182 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 3)))),
2183 (EXTSW (VEXTUWLX (LI8 12), $S))>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002184
2185 def : Pat<(i32 (vector_extract v16i8:$S, i64:$Idx)),
2186 (i32 (EXTRACT_SUBREG (VEXTUBLX $Idx, $S), sub_32))>;
2187 def : Pat<(i32 (vector_extract v16i8:$S, 0)),
2188 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 0), $S), sub_32))>;
2189 def : Pat<(i32 (vector_extract v16i8:$S, 1)),
2190 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 1), $S), sub_32))>;
2191 def : Pat<(i32 (vector_extract v16i8:$S, 2)),
2192 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 2), $S), sub_32))>;
2193 def : Pat<(i32 (vector_extract v16i8:$S, 3)),
2194 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 3), $S), sub_32))>;
2195 def : Pat<(i32 (vector_extract v16i8:$S, 4)),
2196 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 4), $S), sub_32))>;
2197 def : Pat<(i32 (vector_extract v16i8:$S, 5)),
2198 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 5), $S), sub_32))>;
2199 def : Pat<(i32 (vector_extract v16i8:$S, 6)),
2200 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 6), $S), sub_32))>;
2201 def : Pat<(i32 (vector_extract v16i8:$S, 7)),
2202 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 7), $S), sub_32))>;
2203 def : Pat<(i32 (vector_extract v16i8:$S, 8)),
2204 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 8), $S), sub_32))>;
2205 def : Pat<(i32 (vector_extract v16i8:$S, 9)),
2206 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 9), $S), sub_32))>;
2207 def : Pat<(i32 (vector_extract v16i8:$S, 10)),
2208 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 10), $S), sub_32))>;
2209 def : Pat<(i32 (vector_extract v16i8:$S, 11)),
2210 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 11), $S), sub_32))>;
2211 def : Pat<(i32 (vector_extract v16i8:$S, 12)),
2212 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 12), $S), sub_32))>;
2213 def : Pat<(i32 (vector_extract v16i8:$S, 13)),
2214 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 13), $S), sub_32))>;
2215 def : Pat<(i32 (vector_extract v16i8:$S, 14)),
2216 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 14), $S), sub_32))>;
2217 def : Pat<(i32 (vector_extract v16i8:$S, 15)),
2218 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 15), $S), sub_32))>;
2219
2220 def : Pat<(i32 (vector_extract v8i16:$S, i64:$Idx)),
2221 (i32 (EXTRACT_SUBREG (VEXTUHLX
2222 (RLWINM8 $Idx, 1, 28, 30), $S), sub_32))>;
2223 def : Pat<(i32 (vector_extract v8i16:$S, 0)),
2224 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 0), $S), sub_32))>;
2225 def : Pat<(i32 (vector_extract v8i16:$S, 1)),
2226 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 2), $S), sub_32))>;
2227 def : Pat<(i32 (vector_extract v8i16:$S, 2)),
2228 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 4), $S), sub_32))>;
2229 def : Pat<(i32 (vector_extract v8i16:$S, 3)),
2230 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 6), $S), sub_32))>;
2231 def : Pat<(i32 (vector_extract v8i16:$S, 4)),
2232 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 8), $S), sub_32))>;
2233 def : Pat<(i32 (vector_extract v8i16:$S, 5)),
2234 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 10), $S), sub_32))>;
2235 def : Pat<(i32 (vector_extract v8i16:$S, 6)),
2236 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 12), $S), sub_32))>;
2237 def : Pat<(i32 (vector_extract v8i16:$S, 6)),
2238 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 14), $S), sub_32))>;
2239
2240 def : Pat<(i32 (vector_extract v4i32:$S, i64:$Idx)),
2241 (i32 (EXTRACT_SUBREG (VEXTUWLX
2242 (RLWINM8 $Idx, 2, 28, 29), $S), sub_32))>;
2243 def : Pat<(i32 (vector_extract v4i32:$S, 0)),
2244 (i32 (EXTRACT_SUBREG (VEXTUWLX (LI8 0), $S), sub_32))>;
2245 // For extracting BE word 1, MFVSRWZ is better than VEXTUWLX
2246 def : Pat<(i32 (vector_extract v4i32:$S, 1)),
2247 (i32 VectorExtractions.LE_WORD_2)>;
2248 def : Pat<(i32 (vector_extract v4i32:$S, 2)),
2249 (i32 (EXTRACT_SUBREG (VEXTUWLX (LI8 8), $S), sub_32))>;
2250 def : Pat<(i32 (vector_extract v4i32:$S, 3)),
2251 (i32 (EXTRACT_SUBREG (VEXTUWLX (LI8 12), $S), sub_32))>;
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002252}
2253
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00002254let Predicates = [IsLittleEndian, HasDirectMove] in {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002255 // v16i8 scalar <-> vector conversions (LE)
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00002256 def : Pat<(v16i8 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002257 (v16i8 (COPY_TO_REGCLASS MovesToVSR.LE_WORD_0, VSRC))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00002258 def : Pat<(v8i16 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002259 (v8i16 (COPY_TO_REGCLASS MovesToVSR.LE_WORD_0, VSRC))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00002260 def : Pat<(v4i32 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002261 (v4i32 MovesToVSR.LE_WORD_0)>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00002262 def : Pat<(v2i64 (scalar_to_vector i64:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002263 (v2i64 MovesToVSR.LE_DWORD_0)>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002264 // v2i64 scalar <-> vector conversions (LE)
2265 def : Pat<(i64 (vector_extract v2i64:$S, 0)),
2266 (i64 VectorExtractions.LE_DWORD_0)>;
2267 def : Pat<(i64 (vector_extract v2i64:$S, 1)),
2268 (i64 VectorExtractions.LE_DWORD_1)>;
2269 def : Pat<(i64 (vector_extract v2i64:$S, i64:$Idx)),
2270 (i64 VectorExtractions.LE_VARIABLE_DWORD)>;
2271} // IsLittleEndian, HasDirectMove
2272
2273let Predicates = [IsLittleEndian, HasDirectMove, NoP9Altivec] in {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002274 def : Pat<(i32 (vector_extract v16i8:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002275 (i32 VectorExtractions.LE_BYTE_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002276 def : Pat<(i32 (vector_extract v16i8:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002277 (i32 VectorExtractions.LE_BYTE_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002278 def : Pat<(i32 (vector_extract v16i8:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002279 (i32 VectorExtractions.LE_BYTE_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002280 def : Pat<(i32 (vector_extract v16i8:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002281 (i32 VectorExtractions.LE_BYTE_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002282 def : Pat<(i32 (vector_extract v16i8:$S, 4)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002283 (i32 VectorExtractions.LE_BYTE_4)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002284 def : Pat<(i32 (vector_extract v16i8:$S, 5)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002285 (i32 VectorExtractions.LE_BYTE_5)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002286 def : Pat<(i32 (vector_extract v16i8:$S, 6)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002287 (i32 VectorExtractions.LE_BYTE_6)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002288 def : Pat<(i32 (vector_extract v16i8:$S, 7)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002289 (i32 VectorExtractions.LE_BYTE_7)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002290 def : Pat<(i32 (vector_extract v16i8:$S, 8)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002291 (i32 VectorExtractions.LE_BYTE_8)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002292 def : Pat<(i32 (vector_extract v16i8:$S, 9)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002293 (i32 VectorExtractions.LE_BYTE_9)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002294 def : Pat<(i32 (vector_extract v16i8:$S, 10)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002295 (i32 VectorExtractions.LE_BYTE_10)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002296 def : Pat<(i32 (vector_extract v16i8:$S, 11)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002297 (i32 VectorExtractions.LE_BYTE_11)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002298 def : Pat<(i32 (vector_extract v16i8:$S, 12)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002299 (i32 VectorExtractions.LE_BYTE_12)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002300 def : Pat<(i32 (vector_extract v16i8:$S, 13)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002301 (i32 VectorExtractions.LE_BYTE_13)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002302 def : Pat<(i32 (vector_extract v16i8:$S, 14)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002303 (i32 VectorExtractions.LE_BYTE_14)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002304 def : Pat<(i32 (vector_extract v16i8:$S, 15)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002305 (i32 VectorExtractions.LE_BYTE_15)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002306 def : Pat<(i32 (vector_extract v16i8:$S, i64:$Idx)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002307 (i32 VectorExtractions.LE_VARIABLE_BYTE)>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00002308
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002309 // v8i16 scalar <-> vector conversions (LE)
2310 def : Pat<(i32 (vector_extract v8i16:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002311 (i32 VectorExtractions.LE_HALF_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002312 def : Pat<(i32 (vector_extract v8i16:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002313 (i32 VectorExtractions.LE_HALF_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002314 def : Pat<(i32 (vector_extract v8i16:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002315 (i32 VectorExtractions.LE_HALF_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002316 def : Pat<(i32 (vector_extract v8i16:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002317 (i32 VectorExtractions.LE_HALF_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002318 def : Pat<(i32 (vector_extract v8i16:$S, 4)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002319 (i32 VectorExtractions.LE_HALF_4)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002320 def : Pat<(i32 (vector_extract v8i16:$S, 5)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002321 (i32 VectorExtractions.LE_HALF_5)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002322 def : Pat<(i32 (vector_extract v8i16:$S, 6)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002323 (i32 VectorExtractions.LE_HALF_6)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002324 def : Pat<(i32 (vector_extract v8i16:$S, 7)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002325 (i32 VectorExtractions.LE_HALF_7)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002326 def : Pat<(i32 (vector_extract v8i16:$S, i64:$Idx)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002327 (i32 VectorExtractions.LE_VARIABLE_HALF)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002328
2329 // v4i32 scalar <-> vector conversions (LE)
2330 def : Pat<(i32 (vector_extract v4i32:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002331 (i32 VectorExtractions.LE_WORD_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002332 def : Pat<(i32 (vector_extract v4i32:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002333 (i32 VectorExtractions.LE_WORD_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002334 def : Pat<(i32 (vector_extract v4i32:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002335 (i32 VectorExtractions.LE_WORD_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002336 def : Pat<(i32 (vector_extract v4i32:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002337 (i32 VectorExtractions.LE_WORD_3)>;
2338 def : Pat<(i32 (vector_extract v4i32:$S, i64:$Idx)),
2339 (i32 VectorExtractions.LE_VARIABLE_WORD)>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002340} // IsLittleEndian, HasDirectMove, NoP9Altivec
Nemanja Ivanovic89224762015-12-15 14:50:34 +00002341
2342let Predicates = [HasDirectMove, HasVSX] in {
2343// bitconvert f32 -> i32
2344// (convert to 32-bit fp single, shift right 1 word, move to GPR)
2345def : Pat<(i32 (bitconvert f32:$S)),
2346 (i32 (MFVSRWZ (EXTRACT_SUBREG
Lei Huangcd4f3852018-03-12 19:26:18 +00002347 (XXSLDWI (XSCVDPSPN $S), (XSCVDPSPN $S), 3),
Nemanja Ivanovic89224762015-12-15 14:50:34 +00002348 sub_64)))>;
2349// bitconvert i32 -> f32
2350// (move to FPR, shift left 1 word, convert to 64-bit fp single)
2351def : Pat<(f32 (bitconvert i32:$A)),
2352 (f32 (XSCVSPDPN
2353 (XXSLDWI MovesToVSR.LE_WORD_1, MovesToVSR.LE_WORD_1, 1)))>;
2354
2355// bitconvert f64 -> i64
2356// (move to GPR, nothing else needed)
2357def : Pat<(i64 (bitconvert f64:$S)),
2358 (i64 (MFVSRD $S))>;
2359
2360// bitconvert i64 -> f64
2361// (move to FPR, nothing else needed)
2362def : Pat<(f64 (bitconvert i64:$S)),
2363 (f64 (MTVSRD $S))>;
2364}
Kit Barton93612ec2016-02-26 21:11:55 +00002365
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00002366// Materialize a zero-vector of long long
2367def : Pat<(v2i64 immAllZerosV),
2368 (v2i64 (XXLXORz))>;
2369}
2370
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002371def AlignValues {
2372 dag F32_TO_BE_WORD1 = (v4f32 (XXSLDWI (XSCVDPSPN $B), (XSCVDPSPN $B), 3));
2373 dag I32_TO_BE_WORD1 = (COPY_TO_REGCLASS (MTVSRWZ $B), VSRC);
2374}
2375
Kit Barton93612ec2016-02-26 21:11:55 +00002376// The following VSX instructions were introduced in Power ISA 3.0
2377def HasP9Vector : Predicate<"PPCSubTarget->hasP9Vector()">;
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002378let AddedComplexity = 400, Predicates = [HasP9Vector] in {
Kit Barton93612ec2016-02-26 21:11:55 +00002379
2380 // [PO VRT XO VRB XO /]
2381 class X_VT5_XO5_VB5<bits<6> opcode, bits<5> xo2, bits<10> xo, string opc,
2382 list<dag> pattern>
2383 : X_RD5_XO5_RS5<opcode, xo2, xo, (outs vrrc:$vT), (ins vrrc:$vB),
2384 !strconcat(opc, " $vT, $vB"), IIC_VecFP, pattern>;
2385
2386 // [PO VRT XO VRB XO RO], Round to Odd version of [PO VRT XO VRB XO /]
2387 class X_VT5_XO5_VB5_Ro<bits<6> opcode, bits<5> xo2, bits<10> xo, string opc,
2388 list<dag> pattern>
2389 : X_VT5_XO5_VB5<opcode, xo2, xo, opc, pattern>, isDOT;
2390
2391 // [PO VRT XO VRB XO /], but the VRB is only used the left 64 bits (or less),
2392 // So we use different operand class for VRB
2393 class X_VT5_XO5_VB5_TyVB<bits<6> opcode, bits<5> xo2, bits<10> xo, string opc,
2394 RegisterOperand vbtype, list<dag> pattern>
2395 : X_RD5_XO5_RS5<opcode, xo2, xo, (outs vrrc:$vT), (ins vbtype:$vB),
2396 !strconcat(opc, " $vT, $vB"), IIC_VecFP, pattern>;
2397
Lei Huang6270ab62018-07-04 21:59:16 +00002398 // [PO VRT XO VRB XO /]
2399 class X_VT5_XO5_VB5_VSFR<bits<6> opcode, bits<5> xo2, bits<10> xo, string opc,
2400 list<dag> pattern>
2401 : X_RD5_XO5_RS5<opcode, xo2, xo, (outs vfrc:$vT), (ins vrrc:$vB),
2402 !strconcat(opc, " $vT, $vB"), IIC_VecFP, pattern>;
2403
2404 // [PO VRT XO VRB XO RO], Round to Odd version of [PO VRT XO VRB XO /]
2405 class X_VT5_XO5_VB5_VSFR_Ro<bits<6> opcode, bits<5> xo2, bits<10> xo, string opc,
2406 list<dag> pattern>
2407 : X_VT5_XO5_VB5_VSFR<opcode, xo2, xo, opc, pattern>, isDOT;
2408
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002409 let UseVSXReg = 1 in {
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002410 // [PO T XO B XO BX /]
2411 class XX2_RT5_XO5_XB6<bits<6> opcode, bits<5> xo2, bits<9> xo, string opc,
2412 list<dag> pattern>
2413 : XX2_RD5_XO5_RS6<opcode, xo2, xo, (outs g8rc:$rT), (ins vsfrc:$XB),
2414 !strconcat(opc, " $rT, $XB"), IIC_VecFP, pattern>;
2415
Kit Barton93612ec2016-02-26 21:11:55 +00002416 // [PO T XO B XO BX TX]
2417 class XX2_XT6_XO5_XB6<bits<6> opcode, bits<5> xo2, bits<9> xo, string opc,
2418 RegisterOperand vtype, list<dag> pattern>
2419 : XX2_RD6_XO5_RS6<opcode, xo2, xo, (outs vtype:$XT), (ins vtype:$XB),
2420 !strconcat(opc, " $XT, $XB"), IIC_VecFP, pattern>;
2421
2422 // [PO T A B XO AX BX TX], src and dest register use different operand class
2423 class XX3_XT5_XA5_XB5<bits<6> opcode, bits<8> xo, string opc,
2424 RegisterOperand xty, RegisterOperand aty, RegisterOperand bty,
2425 InstrItinClass itin, list<dag> pattern>
2426 : XX3Form<opcode, xo, (outs xty:$XT), (ins aty:$XA, bty:$XB),
2427 !strconcat(opc, " $XT, $XA, $XB"), itin, pattern>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002428 } // UseVSXReg = 1
Kit Barton93612ec2016-02-26 21:11:55 +00002429
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002430 // [PO VRT VRA VRB XO /]
2431 class X_VT5_VA5_VB5<bits<6> opcode, bits<10> xo, string opc,
2432 list<dag> pattern>
2433 : XForm_1<opcode, xo, (outs vrrc:$vT), (ins vrrc:$vA, vrrc:$vB),
2434 !strconcat(opc, " $vT, $vA, $vB"), IIC_VecFP, pattern>;
2435
2436 // [PO VRT VRA VRB XO RO], Round to Odd version of [PO VRT VRA VRB XO /]
2437 class X_VT5_VA5_VB5_Ro<bits<6> opcode, bits<10> xo, string opc,
2438 list<dag> pattern>
2439 : X_VT5_VA5_VB5<opcode, xo, opc, pattern>, isDOT;
2440
Lei Huang09fda632018-04-04 16:43:50 +00002441 // [PO VRT VRA VRB XO /]
2442 class X_VT5_VA5_VB5_FMA<bits<6> opcode, bits<10> xo, string opc,
2443 list<dag> pattern>
2444 : XForm_1<opcode, xo, (outs vrrc:$vT), (ins vrrc:$vTi, vrrc:$vA, vrrc:$vB),
2445 !strconcat(opc, " $vT, $vA, $vB"), IIC_VecFP, pattern>,
2446 RegConstraint<"$vTi = $vT">, NoEncode<"$vTi">;
2447
2448 // [PO VRT VRA VRB XO RO], Round to Odd version of [PO VRT VRA VRB XO /]
2449 class X_VT5_VA5_VB5_FMA_Ro<bits<6> opcode, bits<10> xo, string opc,
2450 list<dag> pattern>
2451 : X_VT5_VA5_VB5_FMA<opcode, xo, opc, pattern>, isDOT;
2452
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002453 //===--------------------------------------------------------------------===//
2454 // Quad-Precision Scalar Move Instructions:
2455
2456 // Copy Sign
Lei Huangecfede92018-03-19 19:22:52 +00002457 def XSCPSGNQP : X_VT5_VA5_VB5<63, 100, "xscpsgnqp",
2458 [(set f128:$vT,
2459 (fcopysign f128:$vB, f128:$vA))]>;
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002460
2461 // Absolute/Negative-Absolute/Negate
Lei Huangecfede92018-03-19 19:22:52 +00002462 def XSABSQP : X_VT5_XO5_VB5<63, 0, 804, "xsabsqp",
2463 [(set f128:$vT, (fabs f128:$vB))]>;
2464 def XSNABSQP : X_VT5_XO5_VB5<63, 8, 804, "xsnabsqp",
2465 [(set f128:$vT, (fneg (fabs f128:$vB)))]>;
2466 def XSNEGQP : X_VT5_XO5_VB5<63, 16, 804, "xsnegqp",
2467 [(set f128:$vT, (fneg f128:$vB))]>;
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002468
2469 //===--------------------------------------------------------------------===//
2470 // Quad-Precision Scalar Floating-Point Arithmetic Instructions:
2471
2472 // Add/Divide/Multiply/Subtract
Lei Huang6d1596a2018-03-19 18:52:20 +00002473 let isCommutable = 1 in {
2474 def XSADDQP : X_VT5_VA5_VB5 <63, 4, "xsaddqp",
2475 [(set f128:$vT, (fadd f128:$vA, f128:$vB))]>;
Stefan Pintilie83a5fe12018-07-09 18:50:06 +00002476 def XSADDQPO : X_VT5_VA5_VB5_Ro<63, 4, "xsaddqpo",
2477 [(set f128:$vT,
2478 (int_ppc_addf128_round_to_odd
2479 f128:$vA, f128:$vB))]>;
Lei Huang6d1596a2018-03-19 18:52:20 +00002480 def XSMULQP : X_VT5_VA5_VB5 <63, 36, "xsmulqp",
2481 [(set f128:$vT, (fmul f128:$vA, f128:$vB))]>;
Stefan Pintilie83a5fe12018-07-09 18:50:06 +00002482 def XSMULQPO : X_VT5_VA5_VB5_Ro<63, 36, "xsmulqpo",
2483 [(set f128:$vT,
2484 (int_ppc_mulf128_round_to_odd
2485 f128:$vA, f128:$vB))]>;
Lei Huang6d1596a2018-03-19 18:52:20 +00002486 }
2487
2488 def XSSUBQP : X_VT5_VA5_VB5 <63, 516, "xssubqp" ,
2489 [(set f128:$vT, (fsub f128:$vA, f128:$vB))]>;
Stefan Pintilie83a5fe12018-07-09 18:50:06 +00002490 def XSSUBQPO : X_VT5_VA5_VB5_Ro<63, 516, "xssubqpo",
2491 [(set f128:$vT,
2492 (int_ppc_subf128_round_to_odd
2493 f128:$vA, f128:$vB))]>;
Lei Huang6d1596a2018-03-19 18:52:20 +00002494 def XSDIVQP : X_VT5_VA5_VB5 <63, 548, "xsdivqp",
2495 [(set f128:$vT, (fdiv f128:$vA, f128:$vB))]>;
Stefan Pintilie83a5fe12018-07-09 18:50:06 +00002496 def XSDIVQPO : X_VT5_VA5_VB5_Ro<63, 548, "xsdivqpo",
2497 [(set f128:$vT,
2498 (int_ppc_divf128_round_to_odd
2499 f128:$vA, f128:$vB))]>;
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002500
2501 // Square-Root
Lei Huangecfede92018-03-19 19:22:52 +00002502 def XSSQRTQP : X_VT5_XO5_VB5 <63, 27, 804, "xssqrtqp",
2503 [(set f128:$vT, (fsqrt f128:$vB))]>;
Stefan Pintilie83a5fe12018-07-09 18:50:06 +00002504 def XSSQRTQPO : X_VT5_XO5_VB5_Ro<63, 27, 804, "xssqrtqpo",
2505 [(set f128:$vT,
2506 (int_ppc_sqrtf128_round_to_odd f128:$vB))]>;
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002507
2508 // (Negative) Multiply-{Add/Subtract}
Lei Huang09fda632018-04-04 16:43:50 +00002509 def XSMADDQP : X_VT5_VA5_VB5_FMA <63, 388, "xsmaddqp",
2510 [(set f128:$vT,
2511 (fma f128:$vA, f128:$vB,
2512 f128:$vTi))]>;
Stefan Pintilie83a5fe12018-07-09 18:50:06 +00002513
2514 def XSMADDQPO : X_VT5_VA5_VB5_FMA_Ro<63, 388, "xsmaddqpo",
2515 [(set f128:$vT,
2516 (int_ppc_fmaf128_round_to_odd
2517 f128:$vA,f128:$vB,f128:$vTi))]>;
2518
Lei Huang09fda632018-04-04 16:43:50 +00002519 def XSMSUBQP : X_VT5_VA5_VB5_FMA <63, 420, "xsmsubqp" ,
2520 [(set f128:$vT,
2521 (fma f128:$vA, f128:$vB,
2522 (fneg f128:$vTi)))]>;
Stefan Pintilieb9d01aa2018-07-11 01:42:22 +00002523 def XSMSUBQPO : X_VT5_VA5_VB5_FMA_Ro<63, 420, "xsmsubqpo" ,
2524 [(set f128:$vT,
2525 (int_ppc_fmaf128_round_to_odd
2526 f128:$vA, f128:$vB, (fneg f128:$vTi)))]>;
Lei Huang09fda632018-04-04 16:43:50 +00002527 def XSNMADDQP : X_VT5_VA5_VB5_FMA <63, 452, "xsnmaddqp",
2528 [(set f128:$vT,
2529 (fneg (fma f128:$vA, f128:$vB,
2530 f128:$vTi)))]>;
Stefan Pintilieb9d01aa2018-07-11 01:42:22 +00002531 def XSNMADDQPO: X_VT5_VA5_VB5_FMA_Ro<63, 452, "xsnmaddqpo",
2532 [(set f128:$vT,
2533 (fneg (int_ppc_fmaf128_round_to_odd
2534 f128:$vA, f128:$vB, f128:$vTi)))]>;
Lei Huang09fda632018-04-04 16:43:50 +00002535 def XSNMSUBQP : X_VT5_VA5_VB5_FMA <63, 484, "xsnmsubqp",
2536 [(set f128:$vT,
2537 (fneg (fma f128:$vA, f128:$vB,
2538 (fneg f128:$vTi))))]>;
Stefan Pintilieb9d01aa2018-07-11 01:42:22 +00002539 def XSNMSUBQPO: X_VT5_VA5_VB5_FMA_Ro<63, 484, "xsnmsubqpo",
2540 [(set f128:$vT,
2541 (fneg (int_ppc_fmaf128_round_to_odd
2542 f128:$vA, f128:$vB, (fneg f128:$vTi))))]>;
Lei Huang09fda632018-04-04 16:43:50 +00002543
2544 // Additional fnmsub patterns: -a*c + b == -(a*c - b)
2545 def : Pat<(fma (fneg f128:$A), f128:$C, f128:$B), (XSNMSUBQP $B, $C, $A)>;
2546 def : Pat<(fma f128:$A, (fneg f128:$C), f128:$B), (XSNMSUBQP $B, $C, $A)>;
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002547
Kit Barton93612ec2016-02-26 21:11:55 +00002548 //===--------------------------------------------------------------------===//
2549 // Quad/Double-Precision Compare Instructions:
2550
2551 // [PO BF // VRA VRB XO /]
2552 class X_BF3_VA5_VB5<bits<6> opcode, bits<10> xo, string opc,
2553 list<dag> pattern>
2554 : XForm_17<opcode, xo, (outs crrc:$crD), (ins vrrc:$VA, vrrc:$VB),
2555 !strconcat(opc, " $crD, $VA, $VB"), IIC_FPCompare> {
2556 let Pattern = pattern;
2557 }
2558
2559 // QP Compare Ordered/Unordered
2560 def XSCMPOQP : X_BF3_VA5_VB5<63, 132, "xscmpoqp", []>;
2561 def XSCMPUQP : X_BF3_VA5_VB5<63, 644, "xscmpuqp", []>;
2562
2563 // DP/QP Compare Exponents
2564 def XSCMPEXPDP : XX3Form_1<60, 59,
2565 (outs crrc:$crD), (ins vsfrc:$XA, vsfrc:$XB),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002566 "xscmpexpdp $crD, $XA, $XB", IIC_FPCompare, []>,
2567 UseVSXReg;
Kit Barton93612ec2016-02-26 21:11:55 +00002568 def XSCMPEXPQP : X_BF3_VA5_VB5<63, 164, "xscmpexpqp", []>;
2569
2570 // DP Compare ==, >=, >, !=
2571 // Use vsrc for XT, because the entire register of XT is set.
2572 // XT.dword[1] = 0x0000_0000_0000_0000
2573 def XSCMPEQDP : XX3_XT5_XA5_XB5<60, 3, "xscmpeqdp", vsrc, vsfrc, vsfrc,
2574 IIC_FPCompare, []>;
2575 def XSCMPGEDP : XX3_XT5_XA5_XB5<60, 19, "xscmpgedp", vsrc, vsfrc, vsfrc,
2576 IIC_FPCompare, []>;
2577 def XSCMPGTDP : XX3_XT5_XA5_XB5<60, 11, "xscmpgtdp", vsrc, vsfrc, vsfrc,
2578 IIC_FPCompare, []>;
Kit Barton93612ec2016-02-26 21:11:55 +00002579
2580 //===--------------------------------------------------------------------===//
2581 // Quad-Precision Floating-Point Conversion Instructions:
2582
2583 // Convert DP -> QP
Lei Huangd17c39c2018-07-05 04:18:37 +00002584 def XSCVDPQP : X_VT5_XO5_VB5_TyVB<63, 22, 836, "xscvdpqp", vfrc,
2585 [(set f128:$vT, (fpextend f64:$vB))]>;
Kit Barton93612ec2016-02-26 21:11:55 +00002586
2587 // Round & Convert QP -> DP (dword[1] is set to zero)
Lei Huang6270ab62018-07-04 21:59:16 +00002588 def XSCVQPDP : X_VT5_XO5_VB5_VSFR<63, 20, 836, "xscvqpdp" , []>;
Stefan Pintilie58e3e0a2018-07-09 20:09:22 +00002589 def XSCVQPDPO : X_VT5_XO5_VB5_VSFR_Ro<63, 20, 836, "xscvqpdpo",
2590 [(set f64:$vT,
2591 (int_ppc_truncf128_round_to_odd
2592 f128:$vB))]>;
Kit Barton93612ec2016-02-26 21:11:55 +00002593
2594 // Truncate & Convert QP -> (Un)Signed (D)Word (dword[1] is set to zero)
2595 def XSCVQPSDZ : X_VT5_XO5_VB5<63, 25, 836, "xscvqpsdz", []>;
2596 def XSCVQPSWZ : X_VT5_XO5_VB5<63, 9, 836, "xscvqpswz", []>;
2597 def XSCVQPUDZ : X_VT5_XO5_VB5<63, 17, 836, "xscvqpudz", []>;
2598 def XSCVQPUWZ : X_VT5_XO5_VB5<63, 1, 836, "xscvqpuwz", []>;
2599
Lei Huangc517e952018-05-08 18:23:31 +00002600 // Convert (Un)Signed DWord -> QP.
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002601 def XSCVSDQP : X_VT5_XO5_VB5_TyVB<63, 10, 836, "xscvsdqp", vfrc, []>;
Lei Huang10367eb2018-04-12 18:00:14 +00002602 def : Pat<(f128 (sint_to_fp i64:$src)),
2603 (f128 (XSCVSDQP (COPY_TO_REGCLASS $src, VFRC)))>;
Lei Huang66e22c22018-07-05 07:46:01 +00002604 def : Pat<(f128 (sint_to_fp (i64 (PPCmfvsr f64:$src)))),
2605 (f128 (XSCVSDQP $src))>;
2606 def : Pat<(f128 (sint_to_fp (i32 (PPCmfvsr f64:$src)))),
2607 (f128 (XSCVSDQP (VEXTSW2Ds $src)))>;
2608
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002609 def XSCVUDQP : X_VT5_XO5_VB5_TyVB<63, 2, 836, "xscvudqp", vfrc, []>;
Lei Huang10367eb2018-04-12 18:00:14 +00002610 def : Pat<(f128 (uint_to_fp i64:$src)),
2611 (f128 (XSCVUDQP (COPY_TO_REGCLASS $src, VFRC)))>;
Lei Huang66e22c22018-07-05 07:46:01 +00002612 def : Pat<(f128 (uint_to_fp (i64 (PPCmfvsr f64:$src)))),
2613 (f128 (XSCVUDQP $src))>;
Kit Barton93612ec2016-02-26 21:11:55 +00002614
Lei Huangc517e952018-05-08 18:23:31 +00002615 // Convert (Un)Signed Word -> QP.
Lei Huang198e6782018-04-18 16:34:22 +00002616 def : Pat<(f128 (sint_to_fp i32:$src)),
2617 (f128 (XSCVSDQP (MTVSRWA $src)))>;
2618 def : Pat<(f128 (sint_to_fp (i32 (load xoaddr:$src)))),
2619 (f128 (XSCVSDQP (LIWAX xoaddr:$src)))>;
2620 def : Pat<(f128 (uint_to_fp i32:$src)),
2621 (f128 (XSCVUDQP (MTVSRWZ $src)))>;
2622 def : Pat<(f128 (uint_to_fp (i32 (load xoaddr:$src)))),
2623 (f128 (XSCVUDQP (LIWZX xoaddr:$src)))>;
2624
Sean Fertilea435e072016-11-14 18:43:59 +00002625 let UseVSXReg = 1 in {
Kit Barton93612ec2016-02-26 21:11:55 +00002626 //===--------------------------------------------------------------------===//
2627 // Round to Floating-Point Integer Instructions
2628
2629 // (Round &) Convert DP <-> HP
2630 // Note! xscvdphp's src and dest register both use the left 64 bits, so we use
2631 // vsfrc for src and dest register. xscvhpdp's src only use the left 16 bits,
2632 // but we still use vsfrc for it.
2633 def XSCVDPHP : XX2_XT6_XO5_XB6<60, 17, 347, "xscvdphp", vsfrc, []>;
2634 def XSCVHPDP : XX2_XT6_XO5_XB6<60, 16, 347, "xscvhpdp", vsfrc, []>;
2635
2636 // Vector HP -> SP
2637 def XVCVHPSP : XX2_XT6_XO5_XB6<60, 24, 475, "xvcvhpsp", vsrc, []>;
Nemanja Ivanovicec4b0c32016-11-11 21:42:01 +00002638 def XVCVSPHP : XX2_XT6_XO5_XB6<60, 25, 475, "xvcvsphp", vsrc,
2639 [(set v4f32:$XT,
2640 (int_ppc_vsx_xvcvsphp v4f32:$XB))]>;
Kit Barton93612ec2016-02-26 21:11:55 +00002641
Sean Fertilea435e072016-11-14 18:43:59 +00002642 } // UseVSXReg = 1
2643
2644 // Pattern for matching Vector HP -> Vector SP intrinsic. Defined as a
Simon Pilgrim68168d12017-03-30 12:59:53 +00002645 // separate pattern so that it can convert the input register class from
Sean Fertilea435e072016-11-14 18:43:59 +00002646 // VRRC(v8i16) to VSRC.
2647 def : Pat<(v4f32 (int_ppc_vsx_xvcvhpsp v8i16:$A)),
2648 (v4f32 (XVCVHPSP (COPY_TO_REGCLASS $A, VSRC)))>;
2649
Kit Barton93612ec2016-02-26 21:11:55 +00002650 class Z23_VT5_R1_VB5_RMC2_EX1<bits<6> opcode, bits<8> xo, bit ex, string opc,
2651 list<dag> pattern>
Zaara Syeda421a5962018-05-14 15:45:15 +00002652 : Z23Form_8<opcode, xo,
Kit Barton93612ec2016-02-26 21:11:55 +00002653 (outs vrrc:$vT), (ins u1imm:$r, vrrc:$vB, u2imm:$rmc),
2654 !strconcat(opc, " $r, $vT, $vB, $rmc"), IIC_VecFP, pattern> {
2655 let RC = ex;
2656 }
2657
2658 // Round to Quad-Precision Integer [with Inexact]
2659 def XSRQPI : Z23_VT5_R1_VB5_RMC2_EX1<63, 5, 0, "xsrqpi" , []>;
2660 def XSRQPIX : Z23_VT5_R1_VB5_RMC2_EX1<63, 5, 1, "xsrqpix", []>;
2661
Stefan Pintilie133acb22018-07-09 20:38:40 +00002662 // Use current rounding mode
2663 def : Pat<(f128 (fnearbyint f128:$vB)), (f128 (XSRQPI 0, $vB, 3))>;
2664 // Round to nearest, ties away from zero
2665 def : Pat<(f128 (fround f128:$vB)), (f128 (XSRQPI 0, $vB, 0))>;
2666 // Round towards Zero
2667 def : Pat<(f128 (ftrunc f128:$vB)), (f128 (XSRQPI 1, $vB, 1))>;
2668 // Round towards +Inf
2669 def : Pat<(f128 (fceil f128:$vB)), (f128 (XSRQPI 1, $vB, 2))>;
2670 // Round towards -Inf
2671 def : Pat<(f128 (ffloor f128:$vB)), (f128 (XSRQPI 1, $vB, 3))>;
2672
2673 // Use current rounding mode, [with Inexact]
2674 def : Pat<(f128 (frint f128:$vB)), (f128 (XSRQPIX 0, $vB, 3))>;
2675
Kit Barton93612ec2016-02-26 21:11:55 +00002676 // Round Quad-Precision to Double-Extended Precision (fp80)
2677 def XSRQPXP : Z23_VT5_R1_VB5_RMC2_EX1<63, 37, 0, "xsrqpxp", []>;
Kit Bartonba532dc2016-03-08 03:49:13 +00002678
2679 //===--------------------------------------------------------------------===//
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002680 // Insert/Extract Instructions
2681
2682 // Insert Exponent DP/QP
2683 // XT NOTE: XT.dword[1] = 0xUUUU_UUUU_UUUU_UUUU
2684 def XSIEXPDP : XX1Form <60, 918, (outs vsrc:$XT), (ins g8rc:$rA, g8rc:$rB),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002685 "xsiexpdp $XT, $rA, $rB", IIC_VecFP, []>, UseVSXReg;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002686 // vB NOTE: only vB.dword[0] is used, that's why we don't use
2687 // X_VT5_VA5_VB5 form
2688 def XSIEXPQP : XForm_18<63, 868, (outs vrrc:$vT), (ins vrrc:$vA, vsfrc:$vB),
2689 "xsiexpqp $vT, $vA, $vB", IIC_VecFP, []>;
2690
Stefan Pintilieb5305772018-09-24 18:14:13 +00002691 def : Pat<(f128 (int_ppc_scalar_insert_exp_qp f128:$vA, i64:$vB)),
2692 (f128 (XSIEXPQP $vA, (MTVSRD $vB)))>;
2693
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002694 // Extract Exponent/Significand DP/QP
2695 def XSXEXPDP : XX2_RT5_XO5_XB6<60, 0, 347, "xsxexpdp", []>;
2696 def XSXSIGDP : XX2_RT5_XO5_XB6<60, 1, 347, "xsxsigdp", []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002697
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002698 def XSXEXPQP : X_VT5_XO5_VB5 <63, 2, 804, "xsxexpqp", []>;
2699 def XSXSIGQP : X_VT5_XO5_VB5 <63, 18, 804, "xsxsigqp", []>;
2700
Stefan Pintilieb5305772018-09-24 18:14:13 +00002701 def : Pat<(i64 (int_ppc_scalar_extract_expq f128:$vA)),
2702 (i64 (MFVSRD (EXTRACT_SUBREG
2703 (v2i64 (XSXEXPQP $vA)), sub_64)))>;
2704
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002705 // Vector Insert Word
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002706 let UseVSXReg = 1 in {
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002707 // XB NOTE: Only XB.dword[1] is used, but we use vsrc on XB.
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002708 def XXINSERTW :
2709 XX2_RD6_UIM5_RS6<60, 181, (outs vsrc:$XT),
2710 (ins vsrc:$XTi, vsrc:$XB, u4imm:$UIM),
2711 "xxinsertw $XT, $XB, $UIM", IIC_VecFP,
Tony Jiang61ef1c52017-09-05 18:08:02 +00002712 [(set v4i32:$XT, (PPCvecinsert v4i32:$XTi, v4i32:$XB,
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002713 imm32SExt16:$UIM))]>,
2714 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002715
2716 // Vector Extract Unsigned Word
2717 def XXEXTRACTUW : XX2_RD6_UIM5_RS6<60, 165,
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002718 (outs vsfrc:$XT), (ins vsrc:$XB, u4imm:$UIMM),
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002719 "xxextractuw $XT, $XB, $UIMM", IIC_VecFP, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002720 } // UseVSXReg = 1
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002721
2722 // Vector Insert Exponent DP/SP
2723 def XVIEXPDP : XX3_XT5_XA5_XB5<60, 248, "xviexpdp", vsrc, vsrc, vsrc,
Nemanja Ivanovic0f459982016-10-26 19:03:40 +00002724 IIC_VecFP, [(set v2f64: $XT,(int_ppc_vsx_xviexpdp v2i64:$XA, v2i64:$XB))]>;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002725 def XVIEXPSP : XX3_XT5_XA5_XB5<60, 216, "xviexpsp", vsrc, vsrc, vsrc,
Nemanja Ivanovic0f459982016-10-26 19:03:40 +00002726 IIC_VecFP, [(set v4f32: $XT,(int_ppc_vsx_xviexpsp v4i32:$XA, v4i32:$XB))]>;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002727
2728 // Vector Extract Exponent/Significand DP/SP
Sean Fertileadda5b22016-11-14 14:42:37 +00002729 def XVXEXPDP : XX2_XT6_XO5_XB6<60, 0, 475, "xvxexpdp", vsrc,
2730 [(set v2i64: $XT,
2731 (int_ppc_vsx_xvxexpdp v2f64:$XB))]>;
2732 def XVXEXPSP : XX2_XT6_XO5_XB6<60, 8, 475, "xvxexpsp", vsrc,
2733 [(set v4i32: $XT,
2734 (int_ppc_vsx_xvxexpsp v4f32:$XB))]>;
2735 def XVXSIGDP : XX2_XT6_XO5_XB6<60, 1, 475, "xvxsigdp", vsrc,
2736 [(set v2i64: $XT,
2737 (int_ppc_vsx_xvxsigdp v2f64:$XB))]>;
2738 def XVXSIGSP : XX2_XT6_XO5_XB6<60, 9, 475, "xvxsigsp", vsrc,
2739 [(set v4i32: $XT,
2740 (int_ppc_vsx_xvxsigsp v4f32:$XB))]>;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002741
Sean Fertile1c4109b2016-12-09 17:21:42 +00002742 let AddedComplexity = 400, Predicates = [HasP9Vector] in {
2743 // Extra patterns expanding to vector Extract Word/Insert Word
2744 def : Pat<(v4i32 (int_ppc_vsx_xxinsertw v4i32:$A, v2i64:$B, imm:$IMM)),
2745 (v4i32 (XXINSERTW $A, $B, imm:$IMM))>;
2746 def : Pat<(v2i64 (int_ppc_vsx_xxextractuw v2i64:$A, imm:$IMM)),
2747 (v2i64 (COPY_TO_REGCLASS (XXEXTRACTUW $A, imm:$IMM), VSRC))>;
2748 } // AddedComplexity = 400, HasP9Vector
2749
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002750 //===--------------------------------------------------------------------===//
2751
2752 // Test Data Class SP/DP/QP
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002753 let UseVSXReg = 1 in {
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002754 def XSTSTDCSP : XX2_BF3_DCMX7_RS6<60, 298,
2755 (outs crrc:$BF), (ins u7imm:$DCMX, vsfrc:$XB),
2756 "xststdcsp $BF, $XB, $DCMX", IIC_VecFP, []>;
2757 def XSTSTDCDP : XX2_BF3_DCMX7_RS6<60, 362,
2758 (outs crrc:$BF), (ins u7imm:$DCMX, vsfrc:$XB),
2759 "xststdcdp $BF, $XB, $DCMX", IIC_VecFP, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002760 } // UseVSXReg = 1
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002761 def XSTSTDCQP : X_BF3_DCMX7_RS5 <63, 708,
2762 (outs crrc:$BF), (ins u7imm:$DCMX, vrrc:$vB),
2763 "xststdcqp $BF, $vB, $DCMX", IIC_VecFP, []>;
2764
2765 // Vector Test Data Class SP/DP
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002766 let UseVSXReg = 1 in {
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002767 def XVTSTDCSP : XX2_RD6_DCMX7_RS6<60, 13, 5,
2768 (outs vsrc:$XT), (ins u7imm:$DCMX, vsrc:$XB),
Sean Fertileadda5b22016-11-14 14:42:37 +00002769 "xvtstdcsp $XT, $XB, $DCMX", IIC_VecFP,
2770 [(set v4i32: $XT,
2771 (int_ppc_vsx_xvtstdcsp v4f32:$XB, imm:$DCMX))]>;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002772 def XVTSTDCDP : XX2_RD6_DCMX7_RS6<60, 15, 5,
2773 (outs vsrc:$XT), (ins u7imm:$DCMX, vsrc:$XB),
Sean Fertileadda5b22016-11-14 14:42:37 +00002774 "xvtstdcdp $XT, $XB, $DCMX", IIC_VecFP,
2775 [(set v2i64: $XT,
2776 (int_ppc_vsx_xvtstdcdp v2f64:$XB, imm:$DCMX))]>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002777 } // UseVSXReg = 1
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002778
2779 //===--------------------------------------------------------------------===//
2780
2781 // Maximum/Minimum Type-C/Type-J DP
2782 // XT.dword[1] = 0xUUUU_UUUU_UUUU_UUUU, so we use vsrc for XT
2783 def XSMAXCDP : XX3_XT5_XA5_XB5<60, 128, "xsmaxcdp", vsrc, vsfrc, vsfrc,
2784 IIC_VecFP, []>;
2785 def XSMAXJDP : XX3_XT5_XA5_XB5<60, 144, "xsmaxjdp", vsrc, vsfrc, vsfrc,
2786 IIC_VecFP, []>;
2787 def XSMINCDP : XX3_XT5_XA5_XB5<60, 136, "xsmincdp", vsrc, vsfrc, vsfrc,
2788 IIC_VecFP, []>;
2789 def XSMINJDP : XX3_XT5_XA5_XB5<60, 152, "xsminjdp", vsrc, vsfrc, vsfrc,
2790 IIC_VecFP, []>;
2791
2792 //===--------------------------------------------------------------------===//
2793
2794 // Vector Byte-Reverse H/W/D/Q Word
2795 def XXBRH : XX2_XT6_XO5_XB6<60, 7, 475, "xxbrh", vsrc, []>;
2796 def XXBRW : XX2_XT6_XO5_XB6<60, 15, 475, "xxbrw", vsrc, []>;
2797 def XXBRD : XX2_XT6_XO5_XB6<60, 23, 475, "xxbrd", vsrc, []>;
2798 def XXBRQ : XX2_XT6_XO5_XB6<60, 31, 475, "xxbrq", vsrc, []>;
2799
Tony Jiang1a8eec12017-06-12 18:24:36 +00002800 // Vector Reverse
2801 def : Pat<(v8i16 (PPCxxreverse v8i16 :$A)),
2802 (v8i16 (COPY_TO_REGCLASS (XXBRH (COPY_TO_REGCLASS $A, VSRC)), VRRC))>;
2803 def : Pat<(v4i32 (PPCxxreverse v4i32 :$A)),
2804 (v4i32 (XXBRW $A))>;
2805 def : Pat<(v2i64 (PPCxxreverse v2i64 :$A)),
2806 (v2i64 (XXBRD $A))>;
2807 def : Pat<(v1i128 (PPCxxreverse v1i128 :$A)),
2808 (v1i128 (COPY_TO_REGCLASS (XXBRQ (COPY_TO_REGCLASS $A, VSRC)), VRRC))>;
2809
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002810 // Vector Permute
2811 def XXPERM : XX3_XT5_XA5_XB5<60, 26, "xxperm" , vsrc, vsrc, vsrc,
2812 IIC_VecPerm, []>;
2813 def XXPERMR : XX3_XT5_XA5_XB5<60, 58, "xxpermr", vsrc, vsrc, vsrc,
2814 IIC_VecPerm, []>;
2815
2816 // Vector Splat Immediate Byte
2817 def XXSPLTIB : X_RD6_IMM8<60, 360, (outs vsrc:$XT), (ins u8imm:$IMM8),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002818 "xxspltib $XT, $IMM8", IIC_VecPerm, []>, UseVSXReg;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002819
2820 //===--------------------------------------------------------------------===//
Kit Bartonba532dc2016-03-08 03:49:13 +00002821 // Vector/Scalar Load/Store Instructions
2822
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00002823 // When adding new D-Form loads/stores, be sure to update the ImmToIdxMap in
2824 // PPCRegisterInfo::PPCRegisterInfo and maybe save yourself some debugging.
Sean Fertile3c8c3852017-01-26 18:59:15 +00002825 let mayLoad = 1, mayStore = 0 in {
Kit Bartonba532dc2016-03-08 03:49:13 +00002826 // Load Vector
2827 def LXV : DQ_RD6_RS5_DQ12<61, 1, (outs vsrc:$XT), (ins memrix16:$src),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002828 "lxv $XT, $src", IIC_LdStLFD, []>, UseVSXReg;
Kit Bartonba532dc2016-03-08 03:49:13 +00002829 // Load DWord
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002830 def LXSD : DSForm_1<57, 2, (outs vfrc:$vD), (ins memrix:$src),
Kit Bartonba532dc2016-03-08 03:49:13 +00002831 "lxsd $vD, $src", IIC_LdStLFD, []>;
2832 // Load SP from src, convert it to DP, and place in dword[0]
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002833 def LXSSP : DSForm_1<57, 3, (outs vfrc:$vD), (ins memrix:$src),
Kit Bartonba532dc2016-03-08 03:49:13 +00002834 "lxssp $vD, $src", IIC_LdStLFD, []>;
2835
2836 // [PO T RA RB XO TX] almost equal to [PO S RA RB XO SX], but has different
2837 // "out" and "in" dag
2838 class X_XT6_RA5_RB5<bits<6> opcode, bits<10> xo, string opc,
2839 RegisterOperand vtype, list<dag> pattern>
Stefan Pintilie26d4f922018-03-26 17:39:18 +00002840 : XX1Form_memOp<opcode, xo, (outs vtype:$XT), (ins memrr:$src),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002841 !strconcat(opc, " $XT, $src"), IIC_LdStLFD, pattern>, UseVSXReg;
Kit Bartonba532dc2016-03-08 03:49:13 +00002842
2843 // Load as Integer Byte/Halfword & Zero Indexed
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002844 def LXSIBZX : X_XT6_RA5_RB5<31, 781, "lxsibzx", vsfrc,
2845 [(set f64:$XT, (PPClxsizx xoaddr:$src, 1))]>;
2846 def LXSIHZX : X_XT6_RA5_RB5<31, 813, "lxsihzx", vsfrc,
2847 [(set f64:$XT, (PPClxsizx xoaddr:$src, 2))]>;
Kit Bartonba532dc2016-03-08 03:49:13 +00002848
2849 // Load Vector Halfword*8/Byte*16 Indexed
2850 def LXVH8X : X_XT6_RA5_RB5<31, 812, "lxvh8x" , vsrc, []>;
2851 def LXVB16X : X_XT6_RA5_RB5<31, 876, "lxvb16x", vsrc, []>;
2852
2853 // Load Vector Indexed
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00002854 def LXVX : X_XT6_RA5_RB5<31, 268, "lxvx" , vsrc,
Zaara Syeda93297832017-05-24 17:50:37 +00002855 [(set v2f64:$XT, (load xaddr:$src))]>;
Kit Bartonba532dc2016-03-08 03:49:13 +00002856 // Load Vector (Left-justified) with Length
Stefan Pintilie26d4f922018-03-26 17:39:18 +00002857 def LXVL : XX1Form_memOp<31, 269, (outs vsrc:$XT), (ins memr:$src, g8rc:$rB),
Zaara Syedaa19c9e62016-11-15 17:54:19 +00002858 "lxvl $XT, $src, $rB", IIC_LdStLoad,
2859 [(set v4i32:$XT, (int_ppc_vsx_lxvl addr:$src, i64:$rB))]>,
2860 UseVSXReg;
Stefan Pintilie26d4f922018-03-26 17:39:18 +00002861 def LXVLL : XX1Form_memOp<31,301, (outs vsrc:$XT), (ins memr:$src, g8rc:$rB),
Zaara Syedaa19c9e62016-11-15 17:54:19 +00002862 "lxvll $XT, $src, $rB", IIC_LdStLoad,
2863 [(set v4i32:$XT, (int_ppc_vsx_lxvll addr:$src, i64:$rB))]>,
2864 UseVSXReg;
Kit Bartonba532dc2016-03-08 03:49:13 +00002865
2866 // Load Vector Word & Splat Indexed
2867 def LXVWSX : X_XT6_RA5_RB5<31, 364, "lxvwsx" , vsrc, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002868 } // mayLoad
Kit Bartonba532dc2016-03-08 03:49:13 +00002869
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00002870 // When adding new D-Form loads/stores, be sure to update the ImmToIdxMap in
2871 // PPCRegisterInfo::PPCRegisterInfo and maybe save yourself some debugging.
Sean Fertile3c8c3852017-01-26 18:59:15 +00002872 let mayStore = 1, mayLoad = 0 in {
Kit Bartonba532dc2016-03-08 03:49:13 +00002873 // Store Vector
2874 def STXV : DQ_RD6_RS5_DQ12<61, 5, (outs), (ins vsrc:$XT, memrix16:$dst),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002875 "stxv $XT, $dst", IIC_LdStSTFD, []>, UseVSXReg;
Kit Bartonba532dc2016-03-08 03:49:13 +00002876 // Store DWord
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002877 def STXSD : DSForm_1<61, 2, (outs), (ins vfrc:$vS, memrix:$dst),
Kit Bartonba532dc2016-03-08 03:49:13 +00002878 "stxsd $vS, $dst", IIC_LdStSTFD, []>;
2879 // Convert DP of dword[0] to SP, and Store to dst
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002880 def STXSSP : DSForm_1<61, 3, (outs), (ins vfrc:$vS, memrix:$dst),
Kit Bartonba532dc2016-03-08 03:49:13 +00002881 "stxssp $vS, $dst", IIC_LdStSTFD, []>;
2882
2883 // [PO S RA RB XO SX]
2884 class X_XS6_RA5_RB5<bits<6> opcode, bits<10> xo, string opc,
2885 RegisterOperand vtype, list<dag> pattern>
Stefan Pintilie26d4f922018-03-26 17:39:18 +00002886 : XX1Form_memOp<opcode, xo, (outs), (ins vtype:$XT, memrr:$dst),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002887 !strconcat(opc, " $XT, $dst"), IIC_LdStSTFD, pattern>, UseVSXReg;
Kit Bartonba532dc2016-03-08 03:49:13 +00002888
2889 // Store as Integer Byte/Halfword Indexed
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002890 def STXSIBX : X_XS6_RA5_RB5<31, 909, "stxsibx" , vsfrc,
2891 [(PPCstxsix f64:$XT, xoaddr:$dst, 1)]>;
2892 def STXSIHX : X_XS6_RA5_RB5<31, 941, "stxsihx" , vsfrc,
2893 [(PPCstxsix f64:$XT, xoaddr:$dst, 2)]>;
2894 let isCodeGenOnly = 1 in {
2895 def STXSIBXv : X_XS6_RA5_RB5<31, 909, "stxsibx" , vrrc, []>;
2896 def STXSIHXv : X_XS6_RA5_RB5<31, 941, "stxsihx" , vrrc, []>;
2897 }
Kit Bartonba532dc2016-03-08 03:49:13 +00002898
2899 // Store Vector Halfword*8/Byte*16 Indexed
2900 def STXVH8X : X_XS6_RA5_RB5<31, 940, "stxvh8x" , vsrc, []>;
2901 def STXVB16X : X_XS6_RA5_RB5<31, 1004, "stxvb16x", vsrc, []>;
2902
2903 // Store Vector Indexed
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00002904 def STXVX : X_XS6_RA5_RB5<31, 396, "stxvx" , vsrc,
Zaara Syeda93297832017-05-24 17:50:37 +00002905 [(store v2f64:$XT, xaddr:$dst)]>;
Kit Bartonba532dc2016-03-08 03:49:13 +00002906
2907 // Store Vector (Left-justified) with Length
Stefan Pintilie26d4f922018-03-26 17:39:18 +00002908 def STXVL : XX1Form_memOp<31, 397, (outs),
2909 (ins vsrc:$XT, memr:$dst, g8rc:$rB),
2910 "stxvl $XT, $dst, $rB", IIC_LdStLoad,
2911 [(int_ppc_vsx_stxvl v4i32:$XT, addr:$dst,
2912 i64:$rB)]>,
2913 UseVSXReg;
2914 def STXVLL : XX1Form_memOp<31, 429, (outs),
2915 (ins vsrc:$XT, memr:$dst, g8rc:$rB),
2916 "stxvll $XT, $dst, $rB", IIC_LdStLoad,
2917 [(int_ppc_vsx_stxvll v4i32:$XT, addr:$dst,
2918 i64:$rB)]>,
2919 UseVSXReg;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002920 } // mayStore
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002921
Lei Huang451ef4a2017-08-14 18:09:29 +00002922 let Predicates = [IsLittleEndian] in {
Lei Huangcd4f3852018-03-12 19:26:18 +00002923 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 0)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002924 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 3))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002925 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 1)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002926 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 2))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002927 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 2)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002928 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 1))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002929 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 3)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002930 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 0))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002931 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 0)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002932 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 3)), VSFRC))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002933 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 1)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002934 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 2)), VSFRC))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002935 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 2)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002936 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 1)), VSFRC))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002937 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 3)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002938 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 0)), VSFRC))>;
2939 }
2940
2941 let Predicates = [IsBigEndian] in {
Lei Huangcd4f3852018-03-12 19:26:18 +00002942 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 0)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002943 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 0))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002944 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 1)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002945 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 1))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002946 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 2)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002947 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 2))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002948 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 3)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002949 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 3))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002950 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 0)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002951 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 0)), VSFRC))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002952 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 1)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002953 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 1)), VSFRC))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002954 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 2)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002955 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 2)), VSFRC))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002956 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 3)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002957 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 3)), VSFRC))>;
2958 }
2959
Graham Yiu5cd044e2017-11-07 20:55:43 +00002960 // Alternate patterns for PPCmtvsrz where the output is v8i16 or v16i8 instead
2961 // of f64
2962 def : Pat<(v8i16 (PPCmtvsrz i32:$A)),
2963 (v8i16 (SUBREG_TO_REG (i64 1), (MTVSRWZ $A), sub_64))>;
2964 def : Pat<(v16i8 (PPCmtvsrz i32:$A)),
2965 (v16i8 (SUBREG_TO_REG (i64 1), (MTVSRWZ $A), sub_64))>;
2966
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002967 // Patterns for which instructions from ISA 3.0 are a better match
2968 let Predicates = [IsLittleEndian, HasP9Vector] in {
Lei Huangcd4f3852018-03-12 19:26:18 +00002969 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 0)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002970 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 12)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002971 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 1)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002972 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 8)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002973 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 2)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002974 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 4)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002975 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 3)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002976 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 0)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002977 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 0)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002978 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 12)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002979 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 1)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002980 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 8)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002981 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 2)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002982 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 4)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002983 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 3)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002984 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 0)))>;
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002985 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 0)),
2986 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 12))>;
2987 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 1)),
2988 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 8))>;
2989 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 2)),
2990 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 4))>;
2991 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 3)),
2992 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 0))>;
2993 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 0)),
2994 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 12))>;
2995 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 1)),
2996 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 8))>;
2997 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 2)),
2998 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 4))>;
2999 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 3)),
3000 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 0))>;
3001 } // IsLittleEndian, HasP9Vector
3002
3003 let Predicates = [IsBigEndian, HasP9Vector] in {
Lei Huangcd4f3852018-03-12 19:26:18 +00003004 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 0)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00003005 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 0)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00003006 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 1)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00003007 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 4)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00003008 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 2)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00003009 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 8)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00003010 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 3)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00003011 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 12)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00003012 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 0)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00003013 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 0)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00003014 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 1)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00003015 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 4)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00003016 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 2)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00003017 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 8)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00003018 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 3)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00003019 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 12)))>;
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00003020 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 0)),
3021 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 0))>;
3022 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 1)),
3023 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 4))>;
3024 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 2)),
3025 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 8))>;
3026 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 3)),
3027 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 12))>;
3028 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 0)),
3029 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 0))>;
3030 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 1)),
3031 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 4))>;
3032 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 2)),
3033 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 8))>;
3034 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 3)),
3035 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 12))>;
3036 } // IsLittleEndian, HasP9Vector
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00003037
Zaara Syeda93297832017-05-24 17:50:37 +00003038 // D-Form Load/Store
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003039 def : Pat<(v4i32 (quadwOffsetLoad iqaddr:$src)), (LXV memrix16:$src)>;
3040 def : Pat<(v4f32 (quadwOffsetLoad iqaddr:$src)), (LXV memrix16:$src)>;
3041 def : Pat<(v2i64 (quadwOffsetLoad iqaddr:$src)), (LXV memrix16:$src)>;
3042 def : Pat<(v2f64 (quadwOffsetLoad iqaddr:$src)), (LXV memrix16:$src)>;
Lei Huang6d1596a2018-03-19 18:52:20 +00003043 def : Pat<(f128 (quadwOffsetLoad iqaddr:$src)),
3044 (COPY_TO_REGCLASS (LXV memrix16:$src), VRRC)>;
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003045 def : Pat<(v4i32 (int_ppc_vsx_lxvw4x iqaddr:$src)), (LXV memrix16:$src)>;
3046 def : Pat<(v2f64 (int_ppc_vsx_lxvd2x iqaddr:$src)), (LXV memrix16:$src)>;
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00003047
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003048 def : Pat<(quadwOffsetStore v4f32:$rS, iqaddr:$dst), (STXV $rS, memrix16:$dst)>;
3049 def : Pat<(quadwOffsetStore v4i32:$rS, iqaddr:$dst), (STXV $rS, memrix16:$dst)>;
3050 def : Pat<(quadwOffsetStore v2f64:$rS, iqaddr:$dst), (STXV $rS, memrix16:$dst)>;
Lei Huang6d1596a2018-03-19 18:52:20 +00003051 def : Pat<(quadwOffsetStore f128:$rS, iqaddr:$dst),
3052 (STXV (COPY_TO_REGCLASS $rS, VSRC), memrix16:$dst)>;
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003053 def : Pat<(quadwOffsetStore v2i64:$rS, iqaddr:$dst), (STXV $rS, memrix16:$dst)>;
3054 def : Pat<(int_ppc_vsx_stxvw4x v4i32:$rS, iqaddr:$dst),
Zaara Syeda93297832017-05-24 17:50:37 +00003055 (STXV $rS, memrix16:$dst)>;
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003056 def : Pat<(int_ppc_vsx_stxvd2x v2f64:$rS, iqaddr:$dst),
Zaara Syeda93297832017-05-24 17:50:37 +00003057 (STXV $rS, memrix16:$dst)>;
3058
3059
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003060 def : Pat<(v2f64 (nonQuadwOffsetLoad xoaddr:$src)), (LXVX xoaddr:$src)>;
3061 def : Pat<(v2i64 (nonQuadwOffsetLoad xoaddr:$src)), (LXVX xoaddr:$src)>;
3062 def : Pat<(v4f32 (nonQuadwOffsetLoad xoaddr:$src)), (LXVX xoaddr:$src)>;
3063 def : Pat<(v4i32 (nonQuadwOffsetLoad xoaddr:$src)), (LXVX xoaddr:$src)>;
3064 def : Pat<(v4i32 (int_ppc_vsx_lxvw4x xoaddr:$src)), (LXVX xoaddr:$src)>;
3065 def : Pat<(v2f64 (int_ppc_vsx_lxvd2x xoaddr:$src)), (LXVX xoaddr:$src)>;
Lei Huang6d1596a2018-03-19 18:52:20 +00003066 def : Pat<(f128 (nonQuadwOffsetLoad xoaddr:$src)),
3067 (COPY_TO_REGCLASS (LXVX xoaddr:$src), VRRC)>;
3068 def : Pat<(nonQuadwOffsetStore f128:$rS, xoaddr:$dst),
3069 (STXVX (COPY_TO_REGCLASS $rS, VSRC), xoaddr:$dst)>;
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003070 def : Pat<(nonQuadwOffsetStore v2f64:$rS, xoaddr:$dst),
3071 (STXVX $rS, xoaddr:$dst)>;
3072 def : Pat<(nonQuadwOffsetStore v2i64:$rS, xoaddr:$dst),
3073 (STXVX $rS, xoaddr:$dst)>;
3074 def : Pat<(nonQuadwOffsetStore v4f32:$rS, xoaddr:$dst),
3075 (STXVX $rS, xoaddr:$dst)>;
3076 def : Pat<(nonQuadwOffsetStore v4i32:$rS, xoaddr:$dst),
3077 (STXVX $rS, xoaddr:$dst)>;
3078 def : Pat<(int_ppc_vsx_stxvw4x v4i32:$rS, xoaddr:$dst),
3079 (STXVX $rS, xoaddr:$dst)>;
3080 def : Pat<(int_ppc_vsx_stxvd2x v2f64:$rS, xoaddr:$dst),
3081 (STXVX $rS, xoaddr:$dst)>;
Zaara Syedab2595b92018-08-08 15:20:43 +00003082
3083 let AddedComplexity = 400 in {
3084 // LIWAX - This instruction is used for sign extending i32 -> i64.
3085 // LIWZX - This instruction will be emitted for i32, f32, and when
3086 // zero-extending i32 to i64 (zext i32 -> i64).
3087 let Predicates = [IsLittleEndian] in {
3088
3089 def : Pat<(v2i64 (scalar_to_vector (i64 (sextloadi32 xoaddr:$src)))),
3090 (v2i64 (XXPERMDIs
3091 (COPY_TO_REGCLASS (LIWAX xoaddr:$src), VSRC), 2))>;
3092
3093 def : Pat<(v2i64 (scalar_to_vector (i64 (zextloadi32 xoaddr:$src)))),
3094 (v2i64 (XXPERMDIs
3095 (COPY_TO_REGCLASS (LIWZX xoaddr:$src), VSRC), 2))>;
3096
3097 def : Pat<(v4i32 (scalar_to_vector (i32 (load xoaddr:$src)))),
3098 (v4i32 (XXPERMDIs
3099 (COPY_TO_REGCLASS (LIWZX xoaddr:$src), VSRC), 2))>;
3100
3101 def : Pat<(v4f32 (scalar_to_vector (f32 (load xoaddr:$src)))),
3102 (v4f32 (XXPERMDIs
3103 (COPY_TO_REGCLASS (LIWZX xoaddr:$src), VSRC), 2))>;
3104 }
3105
3106 let Predicates = [IsBigEndian] in {
3107 def : Pat<(v2i64 (scalar_to_vector (i64 (sextloadi32 xoaddr:$src)))),
3108 (v2i64 (COPY_TO_REGCLASS (LIWAX xoaddr:$src), VSRC))>;
3109
3110 def : Pat<(v2i64 (scalar_to_vector (i64 (zextloadi32 xoaddr:$src)))),
3111 (v2i64 (COPY_TO_REGCLASS (LIWZX xoaddr:$src), VSRC))>;
3112
3113 def : Pat<(v4i32 (scalar_to_vector (i32 (load xoaddr:$src)))),
3114 (v4i32 (XXSLDWIs
3115 (COPY_TO_REGCLASS (LIWZX xoaddr:$src), VSRC), 1))>;
3116
3117 def : Pat<(v4f32 (scalar_to_vector (f32 (load xoaddr:$src)))),
3118 (v4f32 (XXSLDWIs
3119 (COPY_TO_REGCLASS (LIWZX xoaddr:$src), VSRC), 1))>;
3120 }
3121
3122 }
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003123
3124 // Build vectors from i8 loads
3125 def : Pat<(v16i8 (scalar_to_vector ScalarLoads.Li8)),
3126 (v16i8 (VSPLTBs 7, (LXSIBZX xoaddr:$src)))>;
3127 def : Pat<(v8i16 (scalar_to_vector ScalarLoads.ZELi8)),
3128 (v8i16 (VSPLTHs 3, (LXSIBZX xoaddr:$src)))>;
3129 def : Pat<(v4i32 (scalar_to_vector ScalarLoads.ZELi8)),
3130 (v4i32 (XXSPLTWs (LXSIBZX xoaddr:$src), 1))>;
3131 def : Pat<(v2i64 (scalar_to_vector ScalarLoads.ZELi8i64)),
Nemanja Ivanovic15748f42016-12-06 11:47:14 +00003132 (v2i64 (XXPERMDIs (LXSIBZX xoaddr:$src), 0))>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003133 def : Pat<(v4i32 (scalar_to_vector ScalarLoads.SELi8)),
3134 (v4i32 (XXSPLTWs (VEXTSB2Ws (LXSIBZX xoaddr:$src)), 1))>;
3135 def : Pat<(v2i64 (scalar_to_vector ScalarLoads.SELi8i64)),
Nemanja Ivanovic15748f42016-12-06 11:47:14 +00003136 (v2i64 (XXPERMDIs (VEXTSB2Ds (LXSIBZX xoaddr:$src)), 0))>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003137
3138 // Build vectors from i16 loads
3139 def : Pat<(v8i16 (scalar_to_vector ScalarLoads.Li16)),
3140 (v8i16 (VSPLTHs 3, (LXSIHZX xoaddr:$src)))>;
3141 def : Pat<(v4i32 (scalar_to_vector ScalarLoads.ZELi16)),
3142 (v4i32 (XXSPLTWs (LXSIHZX xoaddr:$src), 1))>;
3143 def : Pat<(v2i64 (scalar_to_vector ScalarLoads.ZELi16i64)),
Nemanja Ivanovic15748f42016-12-06 11:47:14 +00003144 (v2i64 (XXPERMDIs (LXSIHZX xoaddr:$src), 0))>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003145 def : Pat<(v4i32 (scalar_to_vector ScalarLoads.SELi16)),
3146 (v4i32 (XXSPLTWs (VEXTSH2Ws (LXSIHZX xoaddr:$src)), 1))>;
3147 def : Pat<(v2i64 (scalar_to_vector ScalarLoads.SELi16i64)),
Nemanja Ivanovic15748f42016-12-06 11:47:14 +00003148 (v2i64 (XXPERMDIs (VEXTSH2Ds (LXSIHZX xoaddr:$src)), 0))>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003149
3150 let Predicates = [IsBigEndian, HasP9Vector] in {
3151 // Scalar stores of i8
3152 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 0)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003153 (STXSIBXv (v16i8 (VSLDOI $S, $S, 9)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003154 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 1)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003155 (STXSIBXv (v16i8 (VSLDOI $S, $S, 10)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003156 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 2)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003157 (STXSIBXv (v16i8 (VSLDOI $S, $S, 11)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003158 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 3)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003159 (STXSIBXv (v16i8 (VSLDOI $S, $S, 12)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003160 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 4)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003161 (STXSIBXv (v16i8 (VSLDOI $S, $S, 13)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003162 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 5)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003163 (STXSIBXv (v16i8 (VSLDOI $S, $S, 14)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003164 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 6)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003165 (STXSIBXv (v16i8 (VSLDOI $S, $S, 15)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003166 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 7)), xoaddr:$dst),
3167 (STXSIBXv $S, xoaddr:$dst)>;
3168 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 8)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003169 (STXSIBXv (v16i8 (VSLDOI $S, $S, 1)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003170 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 9)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003171 (STXSIBXv (v16i8 (VSLDOI $S, $S, 2)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003172 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 10)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003173 (STXSIBXv (v16i8 (VSLDOI $S, $S, 3)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003174 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 11)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003175 (STXSIBXv (v16i8 (VSLDOI $S, $S, 4)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003176 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 12)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003177 (STXSIBXv (v16i8 (VSLDOI $S, $S, 5)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003178 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 13)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003179 (STXSIBXv (v16i8 (VSLDOI $S, $S, 6)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003180 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 14)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003181 (STXSIBXv (v16i8 (VSLDOI $S, $S, 7)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003182 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 15)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003183 (STXSIBXv (v16i8 (VSLDOI $S, $S, 8)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003184
3185 // Scalar stores of i16
3186 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 0)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003187 (STXSIHXv (v16i8 (VSLDOI $S, $S, 10)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003188 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 1)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003189 (STXSIHXv (v16i8 (VSLDOI $S, $S, 12)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003190 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 2)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003191 (STXSIHXv (v16i8 (VSLDOI $S, $S, 14)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003192 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 3)), xoaddr:$dst),
3193 (STXSIHXv $S, xoaddr:$dst)>;
3194 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 4)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003195 (STXSIHXv (v16i8 (VSLDOI $S, $S, 2)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003196 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 5)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003197 (STXSIHXv (v16i8 (VSLDOI $S, $S, 4)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003198 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 6)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003199 (STXSIHXv (v16i8 (VSLDOI $S, $S, 6)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003200 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 7)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003201 (STXSIHXv (v16i8 (VSLDOI $S, $S, 8)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003202 } // IsBigEndian, HasP9Vector
3203
3204 let Predicates = [IsLittleEndian, HasP9Vector] in {
3205 // Scalar stores of i8
3206 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 0)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003207 (STXSIBXv (v16i8 (VSLDOI $S, $S, 8)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003208 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 1)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003209 (STXSIBXv (v16i8 (VSLDOI $S, $S, 7)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003210 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 2)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003211 (STXSIBXv (v16i8 (VSLDOI $S, $S, 6)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003212 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 3)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003213 (STXSIBXv (v16i8 (VSLDOI $S, $S, 5)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003214 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 4)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003215 (STXSIBXv (v16i8 (VSLDOI $S, $S, 4)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003216 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 5)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003217 (STXSIBXv (v16i8 (VSLDOI $S, $S, 3)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003218 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 6)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003219 (STXSIBXv (v16i8 (VSLDOI $S, $S, 2)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003220 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 7)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003221 (STXSIBXv (v16i8 (VSLDOI $S, $S, 1)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003222 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 8)), xoaddr:$dst),
3223 (STXSIBXv $S, xoaddr:$dst)>;
3224 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 9)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003225 (STXSIBXv (v16i8 (VSLDOI $S, $S, 15)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003226 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 10)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003227 (STXSIBXv (v16i8 (VSLDOI $S, $S, 14)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003228 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 11)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003229 (STXSIBXv (v16i8 (VSLDOI $S, $S, 13)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003230 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 12)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003231 (STXSIBXv (v16i8 (VSLDOI $S, $S, 12)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003232 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 13)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003233 (STXSIBXv (v16i8 (VSLDOI $S, $S, 11)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003234 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 14)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003235 (STXSIBXv (v16i8 (VSLDOI $S, $S, 10)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003236 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 15)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003237 (STXSIBXv (v16i8 (VSLDOI $S, $S, 9)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003238
3239 // Scalar stores of i16
3240 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 0)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003241 (STXSIHXv (v16i8 (VSLDOI $S, $S, 8)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003242 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 1)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003243 (STXSIHXv (v16i8 (VSLDOI $S, $S, 6)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003244 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 2)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003245 (STXSIHXv (v16i8 (VSLDOI $S, $S, 4)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003246 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 3)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003247 (STXSIHXv (v16i8 (VSLDOI $S, $S, 2)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003248 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 4)), xoaddr:$dst),
3249 (STXSIHXv $S, xoaddr:$dst)>;
3250 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 5)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003251 (STXSIHXv (v16i8 (VSLDOI $S, $S, 14)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003252 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 6)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003253 (STXSIHXv (v16i8 (VSLDOI $S, $S, 12)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003254 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 7)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003255 (STXSIHXv (v16i8 (VSLDOI $S, $S, 10)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003256 } // IsLittleEndian, HasP9Vector
3257
Sean Fertile1c4109b2016-12-09 17:21:42 +00003258
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003259 // Vector sign extensions
3260 def : Pat<(f64 (PPCVexts f64:$A, 1)),
3261 (f64 (COPY_TO_REGCLASS (VEXTSB2Ds $A), VSFRC))>;
3262 def : Pat<(f64 (PPCVexts f64:$A, 2)),
3263 (f64 (COPY_TO_REGCLASS (VEXTSH2Ds $A), VSFRC))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003264
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00003265 let isPseudo = 1 in {
3266 def DFLOADf32 : Pseudo<(outs vssrc:$XT), (ins memrix:$src),
3267 "#DFLOADf32",
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003268 [(set f32:$XT, (load ixaddr:$src))]>;
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00003269 def DFLOADf64 : Pseudo<(outs vsfrc:$XT), (ins memrix:$src),
3270 "#DFLOADf64",
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003271 [(set f64:$XT, (load ixaddr:$src))]>;
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00003272 def DFSTOREf32 : Pseudo<(outs), (ins vssrc:$XT, memrix:$dst),
3273 "#DFSTOREf32",
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003274 [(store f32:$XT, ixaddr:$dst)]>;
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00003275 def DFSTOREf64 : Pseudo<(outs), (ins vsfrc:$XT, memrix:$dst),
3276 "#DFSTOREf64",
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003277 [(store f64:$XT, ixaddr:$dst)]>;
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00003278 }
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003279 def : Pat<(f64 (extloadf32 ixaddr:$src)),
3280 (COPY_TO_REGCLASS (DFLOADf32 ixaddr:$src), VSFRC)>;
Lei Huangcd4f3852018-03-12 19:26:18 +00003281 def : Pat<(f32 (fpround (f64 (extloadf32 ixaddr:$src)))),
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003282 (f32 (DFLOADf32 ixaddr:$src))>;
Lei Huang10367eb2018-04-12 18:00:14 +00003283
Zaara Syedab2595b92018-08-08 15:20:43 +00003284
3285 let AddedComplexity = 400 in {
3286 // The following pseudoinstructions are used to ensure the utilization
3287 // of all 64 VSX registers.
3288 let Predicates = [IsLittleEndian, HasP9Vector] in {
3289 def : Pat<(v2i64 (scalar_to_vector (i64 (load ixaddr:$src)))),
3290 (v2i64 (XXPERMDIs
3291 (COPY_TO_REGCLASS (DFLOADf64 ixaddr:$src), VSRC), 2))>;
3292 def : Pat<(v2i64 (scalar_to_vector (i64 (load xaddr:$src)))),
3293 (v2i64 (XXPERMDIs
3294 (COPY_TO_REGCLASS (XFLOADf64 xaddr:$src), VSRC), 2))>;
3295
3296 def : Pat<(v2f64 (scalar_to_vector (f64 (load ixaddr:$src)))),
3297 (v2f64 (XXPERMDIs
3298 (COPY_TO_REGCLASS (DFLOADf64 ixaddr:$src), VSRC), 2))>;
3299 def : Pat<(v2f64 (scalar_to_vector (f64 (load xaddr:$src)))),
3300 (v2f64 (XXPERMDIs
3301 (COPY_TO_REGCLASS (XFLOADf64 xaddr:$src), VSRC), 2))>;
3302 }
3303
3304 let Predicates = [IsBigEndian, HasP9Vector] in {
3305 def : Pat<(v2i64 (scalar_to_vector (i64 (load ixaddr:$src)))),
3306 (v2i64 (COPY_TO_REGCLASS (DFLOADf64 ixaddr:$src), VSRC))>;
3307 def : Pat<(v2i64 (scalar_to_vector (i64 (load xaddr:$src)))),
3308 (v2i64 (COPY_TO_REGCLASS (XFLOADf64 xaddr:$src), VSRC))>;
3309
3310 def : Pat<(v2f64 (scalar_to_vector (f64 (load ixaddr:$src)))),
3311 (v2f64 (COPY_TO_REGCLASS (DFLOADf64 ixaddr:$src), VSRC))>;
3312 def : Pat<(v2f64 (scalar_to_vector (f64 (load xaddr:$src)))),
3313 (v2f64 (COPY_TO_REGCLASS (XFLOADf64 xaddr:$src), VSRC))>;
3314 }
3315 }
3316
Lei Huang8b0da652018-05-23 19:31:54 +00003317 let Predicates = [IsBigEndian, HasP9Vector] in {
Lei Huang89901682018-05-23 18:36:51 +00003318
Lei Huang8b0da652018-05-23 19:31:54 +00003319 // (Un)Signed DWord vector extract -> QP
3320 def : Pat<(f128 (sint_to_fp (i64 (extractelt v2i64:$src, 0)))),
3321 (f128 (XSCVSDQP (COPY_TO_REGCLASS $src, VFRC)))>;
3322 def : Pat<(f128 (sint_to_fp (i64 (extractelt v2i64:$src, 1)))),
3323 (f128 (XSCVSDQP
3324 (EXTRACT_SUBREG (XXPERMDI $src, $src, 3), sub_64)))>;
3325 def : Pat<(f128 (uint_to_fp (i64 (extractelt v2i64:$src, 0)))),
3326 (f128 (XSCVUDQP (COPY_TO_REGCLASS $src, VFRC)))>;
3327 def : Pat<(f128 (uint_to_fp (i64 (extractelt v2i64:$src, 1)))),
3328 (f128 (XSCVUDQP
3329 (EXTRACT_SUBREG (XXPERMDI $src, $src, 3), sub_64)))>;
3330
3331 // (Un)Signed Word vector extract -> QP
3332 def : Pat<(f128 (sint_to_fp (i32 (extractelt v4i32:$src, 1)))),
3333 (f128 (XSCVSDQP (EXTRACT_SUBREG (VEXTSW2D $src), sub_64)))>;
3334 foreach Idx = [0,2,3] in {
3335 def : Pat<(f128 (sint_to_fp (i32 (extractelt v4i32:$src, Idx)))),
3336 (f128 (XSCVSDQP (EXTRACT_SUBREG
3337 (VEXTSW2D (VSPLTW Idx, $src)), sub_64)))>;
3338 }
3339 foreach Idx = 0-3 in {
3340 def : Pat<(f128 (uint_to_fp (i32 (extractelt v4i32:$src, Idx)))),
3341 (f128 (XSCVUDQP (XXEXTRACTUW $src, !shl(Idx, 2))))>;
3342 }
3343
Lei Huang651be442018-05-28 16:43:29 +00003344 // (Un)Signed HWord vector extract -> QP
3345 foreach Idx = 0-7 in {
3346 def : Pat<(f128 (sint_to_fp
3347 (i32 (sext_inreg
3348 (vector_extract v8i16:$src, Idx), i16)))),
3349 (f128 (XSCVSDQP (EXTRACT_SUBREG
3350 (VEXTSH2D (VEXTRACTUH !add(Idx, Idx), $src)),
3351 sub_64)))>;
3352 // The SDAG adds the `and` since an `i16` is being extracted as an `i32`.
3353 def : Pat<(f128 (uint_to_fp
3354 (and (i32 (vector_extract v8i16:$src, Idx)), 65535))),
3355 (f128 (XSCVUDQP (EXTRACT_SUBREG
3356 (VEXTRACTUH !add(Idx, Idx), $src), sub_64)))>;
3357 }
3358
3359 // (Un)Signed Byte vector extract -> QP
3360 foreach Idx = 0-15 in {
3361 def : Pat<(f128 (sint_to_fp
3362 (i32 (sext_inreg (vector_extract v16i8:$src, Idx),
3363 i8)))),
3364 (f128 (XSCVSDQP (EXTRACT_SUBREG
3365 (VEXTSB2D (VEXTRACTUB Idx, $src)), sub_64)))>;
3366 def : Pat<(f128 (uint_to_fp
3367 (and (i32 (vector_extract v16i8:$src, Idx)), 255))),
3368 (f128 (XSCVUDQP
3369 (EXTRACT_SUBREG (VEXTRACTUB Idx, $src), sub_64)))>;
3370 }
Lei Huang66e22c22018-07-05 07:46:01 +00003371
3372 // Unsiged int in vsx register -> QP
3373 def : Pat<(f128 (uint_to_fp (i32 (PPCmfvsr f64:$src)))),
3374 (f128 (XSCVUDQP
3375 (XXEXTRACTUW (SUBREG_TO_REG (i64 1), $src, sub_64), 4)))>;
Lei Huang8b0da652018-05-23 19:31:54 +00003376 } // IsBigEndian, HasP9Vector
3377
3378 let Predicates = [IsLittleEndian, HasP9Vector] in {
3379
3380 // (Un)Signed DWord vector extract -> QP
Lei Huang89901682018-05-23 18:36:51 +00003381 def : Pat<(f128 (sint_to_fp (i64 (extractelt v2i64:$src, 0)))),
3382 (f128 (XSCVSDQP
3383 (EXTRACT_SUBREG (XXPERMDI $src, $src, 3), sub_64)))>;
3384 def : Pat<(f128 (sint_to_fp (i64 (extractelt v2i64:$src, 1)))),
3385 (f128 (XSCVSDQP (COPY_TO_REGCLASS $src, VFRC)))>;
3386 def : Pat<(f128 (uint_to_fp (i64 (extractelt v2i64:$src, 0)))),
3387 (f128 (XSCVUDQP
3388 (EXTRACT_SUBREG (XXPERMDI $src, $src, 3), sub_64)))>;
3389 def : Pat<(f128 (uint_to_fp (i64 (extractelt v2i64:$src, 1)))),
3390 (f128 (XSCVUDQP (COPY_TO_REGCLASS $src, VFRC)))>;
Lei Huang8b0da652018-05-23 19:31:54 +00003391
3392 // (Un)Signed Word vector extract -> QP
3393 foreach Idx = [[0,3],[1,2],[3,0]] in {
3394 def : Pat<(f128 (sint_to_fp (i32 (extractelt v4i32:$src, !head(Idx))))),
3395 (f128 (XSCVSDQP (EXTRACT_SUBREG
3396 (VEXTSW2D (VSPLTW !head(!tail(Idx)), $src)),
3397 sub_64)))>;
3398 }
3399 def : Pat<(f128 (sint_to_fp (i32 (extractelt v4i32:$src, 2)))),
3400 (f128 (XSCVSDQP (EXTRACT_SUBREG (VEXTSW2D $src), sub_64)))>;
3401
3402 foreach Idx = [[0,12],[1,8],[2,4],[3,0]] in {
3403 def : Pat<(f128 (uint_to_fp (i32 (extractelt v4i32:$src, !head(Idx))))),
3404 (f128 (XSCVUDQP (XXEXTRACTUW $src, !head(!tail(Idx)))))>;
3405 }
Lei Huang651be442018-05-28 16:43:29 +00003406
3407 // (Un)Signed HWord vector extract -> QP
3408 // The Nested foreach lists identifies the vector element and corresponding
3409 // register byte location.
3410 foreach Idx = [[0,14],[1,12],[2,10],[3,8],[4,6],[5,4],[6,2],[7,0]] in {
3411 def : Pat<(f128 (sint_to_fp
3412 (i32 (sext_inreg
3413 (vector_extract v8i16:$src, !head(Idx)), i16)))),
3414 (f128 (XSCVSDQP
3415 (EXTRACT_SUBREG (VEXTSH2D
3416 (VEXTRACTUH !head(!tail(Idx)), $src)),
3417 sub_64)))>;
3418 def : Pat<(f128 (uint_to_fp
3419 (and (i32 (vector_extract v8i16:$src, !head(Idx))),
3420 65535))),
3421 (f128 (XSCVUDQP (EXTRACT_SUBREG
3422 (VEXTRACTUH !head(!tail(Idx)), $src), sub_64)))>;
3423 }
3424
3425 // (Un)Signed Byte vector extract -> QP
3426 foreach Idx = [[0,15],[1,14],[2,13],[3,12],[4,11],[5,10],[6,9],[7,8],[8,7],
3427 [9,6],[10,5],[11,4],[12,3],[13,2],[14,1],[15,0]] in {
3428 def : Pat<(f128 (sint_to_fp
3429 (i32 (sext_inreg
3430 (vector_extract v16i8:$src, !head(Idx)), i8)))),
3431 (f128 (XSCVSDQP
3432 (EXTRACT_SUBREG
3433 (VEXTSB2D (VEXTRACTUB !head(!tail(Idx)), $src)),
3434 sub_64)))>;
3435 def : Pat<(f128 (uint_to_fp
3436 (and (i32 (vector_extract v16i8:$src, !head(Idx))),
3437 255))),
3438 (f128 (XSCVUDQP
3439 (EXTRACT_SUBREG
3440 (VEXTRACTUB !head(!tail(Idx)), $src), sub_64)))>;
3441 }
Lei Huang66e22c22018-07-05 07:46:01 +00003442
3443 // Unsiged int in vsx register -> QP
3444 def : Pat<(f128 (uint_to_fp (i32 (PPCmfvsr f64:$src)))),
3445 (f128 (XSCVUDQP
3446 (XXEXTRACTUW (SUBREG_TO_REG (i64 1), $src, sub_64), 8)))>;
Lei Huang8b0da652018-05-23 19:31:54 +00003447 } // IsLittleEndian, HasP9Vector
Lei Huang89901682018-05-23 18:36:51 +00003448
Lei Huang10367eb2018-04-12 18:00:14 +00003449 // Convert (Un)Signed DWord in memory -> QP
3450 def : Pat<(f128 (sint_to_fp (i64 (load xaddr:$src)))),
3451 (f128 (XSCVSDQP (LXSDX xaddr:$src)))>;
3452 def : Pat<(f128 (sint_to_fp (i64 (load ixaddr:$src)))),
3453 (f128 (XSCVSDQP (LXSD ixaddr:$src)))>;
3454 def : Pat<(f128 (uint_to_fp (i64 (load xaddr:$src)))),
3455 (f128 (XSCVUDQP (LXSDX xaddr:$src)))>;
3456 def : Pat<(f128 (uint_to_fp (i64 (load ixaddr:$src)))),
3457 (f128 (XSCVUDQP (LXSD ixaddr:$src)))>;
3458
Lei Huang192c6cc2018-04-18 17:41:46 +00003459 // Convert Unsigned HWord in memory -> QP
3460 def : Pat<(f128 (uint_to_fp ScalarLoads.ZELi16)),
3461 (f128 (XSCVUDQP (LXSIHZX xaddr:$src)))>;
3462
3463 // Convert Unsigned Byte in memory -> QP
3464 def : Pat<(f128 (uint_to_fp ScalarLoads.ZELi8)),
3465 (f128 (XSCVUDQP (LXSIBZX xoaddr:$src)))>;
3466
Lei Huangc517e952018-05-08 18:23:31 +00003467 // Truncate & Convert QP -> (Un)Signed (D)Word.
3468 def : Pat<(i64 (fp_to_sint f128:$src)), (i64 (MFVRD (XSCVQPSDZ $src)))>;
3469 def : Pat<(i64 (fp_to_uint f128:$src)), (i64 (MFVRD (XSCVQPUDZ $src)))>;
Lei Huang63642882018-05-08 18:34:00 +00003470 def : Pat<(i32 (fp_to_sint f128:$src)),
3471 (i32 (MFVSRWZ (COPY_TO_REGCLASS (XSCVQPSWZ $src), VFRC)))>;
3472 def : Pat<(i32 (fp_to_uint f128:$src)),
3473 (i32 (MFVSRWZ (COPY_TO_REGCLASS (XSCVQPUWZ $src), VFRC)))>;
Lei Huangc517e952018-05-08 18:23:31 +00003474
Lei Huange41e3d32018-05-08 18:52:06 +00003475 // Instructions for store(fptosi).
Lei Huangc29229a2018-05-08 17:36:40 +00003476 // The 8-byte version is repeated here due to availability of D-Form STXSD.
3477 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huangc517e952018-05-08 18:23:31 +00003478 (f64 (PPCcv_fp_to_sint_in_vsr f128:$src)), xaddr:$dst, 8),
3479 (STXSDX (COPY_TO_REGCLASS (XSCVQPSDZ f128:$src), VFRC),
3480 xaddr:$dst)>;
3481 def : Pat<(PPCstore_scal_int_from_vsr
3482 (f64 (PPCcv_fp_to_sint_in_vsr f128:$src)), ixaddr:$dst, 8),
3483 (STXSD (COPY_TO_REGCLASS (XSCVQPSDZ f128:$src), VFRC),
3484 ixaddr:$dst)>;
3485 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huang63642882018-05-08 18:34:00 +00003486 (f64 (PPCcv_fp_to_sint_in_vsr f128:$src)), xoaddr:$dst, 4),
3487 (STXSIWX (COPY_TO_REGCLASS (XSCVQPSWZ $src), VFRC), xoaddr:$dst)>;
3488 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huange41e3d32018-05-08 18:52:06 +00003489 (f64 (PPCcv_fp_to_sint_in_vsr f128:$src)), xoaddr:$dst, 2),
3490 (STXSIHX (COPY_TO_REGCLASS (XSCVQPSWZ $src), VFRC), xoaddr:$dst)>;
3491 def : Pat<(PPCstore_scal_int_from_vsr
3492 (f64 (PPCcv_fp_to_sint_in_vsr f128:$src)), xoaddr:$dst, 1),
3493 (STXSIBX (COPY_TO_REGCLASS (XSCVQPSWZ $src), VFRC), xoaddr:$dst)>;
3494 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huangc29229a2018-05-08 17:36:40 +00003495 (f64 (PPCcv_fp_to_sint_in_vsr f64:$src)), xaddr:$dst, 8),
3496 (STXSDX (XSCVDPSXDS f64:$src), xaddr:$dst)>;
3497 def : Pat<(PPCstore_scal_int_from_vsr
3498 (f64 (PPCcv_fp_to_sint_in_vsr f64:$src)), ixaddr:$dst, 8),
3499 (STXSD (XSCVDPSXDS f64:$src), ixaddr:$dst)>;
3500 def : Pat<(PPCstore_scal_int_from_vsr
3501 (f64 (PPCcv_fp_to_sint_in_vsr f64:$src)), xoaddr:$dst, 2),
3502 (STXSIHX (XSCVDPSXWS f64:$src), xoaddr:$dst)>;
3503 def : Pat<(PPCstore_scal_int_from_vsr
3504 (f64 (PPCcv_fp_to_sint_in_vsr f64:$src)), xoaddr:$dst, 1),
3505 (STXSIBX (XSCVDPSXWS f64:$src), xoaddr:$dst)>;
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00003506
Lei Huange41e3d32018-05-08 18:52:06 +00003507 // Instructions for store(fptoui).
Lei Huangc29229a2018-05-08 17:36:40 +00003508 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huangc517e952018-05-08 18:23:31 +00003509 (f64 (PPCcv_fp_to_uint_in_vsr f128:$src)), xaddr:$dst, 8),
3510 (STXSDX (COPY_TO_REGCLASS (XSCVQPUDZ f128:$src), VFRC),
3511 xaddr:$dst)>;
3512 def : Pat<(PPCstore_scal_int_from_vsr
3513 (f64 (PPCcv_fp_to_uint_in_vsr f128:$src)), ixaddr:$dst, 8),
3514 (STXSD (COPY_TO_REGCLASS (XSCVQPUDZ f128:$src), VFRC),
3515 ixaddr:$dst)>;
3516 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huang63642882018-05-08 18:34:00 +00003517 (f64 (PPCcv_fp_to_uint_in_vsr f128:$src)), xoaddr:$dst, 4),
3518 (STXSIWX (COPY_TO_REGCLASS (XSCVQPUWZ $src), VFRC), xoaddr:$dst)>;
3519 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huange41e3d32018-05-08 18:52:06 +00003520 (f64 (PPCcv_fp_to_uint_in_vsr f128:$src)), xoaddr:$dst, 2),
3521 (STXSIHX (COPY_TO_REGCLASS (XSCVQPUWZ $src), VFRC), xoaddr:$dst)>;
3522 def : Pat<(PPCstore_scal_int_from_vsr
3523 (f64 (PPCcv_fp_to_uint_in_vsr f128:$src)), xoaddr:$dst, 1),
3524 (STXSIBX (COPY_TO_REGCLASS (XSCVQPUWZ $src), VFRC), xoaddr:$dst)>;
3525 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huangc29229a2018-05-08 17:36:40 +00003526 (f64 (PPCcv_fp_to_uint_in_vsr f64:$src)), xaddr:$dst, 8),
3527 (STXSDX (XSCVDPUXDS f64:$src), xaddr:$dst)>;
3528 def : Pat<(PPCstore_scal_int_from_vsr
3529 (f64 (PPCcv_fp_to_uint_in_vsr f64:$src)), ixaddr:$dst, 8),
3530 (STXSD (XSCVDPUXDS f64:$src), ixaddr:$dst)>;
3531 def : Pat<(PPCstore_scal_int_from_vsr
3532 (f64 (PPCcv_fp_to_uint_in_vsr f64:$src)), xoaddr:$dst, 2),
3533 (STXSIHX (XSCVDPUXWS f64:$src), xoaddr:$dst)>;
3534 def : Pat<(PPCstore_scal_int_from_vsr
3535 (f64 (PPCcv_fp_to_uint_in_vsr f64:$src)), xoaddr:$dst, 1),
3536 (STXSIBX (XSCVDPUXWS f64:$src), xoaddr:$dst)>;
3537
Lei Huang6270ab62018-07-04 21:59:16 +00003538 // Round & Convert QP -> DP/SP
3539 def : Pat<(f64 (fpround f128:$src)), (f64 (XSCVQPDP $src))>;
3540 def : Pat<(f32 (fpround f128:$src)), (f32 (XSRSP (XSCVQPDPO $src)))>;
Lei Huangd17c39c2018-07-05 04:18:37 +00003541
3542 // Convert SP -> QP
3543 def : Pat<(f128 (fpextend f32:$src)),
3544 (f128 (XSCVDPQP (COPY_TO_REGCLASS $src, VFRC)))>;
3545
Lei Huangc29229a2018-05-08 17:36:40 +00003546} // end HasP9Vector, AddedComplexity
Lei Huang6270ab62018-07-04 21:59:16 +00003547
Lei Huanga855e172018-07-05 06:21:37 +00003548let AddedComplexity = 400 in {
3549 let Predicates = [IsISA3_0, HasP9Vector, HasDirectMove, IsBigEndian] in {
3550 def : Pat<(f128 (PPCbuild_fp128 i64:$rB, i64:$rA)),
3551 (f128 (COPY_TO_REGCLASS (MTVSRDD $rB, $rA), VRRC))>;
3552 }
3553 let Predicates = [IsISA3_0, HasP9Vector, HasDirectMove, IsLittleEndian] in {
3554 def : Pat<(f128 (PPCbuild_fp128 i64:$rA, i64:$rB)),
3555 (f128 (COPY_TO_REGCLASS (MTVSRDD $rB, $rA), VRRC))>;
3556 }
3557}
3558
Zaara Syedafcd96972017-09-21 16:12:33 +00003559let Predicates = [HasP9Vector] in {
3560 let isPseudo = 1 in {
3561 let mayStore = 1 in {
Stefan Pintilie26d4f922018-03-26 17:39:18 +00003562 def SPILLTOVSR_STX : PseudoXFormMemOp<(outs),
3563 (ins spilltovsrrc:$XT, memrr:$dst),
3564 "#SPILLTOVSR_STX", []>;
Zaara Syedafcd96972017-09-21 16:12:33 +00003565 def SPILLTOVSR_ST : Pseudo<(outs), (ins spilltovsrrc:$XT, memrix:$dst),
3566 "#SPILLTOVSR_ST", []>;
3567 }
3568 let mayLoad = 1 in {
Stefan Pintilie26d4f922018-03-26 17:39:18 +00003569 def SPILLTOVSR_LDX : PseudoXFormMemOp<(outs spilltovsrrc:$XT),
3570 (ins memrr:$src),
3571 "#SPILLTOVSR_LDX", []>;
Zaara Syedafcd96972017-09-21 16:12:33 +00003572 def SPILLTOVSR_LD : Pseudo<(outs spilltovsrrc:$XT), (ins memrix:$src),
3573 "#SPILLTOVSR_LD", []>;
3574
3575 }
3576 }
3577}
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003578// Integer extend helper dags 32 -> 64
3579def AnyExts {
3580 dag A = (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $A, sub_32);
3581 dag B = (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $B, sub_32);
3582 dag C = (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $C, sub_32);
3583 dag D = (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $D, sub_32);
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00003584}
3585
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003586def DblToFlt {
3587 dag A0 = (f32 (fpround (f64 (extractelt v2f64:$A, 0))));
3588 dag A1 = (f32 (fpround (f64 (extractelt v2f64:$A, 1))));
3589 dag B0 = (f32 (fpround (f64 (extractelt v2f64:$B, 0))));
3590 dag B1 = (f32 (fpround (f64 (extractelt v2f64:$B, 1))));
3591}
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003592
Nemanja Ivanovice1a525e2018-08-02 00:03:22 +00003593def ExtDbl {
3594 dag A0S = (i32 (PPCmfvsr (f64 (PPCfctiwz (f64 (extractelt v2f64:$A, 0))))));
3595 dag A1S = (i32 (PPCmfvsr (f64 (PPCfctiwz (f64 (extractelt v2f64:$A, 1))))));
3596 dag B0S = (i32 (PPCmfvsr (f64 (PPCfctiwz (f64 (extractelt v2f64:$B, 0))))));
3597 dag B1S = (i32 (PPCmfvsr (f64 (PPCfctiwz (f64 (extractelt v2f64:$B, 1))))));
3598 dag A0U = (i32 (PPCmfvsr (f64 (PPCfctiwuz (f64 (extractelt v2f64:$A, 0))))));
3599 dag A1U = (i32 (PPCmfvsr (f64 (PPCfctiwuz (f64 (extractelt v2f64:$A, 1))))));
3600 dag B0U = (i32 (PPCmfvsr (f64 (PPCfctiwuz (f64 (extractelt v2f64:$B, 0))))));
3601 dag B1U = (i32 (PPCmfvsr (f64 (PPCfctiwuz (f64 (extractelt v2f64:$B, 1))))));
3602}
3603
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003604def ByteToWord {
Tony Jiang9a91a182017-07-05 16:00:38 +00003605 dag LE_A0 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 0)), i8));
3606 dag LE_A1 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 4)), i8));
3607 dag LE_A2 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 8)), i8));
3608 dag LE_A3 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 12)), i8));
3609 dag BE_A0 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 3)), i8));
3610 dag BE_A1 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 7)), i8));
3611 dag BE_A2 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 11)), i8));
3612 dag BE_A3 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 15)), i8));
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003613}
3614
3615def ByteToDWord {
Tony Jiang9a91a182017-07-05 16:00:38 +00003616 dag LE_A0 = (i64 (sext_inreg
3617 (i64 (anyext (i32 (vector_extract v16i8:$A, 0)))), i8));
3618 dag LE_A1 = (i64 (sext_inreg
3619 (i64 (anyext (i32 (vector_extract v16i8:$A, 8)))), i8));
3620 dag BE_A0 = (i64 (sext_inreg
3621 (i64 (anyext (i32 (vector_extract v16i8:$A, 7)))), i8));
3622 dag BE_A1 = (i64 (sext_inreg
3623 (i64 (anyext (i32 (vector_extract v16i8:$A, 15)))), i8));
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003624}
3625
3626def HWordToWord {
Tony Jiang9a91a182017-07-05 16:00:38 +00003627 dag LE_A0 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 0)), i16));
3628 dag LE_A1 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 2)), i16));
3629 dag LE_A2 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 4)), i16));
3630 dag LE_A3 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 6)), i16));
3631 dag BE_A0 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 1)), i16));
3632 dag BE_A1 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 3)), i16));
3633 dag BE_A2 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 5)), i16));
3634 dag BE_A3 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 7)), i16));
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003635}
3636
3637def HWordToDWord {
Tony Jiang9a91a182017-07-05 16:00:38 +00003638 dag LE_A0 = (i64 (sext_inreg
3639 (i64 (anyext (i32 (vector_extract v8i16:$A, 0)))), i16));
3640 dag LE_A1 = (i64 (sext_inreg
3641 (i64 (anyext (i32 (vector_extract v8i16:$A, 4)))), i16));
3642 dag BE_A0 = (i64 (sext_inreg
3643 (i64 (anyext (i32 (vector_extract v8i16:$A, 3)))), i16));
3644 dag BE_A1 = (i64 (sext_inreg
3645 (i64 (anyext (i32 (vector_extract v8i16:$A, 7)))), i16));
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003646}
3647
3648def WordToDWord {
Tony Jiang9a91a182017-07-05 16:00:38 +00003649 dag LE_A0 = (i64 (sext (i32 (vector_extract v4i32:$A, 0))));
3650 dag LE_A1 = (i64 (sext (i32 (vector_extract v4i32:$A, 2))));
3651 dag BE_A0 = (i64 (sext (i32 (vector_extract v4i32:$A, 1))));
3652 dag BE_A1 = (i64 (sext (i32 (vector_extract v4i32:$A, 3))));
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003653}
3654
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003655def FltToIntLoad {
3656 dag A = (i32 (PPCmfvsr (PPCfctiwz (f64 (extloadf32 xoaddr:$A)))));
3657}
3658def FltToUIntLoad {
3659 dag A = (i32 (PPCmfvsr (PPCfctiwuz (f64 (extloadf32 xoaddr:$A)))));
3660}
3661def FltToLongLoad {
3662 dag A = (i64 (PPCmfvsr (PPCfctidz (f64 (extloadf32 xoaddr:$A)))));
3663}
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003664def FltToLongLoadP9 {
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003665 dag A = (i64 (PPCmfvsr (PPCfctidz (f64 (extloadf32 ixaddr:$A)))));
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003666}
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003667def FltToULongLoad {
3668 dag A = (i64 (PPCmfvsr (PPCfctiduz (f64 (extloadf32 xoaddr:$A)))));
3669}
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003670def FltToULongLoadP9 {
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003671 dag A = (i64 (PPCmfvsr (PPCfctiduz (f64 (extloadf32 ixaddr:$A)))));
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003672}
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003673def FltToLong {
Lei Huangcd4f3852018-03-12 19:26:18 +00003674 dag A = (i64 (PPCmfvsr (f64 (PPCfctidz (fpextend f32:$A)))));
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003675}
3676def FltToULong {
Lei Huangcd4f3852018-03-12 19:26:18 +00003677 dag A = (i64 (PPCmfvsr (f64 (PPCfctiduz (fpextend f32:$A)))));
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003678}
3679def DblToInt {
3680 dag A = (i32 (PPCmfvsr (f64 (PPCfctiwz f64:$A))));
Nemanja Ivanovice1a525e2018-08-02 00:03:22 +00003681 dag B = (i32 (PPCmfvsr (f64 (PPCfctiwz f64:$B))));
3682 dag C = (i32 (PPCmfvsr (f64 (PPCfctiwz f64:$C))));
3683 dag D = (i32 (PPCmfvsr (f64 (PPCfctiwz f64:$D))));
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003684}
3685def DblToUInt {
3686 dag A = (i32 (PPCmfvsr (f64 (PPCfctiwuz f64:$A))));
Nemanja Ivanovice1a525e2018-08-02 00:03:22 +00003687 dag B = (i32 (PPCmfvsr (f64 (PPCfctiwuz f64:$B))));
3688 dag C = (i32 (PPCmfvsr (f64 (PPCfctiwuz f64:$C))));
3689 dag D = (i32 (PPCmfvsr (f64 (PPCfctiwuz f64:$D))));
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003690}
3691def DblToLong {
3692 dag A = (i64 (PPCmfvsr (f64 (PPCfctidz f64:$A))));
3693}
3694def DblToULong {
3695 dag A = (i64 (PPCmfvsr (f64 (PPCfctiduz f64:$A))));
3696}
3697def DblToIntLoad {
3698 dag A = (i32 (PPCmfvsr (PPCfctiwz (f64 (load xoaddr:$A)))));
3699}
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003700def DblToIntLoadP9 {
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003701 dag A = (i32 (PPCmfvsr (PPCfctiwz (f64 (load ixaddr:$A)))));
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003702}
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003703def DblToUIntLoad {
3704 dag A = (i32 (PPCmfvsr (PPCfctiwuz (f64 (load xoaddr:$A)))));
3705}
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003706def DblToUIntLoadP9 {
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003707 dag A = (i32 (PPCmfvsr (PPCfctiwuz (f64 (load ixaddr:$A)))));
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003708}
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003709def DblToLongLoad {
3710 dag A = (i64 (PPCmfvsr (PPCfctidz (f64 (load xoaddr:$A)))));
3711}
3712def DblToULongLoad {
3713 dag A = (i64 (PPCmfvsr (PPCfctiduz (f64 (load xoaddr:$A)))));
3714}
3715
3716// FP merge dags (for f32 -> v4f32)
3717def MrgFP {
3718 dag AC = (XVCVDPSP (XXPERMDI (COPY_TO_REGCLASS $A, VSRC),
3719 (COPY_TO_REGCLASS $C, VSRC), 0));
3720 dag BD = (XVCVDPSP (XXPERMDI (COPY_TO_REGCLASS $B, VSRC),
3721 (COPY_TO_REGCLASS $D, VSRC), 0));
3722 dag ABhToFlt = (XVCVDPSP (XXPERMDI $A, $B, 0));
3723 dag ABlToFlt = (XVCVDPSP (XXPERMDI $A, $B, 3));
3724 dag BAhToFlt = (XVCVDPSP (XXPERMDI $B, $A, 0));
3725 dag BAlToFlt = (XVCVDPSP (XXPERMDI $B, $A, 3));
3726}
3727
Nemanja Ivanovice1a525e2018-08-02 00:03:22 +00003728// Word-element merge dags - conversions from f64 to i32 merged into vectors.
3729def MrgWords {
3730 // For big endian, we merge low and hi doublewords (A, B).
3731 dag A0B0 = (v2f64 (XXPERMDI v2f64:$A, v2f64:$B, 0));
3732 dag A1B1 = (v2f64 (XXPERMDI v2f64:$A, v2f64:$B, 3));
3733 dag CVA1B1S = (v4i32 (XVCVDPSXWS A1B1));
3734 dag CVA0B0S = (v4i32 (XVCVDPSXWS A0B0));
3735 dag CVA1B1U = (v4i32 (XVCVDPUXWS A1B1));
3736 dag CVA0B0U = (v4i32 (XVCVDPUXWS A0B0));
3737
3738 // For little endian, we merge low and hi doublewords (B, A).
3739 dag B1A1 = (v2f64 (XXPERMDI v2f64:$B, v2f64:$A, 0));
3740 dag B0A0 = (v2f64 (XXPERMDI v2f64:$B, v2f64:$A, 3));
3741 dag CVB1A1S = (v4i32 (XVCVDPSXWS B1A1));
3742 dag CVB0A0S = (v4i32 (XVCVDPSXWS B0A0));
3743 dag CVB1A1U = (v4i32 (XVCVDPUXWS B1A1));
3744 dag CVB0A0U = (v4i32 (XVCVDPUXWS B0A0));
3745
3746 // For big endian, we merge hi doublewords of (A, C) and (B, D), convert
3747 // then merge.
3748 dag AC = (v2f64 (XXPERMDI (COPY_TO_REGCLASS f64:$A, VSRC),
3749 (COPY_TO_REGCLASS f64:$C, VSRC), 0));
3750 dag BD = (v2f64 (XXPERMDI (COPY_TO_REGCLASS f64:$B, VSRC),
3751 (COPY_TO_REGCLASS f64:$D, VSRC), 0));
3752 dag CVACS = (v4i32 (XVCVDPSXWS AC));
3753 dag CVBDS = (v4i32 (XVCVDPSXWS BD));
3754 dag CVACU = (v4i32 (XVCVDPUXWS AC));
3755 dag CVBDU = (v4i32 (XVCVDPUXWS BD));
3756
3757 // For little endian, we merge hi doublewords of (D, B) and (C, A), convert
3758 // then merge.
3759 dag DB = (v2f64 (XXPERMDI (COPY_TO_REGCLASS f64:$D, VSRC),
3760 (COPY_TO_REGCLASS f64:$B, VSRC), 0));
3761 dag CA = (v2f64 (XXPERMDI (COPY_TO_REGCLASS f64:$C, VSRC),
3762 (COPY_TO_REGCLASS f64:$A, VSRC), 0));
3763 dag CVDBS = (v4i32 (XVCVDPSXWS DB));
3764 dag CVCAS = (v4i32 (XVCVDPSXWS CA));
3765 dag CVDBU = (v4i32 (XVCVDPUXWS DB));
3766 dag CVCAU = (v4i32 (XVCVDPUXWS CA));
3767}
3768
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003769// Patterns for BUILD_VECTOR nodes.
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003770let AddedComplexity = 400 in {
3771
3772 let Predicates = [HasVSX] in {
3773 // Build vectors of floating point converted to i32.
3774 def : Pat<(v4i32 (build_vector DblToInt.A, DblToInt.A,
3775 DblToInt.A, DblToInt.A)),
3776 (v4i32 (XXSPLTW (COPY_TO_REGCLASS (XSCVDPSXWS $A), VSRC), 1))>;
3777 def : Pat<(v4i32 (build_vector DblToUInt.A, DblToUInt.A,
3778 DblToUInt.A, DblToUInt.A)),
3779 (v4i32 (XXSPLTW (COPY_TO_REGCLASS (XSCVDPUXWS $A), VSRC), 1))>;
3780 def : Pat<(v2i64 (build_vector DblToLong.A, DblToLong.A)),
3781 (v2i64 (XXPERMDI (COPY_TO_REGCLASS (XSCVDPSXDS $A), VSRC),
3782 (COPY_TO_REGCLASS (XSCVDPSXDS $A), VSRC), 0))>;
3783 def : Pat<(v2i64 (build_vector DblToULong.A, DblToULong.A)),
3784 (v2i64 (XXPERMDI (COPY_TO_REGCLASS (XSCVDPUXDS $A), VSRC),
3785 (COPY_TO_REGCLASS (XSCVDPUXDS $A), VSRC), 0))>;
3786 def : Pat<(v4i32 (scalar_to_vector FltToIntLoad.A)),
3787 (v4i32 (XXSPLTW (COPY_TO_REGCLASS
Tony Jiang438bf4a2017-11-20 14:38:30 +00003788 (XSCVDPSXWSs (XFLOADf32 xoaddr:$A)), VSRC), 1))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003789 def : Pat<(v4i32 (scalar_to_vector FltToUIntLoad.A)),
3790 (v4i32 (XXSPLTW (COPY_TO_REGCLASS
Tony Jiang438bf4a2017-11-20 14:38:30 +00003791 (XSCVDPUXWSs (XFLOADf32 xoaddr:$A)), VSRC), 1))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003792 def : Pat<(v4f32 (build_vector f32:$A, f32:$A, f32:$A, f32:$A)),
3793 (v4f32 (XXSPLTW (v4f32 (XSCVDPSPN $A)), 0))>;
3794
3795 // Build vectors of floating point converted to i64.
3796 def : Pat<(v2i64 (build_vector FltToLong.A, FltToLong.A)),
Nemanja Ivanovic15748f42016-12-06 11:47:14 +00003797 (v2i64 (XXPERMDIs
3798 (COPY_TO_REGCLASS (XSCVDPSXDSs $A), VSFRC), 0))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003799 def : Pat<(v2i64 (build_vector FltToULong.A, FltToULong.A)),
Nemanja Ivanovic15748f42016-12-06 11:47:14 +00003800 (v2i64 (XXPERMDIs
3801 (COPY_TO_REGCLASS (XSCVDPUXDSs $A), VSFRC), 0))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003802 def : Pat<(v2i64 (scalar_to_vector DblToLongLoad.A)),
3803 (v2i64 (XVCVDPSXDS (LXVDSX xoaddr:$A)))>;
3804 def : Pat<(v2i64 (scalar_to_vector DblToULongLoad.A)),
3805 (v2i64 (XVCVDPUXDS (LXVDSX xoaddr:$A)))>;
3806 }
3807
3808 let Predicates = [HasVSX, NoP9Vector] in {
Tony Jiang438bf4a2017-11-20 14:38:30 +00003809 // Load-and-splat with fp-to-int conversion (using X-Form VSX/FP loads).
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003810 def : Pat<(v4i32 (scalar_to_vector DblToIntLoad.A)),
3811 (v4i32 (XXSPLTW (COPY_TO_REGCLASS
Tony Jiang438bf4a2017-11-20 14:38:30 +00003812 (XSCVDPSXWS (XFLOADf64 xoaddr:$A)), VSRC), 1))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003813 def : Pat<(v4i32 (scalar_to_vector DblToUIntLoad.A)),
3814 (v4i32 (XXSPLTW (COPY_TO_REGCLASS
Tony Jiang438bf4a2017-11-20 14:38:30 +00003815 (XSCVDPUXWS (XFLOADf64 xoaddr:$A)), VSRC), 1))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003816 def : Pat<(v2i64 (scalar_to_vector FltToLongLoad.A)),
3817 (v2i64 (XXPERMDIs (XSCVDPSXDS (COPY_TO_REGCLASS
Tony Jiang438bf4a2017-11-20 14:38:30 +00003818 (XFLOADf32 xoaddr:$A), VSFRC)), 0))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003819 def : Pat<(v2i64 (scalar_to_vector FltToULongLoad.A)),
3820 (v2i64 (XXPERMDIs (XSCVDPUXDS (COPY_TO_REGCLASS
Tony Jiang438bf4a2017-11-20 14:38:30 +00003821 (XFLOADf32 xoaddr:$A), VSFRC)), 0))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003822 }
3823
3824 // Big endian, available on all targets with VSX
3825 let Predicates = [IsBigEndian, HasVSX] in {
3826 def : Pat<(v2f64 (build_vector f64:$A, f64:$B)),
3827 (v2f64 (XXPERMDI
3828 (COPY_TO_REGCLASS $A, VSRC),
3829 (COPY_TO_REGCLASS $B, VSRC), 0))>;
3830
3831 def : Pat<(v4f32 (build_vector f32:$A, f32:$B, f32:$C, f32:$D)),
3832 (VMRGEW MrgFP.AC, MrgFP.BD)>;
3833 def : Pat<(v4f32 (build_vector DblToFlt.A0, DblToFlt.A1,
3834 DblToFlt.B0, DblToFlt.B1)),
3835 (v4f32 (VMRGEW MrgFP.ABhToFlt, MrgFP.ABlToFlt))>;
Nemanja Ivanovice1a525e2018-08-02 00:03:22 +00003836
3837 // Convert 4 doubles to a vector of ints.
3838 def : Pat<(v4i32 (build_vector DblToInt.A, DblToInt.B,
3839 DblToInt.C, DblToInt.D)),
3840 (v4i32 (VMRGEW MrgWords.CVACS, MrgWords.CVBDS))>;
3841 def : Pat<(v4i32 (build_vector DblToUInt.A, DblToUInt.B,
3842 DblToUInt.C, DblToUInt.D)),
3843 (v4i32 (VMRGEW MrgWords.CVACU, MrgWords.CVBDU))>;
3844 def : Pat<(v4i32 (build_vector ExtDbl.A0S, ExtDbl.A1S,
3845 ExtDbl.B0S, ExtDbl.B1S)),
3846 (v4i32 (VMRGEW MrgWords.CVA0B0S, MrgWords.CVA1B1S))>;
3847 def : Pat<(v4i32 (build_vector ExtDbl.A0U, ExtDbl.A1U,
3848 ExtDbl.B0U, ExtDbl.B1U)),
3849 (v4i32 (VMRGEW MrgWords.CVA0B0U, MrgWords.CVA1B1U))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003850 }
3851
3852 let Predicates = [IsLittleEndian, HasVSX] in {
3853 // Little endian, available on all targets with VSX
3854 def : Pat<(v2f64 (build_vector f64:$A, f64:$B)),
3855 (v2f64 (XXPERMDI
3856 (COPY_TO_REGCLASS $B, VSRC),
3857 (COPY_TO_REGCLASS $A, VSRC), 0))>;
3858
3859 def : Pat<(v4f32 (build_vector f32:$D, f32:$C, f32:$B, f32:$A)),
3860 (VMRGEW MrgFP.AC, MrgFP.BD)>;
3861 def : Pat<(v4f32 (build_vector DblToFlt.A0, DblToFlt.A1,
3862 DblToFlt.B0, DblToFlt.B1)),
3863 (v4f32 (VMRGEW MrgFP.BAhToFlt, MrgFP.BAlToFlt))>;
Nemanja Ivanovice1a525e2018-08-02 00:03:22 +00003864
3865 // Convert 4 doubles to a vector of ints.
3866 def : Pat<(v4i32 (build_vector DblToInt.A, DblToInt.B,
3867 DblToInt.C, DblToInt.D)),
3868 (v4i32 (VMRGEW MrgWords.CVDBS, MrgWords.CVCAS))>;
3869 def : Pat<(v4i32 (build_vector DblToUInt.A, DblToUInt.B,
3870 DblToUInt.C, DblToUInt.D)),
3871 (v4i32 (VMRGEW MrgWords.CVDBU, MrgWords.CVCAU))>;
3872 def : Pat<(v4i32 (build_vector ExtDbl.A0S, ExtDbl.A1S,
3873 ExtDbl.B0S, ExtDbl.B1S)),
3874 (v4i32 (VMRGEW MrgWords.CVB1A1S, MrgWords.CVB0A0S))>;
3875 def : Pat<(v4i32 (build_vector ExtDbl.A0U, ExtDbl.A1U,
3876 ExtDbl.B0U, ExtDbl.B1U)),
3877 (v4i32 (VMRGEW MrgWords.CVB1A1U, MrgWords.CVB0A0U))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003878 }
3879
3880 let Predicates = [HasDirectMove] in {
3881 // Endianness-neutral constant splat on P8 and newer targets. The reason
3882 // for this pattern is that on targets with direct moves, we don't expand
3883 // BUILD_VECTOR nodes for v4i32.
3884 def : Pat<(v4i32 (build_vector immSExt5NonZero:$A, immSExt5NonZero:$A,
3885 immSExt5NonZero:$A, immSExt5NonZero:$A)),
3886 (v4i32 (VSPLTISW imm:$A))>;
3887 }
3888
3889 let Predicates = [IsBigEndian, HasDirectMove, NoP9Vector] in {
3890 // Big endian integer vectors using direct moves.
3891 def : Pat<(v2i64 (build_vector i64:$A, i64:$B)),
3892 (v2i64 (XXPERMDI
3893 (COPY_TO_REGCLASS (MTVSRD $A), VSRC),
3894 (COPY_TO_REGCLASS (MTVSRD $B), VSRC), 0))>;
3895 def : Pat<(v4i32 (build_vector i32:$A, i32:$B, i32:$C, i32:$D)),
Lei Huangde208432018-10-26 18:09:36 +00003896 (XXPERMDI
3897 (COPY_TO_REGCLASS
3898 (MTVSRD (RLDIMI AnyExts.B, AnyExts.A, 32, 0)), VSRC),
3899 (COPY_TO_REGCLASS
3900 (MTVSRD (RLDIMI AnyExts.D, AnyExts.C, 32, 0)), VSRC), 0)>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003901 def : Pat<(v4i32 (build_vector i32:$A, i32:$A, i32:$A, i32:$A)),
3902 (XXSPLTW (COPY_TO_REGCLASS (MTVSRWZ $A), VSRC), 1)>;
3903 }
3904
3905 let Predicates = [IsLittleEndian, HasDirectMove, NoP9Vector] in {
3906 // Little endian integer vectors using direct moves.
3907 def : Pat<(v2i64 (build_vector i64:$A, i64:$B)),
3908 (v2i64 (XXPERMDI
3909 (COPY_TO_REGCLASS (MTVSRD $B), VSRC),
3910 (COPY_TO_REGCLASS (MTVSRD $A), VSRC), 0))>;
3911 def : Pat<(v4i32 (build_vector i32:$A, i32:$B, i32:$C, i32:$D)),
Lei Huangde208432018-10-26 18:09:36 +00003912 (XXPERMDI
3913 (COPY_TO_REGCLASS
3914 (MTVSRD (RLDIMI AnyExts.C, AnyExts.D, 32, 0)), VSRC),
3915 (COPY_TO_REGCLASS
3916 (MTVSRD (RLDIMI AnyExts.A, AnyExts.B, 32, 0)), VSRC), 0)>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003917 def : Pat<(v4i32 (build_vector i32:$A, i32:$A, i32:$A, i32:$A)),
3918 (XXSPLTW (COPY_TO_REGCLASS (MTVSRWZ $A), VSRC), 1)>;
3919 }
3920
3921 let Predicates = [HasP9Vector] in {
3922 // Endianness-neutral patterns for const splats with ISA 3.0 instructions.
3923 def : Pat<(v4i32 (scalar_to_vector i32:$A)),
3924 (v4i32 (MTVSRWS $A))>;
3925 def : Pat<(v4i32 (build_vector i32:$A, i32:$A, i32:$A, i32:$A)),
3926 (v4i32 (MTVSRWS $A))>;
Nemanja Ivanovic552c8e92016-12-15 11:16:20 +00003927 def : Pat<(v16i8 (build_vector immAnyExt8:$A, immAnyExt8:$A, immAnyExt8:$A,
3928 immAnyExt8:$A, immAnyExt8:$A, immAnyExt8:$A,
3929 immAnyExt8:$A, immAnyExt8:$A, immAnyExt8:$A,
3930 immAnyExt8:$A, immAnyExt8:$A, immAnyExt8:$A,
3931 immAnyExt8:$A, immAnyExt8:$A, immAnyExt8:$A,
3932 immAnyExt8:$A)),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003933 (v16i8 (COPY_TO_REGCLASS (XXSPLTIB imm:$A), VSRC))>;
3934 def : Pat<(v16i8 immAllOnesV),
3935 (v16i8 (COPY_TO_REGCLASS (XXSPLTIB 255), VSRC))>;
3936 def : Pat<(v8i16 immAllOnesV),
3937 (v8i16 (COPY_TO_REGCLASS (XXSPLTIB 255), VSRC))>;
3938 def : Pat<(v4i32 immAllOnesV),
3939 (v4i32 (XXSPLTIB 255))>;
3940 def : Pat<(v2i64 immAllOnesV),
3941 (v2i64 (XXSPLTIB 255))>;
3942 def : Pat<(v4i32 (scalar_to_vector FltToIntLoad.A)),
3943 (v4i32 (XVCVSPSXWS (LXVWSX xoaddr:$A)))>;
3944 def : Pat<(v4i32 (scalar_to_vector FltToUIntLoad.A)),
3945 (v4i32 (XVCVSPUXWS (LXVWSX xoaddr:$A)))>;
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003946 def : Pat<(v4i32 (scalar_to_vector DblToIntLoadP9.A)),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003947 (v4i32 (XXSPLTW (COPY_TO_REGCLASS
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003948 (XSCVDPSXWS (DFLOADf64 ixaddr:$A)), VSRC), 1))>;
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003949 def : Pat<(v4i32 (scalar_to_vector DblToUIntLoadP9.A)),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003950 (v4i32 (XXSPLTW (COPY_TO_REGCLASS
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003951 (XSCVDPUXWS (DFLOADf64 ixaddr:$A)), VSRC), 1))>;
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003952 def : Pat<(v2i64 (scalar_to_vector FltToLongLoadP9.A)),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003953 (v2i64 (XXPERMDIs (XSCVDPSXDS (COPY_TO_REGCLASS
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003954 (DFLOADf32 ixaddr:$A),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003955 VSFRC)), 0))>;
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003956 def : Pat<(v2i64 (scalar_to_vector FltToULongLoadP9.A)),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003957 (v2i64 (XXPERMDIs (XSCVDPUXDS (COPY_TO_REGCLASS
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003958 (DFLOADf32 ixaddr:$A),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003959 VSFRC)), 0))>;
3960 }
3961
3962 let Predicates = [IsISA3_0, HasDirectMove, IsBigEndian] in {
3963 def : Pat<(i64 (extractelt v2i64:$A, 1)),
3964 (i64 (MFVSRLD $A))>;
3965 // Better way to build integer vectors if we have MTVSRDD. Big endian.
3966 def : Pat<(v2i64 (build_vector i64:$rB, i64:$rA)),
3967 (v2i64 (MTVSRDD $rB, $rA))>;
3968 def : Pat<(v4i32 (build_vector i32:$A, i32:$B, i32:$C, i32:$D)),
Lei Huangde208432018-10-26 18:09:36 +00003969 (MTVSRDD
3970 (RLDIMI AnyExts.B, AnyExts.A, 32, 0),
3971 (RLDIMI AnyExts.D, AnyExts.C, 32, 0))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003972 }
3973
3974 let Predicates = [IsISA3_0, HasDirectMove, IsLittleEndian] in {
3975 def : Pat<(i64 (extractelt v2i64:$A, 0)),
3976 (i64 (MFVSRLD $A))>;
3977 // Better way to build integer vectors if we have MTVSRDD. Little endian.
3978 def : Pat<(v2i64 (build_vector i64:$rA, i64:$rB)),
3979 (v2i64 (MTVSRDD $rB, $rA))>;
3980 def : Pat<(v4i32 (build_vector i32:$A, i32:$B, i32:$C, i32:$D)),
Lei Huangde208432018-10-26 18:09:36 +00003981 (MTVSRDD
3982 (RLDIMI AnyExts.C, AnyExts.D, 32, 0),
3983 (RLDIMI AnyExts.A, AnyExts.B, 32, 0))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003984 }
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003985 // P9 Altivec instructions that can be used to build vectors.
3986 // Adding them to PPCInstrVSX.td rather than PPCAltivecVSX.td to compete
3987 // with complexities of existing build vector patterns in this file.
Tony Jiang9a91a182017-07-05 16:00:38 +00003988 let Predicates = [HasP9Altivec, IsLittleEndian] in {
3989 def : Pat<(v2i64 (build_vector WordToDWord.LE_A0, WordToDWord.LE_A1)),
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003990 (v2i64 (VEXTSW2D $A))>;
Tony Jiang9a91a182017-07-05 16:00:38 +00003991 def : Pat<(v2i64 (build_vector HWordToDWord.LE_A0, HWordToDWord.LE_A1)),
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003992 (v2i64 (VEXTSH2D $A))>;
Tony Jiang9a91a182017-07-05 16:00:38 +00003993 def : Pat<(v4i32 (build_vector HWordToWord.LE_A0, HWordToWord.LE_A1,
3994 HWordToWord.LE_A2, HWordToWord.LE_A3)),
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003995 (v4i32 (VEXTSH2W $A))>;
Tony Jiang9a91a182017-07-05 16:00:38 +00003996 def : Pat<(v4i32 (build_vector ByteToWord.LE_A0, ByteToWord.LE_A1,
3997 ByteToWord.LE_A2, ByteToWord.LE_A3)),
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003998 (v4i32 (VEXTSB2W $A))>;
Tony Jiang9a91a182017-07-05 16:00:38 +00003999 def : Pat<(v2i64 (build_vector ByteToDWord.LE_A0, ByteToDWord.LE_A1)),
Zaara Syeda79acbbe2017-06-08 17:14:36 +00004000 (v2i64 (VEXTSB2D $A))>;
4001 }
Tony Jiang9a91a182017-07-05 16:00:38 +00004002
4003 let Predicates = [HasP9Altivec, IsBigEndian] in {
4004 def : Pat<(v2i64 (build_vector WordToDWord.BE_A0, WordToDWord.BE_A1)),
4005 (v2i64 (VEXTSW2D $A))>;
4006 def : Pat<(v2i64 (build_vector HWordToDWord.BE_A0, HWordToDWord.BE_A1)),
4007 (v2i64 (VEXTSH2D $A))>;
4008 def : Pat<(v4i32 (build_vector HWordToWord.BE_A0, HWordToWord.BE_A1,
4009 HWordToWord.BE_A2, HWordToWord.BE_A3)),
4010 (v4i32 (VEXTSH2W $A))>;
4011 def : Pat<(v4i32 (build_vector ByteToWord.BE_A0, ByteToWord.BE_A1,
4012 ByteToWord.BE_A2, ByteToWord.BE_A3)),
4013 (v4i32 (VEXTSB2W $A))>;
4014 def : Pat<(v2i64 (build_vector ByteToDWord.BE_A0, ByteToDWord.BE_A1)),
4015 (v2i64 (VEXTSB2D $A))>;
4016 }
4017
4018 let Predicates = [HasP9Altivec] in {
4019 def: Pat<(v2i64 (PPCSExtVElems v16i8:$A)),
4020 (v2i64 (VEXTSB2D $A))>;
4021 def: Pat<(v2i64 (PPCSExtVElems v8i16:$A)),
4022 (v2i64 (VEXTSH2D $A))>;
4023 def: Pat<(v2i64 (PPCSExtVElems v4i32:$A)),
4024 (v2i64 (VEXTSW2D $A))>;
4025 def: Pat<(v4i32 (PPCSExtVElems v16i8:$A)),
4026 (v4i32 (VEXTSB2W $A))>;
4027 def: Pat<(v4i32 (PPCSExtVElems v8i16:$A)),
4028 (v4i32 (VEXTSH2W $A))>;
4029 }
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00004030}
Zaara Syedab2595b92018-08-08 15:20:43 +00004031