blob: ffba0e5aadb59e7dfd569bd23e4d30a39876bac0 [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),
873 "xxsel $XT, $XA, $XB, $XC", IIC_VecPerm, []>;
874
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))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000880 def XXSPLTW : XX2Form_2<60, 164,
881 (outs vsrc:$XT), (ins vsrc:$XB, u2imm:$UIM),
Nemanja Ivanovic1a2b2f02016-05-04 16:04:02 +0000882 "xxspltw $XT, $XB, $UIM", IIC_VecPerm,
883 [(set v4i32:$XT,
884 (PPCxxsplt v4i32:$XB, imm32SExt16:$UIM))]>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +0000885 let isCodeGenOnly = 1 in
886 def XXSPLTWs : XX2Form_2<60, 164,
887 (outs vsrc:$XT), (ins vfrc:$XB, u2imm:$UIM),
888 "xxspltw $XT, $XB, $UIM", IIC_VecPerm, []>;
Craig Topperc50d64b2014-11-26 00:46:26 +0000889} // hasSideEffects
Nemanja Ivanovic11049f82016-10-04 06:59:23 +0000890} // UseVSXReg = 1
Hal Finkel27774d92014-03-13 07:58:58 +0000891
Bill Schmidt61e65232014-10-22 13:13:40 +0000892// SELECT_CC_* - Used to implement the SELECT_CC DAG operation. Expanded after
893// instruction selection into a branch sequence.
894let usesCustomInserter = 1, // Expanded after instruction selection.
895 PPC970_Single = 1 in {
896
897 def SELECT_CC_VSRC: Pseudo<(outs vsrc:$dst),
898 (ins crrc:$cond, vsrc:$T, vsrc:$F, i32imm:$BROPC),
899 "#SELECT_CC_VSRC",
900 []>;
Bill Schmidt9c54bbd2014-10-22 16:58:20 +0000901 def SELECT_VSRC: Pseudo<(outs vsrc:$dst),
902 (ins crbitrc:$cond, vsrc:$T, vsrc:$F),
903 "#SELECT_VSRC",
Bill Schmidt61e65232014-10-22 13:13:40 +0000904 [(set v2f64:$dst,
905 (select i1:$cond, v2f64:$T, v2f64:$F))]>;
Bill Schmidt9c54bbd2014-10-22 16:58:20 +0000906 def SELECT_CC_VSFRC: Pseudo<(outs f8rc:$dst),
907 (ins crrc:$cond, f8rc:$T, f8rc:$F,
908 i32imm:$BROPC), "#SELECT_CC_VSFRC",
909 []>;
910 def SELECT_VSFRC: Pseudo<(outs f8rc:$dst),
911 (ins crbitrc:$cond, f8rc:$T, f8rc:$F),
912 "#SELECT_VSFRC",
913 [(set f64:$dst,
914 (select i1:$cond, f64:$T, f64:$F))]>;
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +0000915 def SELECT_CC_VSSRC: Pseudo<(outs f4rc:$dst),
916 (ins crrc:$cond, f4rc:$T, f4rc:$F,
917 i32imm:$BROPC), "#SELECT_CC_VSSRC",
918 []>;
919 def SELECT_VSSRC: Pseudo<(outs f4rc:$dst),
920 (ins crbitrc:$cond, f4rc:$T, f4rc:$F),
921 "#SELECT_VSSRC",
922 [(set f32:$dst,
923 (select i1:$cond, f32:$T, f32:$F))]>;
Bill Schmidt9c54bbd2014-10-22 16:58:20 +0000924} // usesCustomInserter
925} // AddedComplexity
Bill Schmidt61e65232014-10-22 13:13:40 +0000926
Hal Finkel27774d92014-03-13 07:58:58 +0000927def : InstAlias<"xvmovdp $XT, $XB",
928 (XVCPSGNDP vsrc:$XT, vsrc:$XB, vsrc:$XB)>;
929def : InstAlias<"xvmovsp $XT, $XB",
930 (XVCPSGNSP vsrc:$XT, vsrc:$XB, vsrc:$XB)>;
931
932def : InstAlias<"xxspltd $XT, $XB, 0",
933 (XXPERMDI vsrc:$XT, vsrc:$XB, vsrc:$XB, 0)>;
934def : InstAlias<"xxspltd $XT, $XB, 1",
935 (XXPERMDI vsrc:$XT, vsrc:$XB, vsrc:$XB, 3)>;
936def : InstAlias<"xxmrghd $XT, $XA, $XB",
937 (XXPERMDI vsrc:$XT, vsrc:$XA, vsrc:$XB, 0)>;
938def : InstAlias<"xxmrgld $XT, $XA, $XB",
939 (XXPERMDI vsrc:$XT, vsrc:$XA, vsrc:$XB, 3)>;
940def : InstAlias<"xxswapd $XT, $XB",
941 (XXPERMDI vsrc:$XT, vsrc:$XB, vsrc:$XB, 2)>;
Nemanja Ivanovic15748f42016-12-06 11:47:14 +0000942def : InstAlias<"xxspltd $XT, $XB, 0",
943 (XXPERMDIs vsrc:$XT, vsfrc:$XB, 0)>;
944def : InstAlias<"xxspltd $XT, $XB, 1",
945 (XXPERMDIs vsrc:$XT, vsfrc:$XB, 3)>;
946def : InstAlias<"xxswapd $XT, $XB",
947 (XXPERMDIs vsrc:$XT, vsfrc:$XB, 2)>;
Hal Finkel27774d92014-03-13 07:58:58 +0000948
949let AddedComplexity = 400 in { // Prefer VSX patterns over non-VSX patterns.
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000950
Nemanja Ivanovic6f22b412016-09-27 08:42:12 +0000951def : Pat<(v4i32 (vnot_ppc v4i32:$A)),
952 (v4i32 (XXLNOR $A, $A))>;
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000953let Predicates = [IsBigEndian] in {
Hal Finkel27774d92014-03-13 07:58:58 +0000954def : Pat<(v2f64 (scalar_to_vector f64:$A)),
Hal Finkel19be5062014-03-29 05:29:01 +0000955 (v2f64 (SUBREG_TO_REG (i64 1), $A, sub_64))>;
Hal Finkel27774d92014-03-13 07:58:58 +0000956
Matt Arsenaultfbd9bbf2015-12-11 19:20:16 +0000957def : Pat<(f64 (extractelt v2f64:$S, 0)),
Hal Finkel19be5062014-03-29 05:29:01 +0000958 (f64 (EXTRACT_SUBREG $S, sub_64))>;
Matt Arsenaultfbd9bbf2015-12-11 19:20:16 +0000959def : Pat<(f64 (extractelt v2f64:$S, 1)),
Hal Finkel19be5062014-03-29 05:29:01 +0000960 (f64 (EXTRACT_SUBREG (XXPERMDI $S, $S, 2), sub_64))>;
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000961}
962
963let Predicates = [IsLittleEndian] in {
964def : Pat<(v2f64 (scalar_to_vector f64:$A)),
965 (v2f64 (XXPERMDI (SUBREG_TO_REG (i64 1), $A, sub_64),
966 (SUBREG_TO_REG (i64 1), $A, sub_64), 0))>;
967
Matt Arsenaultfbd9bbf2015-12-11 19:20:16 +0000968def : Pat<(f64 (extractelt v2f64:$S, 0)),
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000969 (f64 (EXTRACT_SUBREG (XXPERMDI $S, $S, 2), sub_64))>;
Matt Arsenaultfbd9bbf2015-12-11 19:20:16 +0000970def : Pat<(f64 (extractelt v2f64:$S, 1)),
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000971 (f64 (EXTRACT_SUBREG $S, sub_64))>;
972}
Hal Finkel27774d92014-03-13 07:58:58 +0000973
974// Additional fnmsub patterns: -a*c + b == -(a*c - b)
975def : Pat<(fma (fneg f64:$A), f64:$C, f64:$B),
976 (XSNMSUBADP $B, $C, $A)>;
977def : Pat<(fma f64:$A, (fneg f64:$C), f64:$B),
978 (XSNMSUBADP $B, $C, $A)>;
979
980def : Pat<(fma (fneg v2f64:$A), v2f64:$C, v2f64:$B),
981 (XVNMSUBADP $B, $C, $A)>;
982def : Pat<(fma v2f64:$A, (fneg v2f64:$C), v2f64:$B),
983 (XVNMSUBADP $B, $C, $A)>;
984
985def : Pat<(fma (fneg v4f32:$A), v4f32:$C, v4f32:$B),
986 (XVNMSUBASP $B, $C, $A)>;
987def : Pat<(fma v4f32:$A, (fneg v4f32:$C), v4f32:$B),
988 (XVNMSUBASP $B, $C, $A)>;
989
Hal Finkel9e0baa62014-04-01 19:24:27 +0000990def : Pat<(v2f64 (bitconvert v4f32:$A)),
991 (COPY_TO_REGCLASS $A, VSRC)>;
Hal Finkel27774d92014-03-13 07:58:58 +0000992def : Pat<(v2f64 (bitconvert v4i32:$A)),
993 (COPY_TO_REGCLASS $A, VSRC)>;
994def : Pat<(v2f64 (bitconvert v8i16:$A)),
995 (COPY_TO_REGCLASS $A, VSRC)>;
996def : Pat<(v2f64 (bitconvert v16i8:$A)),
997 (COPY_TO_REGCLASS $A, VSRC)>;
998
Hal Finkel9e0baa62014-04-01 19:24:27 +0000999def : Pat<(v4f32 (bitconvert v2f64:$A)),
1000 (COPY_TO_REGCLASS $A, VRRC)>;
Hal Finkel27774d92014-03-13 07:58:58 +00001001def : Pat<(v4i32 (bitconvert v2f64:$A)),
1002 (COPY_TO_REGCLASS $A, VRRC)>;
1003def : Pat<(v8i16 (bitconvert v2f64:$A)),
1004 (COPY_TO_REGCLASS $A, VRRC)>;
1005def : Pat<(v16i8 (bitconvert v2f64:$A)),
1006 (COPY_TO_REGCLASS $A, VRRC)>;
1007
Hal Finkel9e0baa62014-04-01 19:24:27 +00001008def : Pat<(v2i64 (bitconvert v4f32:$A)),
1009 (COPY_TO_REGCLASS $A, VSRC)>;
Hal Finkela6c8b512014-03-26 16:12:58 +00001010def : Pat<(v2i64 (bitconvert v4i32:$A)),
1011 (COPY_TO_REGCLASS $A, VSRC)>;
1012def : Pat<(v2i64 (bitconvert v8i16:$A)),
1013 (COPY_TO_REGCLASS $A, VSRC)>;
1014def : Pat<(v2i64 (bitconvert v16i8:$A)),
1015 (COPY_TO_REGCLASS $A, VSRC)>;
1016
Hal Finkel9e0baa62014-04-01 19:24:27 +00001017def : Pat<(v4f32 (bitconvert v2i64:$A)),
1018 (COPY_TO_REGCLASS $A, VRRC)>;
Hal Finkela6c8b512014-03-26 16:12:58 +00001019def : Pat<(v4i32 (bitconvert v2i64:$A)),
1020 (COPY_TO_REGCLASS $A, VRRC)>;
1021def : Pat<(v8i16 (bitconvert v2i64:$A)),
1022 (COPY_TO_REGCLASS $A, VRRC)>;
1023def : Pat<(v16i8 (bitconvert v2i64:$A)),
1024 (COPY_TO_REGCLASS $A, VRRC)>;
1025
Hal Finkel9281c9a2014-03-26 18:26:30 +00001026def : Pat<(v2f64 (bitconvert v2i64:$A)),
1027 (COPY_TO_REGCLASS $A, VRRC)>;
1028def : Pat<(v2i64 (bitconvert v2f64:$A)),
1029 (COPY_TO_REGCLASS $A, VRRC)>;
1030
Kit Bartond4eb73c2015-05-05 16:10:44 +00001031def : Pat<(v2f64 (bitconvert v1i128:$A)),
1032 (COPY_TO_REGCLASS $A, VRRC)>;
1033def : Pat<(v1i128 (bitconvert v2f64:$A)),
1034 (COPY_TO_REGCLASS $A, VRRC)>;
1035
Hal Finkel5c0d1452014-03-30 13:22:59 +00001036// sign extension patterns
1037// To extend "in place" from v2i32 to v2i64, we have input data like:
1038// | undef | i32 | undef | i32 |
1039// but xvcvsxwdp expects the input in big-Endian format:
1040// | i32 | undef | i32 | undef |
1041// so we need to shift everything to the left by one i32 (word) before
1042// the conversion.
1043def : Pat<(sext_inreg v2i64:$C, v2i32),
1044 (XVCVDPSXDS (XVCVSXWDP (XXSLDWI $C, $C, 1)))>;
1045def : Pat<(v2f64 (sint_to_fp (sext_inreg v2i64:$C, v2i32))),
1046 (XVCVSXWDP (XXSLDWI $C, $C, 1))>;
1047
Nemanja Ivanovic44513e52016-07-05 09:22:29 +00001048def : Pat<(v2f64 (PPCsvec2fp v4i32:$C, 0)),
1049 (v2f64 (XVCVSXWDP (v2i64 (XXMRGHW $C, $C))))>;
1050def : Pat<(v2f64 (PPCsvec2fp v4i32:$C, 1)),
1051 (v2f64 (XVCVSXWDP (v2i64 (XXMRGLW $C, $C))))>;
1052
1053def : Pat<(v2f64 (PPCuvec2fp v4i32:$C, 0)),
1054 (v2f64 (XVCVUXWDP (v2i64 (XXMRGHW $C, $C))))>;
1055def : Pat<(v2f64 (PPCuvec2fp v4i32:$C, 1)),
1056 (v2f64 (XVCVUXWDP (v2i64 (XXMRGLW $C, $C))))>;
1057
Bill Schmidt2d1128a2014-10-17 15:13:38 +00001058// Loads.
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00001059let Predicates = [HasVSX, HasOnlySwappingMemOps] in {
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00001060 def : Pat<(v2f64 (PPClxvd2x xoaddr:$src)), (LXVD2X xoaddr:$src)>;
Bill Schmidt2d1128a2014-10-17 15:13:38 +00001061
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00001062 // Stores.
1063 def : Pat<(int_ppc_vsx_stxvd2x v2f64:$rS, xoaddr:$dst),
1064 (STXVD2X $rS, xoaddr:$dst)>;
Tony Jiang5f850cd2016-11-15 14:25:56 +00001065 def : Pat<(int_ppc_vsx_stxvd2x_be v2f64:$rS, xoaddr:$dst),
1066 (STXVD2X $rS, xoaddr:$dst)>;
1067 def : Pat<(int_ppc_vsx_stxvw4x_be v4i32:$rS, xoaddr:$dst),
1068 (STXVW4X $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
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001155let Predicates = [IsLittleEndian] in {
1156def : Pat<(f64 (PPCfcfid (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1157 (f64 (XSCVSXDDP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1158def : Pat<(f64 (PPCfcfid (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1159 (f64 (XSCVSXDDP (COPY_TO_REGCLASS (f64 (COPY_TO_REGCLASS $S, VSRC)), VSFRC)))>;
1160def : Pat<(f64 (PPCfcfidu (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1161 (f64 (XSCVUXDDP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1162def : Pat<(f64 (PPCfcfidu (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1163 (f64 (XSCVUXDDP (COPY_TO_REGCLASS (f64 (COPY_TO_REGCLASS $S, VSRC)), VSFRC)))>;
1164} // IsLittleEndian
1165
1166let Predicates = [IsBigEndian] in {
1167def : Pat<(f64 (PPCfcfid (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1168 (f64 (XSCVSXDDP (COPY_TO_REGCLASS $S, VSFRC)))>;
1169def : Pat<(f64 (PPCfcfid (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1170 (f64 (XSCVSXDDP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1171def : Pat<(f64 (PPCfcfidu (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1172 (f64 (XSCVUXDDP (COPY_TO_REGCLASS $S, VSFRC)))>;
1173def : Pat<(f64 (PPCfcfidu (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1174 (f64 (XSCVUXDDP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1175} // IsBigEndian
1176
Hal Finkel27774d92014-03-13 07:58:58 +00001177} // AddedComplexity
1178} // HasVSX
1179
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001180def ScalarLoads {
1181 dag Li8 = (i32 (extloadi8 xoaddr:$src));
1182 dag ZELi8 = (i32 (zextloadi8 xoaddr:$src));
1183 dag ZELi8i64 = (i64 (zextloadi8 xoaddr:$src));
1184 dag SELi8 = (i32 (sext_inreg (extloadi8 xoaddr:$src), i8));
1185 dag SELi8i64 = (i64 (sext_inreg (extloadi8 xoaddr:$src), i8));
1186
1187 dag Li16 = (i32 (extloadi16 xoaddr:$src));
1188 dag ZELi16 = (i32 (zextloadi16 xoaddr:$src));
1189 dag ZELi16i64 = (i64 (zextloadi16 xoaddr:$src));
1190 dag SELi16 = (i32 (sextloadi16 xoaddr:$src));
1191 dag SELi16i64 = (i64 (sextloadi16 xoaddr:$src));
1192
1193 dag Li32 = (i32 (load xoaddr:$src));
1194}
1195
Kit Barton298beb52015-02-18 16:21:46 +00001196// The following VSX instructions were introduced in Power ISA 2.07
1197/* FIXME: if the operands are v2i64, these patterns will not match.
1198 we should define new patterns or otherwise match the same patterns
1199 when the elements are larger than i32.
1200*/
1201def HasP8Vector : Predicate<"PPCSubTarget->hasP8Vector()">;
Nemanja Ivanovicc38b5312015-04-11 10:40:42 +00001202def HasDirectMove : Predicate<"PPCSubTarget->hasDirectMove()">;
Lei Huangc29229a2018-05-08 17:36:40 +00001203def NoP9Vector : Predicate<"!PPCSubTarget->hasP9Vector()">;
Kit Barton298beb52015-02-18 16:21:46 +00001204let Predicates = [HasP8Vector] in {
1205let AddedComplexity = 400 in { // Prefer VSX patterns over non-VSX patterns.
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001206 let isCommutable = 1, UseVSXReg = 1 in {
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001207 def XXLEQV : XX3Form<60, 186,
1208 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
1209 "xxleqv $XT, $XA, $XB", IIC_VecGeneral,
1210 [(set v4i32:$XT, (vnot_ppc (xor v4i32:$XA, v4i32:$XB)))]>;
1211 def XXLNAND : XX3Form<60, 178,
1212 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
1213 "xxlnand $XT, $XA, $XB", IIC_VecGeneral,
1214 [(set v4i32:$XT, (vnot_ppc (and v4i32:$XA,
Kit Barton298beb52015-02-18 16:21:46 +00001215 v4i32:$XB)))]>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001216 } // isCommutable, UseVSXReg
Nemanja Ivanovicd9e4b4f2015-07-10 14:25:17 +00001217
Nemanja Ivanovic5655fb32015-07-10 12:38:08 +00001218 def : Pat<(int_ppc_vsx_xxleqv v4i32:$A, v4i32:$B),
1219 (XXLEQV $A, $B)>;
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001220
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001221 let UseVSXReg = 1 in {
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001222 def XXLORC : XX3Form<60, 170,
1223 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
1224 "xxlorc $XT, $XA, $XB", IIC_VecGeneral,
1225 [(set v4i32:$XT, (or v4i32:$XA, (vnot_ppc v4i32:$XB)))]>;
1226
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +00001227 // VSX scalar loads introduced in ISA 2.07
Sean Fertile3c8c3852017-01-26 18:59:15 +00001228 let mayLoad = 1, mayStore = 0 in {
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00001229 let CodeSize = 3 in
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001230 def LXSSPX : XX1Form_memOp<31, 524, (outs vssrc:$XT), (ins memrr:$src),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001231 "lxsspx $XT, $src", IIC_LdStLFD, []>;
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001232 def LXSIWAX : XX1Form_memOp<31, 76, (outs vsfrc:$XT), (ins memrr:$src),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001233 "lxsiwax $XT, $src", IIC_LdStLFD, []>;
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001234 def LXSIWZX : XX1Form_memOp<31, 12, (outs vsfrc:$XT), (ins memrr:$src),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001235 "lxsiwzx $XT, $src", IIC_LdStLFD, []>;
1236
1237 // Please note let isPseudo = 1 is not part of class Pseudo<>. Missing it
1238 // would cause these Pseudos are not expanded in expandPostRAPseudos()
1239 let isPseudo = 1 in {
1240 // Pseudo instruction XFLOADf32 will be expanded to LXSSPX or LFSX later
1241 let CodeSize = 3 in
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001242 def XFLOADf32 : PseudoXFormMemOp<(outs vssrc:$XT), (ins memrr:$src),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001243 "#XFLOADf32",
1244 [(set f32:$XT, (load xoaddr:$src))]>;
1245 // Pseudo instruction LIWAX will be expanded to LXSIWAX or LFIWAX later
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001246 def LIWAX : PseudoXFormMemOp<(outs vsfrc:$XT), (ins memrr:$src),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001247 "#LIWAX",
1248 [(set f64:$XT, (PPClfiwax xoaddr:$src))]>;
1249 // Pseudo instruction LIWZX will be expanded to LXSIWZX or LFIWZX later
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001250 def LIWZX : PseudoXFormMemOp<(outs vsfrc:$XT), (ins memrr:$src),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001251 "#LIWZX",
1252 [(set f64:$XT, (PPClfiwzx xoaddr:$src))]>;
1253 }
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +00001254 } // mayLoad
1255
1256 // VSX scalar stores introduced in ISA 2.07
Sean Fertile3c8c3852017-01-26 18:59:15 +00001257 let mayStore = 1, mayLoad = 0 in {
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00001258 let CodeSize = 3 in
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001259 def STXSSPX : XX1Form_memOp<31, 652, (outs), (ins vssrc:$XT, memrr:$dst),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001260 "stxsspx $XT, $dst", IIC_LdStSTFD, []>;
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001261 def STXSIWX : XX1Form_memOp<31, 140, (outs), (ins vsfrc:$XT, memrr:$dst),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001262 "stxsiwx $XT, $dst", IIC_LdStSTFD, []>;
1263
1264 // Please note let isPseudo = 1 is not part of class Pseudo<>. Missing it
1265 // would cause these Pseudos are not expanded in expandPostRAPseudos()
1266 let isPseudo = 1 in {
1267 // Pseudo instruction XFSTOREf32 will be expanded to STXSSPX or STFSX later
1268 let CodeSize = 3 in
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001269 def XFSTOREf32 : PseudoXFormMemOp<(outs), (ins vssrc:$XT, memrr:$dst),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001270 "#XFSTOREf32",
1271 [(store f32:$XT, xoaddr:$dst)]>;
1272 // Pseudo instruction STIWX will be expanded to STXSIWX or STFIWX later
Stefan Pintilie26d4f922018-03-26 17:39:18 +00001273 def STIWX : PseudoXFormMemOp<(outs), (ins vsfrc:$XT, memrr:$dst),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001274 "#STIWX",
1275 [(PPCstfiwx f64:$XT, xoaddr:$dst)]>;
1276 }
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +00001277 } // mayStore
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001278 } // UseVSXReg = 1
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001279
1280 def : Pat<(f64 (extloadf32 xoaddr:$src)),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001281 (COPY_TO_REGCLASS (XFLOADf32 xoaddr:$src), VSFRC)>;
Lei Huangcd4f3852018-03-12 19:26:18 +00001282 def : Pat<(f32 (fpround (f64 (extloadf32 xoaddr:$src)))),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001283 (f32 (XFLOADf32 xoaddr:$src))>;
Michael Kuperstein2bc3d4d2016-08-18 20:08:15 +00001284 def : Pat<(f64 (fpextend f32:$src)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001285 (COPY_TO_REGCLASS $src, VSFRC)>;
Hal Finkela2cdbce2015-08-30 22:12:50 +00001286
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001287 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETLT)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001288 (SELECT_VSSRC (CRANDC $lhs, $rhs), $tval, $fval)>;
1289 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETULT)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001290 (SELECT_VSSRC (CRANDC $rhs, $lhs), $tval, $fval)>;
1291 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETLE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001292 (SELECT_VSSRC (CRORC $lhs, $rhs), $tval, $fval)>;
1293 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETULE)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001294 (SELECT_VSSRC (CRORC $rhs, $lhs), $tval, $fval)>;
1295 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETEQ)),
1296 (SELECT_VSSRC (CREQV $lhs, $rhs), $tval, $fval)>;
1297 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETGE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001298 (SELECT_VSSRC (CRORC $rhs, $lhs), $tval, $fval)>;
1299 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETUGE)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001300 (SELECT_VSSRC (CRORC $lhs, $rhs), $tval, $fval)>;
1301 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETGT)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001302 (SELECT_VSSRC (CRANDC $rhs, $lhs), $tval, $fval)>;
1303 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETUGT)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001304 (SELECT_VSSRC (CRANDC $lhs, $rhs), $tval, $fval)>;
1305 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETNE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001306 (SELECT_VSSRC (CRXOR $lhs, $rhs), $tval, $fval)>;
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001307
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001308 let UseVSXReg = 1 in {
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001309 // VSX Elementary Scalar FP arithmetic (SP)
1310 let isCommutable = 1 in {
1311 def XSADDSP : XX3Form<60, 0,
1312 (outs vssrc:$XT), (ins vssrc:$XA, vssrc:$XB),
1313 "xsaddsp $XT, $XA, $XB", IIC_VecFP,
1314 [(set f32:$XT, (fadd f32:$XA, f32:$XB))]>;
1315 def XSMULSP : XX3Form<60, 16,
1316 (outs vssrc:$XT), (ins vssrc:$XA, vssrc:$XB),
1317 "xsmulsp $XT, $XA, $XB", IIC_VecFP,
1318 [(set f32:$XT, (fmul f32:$XA, f32:$XB))]>;
1319 } // isCommutable
1320
1321 def XSDIVSP : XX3Form<60, 24,
1322 (outs vssrc:$XT), (ins vssrc:$XA, vssrc:$XB),
1323 "xsdivsp $XT, $XA, $XB", IIC_FPDivS,
1324 [(set f32:$XT, (fdiv f32:$XA, f32:$XB))]>;
1325 def XSRESP : XX2Form<60, 26,
1326 (outs vssrc:$XT), (ins vssrc:$XB),
1327 "xsresp $XT, $XB", IIC_VecFP,
1328 [(set f32:$XT, (PPCfre f32:$XB))]>;
Lei Huang6270ab62018-07-04 21:59:16 +00001329 def XSRSP : XX2Form<60, 281,
1330 (outs vssrc:$XT), (ins vsfrc:$XB),
1331 "xsrsp $XT, $XB", IIC_VecFP, []>;
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001332 def XSSQRTSP : XX2Form<60, 11,
1333 (outs vssrc:$XT), (ins vssrc:$XB),
1334 "xssqrtsp $XT, $XB", IIC_FPSqrtS,
1335 [(set f32:$XT, (fsqrt f32:$XB))]>;
1336 def XSRSQRTESP : XX2Form<60, 10,
1337 (outs vssrc:$XT), (ins vssrc:$XB),
1338 "xsrsqrtesp $XT, $XB", IIC_VecFP,
1339 [(set f32:$XT, (PPCfrsqrte f32:$XB))]>;
1340 def XSSUBSP : XX3Form<60, 8,
1341 (outs vssrc:$XT), (ins vssrc:$XA, vssrc:$XB),
1342 "xssubsp $XT, $XA, $XB", IIC_VecFP,
1343 [(set f32:$XT, (fsub f32:$XA, f32:$XB))]>;
Nemanja Ivanovic376e1732015-05-29 17:13:25 +00001344
1345 // FMA Instructions
1346 let BaseName = "XSMADDASP" in {
1347 let isCommutable = 1 in
1348 def XSMADDASP : XX3Form<60, 1,
1349 (outs vssrc:$XT),
1350 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1351 "xsmaddasp $XT, $XA, $XB", IIC_VecFP,
1352 [(set f32:$XT, (fma f32:$XA, f32:$XB, f32:$XTi))]>,
1353 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1354 AltVSXFMARel;
1355 let IsVSXFMAAlt = 1 in
1356 def XSMADDMSP : XX3Form<60, 9,
1357 (outs vssrc:$XT),
1358 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1359 "xsmaddmsp $XT, $XA, $XB", IIC_VecFP, []>,
1360 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1361 AltVSXFMARel;
1362 }
1363
1364 let BaseName = "XSMSUBASP" in {
1365 let isCommutable = 1 in
1366 def XSMSUBASP : XX3Form<60, 17,
1367 (outs vssrc:$XT),
1368 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1369 "xsmsubasp $XT, $XA, $XB", IIC_VecFP,
1370 [(set f32:$XT, (fma f32:$XA, f32:$XB,
1371 (fneg f32:$XTi)))]>,
1372 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1373 AltVSXFMARel;
1374 let IsVSXFMAAlt = 1 in
1375 def XSMSUBMSP : XX3Form<60, 25,
1376 (outs vssrc:$XT),
1377 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1378 "xsmsubmsp $XT, $XA, $XB", IIC_VecFP, []>,
1379 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1380 AltVSXFMARel;
1381 }
1382
1383 let BaseName = "XSNMADDASP" in {
1384 let isCommutable = 1 in
1385 def XSNMADDASP : XX3Form<60, 129,
1386 (outs vssrc:$XT),
1387 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1388 "xsnmaddasp $XT, $XA, $XB", IIC_VecFP,
1389 [(set f32:$XT, (fneg (fma f32:$XA, f32:$XB,
1390 f32:$XTi)))]>,
1391 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1392 AltVSXFMARel;
1393 let IsVSXFMAAlt = 1 in
1394 def XSNMADDMSP : XX3Form<60, 137,
1395 (outs vssrc:$XT),
1396 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1397 "xsnmaddmsp $XT, $XA, $XB", IIC_VecFP, []>,
1398 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1399 AltVSXFMARel;
1400 }
1401
1402 let BaseName = "XSNMSUBASP" in {
1403 let isCommutable = 1 in
1404 def XSNMSUBASP : XX3Form<60, 145,
1405 (outs vssrc:$XT),
1406 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1407 "xsnmsubasp $XT, $XA, $XB", IIC_VecFP,
1408 [(set f32:$XT, (fneg (fma f32:$XA, f32:$XB,
1409 (fneg f32:$XTi))))]>,
1410 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1411 AltVSXFMARel;
1412 let IsVSXFMAAlt = 1 in
1413 def XSNMSUBMSP : XX3Form<60, 153,
1414 (outs vssrc:$XT),
1415 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1416 "xsnmsubmsp $XT, $XA, $XB", IIC_VecFP, []>,
1417 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1418 AltVSXFMARel;
1419 }
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001420
1421 // Single Precision Conversions (FP <-> INT)
1422 def XSCVSXDSP : XX2Form<60, 312,
1423 (outs vssrc:$XT), (ins vsfrc:$XB),
1424 "xscvsxdsp $XT, $XB", IIC_VecFP,
1425 [(set f32:$XT, (PPCfcfids f64:$XB))]>;
1426 def XSCVUXDSP : XX2Form<60, 296,
1427 (outs vssrc:$XT), (ins vsfrc:$XB),
1428 "xscvuxdsp $XT, $XB", IIC_VecFP,
1429 [(set f32:$XT, (PPCfcfidus f64:$XB))]>;
1430
1431 // Conversions between vector and scalar single precision
1432 def XSCVDPSPN : XX2Form<60, 267, (outs vsrc:$XT), (ins vssrc:$XB),
1433 "xscvdpspn $XT, $XB", IIC_VecFP, []>;
1434 def XSCVSPDPN : XX2Form<60, 331, (outs vssrc:$XT), (ins vsrc:$XB),
1435 "xscvspdpn $XT, $XB", IIC_VecFP, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001436 } // UseVSXReg = 1
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001437
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001438 let Predicates = [IsLittleEndian] in {
Lei Huangcd4f3852018-03-12 19:26:18 +00001439 def : Pat<(f32 (PPCfcfids
1440 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 0)))))),
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001441 (f32 (XSCVSXDSP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00001442 def : Pat<(f32 (PPCfcfids
1443 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 1)))))),
1444 (f32 (XSCVSXDSP (COPY_TO_REGCLASS
1445 (f64 (COPY_TO_REGCLASS $S, VSRC)), VSFRC)))>;
1446 def : Pat<(f32 (PPCfcfidus
1447 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 0)))))),
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001448 (f32 (XSCVUXDSP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00001449 def : Pat<(f32 (PPCfcfidus
1450 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 1)))))),
1451 (f32 (XSCVUXDSP (COPY_TO_REGCLASS
1452 (f64 (COPY_TO_REGCLASS $S, VSRC)), VSFRC)))>;
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001453 }
1454
1455 let Predicates = [IsBigEndian] in {
Lei Huangcd4f3852018-03-12 19:26:18 +00001456 def : Pat<(f32 (PPCfcfids
1457 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 0)))))),
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001458 (f32 (XSCVSXDSP (COPY_TO_REGCLASS $S, VSFRC)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00001459 def : Pat<(f32 (PPCfcfids
1460 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 1)))))),
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 (PPCfcfidus
1463 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 0)))))),
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001464 (f32 (XSCVUXDSP (COPY_TO_REGCLASS $S, VSFRC)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00001465 def : Pat<(f32 (PPCfcfidus
1466 (f64 (PPCmtvsra (i64 (vector_extract v2i64:$S, 1)))))),
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001467 (f32 (XSCVUXDSP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1468 }
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001469 def : Pat<(v4i32 (scalar_to_vector ScalarLoads.Li32)),
Tony Jiang438bf4a2017-11-20 14:38:30 +00001470 (v4i32 (XXSPLTWs (LIWAX xoaddr:$src), 1))>;
Lei Huangc29229a2018-05-08 17:36:40 +00001471
1472 // Instructions for converting float to i64 feeding a store.
1473 let Predicates = [NoP9Vector] in {
1474 def : Pat<(PPCstore_scal_int_from_vsr
1475 (f64 (PPCcv_fp_to_sint_in_vsr f64:$src)), xoaddr:$dst, 8),
1476 (STXSDX (XSCVDPSXDS f64:$src), xoaddr:$dst)>;
1477 def : Pat<(PPCstore_scal_int_from_vsr
1478 (f64 (PPCcv_fp_to_uint_in_vsr f64:$src)), xoaddr:$dst, 8),
1479 (STXSDX (XSCVDPUXDS f64:$src), xoaddr:$dst)>;
1480 }
1481
1482 // Instructions for converting float to i32 feeding a store.
1483 def : Pat<(PPCstore_scal_int_from_vsr
1484 (f64 (PPCcv_fp_to_sint_in_vsr f64:$src)), xoaddr:$dst, 4),
1485 (STIWX (XSCVDPSXWS f64:$src), xoaddr:$dst)>;
1486 def : Pat<(PPCstore_scal_int_from_vsr
1487 (f64 (PPCcv_fp_to_uint_in_vsr f64:$src)), xoaddr:$dst, 4),
1488 (STIWX (XSCVDPUXWS f64:$src), xoaddr:$dst)>;
1489
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +00001490} // AddedComplexity = 400
Kit Barton298beb52015-02-18 16:21:46 +00001491} // HasP8Vector
Nemanja Ivanovicc38b5312015-04-11 10:40:42 +00001492
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00001493let UseVSXReg = 1, AddedComplexity = 400 in {
Ehsan Amiri99b017a2016-03-31 17:47:17 +00001494let Predicates = [HasDirectMove] in {
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001495 // VSX direct move instructions
1496 def MFVSRD : XX1_RS6_RD5_XO<31, 51, (outs g8rc:$rA), (ins vsfrc:$XT),
1497 "mfvsrd $rA, $XT", IIC_VecGeneral,
1498 [(set i64:$rA, (PPCmfvsr f64:$XT))]>,
1499 Requires<[In64BitMode]>;
Nemanja Ivanovicffcf0fb2017-03-15 16:04:53 +00001500 let isCodeGenOnly = 1 in
1501 def MFVRD : XX1_RS6_RD5_XO<31, 51, (outs g8rc:$rA), (ins vrrc:$XT),
1502 "mfvsrd $rA, $XT", IIC_VecGeneral,
1503 []>,
1504 Requires<[In64BitMode]>;
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001505 def MFVSRWZ : XX1_RS6_RD5_XO<31, 115, (outs gprc:$rA), (ins vsfrc:$XT),
1506 "mfvsrwz $rA, $XT", IIC_VecGeneral,
1507 [(set i32:$rA, (PPCmfvsr f64:$XT))]>;
1508 def MTVSRD : XX1_RS6_RD5_XO<31, 179, (outs vsfrc:$XT), (ins g8rc:$rA),
1509 "mtvsrd $XT, $rA", IIC_VecGeneral,
1510 [(set f64:$XT, (PPCmtvsra i64:$rA))]>,
1511 Requires<[In64BitMode]>;
1512 def MTVSRWA : XX1_RS6_RD5_XO<31, 211, (outs vsfrc:$XT), (ins gprc:$rA),
1513 "mtvsrwa $XT, $rA", IIC_VecGeneral,
1514 [(set f64:$XT, (PPCmtvsra i32:$rA))]>;
1515 def MTVSRWZ : XX1_RS6_RD5_XO<31, 243, (outs vsfrc:$XT), (ins gprc:$rA),
1516 "mtvsrwz $XT, $rA", IIC_VecGeneral,
1517 [(set f64:$XT, (PPCmtvsrz i32:$rA))]>;
Ehsan Amiri99b017a2016-03-31 17:47:17 +00001518} // HasDirectMove
1519
1520let Predicates = [IsISA3_0, HasDirectMove] in {
1521 def MTVSRWS: XX1_RS6_RD5_XO<31, 403, (outs vsrc:$XT), (ins gprc:$rA),
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00001522 "mtvsrws $XT, $rA", IIC_VecGeneral, []>;
Ehsan Amiri99b017a2016-03-31 17:47:17 +00001523
Guozhi Wei22e7da92017-05-11 22:17:35 +00001524 def MTVSRDD: XX1Form<31, 435, (outs vsrc:$XT), (ins g8rc_nox0:$rA, g8rc:$rB),
Ehsan Amiri99b017a2016-03-31 17:47:17 +00001525 "mtvsrdd $XT, $rA, $rB", IIC_VecGeneral,
1526 []>, Requires<[In64BitMode]>;
1527
1528 def MFVSRLD: XX1_RS6_RD5_XO<31, 307, (outs g8rc:$rA), (ins vsrc:$XT),
1529 "mfvsrld $rA, $XT", IIC_VecGeneral,
1530 []>, Requires<[In64BitMode]>;
1531
1532} // IsISA3_0, HasDirectMove
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001533} // UseVSXReg = 1
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001534
Nemanja Ivanovicffcf0fb2017-03-15 16:04:53 +00001535// We want to parse this from asm, but we don't want to emit this as it would
1536// be emitted with a VSX reg. So leave Emit = 0 here.
1537def : InstAlias<"mfvrd $rA, $XT",
1538 (MFVRD g8rc:$rA, vrrc:$XT), 0>;
1539def : InstAlias<"mffprd $rA, $src",
1540 (MFVSRD g8rc:$rA, f8rc:$src)>;
1541
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001542/* Direct moves of various widths from GPR's into VSR's. Each move lines
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001543 the value up into element 0 (both BE and LE). Namely, entities smaller than
1544 a doubleword are shifted left and moved for BE. For LE, they're moved, then
1545 swapped to go into the least significant element of the VSR.
1546*/
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001547def MovesToVSR {
1548 dag BE_BYTE_0 =
1549 (MTVSRD
1550 (RLDICR
1551 (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $A, sub_32), 56, 7));
1552 dag BE_HALF_0 =
1553 (MTVSRD
1554 (RLDICR
1555 (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $A, sub_32), 48, 15));
1556 dag BE_WORD_0 =
1557 (MTVSRD
1558 (RLDICR
1559 (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $A, sub_32), 32, 31));
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001560 dag BE_DWORD_0 = (MTVSRD $A);
1561
1562 dag LE_MTVSRW = (MTVSRD (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $A, sub_32));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001563 dag LE_WORD_1 = (v2i64 (INSERT_SUBREG (v2i64 (IMPLICIT_DEF)),
1564 LE_MTVSRW, sub_64));
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001565 dag LE_WORD_0 = (XXPERMDI LE_WORD_1, LE_WORD_1, 2);
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001566 dag LE_DWORD_1 = (v2i64 (INSERT_SUBREG (v2i64 (IMPLICIT_DEF)),
1567 BE_DWORD_0, sub_64));
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001568 dag LE_DWORD_0 = (XXPERMDI LE_DWORD_1, LE_DWORD_1, 2);
1569}
1570
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001571/* Patterns for extracting elements out of vectors. Integer elements are
1572 extracted using direct move operations. Patterns for extracting elements
1573 whose indices are not available at compile time are also provided with
1574 various _VARIABLE_ patterns.
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001575 The numbering for the DAG's is for LE, but when used on BE, the correct
1576 LE element can just be used (i.e. LE_BYTE_2 == BE_BYTE_13).
1577*/
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001578def VectorExtractions {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001579 // Doubleword extraction
1580 dag LE_DWORD_0 =
1581 (MFVSRD
1582 (EXTRACT_SUBREG
1583 (XXPERMDI (COPY_TO_REGCLASS $S, VSRC),
1584 (COPY_TO_REGCLASS $S, VSRC), 2), sub_64));
1585 dag LE_DWORD_1 = (MFVSRD
1586 (EXTRACT_SUBREG
1587 (v2i64 (COPY_TO_REGCLASS $S, VSRC)), sub_64));
1588
1589 // Word extraction
Nemanja Ivanoviceebbcb62016-07-12 12:16:27 +00001590 dag LE_WORD_0 = (MFVSRWZ (EXTRACT_SUBREG (XXPERMDI $S, $S, 2), sub_64));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001591 dag LE_WORD_1 = (MFVSRWZ (EXTRACT_SUBREG (XXSLDWI $S, $S, 1), sub_64));
1592 dag LE_WORD_2 = (MFVSRWZ (EXTRACT_SUBREG
1593 (v2i64 (COPY_TO_REGCLASS $S, VSRC)), sub_64));
1594 dag LE_WORD_3 = (MFVSRWZ (EXTRACT_SUBREG (XXSLDWI $S, $S, 3), sub_64));
1595
1596 // Halfword extraction
1597 dag LE_HALF_0 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 0, 48), sub_32));
1598 dag LE_HALF_1 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 48, 48), sub_32));
1599 dag LE_HALF_2 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 32, 48), sub_32));
1600 dag LE_HALF_3 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 16, 48), sub_32));
1601 dag LE_HALF_4 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 0, 48), sub_32));
1602 dag LE_HALF_5 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 48, 48), sub_32));
1603 dag LE_HALF_6 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 32, 48), sub_32));
1604 dag LE_HALF_7 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 16, 48), sub_32));
1605
1606 // Byte extraction
1607 dag LE_BYTE_0 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 0, 56), sub_32));
1608 dag LE_BYTE_1 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 56, 56), sub_32));
1609 dag LE_BYTE_2 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 48, 56), sub_32));
1610 dag LE_BYTE_3 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 40, 56), sub_32));
1611 dag LE_BYTE_4 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 32, 56), sub_32));
1612 dag LE_BYTE_5 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 24, 56), sub_32));
1613 dag LE_BYTE_6 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 16, 56), sub_32));
1614 dag LE_BYTE_7 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 8, 56), sub_32));
1615 dag LE_BYTE_8 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 0, 56), sub_32));
1616 dag LE_BYTE_9 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 56, 56), sub_32));
1617 dag LE_BYTE_10 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 48, 56), sub_32));
1618 dag LE_BYTE_11 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 40, 56), sub_32));
1619 dag LE_BYTE_12 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 32, 56), sub_32));
1620 dag LE_BYTE_13 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 24, 56), sub_32));
1621 dag LE_BYTE_14 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 16, 56), sub_32));
1622 dag LE_BYTE_15 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 8, 56), sub_32));
1623
1624 /* Variable element number (BE and LE patterns must be specified separately)
1625 This is a rather involved process.
1626
1627 Conceptually, this is how the move is accomplished:
1628 1. Identify which doubleword contains the element
1629 2. Shift in the VMX register so that the correct doubleword is correctly
1630 lined up for the MFVSRD
1631 3. Perform the move so that the element (along with some extra stuff)
1632 is in the GPR
1633 4. Right shift within the GPR so that the element is right-justified
1634
1635 Of course, the index is an element number which has a different meaning
1636 on LE/BE so the patterns have to be specified separately.
1637
1638 Note: The final result will be the element right-justified with high
1639 order bits being arbitrarily defined (namely, whatever was in the
1640 vector register to the left of the value originally).
1641 */
1642
1643 /* LE variable byte
1644 Number 1. above:
1645 - For elements 0-7, we shift left by 8 bytes since they're on the right
1646 - For elements 8-15, we need not shift (shift left by zero bytes)
1647 This is accomplished by inverting the bits of the index and AND-ing
1648 with 0x8 (i.e. clearing all bits of the index and inverting bit 60).
1649 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001650 dag LE_VBYTE_PERM_VEC = (v16i8 (LVSL ZERO8, (ANDC8 (LI8 8), $Idx)));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001651
1652 // Number 2. above:
1653 // - Now that we set up the shift amount, we shift in the VMX register
Lei Huangcd4f3852018-03-12 19:26:18 +00001654 dag LE_VBYTE_PERMUTE = (v16i8 (VPERM $S, $S, LE_VBYTE_PERM_VEC));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001655
1656 // Number 3. above:
1657 // - The doubleword containing our element is moved to a GPR
1658 dag LE_MV_VBYTE = (MFVSRD
1659 (EXTRACT_SUBREG
1660 (v2i64 (COPY_TO_REGCLASS LE_VBYTE_PERMUTE, VSRC)),
1661 sub_64));
1662
1663 /* Number 4. above:
1664 - Truncate the element number to the range 0-7 (8-15 are symmetrical
1665 and out of range values are truncated accordingly)
1666 - Multiply by 8 as we need to shift right by the number of bits, not bytes
1667 - Shift right in the GPR by the calculated value
1668 */
1669 dag LE_VBYTE_SHIFT = (EXTRACT_SUBREG (RLDICR (AND8 (LI8 7), $Idx), 3, 60),
1670 sub_32);
1671 dag LE_VARIABLE_BYTE = (EXTRACT_SUBREG (SRD LE_MV_VBYTE, LE_VBYTE_SHIFT),
1672 sub_32);
1673
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001674 /* LE variable halfword
1675 Number 1. above:
1676 - For elements 0-3, we shift left by 8 since they're on the right
1677 - For elements 4-7, we need not shift (shift left by zero bytes)
1678 Similarly to the byte pattern, we invert the bits of the index, but we
1679 AND with 0x4 (i.e. clear all bits of the index and invert bit 61).
1680 Of course, the shift is still by 8 bytes, so we must multiply by 2.
1681 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001682 dag LE_VHALF_PERM_VEC =
1683 (v16i8 (LVSL ZERO8, (RLDICR (ANDC8 (LI8 4), $Idx), 1, 62)));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001684
1685 // Number 2. above:
1686 // - Now that we set up the shift amount, we shift in the VMX register
Lei Huangcd4f3852018-03-12 19:26:18 +00001687 dag LE_VHALF_PERMUTE = (v16i8 (VPERM $S, $S, LE_VHALF_PERM_VEC));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001688
1689 // Number 3. above:
1690 // - The doubleword containing our element is moved to a GPR
1691 dag LE_MV_VHALF = (MFVSRD
1692 (EXTRACT_SUBREG
1693 (v2i64 (COPY_TO_REGCLASS LE_VHALF_PERMUTE, VSRC)),
1694 sub_64));
1695
1696 /* Number 4. above:
1697 - Truncate the element number to the range 0-3 (4-7 are symmetrical
1698 and out of range values are truncated accordingly)
1699 - Multiply by 16 as we need to shift right by the number of bits
1700 - Shift right in the GPR by the calculated value
1701 */
1702 dag LE_VHALF_SHIFT = (EXTRACT_SUBREG (RLDICR (AND8 (LI8 3), $Idx), 4, 59),
1703 sub_32);
1704 dag LE_VARIABLE_HALF = (EXTRACT_SUBREG (SRD LE_MV_VHALF, LE_VHALF_SHIFT),
1705 sub_32);
1706
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001707 /* LE variable word
1708 Number 1. above:
1709 - For elements 0-1, we shift left by 8 since they're on the right
1710 - For elements 2-3, we need not shift
1711 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001712 dag LE_VWORD_PERM_VEC = (v16i8 (LVSL ZERO8,
1713 (RLDICR (ANDC8 (LI8 2), $Idx), 2, 61)));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001714
1715 // Number 2. above:
1716 // - Now that we set up the shift amount, we shift in the VMX register
Lei Huangcd4f3852018-03-12 19:26:18 +00001717 dag LE_VWORD_PERMUTE = (v16i8 (VPERM $S, $S, LE_VWORD_PERM_VEC));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001718
1719 // Number 3. above:
1720 // - The doubleword containing our element is moved to a GPR
1721 dag LE_MV_VWORD = (MFVSRD
1722 (EXTRACT_SUBREG
1723 (v2i64 (COPY_TO_REGCLASS LE_VWORD_PERMUTE, VSRC)),
1724 sub_64));
1725
1726 /* Number 4. above:
1727 - Truncate the element number to the range 0-1 (2-3 are symmetrical
1728 and out of range values are truncated accordingly)
1729 - Multiply by 32 as we need to shift right by the number of bits
1730 - Shift right in the GPR by the calculated value
1731 */
1732 dag LE_VWORD_SHIFT = (EXTRACT_SUBREG (RLDICR (AND8 (LI8 1), $Idx), 5, 58),
1733 sub_32);
1734 dag LE_VARIABLE_WORD = (EXTRACT_SUBREG (SRD LE_MV_VWORD, LE_VWORD_SHIFT),
1735 sub_32);
1736
1737 /* LE variable doubleword
1738 Number 1. above:
1739 - For element 0, we shift left by 8 since it's on the right
1740 - For element 1, we need not shift
1741 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001742 dag LE_VDWORD_PERM_VEC = (v16i8 (LVSL ZERO8,
1743 (RLDICR (ANDC8 (LI8 1), $Idx), 3, 60)));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001744
1745 // Number 2. above:
1746 // - Now that we set up the shift amount, we shift in the VMX register
Lei Huangcd4f3852018-03-12 19:26:18 +00001747 dag LE_VDWORD_PERMUTE = (v16i8 (VPERM $S, $S, LE_VDWORD_PERM_VEC));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001748
1749 // Number 3. above:
1750 // - The doubleword containing our element is moved to a GPR
1751 // - Number 4. is not needed for the doubleword as the value is 64-bits
1752 dag LE_VARIABLE_DWORD =
1753 (MFVSRD (EXTRACT_SUBREG
1754 (v2i64 (COPY_TO_REGCLASS LE_VDWORD_PERMUTE, VSRC)),
1755 sub_64));
1756
1757 /* LE variable float
1758 - Shift the vector to line up the desired element to BE Word 0
1759 - Convert 32-bit float to a 64-bit single precision float
1760 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001761 dag LE_VFLOAT_PERM_VEC = (v16i8 (LVSL ZERO8,
1762 (RLDICR (XOR8 (LI8 3), $Idx), 2, 61)));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001763 dag LE_VFLOAT_PERMUTE = (VPERM $S, $S, LE_VFLOAT_PERM_VEC);
1764 dag LE_VARIABLE_FLOAT = (XSCVSPDPN LE_VFLOAT_PERMUTE);
1765
1766 /* LE variable double
1767 Same as the LE doubleword except there is no move.
1768 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001769 dag LE_VDOUBLE_PERMUTE = (v16i8 (VPERM (v16i8 (COPY_TO_REGCLASS $S, VRRC)),
1770 (v16i8 (COPY_TO_REGCLASS $S, VRRC)),
1771 LE_VDWORD_PERM_VEC));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001772 dag LE_VARIABLE_DOUBLE = (COPY_TO_REGCLASS LE_VDOUBLE_PERMUTE, VSRC);
1773
1774 /* BE variable byte
1775 The algorithm here is the same as the LE variable byte except:
1776 - The shift in the VMX register is by 0/8 for opposite element numbers so
1777 we simply AND the element number with 0x8
1778 - The order of elements after the move to GPR is reversed, so we invert
1779 the bits of the index prior to truncating to the range 0-7
1780 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001781 dag BE_VBYTE_PERM_VEC = (v16i8 (LVSL ZERO8, (ANDIo8 $Idx, 8)));
1782 dag BE_VBYTE_PERMUTE = (v16i8 (VPERM $S, $S, BE_VBYTE_PERM_VEC));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001783 dag BE_MV_VBYTE = (MFVSRD
1784 (EXTRACT_SUBREG
1785 (v2i64 (COPY_TO_REGCLASS BE_VBYTE_PERMUTE, VSRC)),
1786 sub_64));
1787 dag BE_VBYTE_SHIFT = (EXTRACT_SUBREG (RLDICR (ANDC8 (LI8 7), $Idx), 3, 60),
1788 sub_32);
1789 dag BE_VARIABLE_BYTE = (EXTRACT_SUBREG (SRD BE_MV_VBYTE, BE_VBYTE_SHIFT),
1790 sub_32);
1791
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001792 /* BE variable halfword
1793 The algorithm here is the same as the LE variable halfword 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 0x4 and multiply by 2
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-3
1798 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001799 dag BE_VHALF_PERM_VEC = (v16i8 (LVSL ZERO8,
1800 (RLDICR (ANDIo8 $Idx, 4), 1, 62)));
1801 dag BE_VHALF_PERMUTE = (v16i8 (VPERM $S, $S, BE_VHALF_PERM_VEC));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001802 dag BE_MV_VHALF = (MFVSRD
1803 (EXTRACT_SUBREG
1804 (v2i64 (COPY_TO_REGCLASS BE_VHALF_PERMUTE, VSRC)),
1805 sub_64));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001806 dag BE_VHALF_SHIFT = (EXTRACT_SUBREG (RLDICR (ANDC8 (LI8 3), $Idx), 4, 59),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001807 sub_32);
1808 dag BE_VARIABLE_HALF = (EXTRACT_SUBREG (SRD BE_MV_VHALF, BE_VHALF_SHIFT),
1809 sub_32);
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001810
1811 /* BE variable word
1812 The algorithm is the same as the LE variable word except:
1813 - The shift in the VMX register happens for opposite element numbers
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-1
1816 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001817 dag BE_VWORD_PERM_VEC = (v16i8 (LVSL ZERO8,
1818 (RLDICR (ANDIo8 $Idx, 2), 2, 61)));
1819 dag BE_VWORD_PERMUTE = (v16i8 (VPERM $S, $S, BE_VWORD_PERM_VEC));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001820 dag BE_MV_VWORD = (MFVSRD
1821 (EXTRACT_SUBREG
1822 (v2i64 (COPY_TO_REGCLASS BE_VWORD_PERMUTE, VSRC)),
1823 sub_64));
1824 dag BE_VWORD_SHIFT = (EXTRACT_SUBREG (RLDICR (ANDC8 (LI8 1), $Idx), 5, 58),
1825 sub_32);
1826 dag BE_VARIABLE_WORD = (EXTRACT_SUBREG (SRD BE_MV_VWORD, BE_VWORD_SHIFT),
1827 sub_32);
1828
1829 /* BE variable doubleword
1830 Same as the LE doubleword except we shift in the VMX register for opposite
1831 element indices.
1832 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001833 dag BE_VDWORD_PERM_VEC = (v16i8 (LVSL ZERO8,
1834 (RLDICR (ANDIo8 $Idx, 1), 3, 60)));
1835 dag BE_VDWORD_PERMUTE = (v16i8 (VPERM $S, $S, BE_VDWORD_PERM_VEC));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001836 dag BE_VARIABLE_DWORD =
1837 (MFVSRD (EXTRACT_SUBREG
1838 (v2i64 (COPY_TO_REGCLASS BE_VDWORD_PERMUTE, VSRC)),
1839 sub_64));
1840
1841 /* BE variable float
1842 - Shift the vector to line up the desired element to BE Word 0
1843 - Convert 32-bit float to a 64-bit single precision float
1844 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001845 dag BE_VFLOAT_PERM_VEC = (v16i8 (LVSL ZERO8, (RLDICR $Idx, 2, 61)));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001846 dag BE_VFLOAT_PERMUTE = (VPERM $S, $S, BE_VFLOAT_PERM_VEC);
1847 dag BE_VARIABLE_FLOAT = (XSCVSPDPN BE_VFLOAT_PERMUTE);
1848
1849 /* BE variable double
1850 Same as the BE doubleword except there is no move.
1851 */
Lei Huangcd4f3852018-03-12 19:26:18 +00001852 dag BE_VDOUBLE_PERMUTE = (v16i8 (VPERM (v16i8 (COPY_TO_REGCLASS $S, VRRC)),
1853 (v16i8 (COPY_TO_REGCLASS $S, VRRC)),
1854 BE_VDWORD_PERM_VEC));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001855 dag BE_VARIABLE_DOUBLE = (COPY_TO_REGCLASS BE_VDOUBLE_PERMUTE, VSRC);
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001856}
1857
Zaara Syeda48cb3c12017-11-27 17:11:03 +00001858def NoP9Altivec : Predicate<"!PPCSubTarget->hasP9Altivec()">;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00001859let AddedComplexity = 400 in {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001860// v4f32 scalar <-> vector conversions (BE)
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001861let Predicates = [IsBigEndian, HasP8Vector] in {
1862 def : Pat<(v4f32 (scalar_to_vector f32:$A)),
1863 (v4f32 (XSCVDPSPN $A))>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001864 def : Pat<(f32 (vector_extract v4f32:$S, 0)),
1865 (f32 (XSCVSPDPN $S))>;
1866 def : Pat<(f32 (vector_extract v4f32:$S, 1)),
1867 (f32 (XSCVSPDPN (XXSLDWI $S, $S, 1)))>;
1868 def : Pat<(f32 (vector_extract v4f32:$S, 2)),
Nemanja Ivanoviceebbcb62016-07-12 12:16:27 +00001869 (f32 (XSCVSPDPN (XXPERMDI $S, $S, 2)))>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001870 def : Pat<(f32 (vector_extract v4f32:$S, 3)),
1871 (f32 (XSCVSPDPN (XXSLDWI $S, $S, 3)))>;
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001872 def : Pat<(f32 (vector_extract v4f32:$S, i64:$Idx)),
1873 (f32 VectorExtractions.BE_VARIABLE_FLOAT)>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001874} // IsBigEndian, HasP8Vector
1875
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001876// Variable index vector_extract for v2f64 does not require P8Vector
1877let Predicates = [IsBigEndian, HasVSX] in
1878 def : Pat<(f64 (vector_extract v2f64:$S, i64:$Idx)),
1879 (f64 VectorExtractions.BE_VARIABLE_DOUBLE)>;
1880
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001881let Predicates = [IsBigEndian, HasDirectMove] in {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001882 // v16i8 scalar <-> vector conversions (BE)
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001883 def : Pat<(v16i8 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001884 (v16i8 (SUBREG_TO_REG (i64 1), MovesToVSR.BE_BYTE_0, sub_64))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001885 def : Pat<(v8i16 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001886 (v8i16 (SUBREG_TO_REG (i64 1), MovesToVSR.BE_HALF_0, sub_64))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001887 def : Pat<(v4i32 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001888 (v4i32 (SUBREG_TO_REG (i64 1), MovesToVSR.BE_WORD_0, sub_64))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001889 def : Pat<(v2i64 (scalar_to_vector i64:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001890 (v2i64 (SUBREG_TO_REG (i64 1), MovesToVSR.BE_DWORD_0, sub_64))>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00001891
1892 // v2i64 scalar <-> vector conversions (BE)
1893 def : Pat<(i64 (vector_extract v2i64:$S, 0)),
1894 (i64 VectorExtractions.LE_DWORD_1)>;
1895 def : Pat<(i64 (vector_extract v2i64:$S, 1)),
1896 (i64 VectorExtractions.LE_DWORD_0)>;
1897 def : Pat<(i64 (vector_extract v2i64:$S, i64:$Idx)),
1898 (i64 VectorExtractions.BE_VARIABLE_DWORD)>;
1899} // IsBigEndian, HasDirectMove
1900
1901let Predicates = [IsBigEndian, HasDirectMove, NoP9Altivec] in {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001902 def : Pat<(i32 (vector_extract v16i8:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001903 (i32 VectorExtractions.LE_BYTE_15)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001904 def : Pat<(i32 (vector_extract v16i8:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001905 (i32 VectorExtractions.LE_BYTE_14)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001906 def : Pat<(i32 (vector_extract v16i8:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001907 (i32 VectorExtractions.LE_BYTE_13)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001908 def : Pat<(i32 (vector_extract v16i8:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001909 (i32 VectorExtractions.LE_BYTE_12)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001910 def : Pat<(i32 (vector_extract v16i8:$S, 4)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001911 (i32 VectorExtractions.LE_BYTE_11)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001912 def : Pat<(i32 (vector_extract v16i8:$S, 5)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001913 (i32 VectorExtractions.LE_BYTE_10)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001914 def : Pat<(i32 (vector_extract v16i8:$S, 6)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001915 (i32 VectorExtractions.LE_BYTE_9)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001916 def : Pat<(i32 (vector_extract v16i8:$S, 7)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001917 (i32 VectorExtractions.LE_BYTE_8)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001918 def : Pat<(i32 (vector_extract v16i8:$S, 8)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001919 (i32 VectorExtractions.LE_BYTE_7)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001920 def : Pat<(i32 (vector_extract v16i8:$S, 9)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001921 (i32 VectorExtractions.LE_BYTE_6)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001922 def : Pat<(i32 (vector_extract v16i8:$S, 10)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001923 (i32 VectorExtractions.LE_BYTE_5)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001924 def : Pat<(i32 (vector_extract v16i8:$S, 11)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001925 (i32 VectorExtractions.LE_BYTE_4)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001926 def : Pat<(i32 (vector_extract v16i8:$S, 12)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001927 (i32 VectorExtractions.LE_BYTE_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001928 def : Pat<(i32 (vector_extract v16i8:$S, 13)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001929 (i32 VectorExtractions.LE_BYTE_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001930 def : Pat<(i32 (vector_extract v16i8:$S, 14)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001931 (i32 VectorExtractions.LE_BYTE_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001932 def : Pat<(i32 (vector_extract v16i8:$S, 15)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001933 (i32 VectorExtractions.LE_BYTE_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001934 def : Pat<(i32 (vector_extract v16i8:$S, i64:$Idx)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001935 (i32 VectorExtractions.BE_VARIABLE_BYTE)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001936
1937 // v8i16 scalar <-> vector conversions (BE)
1938 def : Pat<(i32 (vector_extract v8i16:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001939 (i32 VectorExtractions.LE_HALF_7)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001940 def : Pat<(i32 (vector_extract v8i16:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001941 (i32 VectorExtractions.LE_HALF_6)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001942 def : Pat<(i32 (vector_extract v8i16:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001943 (i32 VectorExtractions.LE_HALF_5)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001944 def : Pat<(i32 (vector_extract v8i16:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001945 (i32 VectorExtractions.LE_HALF_4)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001946 def : Pat<(i32 (vector_extract v8i16:$S, 4)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001947 (i32 VectorExtractions.LE_HALF_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001948 def : Pat<(i32 (vector_extract v8i16:$S, 5)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001949 (i32 VectorExtractions.LE_HALF_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001950 def : Pat<(i32 (vector_extract v8i16:$S, 6)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001951 (i32 VectorExtractions.LE_HALF_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001952 def : Pat<(i32 (vector_extract v8i16:$S, 7)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001953 (i32 VectorExtractions.LE_HALF_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001954 def : Pat<(i32 (vector_extract v8i16:$S, i64:$Idx)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001955 (i32 VectorExtractions.BE_VARIABLE_HALF)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001956
1957 // v4i32 scalar <-> vector conversions (BE)
1958 def : Pat<(i32 (vector_extract v4i32:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001959 (i32 VectorExtractions.LE_WORD_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001960 def : Pat<(i32 (vector_extract v4i32:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001961 (i32 VectorExtractions.LE_WORD_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001962 def : Pat<(i32 (vector_extract v4i32:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001963 (i32 VectorExtractions.LE_WORD_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001964 def : Pat<(i32 (vector_extract v4i32:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001965 (i32 VectorExtractions.LE_WORD_0)>;
1966 def : Pat<(i32 (vector_extract v4i32:$S, i64:$Idx)),
1967 (i32 VectorExtractions.BE_VARIABLE_WORD)>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00001968} // IsBigEndian, HasDirectMove, NoP9Altivec
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001969
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001970// v4f32 scalar <-> vector conversions (LE)
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001971let Predicates = [IsLittleEndian, HasP8Vector] in {
1972 def : Pat<(v4f32 (scalar_to_vector f32:$A)),
1973 (v4f32 (XXSLDWI (XSCVDPSPN $A), (XSCVDPSPN $A), 1))>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001974 def : Pat<(f32 (vector_extract v4f32:$S, 0)),
1975 (f32 (XSCVSPDPN (XXSLDWI $S, $S, 3)))>;
1976 def : Pat<(f32 (vector_extract v4f32:$S, 1)),
Nemanja Ivanoviceebbcb62016-07-12 12:16:27 +00001977 (f32 (XSCVSPDPN (XXPERMDI $S, $S, 2)))>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001978 def : Pat<(f32 (vector_extract v4f32:$S, 2)),
1979 (f32 (XSCVSPDPN (XXSLDWI $S, $S, 1)))>;
1980 def : Pat<(f32 (vector_extract v4f32:$S, 3)),
1981 (f32 (XSCVSPDPN $S))>;
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001982 def : Pat<(f32 (vector_extract v4f32:$S, i64:$Idx)),
1983 (f32 VectorExtractions.LE_VARIABLE_FLOAT)>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001984} // IsLittleEndian, HasP8Vector
1985
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001986// Variable index vector_extract for v2f64 does not require P8Vector
1987let Predicates = [IsLittleEndian, HasVSX] in
1988 def : Pat<(f64 (vector_extract v2f64:$S, i64:$Idx)),
1989 (f64 VectorExtractions.LE_VARIABLE_DOUBLE)>;
1990
Nemanja Ivanovicb89c27f2017-05-02 01:47:34 +00001991def : Pat<(v4i32 (int_ppc_vsx_lxvw4x_be xoaddr:$src)), (LXVW4X xoaddr:$src)>;
1992def : Pat<(v2f64 (int_ppc_vsx_lxvd2x_be xoaddr:$src)), (LXVD2X xoaddr:$src)>;
Tony Jiang5f850cd2016-11-15 14:25:56 +00001993
Tony Jiangaa5a6a12017-07-05 16:55:00 +00001994// Variable index unsigned vector_extract on Power9
1995let Predicates = [HasP9Altivec, IsLittleEndian] in {
1996 def : Pat<(i64 (anyext (i32 (vector_extract v16i8:$S, i64:$Idx)))),
1997 (VEXTUBRX $Idx, $S)>;
1998
1999 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, i64:$Idx)))),
2000 (VEXTUHRX (RLWINM8 $Idx, 1, 28, 30), $S)>;
2001 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 0)))),
2002 (VEXTUHRX (LI8 0), $S)>;
2003 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 1)))),
2004 (VEXTUHRX (LI8 2), $S)>;
2005 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 2)))),
2006 (VEXTUHRX (LI8 4), $S)>;
2007 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 3)))),
2008 (VEXTUHRX (LI8 6), $S)>;
2009 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 4)))),
2010 (VEXTUHRX (LI8 8), $S)>;
2011 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 5)))),
2012 (VEXTUHRX (LI8 10), $S)>;
2013 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 6)))),
2014 (VEXTUHRX (LI8 12), $S)>;
2015 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 7)))),
2016 (VEXTUHRX (LI8 14), $S)>;
2017
2018 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, i64:$Idx)))),
2019 (VEXTUWRX (RLWINM8 $Idx, 2, 28, 29), $S)>;
2020 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 0)))),
2021 (VEXTUWRX (LI8 0), $S)>;
2022 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 1)))),
2023 (VEXTUWRX (LI8 4), $S)>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002024 // For extracting LE word 2, MFVSRWZ is better than VEXTUWRX
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002025 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 2)))),
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002026 (INSERT_SUBREG (i64 (IMPLICIT_DEF)),
2027 (i32 VectorExtractions.LE_WORD_2), sub_32)>;
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002028 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 3)))),
2029 (VEXTUWRX (LI8 12), $S)>;
2030
2031 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, i64:$Idx)))),
2032 (EXTSW (VEXTUWRX (RLWINM8 $Idx, 2, 28, 29), $S))>;
2033 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 0)))),
2034 (EXTSW (VEXTUWRX (LI8 0), $S))>;
2035 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 1)))),
2036 (EXTSW (VEXTUWRX (LI8 4), $S))>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002037 // For extracting LE word 2, MFVSRWZ is better than VEXTUWRX
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002038 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 2)))),
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002039 (EXTSW (INSERT_SUBREG (i64 (IMPLICIT_DEF)),
2040 (i32 VectorExtractions.LE_WORD_2), sub_32))>;
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002041 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 3)))),
2042 (EXTSW (VEXTUWRX (LI8 12), $S))>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002043
2044 def : Pat<(i32 (vector_extract v16i8:$S, i64:$Idx)),
2045 (i32 (EXTRACT_SUBREG (VEXTUBRX $Idx, $S), sub_32))>;
2046 def : Pat<(i32 (vector_extract v16i8:$S, 0)),
2047 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 0), $S), sub_32))>;
2048 def : Pat<(i32 (vector_extract v16i8:$S, 1)),
2049 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 1), $S), sub_32))>;
2050 def : Pat<(i32 (vector_extract v16i8:$S, 2)),
2051 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 2), $S), sub_32))>;
2052 def : Pat<(i32 (vector_extract v16i8:$S, 3)),
2053 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 3), $S), sub_32))>;
2054 def : Pat<(i32 (vector_extract v16i8:$S, 4)),
2055 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 4), $S), sub_32))>;
2056 def : Pat<(i32 (vector_extract v16i8:$S, 5)),
2057 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 5), $S), sub_32))>;
2058 def : Pat<(i32 (vector_extract v16i8:$S, 6)),
2059 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 6), $S), sub_32))>;
2060 def : Pat<(i32 (vector_extract v16i8:$S, 7)),
2061 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 7), $S), sub_32))>;
2062 def : Pat<(i32 (vector_extract v16i8:$S, 8)),
2063 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 8), $S), sub_32))>;
2064 def : Pat<(i32 (vector_extract v16i8:$S, 9)),
2065 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 9), $S), sub_32))>;
2066 def : Pat<(i32 (vector_extract v16i8:$S, 10)),
2067 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 10), $S), sub_32))>;
2068 def : Pat<(i32 (vector_extract v16i8:$S, 11)),
2069 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 11), $S), sub_32))>;
2070 def : Pat<(i32 (vector_extract v16i8:$S, 12)),
2071 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 12), $S), sub_32))>;
2072 def : Pat<(i32 (vector_extract v16i8:$S, 13)),
2073 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 13), $S), sub_32))>;
2074 def : Pat<(i32 (vector_extract v16i8:$S, 14)),
2075 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 14), $S), sub_32))>;
2076 def : Pat<(i32 (vector_extract v16i8:$S, 15)),
2077 (i32 (EXTRACT_SUBREG (VEXTUBRX (LI8 15), $S), sub_32))>;
2078
2079 def : Pat<(i32 (vector_extract v8i16:$S, i64:$Idx)),
2080 (i32 (EXTRACT_SUBREG (VEXTUHRX
2081 (RLWINM8 $Idx, 1, 28, 30), $S), sub_32))>;
2082 def : Pat<(i32 (vector_extract v8i16:$S, 0)),
2083 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 0), $S), sub_32))>;
2084 def : Pat<(i32 (vector_extract v8i16:$S, 1)),
2085 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 2), $S), sub_32))>;
2086 def : Pat<(i32 (vector_extract v8i16:$S, 2)),
2087 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 4), $S), sub_32))>;
2088 def : Pat<(i32 (vector_extract v8i16:$S, 3)),
2089 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 6), $S), sub_32))>;
2090 def : Pat<(i32 (vector_extract v8i16:$S, 4)),
2091 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 8), $S), sub_32))>;
2092 def : Pat<(i32 (vector_extract v8i16:$S, 5)),
2093 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 10), $S), sub_32))>;
2094 def : Pat<(i32 (vector_extract v8i16:$S, 6)),
2095 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 12), $S), sub_32))>;
2096 def : Pat<(i32 (vector_extract v8i16:$S, 6)),
2097 (i32 (EXTRACT_SUBREG (VEXTUHRX (LI8 14), $S), sub_32))>;
2098
2099 def : Pat<(i32 (vector_extract v4i32:$S, i64:$Idx)),
2100 (i32 (EXTRACT_SUBREG (VEXTUWRX
2101 (RLWINM8 $Idx, 2, 28, 29), $S), sub_32))>;
2102 def : Pat<(i32 (vector_extract v4i32:$S, 0)),
2103 (i32 (EXTRACT_SUBREG (VEXTUWRX (LI8 0), $S), sub_32))>;
2104 def : Pat<(i32 (vector_extract v4i32:$S, 1)),
2105 (i32 (EXTRACT_SUBREG (VEXTUWRX (LI8 4), $S), sub_32))>;
2106 // For extracting LE word 2, MFVSRWZ is better than VEXTUWRX
2107 def : Pat<(i32 (vector_extract v4i32:$S, 2)),
2108 (i32 VectorExtractions.LE_WORD_2)>;
2109 def : Pat<(i32 (vector_extract v4i32:$S, 3)),
2110 (i32 (EXTRACT_SUBREG (VEXTUWRX (LI8 12), $S), sub_32))>;
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002111}
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002112
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002113let Predicates = [HasP9Altivec, IsBigEndian] in {
2114 def : Pat<(i64 (anyext (i32 (vector_extract v16i8:$S, i64:$Idx)))),
2115 (VEXTUBLX $Idx, $S)>;
2116
2117 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, i64:$Idx)))),
2118 (VEXTUHLX (RLWINM8 $Idx, 1, 28, 30), $S)>;
2119 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 0)))),
2120 (VEXTUHLX (LI8 0), $S)>;
2121 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 1)))),
2122 (VEXTUHLX (LI8 2), $S)>;
2123 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 2)))),
2124 (VEXTUHLX (LI8 4), $S)>;
2125 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 3)))),
2126 (VEXTUHLX (LI8 6), $S)>;
2127 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 4)))),
2128 (VEXTUHLX (LI8 8), $S)>;
2129 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 5)))),
2130 (VEXTUHLX (LI8 10), $S)>;
2131 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 6)))),
2132 (VEXTUHLX (LI8 12), $S)>;
2133 def : Pat<(i64 (anyext (i32 (vector_extract v8i16:$S, 7)))),
2134 (VEXTUHLX (LI8 14), $S)>;
2135
2136 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, i64:$Idx)))),
2137 (VEXTUWLX (RLWINM8 $Idx, 2, 28, 29), $S)>;
2138 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 0)))),
2139 (VEXTUWLX (LI8 0), $S)>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002140
2141 // For extracting BE word 1, MFVSRWZ is better than VEXTUWLX
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002142 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 1)))),
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002143 (INSERT_SUBREG (i64 (IMPLICIT_DEF)),
2144 (i32 VectorExtractions.LE_WORD_2), sub_32)>;
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002145 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 2)))),
2146 (VEXTUWLX (LI8 8), $S)>;
2147 def : Pat<(i64 (zext (i32 (vector_extract v4i32:$S, 3)))),
2148 (VEXTUWLX (LI8 12), $S)>;
2149
2150 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, i64:$Idx)))),
2151 (EXTSW (VEXTUWLX (RLWINM8 $Idx, 2, 28, 29), $S))>;
2152 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 0)))),
2153 (EXTSW (VEXTUWLX (LI8 0), $S))>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002154 // For extracting BE word 1, MFVSRWZ is better than VEXTUWLX
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002155 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 1)))),
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002156 (EXTSW (INSERT_SUBREG (i64 (IMPLICIT_DEF)),
2157 (i32 VectorExtractions.LE_WORD_2), sub_32))>;
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002158 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 2)))),
2159 (EXTSW (VEXTUWLX (LI8 8), $S))>;
2160 def : Pat<(i64 (sext (i32 (vector_extract v4i32:$S, 3)))),
2161 (EXTSW (VEXTUWLX (LI8 12), $S))>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002162
2163 def : Pat<(i32 (vector_extract v16i8:$S, i64:$Idx)),
2164 (i32 (EXTRACT_SUBREG (VEXTUBLX $Idx, $S), sub_32))>;
2165 def : Pat<(i32 (vector_extract v16i8:$S, 0)),
2166 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 0), $S), sub_32))>;
2167 def : Pat<(i32 (vector_extract v16i8:$S, 1)),
2168 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 1), $S), sub_32))>;
2169 def : Pat<(i32 (vector_extract v16i8:$S, 2)),
2170 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 2), $S), sub_32))>;
2171 def : Pat<(i32 (vector_extract v16i8:$S, 3)),
2172 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 3), $S), sub_32))>;
2173 def : Pat<(i32 (vector_extract v16i8:$S, 4)),
2174 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 4), $S), sub_32))>;
2175 def : Pat<(i32 (vector_extract v16i8:$S, 5)),
2176 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 5), $S), sub_32))>;
2177 def : Pat<(i32 (vector_extract v16i8:$S, 6)),
2178 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 6), $S), sub_32))>;
2179 def : Pat<(i32 (vector_extract v16i8:$S, 7)),
2180 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 7), $S), sub_32))>;
2181 def : Pat<(i32 (vector_extract v16i8:$S, 8)),
2182 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 8), $S), sub_32))>;
2183 def : Pat<(i32 (vector_extract v16i8:$S, 9)),
2184 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 9), $S), sub_32))>;
2185 def : Pat<(i32 (vector_extract v16i8:$S, 10)),
2186 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 10), $S), sub_32))>;
2187 def : Pat<(i32 (vector_extract v16i8:$S, 11)),
2188 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 11), $S), sub_32))>;
2189 def : Pat<(i32 (vector_extract v16i8:$S, 12)),
2190 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 12), $S), sub_32))>;
2191 def : Pat<(i32 (vector_extract v16i8:$S, 13)),
2192 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 13), $S), sub_32))>;
2193 def : Pat<(i32 (vector_extract v16i8:$S, 14)),
2194 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 14), $S), sub_32))>;
2195 def : Pat<(i32 (vector_extract v16i8:$S, 15)),
2196 (i32 (EXTRACT_SUBREG (VEXTUBLX (LI8 15), $S), sub_32))>;
2197
2198 def : Pat<(i32 (vector_extract v8i16:$S, i64:$Idx)),
2199 (i32 (EXTRACT_SUBREG (VEXTUHLX
2200 (RLWINM8 $Idx, 1, 28, 30), $S), sub_32))>;
2201 def : Pat<(i32 (vector_extract v8i16:$S, 0)),
2202 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 0), $S), sub_32))>;
2203 def : Pat<(i32 (vector_extract v8i16:$S, 1)),
2204 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 2), $S), sub_32))>;
2205 def : Pat<(i32 (vector_extract v8i16:$S, 2)),
2206 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 4), $S), sub_32))>;
2207 def : Pat<(i32 (vector_extract v8i16:$S, 3)),
2208 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 6), $S), sub_32))>;
2209 def : Pat<(i32 (vector_extract v8i16:$S, 4)),
2210 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 8), $S), sub_32))>;
2211 def : Pat<(i32 (vector_extract v8i16:$S, 5)),
2212 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 10), $S), sub_32))>;
2213 def : Pat<(i32 (vector_extract v8i16:$S, 6)),
2214 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 12), $S), sub_32))>;
2215 def : Pat<(i32 (vector_extract v8i16:$S, 6)),
2216 (i32 (EXTRACT_SUBREG (VEXTUHLX (LI8 14), $S), sub_32))>;
2217
2218 def : Pat<(i32 (vector_extract v4i32:$S, i64:$Idx)),
2219 (i32 (EXTRACT_SUBREG (VEXTUWLX
2220 (RLWINM8 $Idx, 2, 28, 29), $S), sub_32))>;
2221 def : Pat<(i32 (vector_extract v4i32:$S, 0)),
2222 (i32 (EXTRACT_SUBREG (VEXTUWLX (LI8 0), $S), sub_32))>;
2223 // For extracting BE word 1, MFVSRWZ is better than VEXTUWLX
2224 def : Pat<(i32 (vector_extract v4i32:$S, 1)),
2225 (i32 VectorExtractions.LE_WORD_2)>;
2226 def : Pat<(i32 (vector_extract v4i32:$S, 2)),
2227 (i32 (EXTRACT_SUBREG (VEXTUWLX (LI8 8), $S), sub_32))>;
2228 def : Pat<(i32 (vector_extract v4i32:$S, 3)),
2229 (i32 (EXTRACT_SUBREG (VEXTUWLX (LI8 12), $S), sub_32))>;
Tony Jiangaa5a6a12017-07-05 16:55:00 +00002230}
2231
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00002232let Predicates = [IsLittleEndian, HasDirectMove] in {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002233 // v16i8 scalar <-> vector conversions (LE)
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00002234 def : Pat<(v16i8 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002235 (v16i8 (COPY_TO_REGCLASS MovesToVSR.LE_WORD_0, VSRC))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00002236 def : Pat<(v8i16 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002237 (v8i16 (COPY_TO_REGCLASS MovesToVSR.LE_WORD_0, VSRC))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00002238 def : Pat<(v4i32 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002239 (v4i32 MovesToVSR.LE_WORD_0)>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00002240 def : Pat<(v2i64 (scalar_to_vector i64:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002241 (v2i64 MovesToVSR.LE_DWORD_0)>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002242 // v2i64 scalar <-> vector conversions (LE)
2243 def : Pat<(i64 (vector_extract v2i64:$S, 0)),
2244 (i64 VectorExtractions.LE_DWORD_0)>;
2245 def : Pat<(i64 (vector_extract v2i64:$S, 1)),
2246 (i64 VectorExtractions.LE_DWORD_1)>;
2247 def : Pat<(i64 (vector_extract v2i64:$S, i64:$Idx)),
2248 (i64 VectorExtractions.LE_VARIABLE_DWORD)>;
2249} // IsLittleEndian, HasDirectMove
2250
2251let Predicates = [IsLittleEndian, HasDirectMove, NoP9Altivec] in {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002252 def : Pat<(i32 (vector_extract v16i8:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002253 (i32 VectorExtractions.LE_BYTE_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002254 def : Pat<(i32 (vector_extract v16i8:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002255 (i32 VectorExtractions.LE_BYTE_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002256 def : Pat<(i32 (vector_extract v16i8:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002257 (i32 VectorExtractions.LE_BYTE_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002258 def : Pat<(i32 (vector_extract v16i8:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002259 (i32 VectorExtractions.LE_BYTE_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002260 def : Pat<(i32 (vector_extract v16i8:$S, 4)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002261 (i32 VectorExtractions.LE_BYTE_4)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002262 def : Pat<(i32 (vector_extract v16i8:$S, 5)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002263 (i32 VectorExtractions.LE_BYTE_5)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002264 def : Pat<(i32 (vector_extract v16i8:$S, 6)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002265 (i32 VectorExtractions.LE_BYTE_6)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002266 def : Pat<(i32 (vector_extract v16i8:$S, 7)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002267 (i32 VectorExtractions.LE_BYTE_7)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002268 def : Pat<(i32 (vector_extract v16i8:$S, 8)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002269 (i32 VectorExtractions.LE_BYTE_8)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002270 def : Pat<(i32 (vector_extract v16i8:$S, 9)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002271 (i32 VectorExtractions.LE_BYTE_9)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002272 def : Pat<(i32 (vector_extract v16i8:$S, 10)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002273 (i32 VectorExtractions.LE_BYTE_10)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002274 def : Pat<(i32 (vector_extract v16i8:$S, 11)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002275 (i32 VectorExtractions.LE_BYTE_11)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002276 def : Pat<(i32 (vector_extract v16i8:$S, 12)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002277 (i32 VectorExtractions.LE_BYTE_12)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002278 def : Pat<(i32 (vector_extract v16i8:$S, 13)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002279 (i32 VectorExtractions.LE_BYTE_13)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002280 def : Pat<(i32 (vector_extract v16i8:$S, 14)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002281 (i32 VectorExtractions.LE_BYTE_14)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002282 def : Pat<(i32 (vector_extract v16i8:$S, 15)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002283 (i32 VectorExtractions.LE_BYTE_15)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002284 def : Pat<(i32 (vector_extract v16i8:$S, i64:$Idx)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002285 (i32 VectorExtractions.LE_VARIABLE_BYTE)>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00002286
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002287 // v8i16 scalar <-> vector conversions (LE)
2288 def : Pat<(i32 (vector_extract v8i16:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002289 (i32 VectorExtractions.LE_HALF_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002290 def : Pat<(i32 (vector_extract v8i16:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002291 (i32 VectorExtractions.LE_HALF_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002292 def : Pat<(i32 (vector_extract v8i16:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002293 (i32 VectorExtractions.LE_HALF_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002294 def : Pat<(i32 (vector_extract v8i16:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002295 (i32 VectorExtractions.LE_HALF_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002296 def : Pat<(i32 (vector_extract v8i16:$S, 4)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002297 (i32 VectorExtractions.LE_HALF_4)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002298 def : Pat<(i32 (vector_extract v8i16:$S, 5)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002299 (i32 VectorExtractions.LE_HALF_5)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002300 def : Pat<(i32 (vector_extract v8i16:$S, 6)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002301 (i32 VectorExtractions.LE_HALF_6)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002302 def : Pat<(i32 (vector_extract v8i16:$S, 7)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002303 (i32 VectorExtractions.LE_HALF_7)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002304 def : Pat<(i32 (vector_extract v8i16:$S, i64:$Idx)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002305 (i32 VectorExtractions.LE_VARIABLE_HALF)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002306
2307 // v4i32 scalar <-> vector conversions (LE)
2308 def : Pat<(i32 (vector_extract v4i32:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002309 (i32 VectorExtractions.LE_WORD_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002310 def : Pat<(i32 (vector_extract v4i32:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002311 (i32 VectorExtractions.LE_WORD_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002312 def : Pat<(i32 (vector_extract v4i32:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002313 (i32 VectorExtractions.LE_WORD_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00002314 def : Pat<(i32 (vector_extract v4i32:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00002315 (i32 VectorExtractions.LE_WORD_3)>;
2316 def : Pat<(i32 (vector_extract v4i32:$S, i64:$Idx)),
2317 (i32 VectorExtractions.LE_VARIABLE_WORD)>;
Zaara Syeda48cb3c12017-11-27 17:11:03 +00002318} // IsLittleEndian, HasDirectMove, NoP9Altivec
Nemanja Ivanovic89224762015-12-15 14:50:34 +00002319
2320let Predicates = [HasDirectMove, HasVSX] in {
2321// bitconvert f32 -> i32
2322// (convert to 32-bit fp single, shift right 1 word, move to GPR)
2323def : Pat<(i32 (bitconvert f32:$S)),
2324 (i32 (MFVSRWZ (EXTRACT_SUBREG
Lei Huangcd4f3852018-03-12 19:26:18 +00002325 (XXSLDWI (XSCVDPSPN $S), (XSCVDPSPN $S), 3),
Nemanja Ivanovic89224762015-12-15 14:50:34 +00002326 sub_64)))>;
2327// bitconvert i32 -> f32
2328// (move to FPR, shift left 1 word, convert to 64-bit fp single)
2329def : Pat<(f32 (bitconvert i32:$A)),
2330 (f32 (XSCVSPDPN
2331 (XXSLDWI MovesToVSR.LE_WORD_1, MovesToVSR.LE_WORD_1, 1)))>;
2332
2333// bitconvert f64 -> i64
2334// (move to GPR, nothing else needed)
2335def : Pat<(i64 (bitconvert f64:$S)),
2336 (i64 (MFVSRD $S))>;
2337
2338// bitconvert i64 -> f64
2339// (move to FPR, nothing else needed)
2340def : Pat<(f64 (bitconvert i64:$S)),
2341 (f64 (MTVSRD $S))>;
2342}
Kit Barton93612ec2016-02-26 21:11:55 +00002343
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00002344// Materialize a zero-vector of long long
2345def : Pat<(v2i64 immAllZerosV),
2346 (v2i64 (XXLXORz))>;
2347}
2348
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002349def AlignValues {
2350 dag F32_TO_BE_WORD1 = (v4f32 (XXSLDWI (XSCVDPSPN $B), (XSCVDPSPN $B), 3));
2351 dag I32_TO_BE_WORD1 = (COPY_TO_REGCLASS (MTVSRWZ $B), VSRC);
2352}
2353
Kit Barton93612ec2016-02-26 21:11:55 +00002354// The following VSX instructions were introduced in Power ISA 3.0
2355def HasP9Vector : Predicate<"PPCSubTarget->hasP9Vector()">;
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002356let AddedComplexity = 400, Predicates = [HasP9Vector] in {
Kit Barton93612ec2016-02-26 21:11:55 +00002357
2358 // [PO VRT XO VRB XO /]
2359 class X_VT5_XO5_VB5<bits<6> opcode, bits<5> xo2, bits<10> xo, string opc,
2360 list<dag> pattern>
2361 : X_RD5_XO5_RS5<opcode, xo2, xo, (outs vrrc:$vT), (ins vrrc:$vB),
2362 !strconcat(opc, " $vT, $vB"), IIC_VecFP, pattern>;
2363
2364 // [PO VRT XO VRB XO RO], Round to Odd version of [PO VRT XO VRB XO /]
2365 class X_VT5_XO5_VB5_Ro<bits<6> opcode, bits<5> xo2, bits<10> xo, string opc,
2366 list<dag> pattern>
2367 : X_VT5_XO5_VB5<opcode, xo2, xo, opc, pattern>, isDOT;
2368
2369 // [PO VRT XO VRB XO /], but the VRB is only used the left 64 bits (or less),
2370 // So we use different operand class for VRB
2371 class X_VT5_XO5_VB5_TyVB<bits<6> opcode, bits<5> xo2, bits<10> xo, string opc,
2372 RegisterOperand vbtype, list<dag> pattern>
2373 : X_RD5_XO5_RS5<opcode, xo2, xo, (outs vrrc:$vT), (ins vbtype:$vB),
2374 !strconcat(opc, " $vT, $vB"), IIC_VecFP, pattern>;
2375
Lei Huang6270ab62018-07-04 21:59:16 +00002376 // [PO VRT XO VRB XO /]
2377 class X_VT5_XO5_VB5_VSFR<bits<6> opcode, bits<5> xo2, bits<10> xo, string opc,
2378 list<dag> pattern>
2379 : X_RD5_XO5_RS5<opcode, xo2, xo, (outs vfrc:$vT), (ins vrrc:$vB),
2380 !strconcat(opc, " $vT, $vB"), IIC_VecFP, pattern>;
2381
2382 // [PO VRT XO VRB XO RO], Round to Odd version of [PO VRT XO VRB XO /]
2383 class X_VT5_XO5_VB5_VSFR_Ro<bits<6> opcode, bits<5> xo2, bits<10> xo, string opc,
2384 list<dag> pattern>
2385 : X_VT5_XO5_VB5_VSFR<opcode, xo2, xo, opc, pattern>, isDOT;
2386
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002387 let UseVSXReg = 1 in {
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002388 // [PO T XO B XO BX /]
2389 class XX2_RT5_XO5_XB6<bits<6> opcode, bits<5> xo2, bits<9> xo, string opc,
2390 list<dag> pattern>
2391 : XX2_RD5_XO5_RS6<opcode, xo2, xo, (outs g8rc:$rT), (ins vsfrc:$XB),
2392 !strconcat(opc, " $rT, $XB"), IIC_VecFP, pattern>;
2393
Kit Barton93612ec2016-02-26 21:11:55 +00002394 // [PO T XO B XO BX TX]
2395 class XX2_XT6_XO5_XB6<bits<6> opcode, bits<5> xo2, bits<9> xo, string opc,
2396 RegisterOperand vtype, list<dag> pattern>
2397 : XX2_RD6_XO5_RS6<opcode, xo2, xo, (outs vtype:$XT), (ins vtype:$XB),
2398 !strconcat(opc, " $XT, $XB"), IIC_VecFP, pattern>;
2399
2400 // [PO T A B XO AX BX TX], src and dest register use different operand class
2401 class XX3_XT5_XA5_XB5<bits<6> opcode, bits<8> xo, string opc,
2402 RegisterOperand xty, RegisterOperand aty, RegisterOperand bty,
2403 InstrItinClass itin, list<dag> pattern>
2404 : XX3Form<opcode, xo, (outs xty:$XT), (ins aty:$XA, bty:$XB),
2405 !strconcat(opc, " $XT, $XA, $XB"), itin, pattern>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002406 } // UseVSXReg = 1
Kit Barton93612ec2016-02-26 21:11:55 +00002407
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002408 // [PO VRT VRA VRB XO /]
2409 class X_VT5_VA5_VB5<bits<6> opcode, bits<10> xo, string opc,
2410 list<dag> pattern>
2411 : XForm_1<opcode, xo, (outs vrrc:$vT), (ins vrrc:$vA, vrrc:$vB),
2412 !strconcat(opc, " $vT, $vA, $vB"), IIC_VecFP, pattern>;
2413
2414 // [PO VRT VRA VRB XO RO], Round to Odd version of [PO VRT VRA VRB XO /]
2415 class X_VT5_VA5_VB5_Ro<bits<6> opcode, bits<10> xo, string opc,
2416 list<dag> pattern>
2417 : X_VT5_VA5_VB5<opcode, xo, opc, pattern>, isDOT;
2418
Lei Huang09fda632018-04-04 16:43:50 +00002419 // [PO VRT VRA VRB XO /]
2420 class X_VT5_VA5_VB5_FMA<bits<6> opcode, bits<10> xo, string opc,
2421 list<dag> pattern>
2422 : XForm_1<opcode, xo, (outs vrrc:$vT), (ins vrrc:$vTi, vrrc:$vA, vrrc:$vB),
2423 !strconcat(opc, " $vT, $vA, $vB"), IIC_VecFP, pattern>,
2424 RegConstraint<"$vTi = $vT">, NoEncode<"$vTi">;
2425
2426 // [PO VRT VRA VRB XO RO], Round to Odd version of [PO VRT VRA VRB XO /]
2427 class X_VT5_VA5_VB5_FMA_Ro<bits<6> opcode, bits<10> xo, string opc,
2428 list<dag> pattern>
2429 : X_VT5_VA5_VB5_FMA<opcode, xo, opc, pattern>, isDOT;
2430
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002431 //===--------------------------------------------------------------------===//
2432 // Quad-Precision Scalar Move Instructions:
2433
2434 // Copy Sign
Lei Huangecfede92018-03-19 19:22:52 +00002435 def XSCPSGNQP : X_VT5_VA5_VB5<63, 100, "xscpsgnqp",
2436 [(set f128:$vT,
2437 (fcopysign f128:$vB, f128:$vA))]>;
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002438
2439 // Absolute/Negative-Absolute/Negate
Lei Huangecfede92018-03-19 19:22:52 +00002440 def XSABSQP : X_VT5_XO5_VB5<63, 0, 804, "xsabsqp",
2441 [(set f128:$vT, (fabs f128:$vB))]>;
2442 def XSNABSQP : X_VT5_XO5_VB5<63, 8, 804, "xsnabsqp",
2443 [(set f128:$vT, (fneg (fabs f128:$vB)))]>;
2444 def XSNEGQP : X_VT5_XO5_VB5<63, 16, 804, "xsnegqp",
2445 [(set f128:$vT, (fneg f128:$vB))]>;
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002446
2447 //===--------------------------------------------------------------------===//
2448 // Quad-Precision Scalar Floating-Point Arithmetic Instructions:
2449
2450 // Add/Divide/Multiply/Subtract
Lei Huang6d1596a2018-03-19 18:52:20 +00002451 let isCommutable = 1 in {
2452 def XSADDQP : X_VT5_VA5_VB5 <63, 4, "xsaddqp",
2453 [(set f128:$vT, (fadd f128:$vA, f128:$vB))]>;
Stefan Pintilie83a5fe12018-07-09 18:50:06 +00002454 def XSADDQPO : X_VT5_VA5_VB5_Ro<63, 4, "xsaddqpo",
2455 [(set f128:$vT,
2456 (int_ppc_addf128_round_to_odd
2457 f128:$vA, f128:$vB))]>;
Lei Huang6d1596a2018-03-19 18:52:20 +00002458 def XSMULQP : X_VT5_VA5_VB5 <63, 36, "xsmulqp",
2459 [(set f128:$vT, (fmul f128:$vA, f128:$vB))]>;
Stefan Pintilie83a5fe12018-07-09 18:50:06 +00002460 def XSMULQPO : X_VT5_VA5_VB5_Ro<63, 36, "xsmulqpo",
2461 [(set f128:$vT,
2462 (int_ppc_mulf128_round_to_odd
2463 f128:$vA, f128:$vB))]>;
Lei Huang6d1596a2018-03-19 18:52:20 +00002464 }
2465
2466 def XSSUBQP : X_VT5_VA5_VB5 <63, 516, "xssubqp" ,
2467 [(set f128:$vT, (fsub f128:$vA, f128:$vB))]>;
Stefan Pintilie83a5fe12018-07-09 18:50:06 +00002468 def XSSUBQPO : X_VT5_VA5_VB5_Ro<63, 516, "xssubqpo",
2469 [(set f128:$vT,
2470 (int_ppc_subf128_round_to_odd
2471 f128:$vA, f128:$vB))]>;
Lei Huang6d1596a2018-03-19 18:52:20 +00002472 def XSDIVQP : X_VT5_VA5_VB5 <63, 548, "xsdivqp",
2473 [(set f128:$vT, (fdiv f128:$vA, f128:$vB))]>;
Stefan Pintilie83a5fe12018-07-09 18:50:06 +00002474 def XSDIVQPO : X_VT5_VA5_VB5_Ro<63, 548, "xsdivqpo",
2475 [(set f128:$vT,
2476 (int_ppc_divf128_round_to_odd
2477 f128:$vA, f128:$vB))]>;
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002478
2479 // Square-Root
Lei Huangecfede92018-03-19 19:22:52 +00002480 def XSSQRTQP : X_VT5_XO5_VB5 <63, 27, 804, "xssqrtqp",
2481 [(set f128:$vT, (fsqrt f128:$vB))]>;
Stefan Pintilie83a5fe12018-07-09 18:50:06 +00002482 def XSSQRTQPO : X_VT5_XO5_VB5_Ro<63, 27, 804, "xssqrtqpo",
2483 [(set f128:$vT,
2484 (int_ppc_sqrtf128_round_to_odd f128:$vB))]>;
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002485
2486 // (Negative) Multiply-{Add/Subtract}
Lei Huang09fda632018-04-04 16:43:50 +00002487 def XSMADDQP : X_VT5_VA5_VB5_FMA <63, 388, "xsmaddqp",
2488 [(set f128:$vT,
2489 (fma f128:$vA, f128:$vB,
2490 f128:$vTi))]>;
Stefan Pintilie83a5fe12018-07-09 18:50:06 +00002491
2492 def XSMADDQPO : X_VT5_VA5_VB5_FMA_Ro<63, 388, "xsmaddqpo",
2493 [(set f128:$vT,
2494 (int_ppc_fmaf128_round_to_odd
2495 f128:$vA,f128:$vB,f128:$vTi))]>;
2496
Lei Huang09fda632018-04-04 16:43:50 +00002497 def XSMSUBQP : X_VT5_VA5_VB5_FMA <63, 420, "xsmsubqp" ,
2498 [(set f128:$vT,
2499 (fma f128:$vA, f128:$vB,
2500 (fneg f128:$vTi)))]>;
Stefan Pintilieb9d01aa2018-07-11 01:42:22 +00002501 def XSMSUBQPO : X_VT5_VA5_VB5_FMA_Ro<63, 420, "xsmsubqpo" ,
2502 [(set f128:$vT,
2503 (int_ppc_fmaf128_round_to_odd
2504 f128:$vA, f128:$vB, (fneg f128:$vTi)))]>;
Lei Huang09fda632018-04-04 16:43:50 +00002505 def XSNMADDQP : X_VT5_VA5_VB5_FMA <63, 452, "xsnmaddqp",
2506 [(set f128:$vT,
2507 (fneg (fma f128:$vA, f128:$vB,
2508 f128:$vTi)))]>;
Stefan Pintilieb9d01aa2018-07-11 01:42:22 +00002509 def XSNMADDQPO: X_VT5_VA5_VB5_FMA_Ro<63, 452, "xsnmaddqpo",
2510 [(set f128:$vT,
2511 (fneg (int_ppc_fmaf128_round_to_odd
2512 f128:$vA, f128:$vB, f128:$vTi)))]>;
Lei Huang09fda632018-04-04 16:43:50 +00002513 def XSNMSUBQP : X_VT5_VA5_VB5_FMA <63, 484, "xsnmsubqp",
2514 [(set f128:$vT,
2515 (fneg (fma f128:$vA, f128:$vB,
2516 (fneg f128:$vTi))))]>;
Stefan Pintilieb9d01aa2018-07-11 01:42:22 +00002517 def XSNMSUBQPO: X_VT5_VA5_VB5_FMA_Ro<63, 484, "xsnmsubqpo",
2518 [(set f128:$vT,
2519 (fneg (int_ppc_fmaf128_round_to_odd
2520 f128:$vA, f128:$vB, (fneg f128:$vTi))))]>;
Lei Huang09fda632018-04-04 16:43:50 +00002521
2522 // Additional fnmsub patterns: -a*c + b == -(a*c - b)
2523 def : Pat<(fma (fneg f128:$A), f128:$C, f128:$B), (XSNMSUBQP $B, $C, $A)>;
2524 def : Pat<(fma f128:$A, (fneg f128:$C), f128:$B), (XSNMSUBQP $B, $C, $A)>;
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002525
Kit Barton93612ec2016-02-26 21:11:55 +00002526 //===--------------------------------------------------------------------===//
2527 // Quad/Double-Precision Compare Instructions:
2528
2529 // [PO BF // VRA VRB XO /]
2530 class X_BF3_VA5_VB5<bits<6> opcode, bits<10> xo, string opc,
2531 list<dag> pattern>
2532 : XForm_17<opcode, xo, (outs crrc:$crD), (ins vrrc:$VA, vrrc:$VB),
2533 !strconcat(opc, " $crD, $VA, $VB"), IIC_FPCompare> {
2534 let Pattern = pattern;
2535 }
2536
2537 // QP Compare Ordered/Unordered
2538 def XSCMPOQP : X_BF3_VA5_VB5<63, 132, "xscmpoqp", []>;
2539 def XSCMPUQP : X_BF3_VA5_VB5<63, 644, "xscmpuqp", []>;
2540
2541 // DP/QP Compare Exponents
2542 def XSCMPEXPDP : XX3Form_1<60, 59,
2543 (outs crrc:$crD), (ins vsfrc:$XA, vsfrc:$XB),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002544 "xscmpexpdp $crD, $XA, $XB", IIC_FPCompare, []>,
2545 UseVSXReg;
Kit Barton93612ec2016-02-26 21:11:55 +00002546 def XSCMPEXPQP : X_BF3_VA5_VB5<63, 164, "xscmpexpqp", []>;
2547
2548 // DP Compare ==, >=, >, !=
2549 // Use vsrc for XT, because the entire register of XT is set.
2550 // XT.dword[1] = 0x0000_0000_0000_0000
2551 def XSCMPEQDP : XX3_XT5_XA5_XB5<60, 3, "xscmpeqdp", vsrc, vsfrc, vsfrc,
2552 IIC_FPCompare, []>;
2553 def XSCMPGEDP : XX3_XT5_XA5_XB5<60, 19, "xscmpgedp", vsrc, vsfrc, vsfrc,
2554 IIC_FPCompare, []>;
2555 def XSCMPGTDP : XX3_XT5_XA5_XB5<60, 11, "xscmpgtdp", vsrc, vsfrc, vsfrc,
2556 IIC_FPCompare, []>;
Kit Barton93612ec2016-02-26 21:11:55 +00002557
2558 //===--------------------------------------------------------------------===//
2559 // Quad-Precision Floating-Point Conversion Instructions:
2560
2561 // Convert DP -> QP
Lei Huangd17c39c2018-07-05 04:18:37 +00002562 def XSCVDPQP : X_VT5_XO5_VB5_TyVB<63, 22, 836, "xscvdpqp", vfrc,
2563 [(set f128:$vT, (fpextend f64:$vB))]>;
Kit Barton93612ec2016-02-26 21:11:55 +00002564
2565 // Round & Convert QP -> DP (dword[1] is set to zero)
Lei Huang6270ab62018-07-04 21:59:16 +00002566 def XSCVQPDP : X_VT5_XO5_VB5_VSFR<63, 20, 836, "xscvqpdp" , []>;
Stefan Pintilie58e3e0a2018-07-09 20:09:22 +00002567 def XSCVQPDPO : X_VT5_XO5_VB5_VSFR_Ro<63, 20, 836, "xscvqpdpo",
2568 [(set f64:$vT,
2569 (int_ppc_truncf128_round_to_odd
2570 f128:$vB))]>;
Kit Barton93612ec2016-02-26 21:11:55 +00002571
2572 // Truncate & Convert QP -> (Un)Signed (D)Word (dword[1] is set to zero)
2573 def XSCVQPSDZ : X_VT5_XO5_VB5<63, 25, 836, "xscvqpsdz", []>;
2574 def XSCVQPSWZ : X_VT5_XO5_VB5<63, 9, 836, "xscvqpswz", []>;
2575 def XSCVQPUDZ : X_VT5_XO5_VB5<63, 17, 836, "xscvqpudz", []>;
2576 def XSCVQPUWZ : X_VT5_XO5_VB5<63, 1, 836, "xscvqpuwz", []>;
2577
Lei Huangc517e952018-05-08 18:23:31 +00002578 // Convert (Un)Signed DWord -> QP.
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002579 def XSCVSDQP : X_VT5_XO5_VB5_TyVB<63, 10, 836, "xscvsdqp", vfrc, []>;
Lei Huang10367eb2018-04-12 18:00:14 +00002580 def : Pat<(f128 (sint_to_fp i64:$src)),
2581 (f128 (XSCVSDQP (COPY_TO_REGCLASS $src, VFRC)))>;
Lei Huang66e22c22018-07-05 07:46:01 +00002582 def : Pat<(f128 (sint_to_fp (i64 (PPCmfvsr f64:$src)))),
2583 (f128 (XSCVSDQP $src))>;
2584 def : Pat<(f128 (sint_to_fp (i32 (PPCmfvsr f64:$src)))),
2585 (f128 (XSCVSDQP (VEXTSW2Ds $src)))>;
2586
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002587 def XSCVUDQP : X_VT5_XO5_VB5_TyVB<63, 2, 836, "xscvudqp", vfrc, []>;
Lei Huang10367eb2018-04-12 18:00:14 +00002588 def : Pat<(f128 (uint_to_fp i64:$src)),
2589 (f128 (XSCVUDQP (COPY_TO_REGCLASS $src, VFRC)))>;
Lei Huang66e22c22018-07-05 07:46:01 +00002590 def : Pat<(f128 (uint_to_fp (i64 (PPCmfvsr f64:$src)))),
2591 (f128 (XSCVUDQP $src))>;
Kit Barton93612ec2016-02-26 21:11:55 +00002592
Lei Huangc517e952018-05-08 18:23:31 +00002593 // Convert (Un)Signed Word -> QP.
Lei Huang198e6782018-04-18 16:34:22 +00002594 def : Pat<(f128 (sint_to_fp i32:$src)),
2595 (f128 (XSCVSDQP (MTVSRWA $src)))>;
2596 def : Pat<(f128 (sint_to_fp (i32 (load xoaddr:$src)))),
2597 (f128 (XSCVSDQP (LIWAX xoaddr:$src)))>;
2598 def : Pat<(f128 (uint_to_fp i32:$src)),
2599 (f128 (XSCVUDQP (MTVSRWZ $src)))>;
2600 def : Pat<(f128 (uint_to_fp (i32 (load xoaddr:$src)))),
2601 (f128 (XSCVUDQP (LIWZX xoaddr:$src)))>;
2602
Sean Fertilea435e072016-11-14 18:43:59 +00002603 let UseVSXReg = 1 in {
Kit Barton93612ec2016-02-26 21:11:55 +00002604 //===--------------------------------------------------------------------===//
2605 // Round to Floating-Point Integer Instructions
2606
2607 // (Round &) Convert DP <-> HP
2608 // Note! xscvdphp's src and dest register both use the left 64 bits, so we use
2609 // vsfrc for src and dest register. xscvhpdp's src only use the left 16 bits,
2610 // but we still use vsfrc for it.
2611 def XSCVDPHP : XX2_XT6_XO5_XB6<60, 17, 347, "xscvdphp", vsfrc, []>;
2612 def XSCVHPDP : XX2_XT6_XO5_XB6<60, 16, 347, "xscvhpdp", vsfrc, []>;
2613
2614 // Vector HP -> SP
2615 def XVCVHPSP : XX2_XT6_XO5_XB6<60, 24, 475, "xvcvhpsp", vsrc, []>;
Nemanja Ivanovicec4b0c32016-11-11 21:42:01 +00002616 def XVCVSPHP : XX2_XT6_XO5_XB6<60, 25, 475, "xvcvsphp", vsrc,
2617 [(set v4f32:$XT,
2618 (int_ppc_vsx_xvcvsphp v4f32:$XB))]>;
Kit Barton93612ec2016-02-26 21:11:55 +00002619
Sean Fertilea435e072016-11-14 18:43:59 +00002620 } // UseVSXReg = 1
2621
2622 // Pattern for matching Vector HP -> Vector SP intrinsic. Defined as a
Simon Pilgrim68168d12017-03-30 12:59:53 +00002623 // separate pattern so that it can convert the input register class from
Sean Fertilea435e072016-11-14 18:43:59 +00002624 // VRRC(v8i16) to VSRC.
2625 def : Pat<(v4f32 (int_ppc_vsx_xvcvhpsp v8i16:$A)),
2626 (v4f32 (XVCVHPSP (COPY_TO_REGCLASS $A, VSRC)))>;
2627
Kit Barton93612ec2016-02-26 21:11:55 +00002628 class Z23_VT5_R1_VB5_RMC2_EX1<bits<6> opcode, bits<8> xo, bit ex, string opc,
2629 list<dag> pattern>
Zaara Syeda421a5962018-05-14 15:45:15 +00002630 : Z23Form_8<opcode, xo,
Kit Barton93612ec2016-02-26 21:11:55 +00002631 (outs vrrc:$vT), (ins u1imm:$r, vrrc:$vB, u2imm:$rmc),
2632 !strconcat(opc, " $r, $vT, $vB, $rmc"), IIC_VecFP, pattern> {
2633 let RC = ex;
2634 }
2635
2636 // Round to Quad-Precision Integer [with Inexact]
2637 def XSRQPI : Z23_VT5_R1_VB5_RMC2_EX1<63, 5, 0, "xsrqpi" , []>;
2638 def XSRQPIX : Z23_VT5_R1_VB5_RMC2_EX1<63, 5, 1, "xsrqpix", []>;
2639
Stefan Pintilie133acb22018-07-09 20:38:40 +00002640 // Use current rounding mode
2641 def : Pat<(f128 (fnearbyint f128:$vB)), (f128 (XSRQPI 0, $vB, 3))>;
2642 // Round to nearest, ties away from zero
2643 def : Pat<(f128 (fround f128:$vB)), (f128 (XSRQPI 0, $vB, 0))>;
2644 // Round towards Zero
2645 def : Pat<(f128 (ftrunc f128:$vB)), (f128 (XSRQPI 1, $vB, 1))>;
2646 // Round towards +Inf
2647 def : Pat<(f128 (fceil f128:$vB)), (f128 (XSRQPI 1, $vB, 2))>;
2648 // Round towards -Inf
2649 def : Pat<(f128 (ffloor f128:$vB)), (f128 (XSRQPI 1, $vB, 3))>;
2650
2651 // Use current rounding mode, [with Inexact]
2652 def : Pat<(f128 (frint f128:$vB)), (f128 (XSRQPIX 0, $vB, 3))>;
2653
Kit Barton93612ec2016-02-26 21:11:55 +00002654 // Round Quad-Precision to Double-Extended Precision (fp80)
2655 def XSRQPXP : Z23_VT5_R1_VB5_RMC2_EX1<63, 37, 0, "xsrqpxp", []>;
Kit Bartonba532dc2016-03-08 03:49:13 +00002656
2657 //===--------------------------------------------------------------------===//
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002658 // Insert/Extract Instructions
2659
2660 // Insert Exponent DP/QP
2661 // XT NOTE: XT.dword[1] = 0xUUUU_UUUU_UUUU_UUUU
2662 def XSIEXPDP : XX1Form <60, 918, (outs vsrc:$XT), (ins g8rc:$rA, g8rc:$rB),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002663 "xsiexpdp $XT, $rA, $rB", IIC_VecFP, []>, UseVSXReg;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002664 // vB NOTE: only vB.dword[0] is used, that's why we don't use
2665 // X_VT5_VA5_VB5 form
2666 def XSIEXPQP : XForm_18<63, 868, (outs vrrc:$vT), (ins vrrc:$vA, vsfrc:$vB),
2667 "xsiexpqp $vT, $vA, $vB", IIC_VecFP, []>;
2668
2669 // Extract Exponent/Significand DP/QP
2670 def XSXEXPDP : XX2_RT5_XO5_XB6<60, 0, 347, "xsxexpdp", []>;
2671 def XSXSIGDP : XX2_RT5_XO5_XB6<60, 1, 347, "xsxsigdp", []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002672
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002673 def XSXEXPQP : X_VT5_XO5_VB5 <63, 2, 804, "xsxexpqp", []>;
2674 def XSXSIGQP : X_VT5_XO5_VB5 <63, 18, 804, "xsxsigqp", []>;
2675
2676 // Vector Insert Word
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002677 let UseVSXReg = 1 in {
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002678 // XB NOTE: Only XB.dword[1] is used, but we use vsrc on XB.
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002679 def XXINSERTW :
2680 XX2_RD6_UIM5_RS6<60, 181, (outs vsrc:$XT),
2681 (ins vsrc:$XTi, vsrc:$XB, u4imm:$UIM),
2682 "xxinsertw $XT, $XB, $UIM", IIC_VecFP,
Tony Jiang61ef1c52017-09-05 18:08:02 +00002683 [(set v4i32:$XT, (PPCvecinsert v4i32:$XTi, v4i32:$XB,
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002684 imm32SExt16:$UIM))]>,
2685 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002686
2687 // Vector Extract Unsigned Word
2688 def XXEXTRACTUW : XX2_RD6_UIM5_RS6<60, 165,
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002689 (outs vsfrc:$XT), (ins vsrc:$XB, u4imm:$UIMM),
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002690 "xxextractuw $XT, $XB, $UIMM", IIC_VecFP, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002691 } // UseVSXReg = 1
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002692
2693 // Vector Insert Exponent DP/SP
2694 def XVIEXPDP : XX3_XT5_XA5_XB5<60, 248, "xviexpdp", vsrc, vsrc, vsrc,
Nemanja Ivanovic0f459982016-10-26 19:03:40 +00002695 IIC_VecFP, [(set v2f64: $XT,(int_ppc_vsx_xviexpdp v2i64:$XA, v2i64:$XB))]>;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002696 def XVIEXPSP : XX3_XT5_XA5_XB5<60, 216, "xviexpsp", vsrc, vsrc, vsrc,
Nemanja Ivanovic0f459982016-10-26 19:03:40 +00002697 IIC_VecFP, [(set v4f32: $XT,(int_ppc_vsx_xviexpsp v4i32:$XA, v4i32:$XB))]>;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002698
2699 // Vector Extract Exponent/Significand DP/SP
Sean Fertileadda5b22016-11-14 14:42:37 +00002700 def XVXEXPDP : XX2_XT6_XO5_XB6<60, 0, 475, "xvxexpdp", vsrc,
2701 [(set v2i64: $XT,
2702 (int_ppc_vsx_xvxexpdp v2f64:$XB))]>;
2703 def XVXEXPSP : XX2_XT6_XO5_XB6<60, 8, 475, "xvxexpsp", vsrc,
2704 [(set v4i32: $XT,
2705 (int_ppc_vsx_xvxexpsp v4f32:$XB))]>;
2706 def XVXSIGDP : XX2_XT6_XO5_XB6<60, 1, 475, "xvxsigdp", vsrc,
2707 [(set v2i64: $XT,
2708 (int_ppc_vsx_xvxsigdp v2f64:$XB))]>;
2709 def XVXSIGSP : XX2_XT6_XO5_XB6<60, 9, 475, "xvxsigsp", vsrc,
2710 [(set v4i32: $XT,
2711 (int_ppc_vsx_xvxsigsp v4f32:$XB))]>;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002712
Sean Fertile1c4109b2016-12-09 17:21:42 +00002713 let AddedComplexity = 400, Predicates = [HasP9Vector] in {
2714 // Extra patterns expanding to vector Extract Word/Insert Word
2715 def : Pat<(v4i32 (int_ppc_vsx_xxinsertw v4i32:$A, v2i64:$B, imm:$IMM)),
2716 (v4i32 (XXINSERTW $A, $B, imm:$IMM))>;
2717 def : Pat<(v2i64 (int_ppc_vsx_xxextractuw v2i64:$A, imm:$IMM)),
2718 (v2i64 (COPY_TO_REGCLASS (XXEXTRACTUW $A, imm:$IMM), VSRC))>;
2719 } // AddedComplexity = 400, HasP9Vector
2720
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002721 //===--------------------------------------------------------------------===//
2722
2723 // Test Data Class SP/DP/QP
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002724 let UseVSXReg = 1 in {
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002725 def XSTSTDCSP : XX2_BF3_DCMX7_RS6<60, 298,
2726 (outs crrc:$BF), (ins u7imm:$DCMX, vsfrc:$XB),
2727 "xststdcsp $BF, $XB, $DCMX", IIC_VecFP, []>;
2728 def XSTSTDCDP : XX2_BF3_DCMX7_RS6<60, 362,
2729 (outs crrc:$BF), (ins u7imm:$DCMX, vsfrc:$XB),
2730 "xststdcdp $BF, $XB, $DCMX", IIC_VecFP, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002731 } // UseVSXReg = 1
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002732 def XSTSTDCQP : X_BF3_DCMX7_RS5 <63, 708,
2733 (outs crrc:$BF), (ins u7imm:$DCMX, vrrc:$vB),
2734 "xststdcqp $BF, $vB, $DCMX", IIC_VecFP, []>;
2735
2736 // Vector Test Data Class SP/DP
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002737 let UseVSXReg = 1 in {
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002738 def XVTSTDCSP : XX2_RD6_DCMX7_RS6<60, 13, 5,
2739 (outs vsrc:$XT), (ins u7imm:$DCMX, vsrc:$XB),
Sean Fertileadda5b22016-11-14 14:42:37 +00002740 "xvtstdcsp $XT, $XB, $DCMX", IIC_VecFP,
2741 [(set v4i32: $XT,
2742 (int_ppc_vsx_xvtstdcsp v4f32:$XB, imm:$DCMX))]>;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002743 def XVTSTDCDP : XX2_RD6_DCMX7_RS6<60, 15, 5,
2744 (outs vsrc:$XT), (ins u7imm:$DCMX, vsrc:$XB),
Sean Fertileadda5b22016-11-14 14:42:37 +00002745 "xvtstdcdp $XT, $XB, $DCMX", IIC_VecFP,
2746 [(set v2i64: $XT,
2747 (int_ppc_vsx_xvtstdcdp v2f64:$XB, imm:$DCMX))]>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002748 } // UseVSXReg = 1
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002749
2750 //===--------------------------------------------------------------------===//
2751
2752 // Maximum/Minimum Type-C/Type-J DP
2753 // XT.dword[1] = 0xUUUU_UUUU_UUUU_UUUU, so we use vsrc for XT
2754 def XSMAXCDP : XX3_XT5_XA5_XB5<60, 128, "xsmaxcdp", vsrc, vsfrc, vsfrc,
2755 IIC_VecFP, []>;
2756 def XSMAXJDP : XX3_XT5_XA5_XB5<60, 144, "xsmaxjdp", vsrc, vsfrc, vsfrc,
2757 IIC_VecFP, []>;
2758 def XSMINCDP : XX3_XT5_XA5_XB5<60, 136, "xsmincdp", vsrc, vsfrc, vsfrc,
2759 IIC_VecFP, []>;
2760 def XSMINJDP : XX3_XT5_XA5_XB5<60, 152, "xsminjdp", vsrc, vsfrc, vsfrc,
2761 IIC_VecFP, []>;
2762
2763 //===--------------------------------------------------------------------===//
2764
2765 // Vector Byte-Reverse H/W/D/Q Word
2766 def XXBRH : XX2_XT6_XO5_XB6<60, 7, 475, "xxbrh", vsrc, []>;
2767 def XXBRW : XX2_XT6_XO5_XB6<60, 15, 475, "xxbrw", vsrc, []>;
2768 def XXBRD : XX2_XT6_XO5_XB6<60, 23, 475, "xxbrd", vsrc, []>;
2769 def XXBRQ : XX2_XT6_XO5_XB6<60, 31, 475, "xxbrq", vsrc, []>;
2770
Tony Jiang1a8eec12017-06-12 18:24:36 +00002771 // Vector Reverse
2772 def : Pat<(v8i16 (PPCxxreverse v8i16 :$A)),
2773 (v8i16 (COPY_TO_REGCLASS (XXBRH (COPY_TO_REGCLASS $A, VSRC)), VRRC))>;
2774 def : Pat<(v4i32 (PPCxxreverse v4i32 :$A)),
2775 (v4i32 (XXBRW $A))>;
2776 def : Pat<(v2i64 (PPCxxreverse v2i64 :$A)),
2777 (v2i64 (XXBRD $A))>;
2778 def : Pat<(v1i128 (PPCxxreverse v1i128 :$A)),
2779 (v1i128 (COPY_TO_REGCLASS (XXBRQ (COPY_TO_REGCLASS $A, VSRC)), VRRC))>;
2780
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002781 // Vector Permute
2782 def XXPERM : XX3_XT5_XA5_XB5<60, 26, "xxperm" , vsrc, vsrc, vsrc,
2783 IIC_VecPerm, []>;
2784 def XXPERMR : XX3_XT5_XA5_XB5<60, 58, "xxpermr", vsrc, vsrc, vsrc,
2785 IIC_VecPerm, []>;
2786
2787 // Vector Splat Immediate Byte
2788 def XXSPLTIB : X_RD6_IMM8<60, 360, (outs vsrc:$XT), (ins u8imm:$IMM8),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002789 "xxspltib $XT, $IMM8", IIC_VecPerm, []>, UseVSXReg;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002790
2791 //===--------------------------------------------------------------------===//
Kit Bartonba532dc2016-03-08 03:49:13 +00002792 // Vector/Scalar Load/Store Instructions
2793
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00002794 // When adding new D-Form loads/stores, be sure to update the ImmToIdxMap in
2795 // PPCRegisterInfo::PPCRegisterInfo and maybe save yourself some debugging.
Sean Fertile3c8c3852017-01-26 18:59:15 +00002796 let mayLoad = 1, mayStore = 0 in {
Kit Bartonba532dc2016-03-08 03:49:13 +00002797 // Load Vector
2798 def LXV : DQ_RD6_RS5_DQ12<61, 1, (outs vsrc:$XT), (ins memrix16:$src),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002799 "lxv $XT, $src", IIC_LdStLFD, []>, UseVSXReg;
Kit Bartonba532dc2016-03-08 03:49:13 +00002800 // Load DWord
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002801 def LXSD : DSForm_1<57, 2, (outs vfrc:$vD), (ins memrix:$src),
Kit Bartonba532dc2016-03-08 03:49:13 +00002802 "lxsd $vD, $src", IIC_LdStLFD, []>;
2803 // Load SP from src, convert it to DP, and place in dword[0]
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002804 def LXSSP : DSForm_1<57, 3, (outs vfrc:$vD), (ins memrix:$src),
Kit Bartonba532dc2016-03-08 03:49:13 +00002805 "lxssp $vD, $src", IIC_LdStLFD, []>;
2806
2807 // [PO T RA RB XO TX] almost equal to [PO S RA RB XO SX], but has different
2808 // "out" and "in" dag
2809 class X_XT6_RA5_RB5<bits<6> opcode, bits<10> xo, string opc,
2810 RegisterOperand vtype, list<dag> pattern>
Stefan Pintilie26d4f922018-03-26 17:39:18 +00002811 : XX1Form_memOp<opcode, xo, (outs vtype:$XT), (ins memrr:$src),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002812 !strconcat(opc, " $XT, $src"), IIC_LdStLFD, pattern>, UseVSXReg;
Kit Bartonba532dc2016-03-08 03:49:13 +00002813
2814 // Load as Integer Byte/Halfword & Zero Indexed
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002815 def LXSIBZX : X_XT6_RA5_RB5<31, 781, "lxsibzx", vsfrc,
2816 [(set f64:$XT, (PPClxsizx xoaddr:$src, 1))]>;
2817 def LXSIHZX : X_XT6_RA5_RB5<31, 813, "lxsihzx", vsfrc,
2818 [(set f64:$XT, (PPClxsizx xoaddr:$src, 2))]>;
Kit Bartonba532dc2016-03-08 03:49:13 +00002819
2820 // Load Vector Halfword*8/Byte*16 Indexed
2821 def LXVH8X : X_XT6_RA5_RB5<31, 812, "lxvh8x" , vsrc, []>;
2822 def LXVB16X : X_XT6_RA5_RB5<31, 876, "lxvb16x", vsrc, []>;
2823
2824 // Load Vector Indexed
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00002825 def LXVX : X_XT6_RA5_RB5<31, 268, "lxvx" , vsrc,
Zaara Syeda93297832017-05-24 17:50:37 +00002826 [(set v2f64:$XT, (load xaddr:$src))]>;
Kit Bartonba532dc2016-03-08 03:49:13 +00002827 // Load Vector (Left-justified) with Length
Stefan Pintilie26d4f922018-03-26 17:39:18 +00002828 def LXVL : XX1Form_memOp<31, 269, (outs vsrc:$XT), (ins memr:$src, g8rc:$rB),
Zaara Syedaa19c9e62016-11-15 17:54:19 +00002829 "lxvl $XT, $src, $rB", IIC_LdStLoad,
2830 [(set v4i32:$XT, (int_ppc_vsx_lxvl addr:$src, i64:$rB))]>,
2831 UseVSXReg;
Stefan Pintilie26d4f922018-03-26 17:39:18 +00002832 def LXVLL : XX1Form_memOp<31,301, (outs vsrc:$XT), (ins memr:$src, g8rc:$rB),
Zaara Syedaa19c9e62016-11-15 17:54:19 +00002833 "lxvll $XT, $src, $rB", IIC_LdStLoad,
2834 [(set v4i32:$XT, (int_ppc_vsx_lxvll addr:$src, i64:$rB))]>,
2835 UseVSXReg;
Kit Bartonba532dc2016-03-08 03:49:13 +00002836
2837 // Load Vector Word & Splat Indexed
2838 def LXVWSX : X_XT6_RA5_RB5<31, 364, "lxvwsx" , vsrc, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002839 } // mayLoad
Kit Bartonba532dc2016-03-08 03:49:13 +00002840
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00002841 // When adding new D-Form loads/stores, be sure to update the ImmToIdxMap in
2842 // PPCRegisterInfo::PPCRegisterInfo and maybe save yourself some debugging.
Sean Fertile3c8c3852017-01-26 18:59:15 +00002843 let mayStore = 1, mayLoad = 0 in {
Kit Bartonba532dc2016-03-08 03:49:13 +00002844 // Store Vector
2845 def STXV : DQ_RD6_RS5_DQ12<61, 5, (outs), (ins vsrc:$XT, memrix16:$dst),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002846 "stxv $XT, $dst", IIC_LdStSTFD, []>, UseVSXReg;
Kit Bartonba532dc2016-03-08 03:49:13 +00002847 // Store DWord
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002848 def STXSD : DSForm_1<61, 2, (outs), (ins vfrc:$vS, memrix:$dst),
Kit Bartonba532dc2016-03-08 03:49:13 +00002849 "stxsd $vS, $dst", IIC_LdStSTFD, []>;
2850 // Convert DP of dword[0] to SP, and Store to dst
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002851 def STXSSP : DSForm_1<61, 3, (outs), (ins vfrc:$vS, memrix:$dst),
Kit Bartonba532dc2016-03-08 03:49:13 +00002852 "stxssp $vS, $dst", IIC_LdStSTFD, []>;
2853
2854 // [PO S RA RB XO SX]
2855 class X_XS6_RA5_RB5<bits<6> opcode, bits<10> xo, string opc,
2856 RegisterOperand vtype, list<dag> pattern>
Stefan Pintilie26d4f922018-03-26 17:39:18 +00002857 : XX1Form_memOp<opcode, xo, (outs), (ins vtype:$XT, memrr:$dst),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002858 !strconcat(opc, " $XT, $dst"), IIC_LdStSTFD, pattern>, UseVSXReg;
Kit Bartonba532dc2016-03-08 03:49:13 +00002859
2860 // Store as Integer Byte/Halfword Indexed
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002861 def STXSIBX : X_XS6_RA5_RB5<31, 909, "stxsibx" , vsfrc,
2862 [(PPCstxsix f64:$XT, xoaddr:$dst, 1)]>;
2863 def STXSIHX : X_XS6_RA5_RB5<31, 941, "stxsihx" , vsfrc,
2864 [(PPCstxsix f64:$XT, xoaddr:$dst, 2)]>;
2865 let isCodeGenOnly = 1 in {
2866 def STXSIBXv : X_XS6_RA5_RB5<31, 909, "stxsibx" , vrrc, []>;
2867 def STXSIHXv : X_XS6_RA5_RB5<31, 941, "stxsihx" , vrrc, []>;
2868 }
Kit Bartonba532dc2016-03-08 03:49:13 +00002869
2870 // Store Vector Halfword*8/Byte*16 Indexed
2871 def STXVH8X : X_XS6_RA5_RB5<31, 940, "stxvh8x" , vsrc, []>;
2872 def STXVB16X : X_XS6_RA5_RB5<31, 1004, "stxvb16x", vsrc, []>;
2873
2874 // Store Vector Indexed
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00002875 def STXVX : X_XS6_RA5_RB5<31, 396, "stxvx" , vsrc,
Zaara Syeda93297832017-05-24 17:50:37 +00002876 [(store v2f64:$XT, xaddr:$dst)]>;
Kit Bartonba532dc2016-03-08 03:49:13 +00002877
2878 // Store Vector (Left-justified) with Length
Stefan Pintilie26d4f922018-03-26 17:39:18 +00002879 def STXVL : XX1Form_memOp<31, 397, (outs),
2880 (ins vsrc:$XT, memr:$dst, g8rc:$rB),
2881 "stxvl $XT, $dst, $rB", IIC_LdStLoad,
2882 [(int_ppc_vsx_stxvl v4i32:$XT, addr:$dst,
2883 i64:$rB)]>,
2884 UseVSXReg;
2885 def STXVLL : XX1Form_memOp<31, 429, (outs),
2886 (ins vsrc:$XT, memr:$dst, g8rc:$rB),
2887 "stxvll $XT, $dst, $rB", IIC_LdStLoad,
2888 [(int_ppc_vsx_stxvll v4i32:$XT, addr:$dst,
2889 i64:$rB)]>,
2890 UseVSXReg;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002891 } // mayStore
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002892
Lei Huang451ef4a2017-08-14 18:09:29 +00002893 let Predicates = [IsLittleEndian] in {
Lei Huangcd4f3852018-03-12 19:26:18 +00002894 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 0)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002895 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 3))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002896 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 1)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002897 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 2))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002898 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 2)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002899 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 1))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002900 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 3)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002901 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 0))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002902 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 0)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002903 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 3)), VSFRC))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002904 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 1)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002905 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 2)), VSFRC))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002906 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 2)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002907 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 1)), VSFRC))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002908 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 3)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002909 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 0)), VSFRC))>;
2910 }
2911
2912 let Predicates = [IsBigEndian] in {
Lei Huangcd4f3852018-03-12 19:26:18 +00002913 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 0)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002914 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 0))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002915 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 1)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002916 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 1))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002917 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 2)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002918 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 2))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002919 def: Pat<(f32 (PPCfcfids (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 3)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002920 (f32 (XSCVSPDPN (XVCVSXWSP (XXSPLTW $A, 3))))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002921 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 0)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002922 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 0)), VSFRC))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002923 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 1)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002924 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 1)), VSFRC))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002925 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 2)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002926 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 2)), VSFRC))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002927 def: Pat<(f64 (PPCfcfid (f64 (PPCmtvsra (i32 (extractelt v4i32:$A, 3)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002928 (f64 (COPY_TO_REGCLASS (XVCVSXWDP (XXSPLTW $A, 3)), VSFRC))>;
2929 }
2930
Graham Yiu5cd044e2017-11-07 20:55:43 +00002931 // Alternate patterns for PPCmtvsrz where the output is v8i16 or v16i8 instead
2932 // of f64
2933 def : Pat<(v8i16 (PPCmtvsrz i32:$A)),
2934 (v8i16 (SUBREG_TO_REG (i64 1), (MTVSRWZ $A), sub_64))>;
2935 def : Pat<(v16i8 (PPCmtvsrz i32:$A)),
2936 (v16i8 (SUBREG_TO_REG (i64 1), (MTVSRWZ $A), sub_64))>;
2937
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002938 // Patterns for which instructions from ISA 3.0 are a better match
2939 let Predicates = [IsLittleEndian, HasP9Vector] in {
Lei Huangcd4f3852018-03-12 19:26:18 +00002940 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 0)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002941 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 12)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002942 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 1)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002943 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 8)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002944 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 2)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002945 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 4)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002946 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 3)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002947 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 0)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002948 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 0)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002949 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 12)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002950 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 1)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002951 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 8)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002952 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 2)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002953 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 4)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002954 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 3)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002955 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 0)))>;
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002956 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 0)),
2957 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 12))>;
2958 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 1)),
2959 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 8))>;
2960 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 2)),
2961 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 4))>;
2962 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 3)),
2963 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 0))>;
2964 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 0)),
2965 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 12))>;
2966 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 1)),
2967 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 8))>;
2968 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 2)),
2969 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 4))>;
2970 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 3)),
2971 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 0))>;
2972 } // IsLittleEndian, HasP9Vector
2973
2974 let Predicates = [IsBigEndian, HasP9Vector] in {
Lei Huangcd4f3852018-03-12 19:26:18 +00002975 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 0)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002976 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 0)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002977 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 1)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002978 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 4)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002979 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 2)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002980 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 8)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002981 def : Pat<(f32 (PPCfcfidus (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 3)))))),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002982 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 12)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002983 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 0)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002984 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 0)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002985 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 1)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002986 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 4)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002987 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 2)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002988 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 8)))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00002989 def : Pat<(f64 (PPCfcfidu (f64 (PPCmtvsrz (i32 (extractelt v4i32:$A, 3)))))),
Lei Huang451ef4a2017-08-14 18:09:29 +00002990 (f64 (XSCVUXDDP (XXEXTRACTUW $A, 12)))>;
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002991 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 0)),
2992 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 0))>;
2993 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 1)),
2994 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 4))>;
2995 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 2)),
2996 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 8))>;
2997 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 3)),
2998 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 12))>;
2999 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 0)),
3000 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 0))>;
3001 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 1)),
3002 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 4))>;
3003 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 2)),
3004 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 8))>;
3005 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 3)),
3006 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 12))>;
3007 } // IsLittleEndian, HasP9Vector
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00003008
Zaara Syeda93297832017-05-24 17:50:37 +00003009 // D-Form Load/Store
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003010 def : Pat<(v4i32 (quadwOffsetLoad iqaddr:$src)), (LXV memrix16:$src)>;
3011 def : Pat<(v4f32 (quadwOffsetLoad iqaddr:$src)), (LXV memrix16:$src)>;
3012 def : Pat<(v2i64 (quadwOffsetLoad iqaddr:$src)), (LXV memrix16:$src)>;
3013 def : Pat<(v2f64 (quadwOffsetLoad iqaddr:$src)), (LXV memrix16:$src)>;
Lei Huang6d1596a2018-03-19 18:52:20 +00003014 def : Pat<(f128 (quadwOffsetLoad iqaddr:$src)),
3015 (COPY_TO_REGCLASS (LXV memrix16:$src), VRRC)>;
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003016 def : Pat<(v4i32 (int_ppc_vsx_lxvw4x iqaddr:$src)), (LXV memrix16:$src)>;
3017 def : Pat<(v2f64 (int_ppc_vsx_lxvd2x iqaddr:$src)), (LXV memrix16:$src)>;
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00003018
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003019 def : Pat<(quadwOffsetStore v4f32:$rS, iqaddr:$dst), (STXV $rS, memrix16:$dst)>;
3020 def : Pat<(quadwOffsetStore v4i32:$rS, iqaddr:$dst), (STXV $rS, memrix16:$dst)>;
3021 def : Pat<(quadwOffsetStore v2f64:$rS, iqaddr:$dst), (STXV $rS, memrix16:$dst)>;
Lei Huang6d1596a2018-03-19 18:52:20 +00003022 def : Pat<(quadwOffsetStore f128:$rS, iqaddr:$dst),
3023 (STXV (COPY_TO_REGCLASS $rS, VSRC), memrix16:$dst)>;
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003024 def : Pat<(quadwOffsetStore v2i64:$rS, iqaddr:$dst), (STXV $rS, memrix16:$dst)>;
3025 def : Pat<(int_ppc_vsx_stxvw4x v4i32:$rS, iqaddr:$dst),
Zaara Syeda93297832017-05-24 17:50:37 +00003026 (STXV $rS, memrix16:$dst)>;
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003027 def : Pat<(int_ppc_vsx_stxvd2x v2f64:$rS, iqaddr:$dst),
Zaara Syeda93297832017-05-24 17:50:37 +00003028 (STXV $rS, memrix16:$dst)>;
3029
3030
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003031 def : Pat<(v2f64 (nonQuadwOffsetLoad xoaddr:$src)), (LXVX xoaddr:$src)>;
3032 def : Pat<(v2i64 (nonQuadwOffsetLoad xoaddr:$src)), (LXVX xoaddr:$src)>;
3033 def : Pat<(v4f32 (nonQuadwOffsetLoad xoaddr:$src)), (LXVX xoaddr:$src)>;
3034 def : Pat<(v4i32 (nonQuadwOffsetLoad xoaddr:$src)), (LXVX xoaddr:$src)>;
3035 def : Pat<(v4i32 (int_ppc_vsx_lxvw4x xoaddr:$src)), (LXVX xoaddr:$src)>;
3036 def : Pat<(v2f64 (int_ppc_vsx_lxvd2x xoaddr:$src)), (LXVX xoaddr:$src)>;
Lei Huang6d1596a2018-03-19 18:52:20 +00003037 def : Pat<(f128 (nonQuadwOffsetLoad xoaddr:$src)),
3038 (COPY_TO_REGCLASS (LXVX xoaddr:$src), VRRC)>;
3039 def : Pat<(nonQuadwOffsetStore f128:$rS, xoaddr:$dst),
3040 (STXVX (COPY_TO_REGCLASS $rS, VSRC), xoaddr:$dst)>;
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003041 def : Pat<(nonQuadwOffsetStore v2f64:$rS, xoaddr:$dst),
3042 (STXVX $rS, xoaddr:$dst)>;
3043 def : Pat<(nonQuadwOffsetStore v2i64:$rS, xoaddr:$dst),
3044 (STXVX $rS, xoaddr:$dst)>;
3045 def : Pat<(nonQuadwOffsetStore v4f32:$rS, xoaddr:$dst),
3046 (STXVX $rS, xoaddr:$dst)>;
3047 def : Pat<(nonQuadwOffsetStore v4i32:$rS, xoaddr:$dst),
3048 (STXVX $rS, xoaddr:$dst)>;
3049 def : Pat<(int_ppc_vsx_stxvw4x v4i32:$rS, xoaddr:$dst),
3050 (STXVX $rS, xoaddr:$dst)>;
3051 def : Pat<(int_ppc_vsx_stxvd2x v2f64:$rS, xoaddr:$dst),
3052 (STXVX $rS, xoaddr:$dst)>;
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00003053 def : Pat<(v4i32 (scalar_to_vector (i32 (load xoaddr:$src)))),
3054 (v4i32 (LXVWSX xoaddr:$src))>;
3055 def : Pat<(v4f32 (scalar_to_vector (f32 (load xoaddr:$src)))),
3056 (v4f32 (LXVWSX xoaddr:$src))>;
Lei Huangcd4f3852018-03-12 19:26:18 +00003057 def : Pat<(v4f32 (scalar_to_vector
3058 (f32 (fpround (f64 (extloadf32 xoaddr:$src)))))),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003059 (v4f32 (LXVWSX xoaddr:$src))>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003060
3061 // Build vectors from i8 loads
3062 def : Pat<(v16i8 (scalar_to_vector ScalarLoads.Li8)),
3063 (v16i8 (VSPLTBs 7, (LXSIBZX xoaddr:$src)))>;
3064 def : Pat<(v8i16 (scalar_to_vector ScalarLoads.ZELi8)),
3065 (v8i16 (VSPLTHs 3, (LXSIBZX xoaddr:$src)))>;
3066 def : Pat<(v4i32 (scalar_to_vector ScalarLoads.ZELi8)),
3067 (v4i32 (XXSPLTWs (LXSIBZX xoaddr:$src), 1))>;
3068 def : Pat<(v2i64 (scalar_to_vector ScalarLoads.ZELi8i64)),
Nemanja Ivanovic15748f42016-12-06 11:47:14 +00003069 (v2i64 (XXPERMDIs (LXSIBZX xoaddr:$src), 0))>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003070 def : Pat<(v4i32 (scalar_to_vector ScalarLoads.SELi8)),
3071 (v4i32 (XXSPLTWs (VEXTSB2Ws (LXSIBZX xoaddr:$src)), 1))>;
3072 def : Pat<(v2i64 (scalar_to_vector ScalarLoads.SELi8i64)),
Nemanja Ivanovic15748f42016-12-06 11:47:14 +00003073 (v2i64 (XXPERMDIs (VEXTSB2Ds (LXSIBZX xoaddr:$src)), 0))>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003074
3075 // Build vectors from i16 loads
3076 def : Pat<(v8i16 (scalar_to_vector ScalarLoads.Li16)),
3077 (v8i16 (VSPLTHs 3, (LXSIHZX xoaddr:$src)))>;
3078 def : Pat<(v4i32 (scalar_to_vector ScalarLoads.ZELi16)),
3079 (v4i32 (XXSPLTWs (LXSIHZX xoaddr:$src), 1))>;
3080 def : Pat<(v2i64 (scalar_to_vector ScalarLoads.ZELi16i64)),
Nemanja Ivanovic15748f42016-12-06 11:47:14 +00003081 (v2i64 (XXPERMDIs (LXSIHZX xoaddr:$src), 0))>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003082 def : Pat<(v4i32 (scalar_to_vector ScalarLoads.SELi16)),
3083 (v4i32 (XXSPLTWs (VEXTSH2Ws (LXSIHZX xoaddr:$src)), 1))>;
3084 def : Pat<(v2i64 (scalar_to_vector ScalarLoads.SELi16i64)),
Nemanja Ivanovic15748f42016-12-06 11:47:14 +00003085 (v2i64 (XXPERMDIs (VEXTSH2Ds (LXSIHZX xoaddr:$src)), 0))>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003086
3087 let Predicates = [IsBigEndian, HasP9Vector] in {
3088 // Scalar stores of i8
3089 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 0)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003090 (STXSIBXv (v16i8 (VSLDOI $S, $S, 9)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003091 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 1)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003092 (STXSIBXv (v16i8 (VSLDOI $S, $S, 10)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003093 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 2)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003094 (STXSIBXv (v16i8 (VSLDOI $S, $S, 11)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003095 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 3)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003096 (STXSIBXv (v16i8 (VSLDOI $S, $S, 12)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003097 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 4)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003098 (STXSIBXv (v16i8 (VSLDOI $S, $S, 13)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003099 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 5)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003100 (STXSIBXv (v16i8 (VSLDOI $S, $S, 14)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003101 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 6)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003102 (STXSIBXv (v16i8 (VSLDOI $S, $S, 15)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003103 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 7)), xoaddr:$dst),
3104 (STXSIBXv $S, xoaddr:$dst)>;
3105 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 8)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003106 (STXSIBXv (v16i8 (VSLDOI $S, $S, 1)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003107 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 9)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003108 (STXSIBXv (v16i8 (VSLDOI $S, $S, 2)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003109 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 10)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003110 (STXSIBXv (v16i8 (VSLDOI $S, $S, 3)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003111 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 11)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003112 (STXSIBXv (v16i8 (VSLDOI $S, $S, 4)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003113 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 12)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003114 (STXSIBXv (v16i8 (VSLDOI $S, $S, 5)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003115 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 13)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003116 (STXSIBXv (v16i8 (VSLDOI $S, $S, 6)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003117 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 14)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003118 (STXSIBXv (v16i8 (VSLDOI $S, $S, 7)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003119 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 15)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003120 (STXSIBXv (v16i8 (VSLDOI $S, $S, 8)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003121
3122 // Scalar stores of i16
3123 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 0)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003124 (STXSIHXv (v16i8 (VSLDOI $S, $S, 10)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003125 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 1)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003126 (STXSIHXv (v16i8 (VSLDOI $S, $S, 12)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003127 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 2)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003128 (STXSIHXv (v16i8 (VSLDOI $S, $S, 14)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003129 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 3)), xoaddr:$dst),
3130 (STXSIHXv $S, xoaddr:$dst)>;
3131 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 4)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003132 (STXSIHXv (v16i8 (VSLDOI $S, $S, 2)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003133 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 5)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003134 (STXSIHXv (v16i8 (VSLDOI $S, $S, 4)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003135 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 6)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003136 (STXSIHXv (v16i8 (VSLDOI $S, $S, 6)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003137 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 7)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003138 (STXSIHXv (v16i8 (VSLDOI $S, $S, 8)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003139 } // IsBigEndian, HasP9Vector
3140
3141 let Predicates = [IsLittleEndian, HasP9Vector] in {
3142 // Scalar stores of i8
3143 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 0)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003144 (STXSIBXv (v16i8 (VSLDOI $S, $S, 8)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003145 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 1)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003146 (STXSIBXv (v16i8 (VSLDOI $S, $S, 7)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003147 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 2)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003148 (STXSIBXv (v16i8 (VSLDOI $S, $S, 6)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003149 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 3)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003150 (STXSIBXv (v16i8 (VSLDOI $S, $S, 5)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003151 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 4)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003152 (STXSIBXv (v16i8 (VSLDOI $S, $S, 4)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003153 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 5)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003154 (STXSIBXv (v16i8 (VSLDOI $S, $S, 3)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003155 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 6)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003156 (STXSIBXv (v16i8 (VSLDOI $S, $S, 2)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003157 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 7)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003158 (STXSIBXv (v16i8 (VSLDOI $S, $S, 1)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003159 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 8)), xoaddr:$dst),
3160 (STXSIBXv $S, xoaddr:$dst)>;
3161 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 9)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003162 (STXSIBXv (v16i8 (VSLDOI $S, $S, 15)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003163 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 10)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003164 (STXSIBXv (v16i8 (VSLDOI $S, $S, 14)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003165 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 11)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003166 (STXSIBXv (v16i8 (VSLDOI $S, $S, 13)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003167 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 12)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003168 (STXSIBXv (v16i8 (VSLDOI $S, $S, 12)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003169 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 13)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003170 (STXSIBXv (v16i8 (VSLDOI $S, $S, 11)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003171 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 14)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003172 (STXSIBXv (v16i8 (VSLDOI $S, $S, 10)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003173 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 15)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003174 (STXSIBXv (v16i8 (VSLDOI $S, $S, 9)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003175
3176 // Scalar stores of i16
3177 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 0)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003178 (STXSIHXv (v16i8 (VSLDOI $S, $S, 8)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003179 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 1)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003180 (STXSIHXv (v16i8 (VSLDOI $S, $S, 6)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003181 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 2)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003182 (STXSIHXv (v16i8 (VSLDOI $S, $S, 4)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003183 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 3)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003184 (STXSIHXv (v16i8 (VSLDOI $S, $S, 2)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003185 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 4)), xoaddr:$dst),
3186 (STXSIHXv $S, xoaddr:$dst)>;
3187 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 5)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003188 (STXSIHXv (v16i8 (VSLDOI $S, $S, 14)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003189 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 6)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003190 (STXSIHXv (v16i8 (VSLDOI $S, $S, 12)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003191 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 7)), xoaddr:$dst),
Lei Huangcd4f3852018-03-12 19:26:18 +00003192 (STXSIHXv (v16i8 (VSLDOI $S, $S, 10)), xoaddr:$dst)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003193 } // IsLittleEndian, HasP9Vector
3194
Sean Fertile1c4109b2016-12-09 17:21:42 +00003195
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00003196 // Vector sign extensions
3197 def : Pat<(f64 (PPCVexts f64:$A, 1)),
3198 (f64 (COPY_TO_REGCLASS (VEXTSB2Ds $A), VSFRC))>;
3199 def : Pat<(f64 (PPCVexts f64:$A, 2)),
3200 (f64 (COPY_TO_REGCLASS (VEXTSH2Ds $A), VSFRC))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003201
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00003202 let isPseudo = 1 in {
3203 def DFLOADf32 : Pseudo<(outs vssrc:$XT), (ins memrix:$src),
3204 "#DFLOADf32",
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003205 [(set f32:$XT, (load ixaddr:$src))]>;
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00003206 def DFLOADf64 : Pseudo<(outs vsfrc:$XT), (ins memrix:$src),
3207 "#DFLOADf64",
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003208 [(set f64:$XT, (load ixaddr:$src))]>;
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00003209 def DFSTOREf32 : Pseudo<(outs), (ins vssrc:$XT, memrix:$dst),
3210 "#DFSTOREf32",
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003211 [(store f32:$XT, ixaddr:$dst)]>;
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00003212 def DFSTOREf64 : Pseudo<(outs), (ins vsfrc:$XT, memrix:$dst),
3213 "#DFSTOREf64",
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003214 [(store f64:$XT, ixaddr:$dst)]>;
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00003215 }
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003216 def : Pat<(f64 (extloadf32 ixaddr:$src)),
3217 (COPY_TO_REGCLASS (DFLOADf32 ixaddr:$src), VSFRC)>;
Lei Huangcd4f3852018-03-12 19:26:18 +00003218 def : Pat<(f32 (fpround (f64 (extloadf32 ixaddr:$src)))),
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003219 (f32 (DFLOADf32 ixaddr:$src))>;
Lei Huang10367eb2018-04-12 18:00:14 +00003220
Lei Huang8b0da652018-05-23 19:31:54 +00003221 let Predicates = [IsBigEndian, HasP9Vector] in {
Lei Huang89901682018-05-23 18:36:51 +00003222
Lei Huang8b0da652018-05-23 19:31:54 +00003223 // (Un)Signed DWord vector extract -> QP
3224 def : Pat<(f128 (sint_to_fp (i64 (extractelt v2i64:$src, 0)))),
3225 (f128 (XSCVSDQP (COPY_TO_REGCLASS $src, VFRC)))>;
3226 def : Pat<(f128 (sint_to_fp (i64 (extractelt v2i64:$src, 1)))),
3227 (f128 (XSCVSDQP
3228 (EXTRACT_SUBREG (XXPERMDI $src, $src, 3), sub_64)))>;
3229 def : Pat<(f128 (uint_to_fp (i64 (extractelt v2i64:$src, 0)))),
3230 (f128 (XSCVUDQP (COPY_TO_REGCLASS $src, VFRC)))>;
3231 def : Pat<(f128 (uint_to_fp (i64 (extractelt v2i64:$src, 1)))),
3232 (f128 (XSCVUDQP
3233 (EXTRACT_SUBREG (XXPERMDI $src, $src, 3), sub_64)))>;
3234
3235 // (Un)Signed Word vector extract -> QP
3236 def : Pat<(f128 (sint_to_fp (i32 (extractelt v4i32:$src, 1)))),
3237 (f128 (XSCVSDQP (EXTRACT_SUBREG (VEXTSW2D $src), sub_64)))>;
3238 foreach Idx = [0,2,3] in {
3239 def : Pat<(f128 (sint_to_fp (i32 (extractelt v4i32:$src, Idx)))),
3240 (f128 (XSCVSDQP (EXTRACT_SUBREG
3241 (VEXTSW2D (VSPLTW Idx, $src)), sub_64)))>;
3242 }
3243 foreach Idx = 0-3 in {
3244 def : Pat<(f128 (uint_to_fp (i32 (extractelt v4i32:$src, Idx)))),
3245 (f128 (XSCVUDQP (XXEXTRACTUW $src, !shl(Idx, 2))))>;
3246 }
3247
Lei Huang651be442018-05-28 16:43:29 +00003248 // (Un)Signed HWord vector extract -> QP
3249 foreach Idx = 0-7 in {
3250 def : Pat<(f128 (sint_to_fp
3251 (i32 (sext_inreg
3252 (vector_extract v8i16:$src, Idx), i16)))),
3253 (f128 (XSCVSDQP (EXTRACT_SUBREG
3254 (VEXTSH2D (VEXTRACTUH !add(Idx, Idx), $src)),
3255 sub_64)))>;
3256 // The SDAG adds the `and` since an `i16` is being extracted as an `i32`.
3257 def : Pat<(f128 (uint_to_fp
3258 (and (i32 (vector_extract v8i16:$src, Idx)), 65535))),
3259 (f128 (XSCVUDQP (EXTRACT_SUBREG
3260 (VEXTRACTUH !add(Idx, Idx), $src), sub_64)))>;
3261 }
3262
3263 // (Un)Signed Byte vector extract -> QP
3264 foreach Idx = 0-15 in {
3265 def : Pat<(f128 (sint_to_fp
3266 (i32 (sext_inreg (vector_extract v16i8:$src, Idx),
3267 i8)))),
3268 (f128 (XSCVSDQP (EXTRACT_SUBREG
3269 (VEXTSB2D (VEXTRACTUB Idx, $src)), sub_64)))>;
3270 def : Pat<(f128 (uint_to_fp
3271 (and (i32 (vector_extract v16i8:$src, Idx)), 255))),
3272 (f128 (XSCVUDQP
3273 (EXTRACT_SUBREG (VEXTRACTUB Idx, $src), sub_64)))>;
3274 }
Lei Huang66e22c22018-07-05 07:46:01 +00003275
3276 // Unsiged int in vsx register -> QP
3277 def : Pat<(f128 (uint_to_fp (i32 (PPCmfvsr f64:$src)))),
3278 (f128 (XSCVUDQP
3279 (XXEXTRACTUW (SUBREG_TO_REG (i64 1), $src, sub_64), 4)))>;
Lei Huang8b0da652018-05-23 19:31:54 +00003280 } // IsBigEndian, HasP9Vector
3281
3282 let Predicates = [IsLittleEndian, HasP9Vector] in {
3283
3284 // (Un)Signed DWord vector extract -> QP
Lei Huang89901682018-05-23 18:36:51 +00003285 def : Pat<(f128 (sint_to_fp (i64 (extractelt v2i64:$src, 0)))),
3286 (f128 (XSCVSDQP
3287 (EXTRACT_SUBREG (XXPERMDI $src, $src, 3), sub_64)))>;
3288 def : Pat<(f128 (sint_to_fp (i64 (extractelt v2i64:$src, 1)))),
3289 (f128 (XSCVSDQP (COPY_TO_REGCLASS $src, VFRC)))>;
3290 def : Pat<(f128 (uint_to_fp (i64 (extractelt v2i64:$src, 0)))),
3291 (f128 (XSCVUDQP
3292 (EXTRACT_SUBREG (XXPERMDI $src, $src, 3), sub_64)))>;
3293 def : Pat<(f128 (uint_to_fp (i64 (extractelt v2i64:$src, 1)))),
3294 (f128 (XSCVUDQP (COPY_TO_REGCLASS $src, VFRC)))>;
Lei Huang8b0da652018-05-23 19:31:54 +00003295
3296 // (Un)Signed Word vector extract -> QP
3297 foreach Idx = [[0,3],[1,2],[3,0]] in {
3298 def : Pat<(f128 (sint_to_fp (i32 (extractelt v4i32:$src, !head(Idx))))),
3299 (f128 (XSCVSDQP (EXTRACT_SUBREG
3300 (VEXTSW2D (VSPLTW !head(!tail(Idx)), $src)),
3301 sub_64)))>;
3302 }
3303 def : Pat<(f128 (sint_to_fp (i32 (extractelt v4i32:$src, 2)))),
3304 (f128 (XSCVSDQP (EXTRACT_SUBREG (VEXTSW2D $src), sub_64)))>;
3305
3306 foreach Idx = [[0,12],[1,8],[2,4],[3,0]] in {
3307 def : Pat<(f128 (uint_to_fp (i32 (extractelt v4i32:$src, !head(Idx))))),
3308 (f128 (XSCVUDQP (XXEXTRACTUW $src, !head(!tail(Idx)))))>;
3309 }
Lei Huang651be442018-05-28 16:43:29 +00003310
3311 // (Un)Signed HWord vector extract -> QP
3312 // The Nested foreach lists identifies the vector element and corresponding
3313 // register byte location.
3314 foreach Idx = [[0,14],[1,12],[2,10],[3,8],[4,6],[5,4],[6,2],[7,0]] in {
3315 def : Pat<(f128 (sint_to_fp
3316 (i32 (sext_inreg
3317 (vector_extract v8i16:$src, !head(Idx)), i16)))),
3318 (f128 (XSCVSDQP
3319 (EXTRACT_SUBREG (VEXTSH2D
3320 (VEXTRACTUH !head(!tail(Idx)), $src)),
3321 sub_64)))>;
3322 def : Pat<(f128 (uint_to_fp
3323 (and (i32 (vector_extract v8i16:$src, !head(Idx))),
3324 65535))),
3325 (f128 (XSCVUDQP (EXTRACT_SUBREG
3326 (VEXTRACTUH !head(!tail(Idx)), $src), sub_64)))>;
3327 }
3328
3329 // (Un)Signed Byte vector extract -> QP
3330 foreach Idx = [[0,15],[1,14],[2,13],[3,12],[4,11],[5,10],[6,9],[7,8],[8,7],
3331 [9,6],[10,5],[11,4],[12,3],[13,2],[14,1],[15,0]] in {
3332 def : Pat<(f128 (sint_to_fp
3333 (i32 (sext_inreg
3334 (vector_extract v16i8:$src, !head(Idx)), i8)))),
3335 (f128 (XSCVSDQP
3336 (EXTRACT_SUBREG
3337 (VEXTSB2D (VEXTRACTUB !head(!tail(Idx)), $src)),
3338 sub_64)))>;
3339 def : Pat<(f128 (uint_to_fp
3340 (and (i32 (vector_extract v16i8:$src, !head(Idx))),
3341 255))),
3342 (f128 (XSCVUDQP
3343 (EXTRACT_SUBREG
3344 (VEXTRACTUB !head(!tail(Idx)), $src), sub_64)))>;
3345 }
Lei Huang66e22c22018-07-05 07:46:01 +00003346
3347 // Unsiged int in vsx register -> QP
3348 def : Pat<(f128 (uint_to_fp (i32 (PPCmfvsr f64:$src)))),
3349 (f128 (XSCVUDQP
3350 (XXEXTRACTUW (SUBREG_TO_REG (i64 1), $src, sub_64), 8)))>;
Lei Huang8b0da652018-05-23 19:31:54 +00003351 } // IsLittleEndian, HasP9Vector
Lei Huang89901682018-05-23 18:36:51 +00003352
Lei Huang10367eb2018-04-12 18:00:14 +00003353 // Convert (Un)Signed DWord in memory -> QP
3354 def : Pat<(f128 (sint_to_fp (i64 (load xaddr:$src)))),
3355 (f128 (XSCVSDQP (LXSDX xaddr:$src)))>;
3356 def : Pat<(f128 (sint_to_fp (i64 (load ixaddr:$src)))),
3357 (f128 (XSCVSDQP (LXSD ixaddr:$src)))>;
3358 def : Pat<(f128 (uint_to_fp (i64 (load xaddr:$src)))),
3359 (f128 (XSCVUDQP (LXSDX xaddr:$src)))>;
3360 def : Pat<(f128 (uint_to_fp (i64 (load ixaddr:$src)))),
3361 (f128 (XSCVUDQP (LXSD ixaddr:$src)))>;
3362
Lei Huang192c6cc2018-04-18 17:41:46 +00003363 // Convert Unsigned HWord in memory -> QP
3364 def : Pat<(f128 (uint_to_fp ScalarLoads.ZELi16)),
3365 (f128 (XSCVUDQP (LXSIHZX xaddr:$src)))>;
3366
3367 // Convert Unsigned Byte in memory -> QP
3368 def : Pat<(f128 (uint_to_fp ScalarLoads.ZELi8)),
3369 (f128 (XSCVUDQP (LXSIBZX xoaddr:$src)))>;
3370
Lei Huangc517e952018-05-08 18:23:31 +00003371 // Truncate & Convert QP -> (Un)Signed (D)Word.
3372 def : Pat<(i64 (fp_to_sint f128:$src)), (i64 (MFVRD (XSCVQPSDZ $src)))>;
3373 def : Pat<(i64 (fp_to_uint f128:$src)), (i64 (MFVRD (XSCVQPUDZ $src)))>;
Lei Huang63642882018-05-08 18:34:00 +00003374 def : Pat<(i32 (fp_to_sint f128:$src)),
3375 (i32 (MFVSRWZ (COPY_TO_REGCLASS (XSCVQPSWZ $src), VFRC)))>;
3376 def : Pat<(i32 (fp_to_uint f128:$src)),
3377 (i32 (MFVSRWZ (COPY_TO_REGCLASS (XSCVQPUWZ $src), VFRC)))>;
Lei Huangc517e952018-05-08 18:23:31 +00003378
Lei Huange41e3d32018-05-08 18:52:06 +00003379 // Instructions for store(fptosi).
Lei Huangc29229a2018-05-08 17:36:40 +00003380 // The 8-byte version is repeated here due to availability of D-Form STXSD.
3381 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huangc517e952018-05-08 18:23:31 +00003382 (f64 (PPCcv_fp_to_sint_in_vsr f128:$src)), xaddr:$dst, 8),
3383 (STXSDX (COPY_TO_REGCLASS (XSCVQPSDZ f128:$src), VFRC),
3384 xaddr:$dst)>;
3385 def : Pat<(PPCstore_scal_int_from_vsr
3386 (f64 (PPCcv_fp_to_sint_in_vsr f128:$src)), ixaddr:$dst, 8),
3387 (STXSD (COPY_TO_REGCLASS (XSCVQPSDZ f128:$src), VFRC),
3388 ixaddr:$dst)>;
3389 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huang63642882018-05-08 18:34:00 +00003390 (f64 (PPCcv_fp_to_sint_in_vsr f128:$src)), xoaddr:$dst, 4),
3391 (STXSIWX (COPY_TO_REGCLASS (XSCVQPSWZ $src), VFRC), xoaddr:$dst)>;
3392 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huange41e3d32018-05-08 18:52:06 +00003393 (f64 (PPCcv_fp_to_sint_in_vsr f128:$src)), xoaddr:$dst, 2),
3394 (STXSIHX (COPY_TO_REGCLASS (XSCVQPSWZ $src), VFRC), xoaddr:$dst)>;
3395 def : Pat<(PPCstore_scal_int_from_vsr
3396 (f64 (PPCcv_fp_to_sint_in_vsr f128:$src)), xoaddr:$dst, 1),
3397 (STXSIBX (COPY_TO_REGCLASS (XSCVQPSWZ $src), VFRC), xoaddr:$dst)>;
3398 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huangc29229a2018-05-08 17:36:40 +00003399 (f64 (PPCcv_fp_to_sint_in_vsr f64:$src)), xaddr:$dst, 8),
3400 (STXSDX (XSCVDPSXDS f64:$src), xaddr:$dst)>;
3401 def : Pat<(PPCstore_scal_int_from_vsr
3402 (f64 (PPCcv_fp_to_sint_in_vsr f64:$src)), ixaddr:$dst, 8),
3403 (STXSD (XSCVDPSXDS f64:$src), ixaddr:$dst)>;
3404 def : Pat<(PPCstore_scal_int_from_vsr
3405 (f64 (PPCcv_fp_to_sint_in_vsr f64:$src)), xoaddr:$dst, 2),
3406 (STXSIHX (XSCVDPSXWS f64:$src), xoaddr:$dst)>;
3407 def : Pat<(PPCstore_scal_int_from_vsr
3408 (f64 (PPCcv_fp_to_sint_in_vsr f64:$src)), xoaddr:$dst, 1),
3409 (STXSIBX (XSCVDPSXWS f64:$src), xoaddr:$dst)>;
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00003410
Lei Huange41e3d32018-05-08 18:52:06 +00003411 // Instructions for store(fptoui).
Lei Huangc29229a2018-05-08 17:36:40 +00003412 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huangc517e952018-05-08 18:23:31 +00003413 (f64 (PPCcv_fp_to_uint_in_vsr f128:$src)), xaddr:$dst, 8),
3414 (STXSDX (COPY_TO_REGCLASS (XSCVQPUDZ f128:$src), VFRC),
3415 xaddr:$dst)>;
3416 def : Pat<(PPCstore_scal_int_from_vsr
3417 (f64 (PPCcv_fp_to_uint_in_vsr f128:$src)), ixaddr:$dst, 8),
3418 (STXSD (COPY_TO_REGCLASS (XSCVQPUDZ f128:$src), VFRC),
3419 ixaddr:$dst)>;
3420 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huang63642882018-05-08 18:34:00 +00003421 (f64 (PPCcv_fp_to_uint_in_vsr f128:$src)), xoaddr:$dst, 4),
3422 (STXSIWX (COPY_TO_REGCLASS (XSCVQPUWZ $src), VFRC), xoaddr:$dst)>;
3423 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huange41e3d32018-05-08 18:52:06 +00003424 (f64 (PPCcv_fp_to_uint_in_vsr f128:$src)), xoaddr:$dst, 2),
3425 (STXSIHX (COPY_TO_REGCLASS (XSCVQPUWZ $src), VFRC), xoaddr:$dst)>;
3426 def : Pat<(PPCstore_scal_int_from_vsr
3427 (f64 (PPCcv_fp_to_uint_in_vsr f128:$src)), xoaddr:$dst, 1),
3428 (STXSIBX (COPY_TO_REGCLASS (XSCVQPUWZ $src), VFRC), xoaddr:$dst)>;
3429 def : Pat<(PPCstore_scal_int_from_vsr
Lei Huangc29229a2018-05-08 17:36:40 +00003430 (f64 (PPCcv_fp_to_uint_in_vsr f64:$src)), xaddr:$dst, 8),
3431 (STXSDX (XSCVDPUXDS f64:$src), xaddr:$dst)>;
3432 def : Pat<(PPCstore_scal_int_from_vsr
3433 (f64 (PPCcv_fp_to_uint_in_vsr f64:$src)), ixaddr:$dst, 8),
3434 (STXSD (XSCVDPUXDS f64:$src), ixaddr:$dst)>;
3435 def : Pat<(PPCstore_scal_int_from_vsr
3436 (f64 (PPCcv_fp_to_uint_in_vsr f64:$src)), xoaddr:$dst, 2),
3437 (STXSIHX (XSCVDPUXWS f64:$src), xoaddr:$dst)>;
3438 def : Pat<(PPCstore_scal_int_from_vsr
3439 (f64 (PPCcv_fp_to_uint_in_vsr f64:$src)), xoaddr:$dst, 1),
3440 (STXSIBX (XSCVDPUXWS f64:$src), xoaddr:$dst)>;
3441
Lei Huang6270ab62018-07-04 21:59:16 +00003442 // Round & Convert QP -> DP/SP
3443 def : Pat<(f64 (fpround f128:$src)), (f64 (XSCVQPDP $src))>;
3444 def : Pat<(f32 (fpround f128:$src)), (f32 (XSRSP (XSCVQPDPO $src)))>;
Lei Huangd17c39c2018-07-05 04:18:37 +00003445
3446 // Convert SP -> QP
3447 def : Pat<(f128 (fpextend f32:$src)),
3448 (f128 (XSCVDPQP (COPY_TO_REGCLASS $src, VFRC)))>;
3449
Lei Huangc29229a2018-05-08 17:36:40 +00003450} // end HasP9Vector, AddedComplexity
Lei Huang6270ab62018-07-04 21:59:16 +00003451
Lei Huanga855e172018-07-05 06:21:37 +00003452let AddedComplexity = 400 in {
3453 let Predicates = [IsISA3_0, HasP9Vector, HasDirectMove, IsBigEndian] in {
3454 def : Pat<(f128 (PPCbuild_fp128 i64:$rB, i64:$rA)),
3455 (f128 (COPY_TO_REGCLASS (MTVSRDD $rB, $rA), VRRC))>;
3456 }
3457 let Predicates = [IsISA3_0, HasP9Vector, HasDirectMove, IsLittleEndian] in {
3458 def : Pat<(f128 (PPCbuild_fp128 i64:$rA, i64:$rB)),
3459 (f128 (COPY_TO_REGCLASS (MTVSRDD $rB, $rA), VRRC))>;
3460 }
3461}
3462
Zaara Syedafcd96972017-09-21 16:12:33 +00003463let Predicates = [HasP9Vector] in {
3464 let isPseudo = 1 in {
3465 let mayStore = 1 in {
Stefan Pintilie26d4f922018-03-26 17:39:18 +00003466 def SPILLTOVSR_STX : PseudoXFormMemOp<(outs),
3467 (ins spilltovsrrc:$XT, memrr:$dst),
3468 "#SPILLTOVSR_STX", []>;
Zaara Syedafcd96972017-09-21 16:12:33 +00003469 def SPILLTOVSR_ST : Pseudo<(outs), (ins spilltovsrrc:$XT, memrix:$dst),
3470 "#SPILLTOVSR_ST", []>;
3471 }
3472 let mayLoad = 1 in {
Stefan Pintilie26d4f922018-03-26 17:39:18 +00003473 def SPILLTOVSR_LDX : PseudoXFormMemOp<(outs spilltovsrrc:$XT),
3474 (ins memrr:$src),
3475 "#SPILLTOVSR_LDX", []>;
Zaara Syedafcd96972017-09-21 16:12:33 +00003476 def SPILLTOVSR_LD : Pseudo<(outs spilltovsrrc:$XT), (ins memrix:$src),
3477 "#SPILLTOVSR_LD", []>;
3478
3479 }
3480 }
3481}
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003482// Integer extend helper dags 32 -> 64
3483def AnyExts {
3484 dag A = (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $A, sub_32);
3485 dag B = (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $B, sub_32);
3486 dag C = (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $C, sub_32);
3487 dag D = (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $D, sub_32);
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00003488}
3489
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003490def DblToFlt {
3491 dag A0 = (f32 (fpround (f64 (extractelt v2f64:$A, 0))));
3492 dag A1 = (f32 (fpround (f64 (extractelt v2f64:$A, 1))));
3493 dag B0 = (f32 (fpround (f64 (extractelt v2f64:$B, 0))));
3494 dag B1 = (f32 (fpround (f64 (extractelt v2f64:$B, 1))));
3495}
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003496
3497def ByteToWord {
Tony Jiang9a91a182017-07-05 16:00:38 +00003498 dag LE_A0 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 0)), i8));
3499 dag LE_A1 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 4)), i8));
3500 dag LE_A2 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 8)), i8));
3501 dag LE_A3 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 12)), i8));
3502 dag BE_A0 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 3)), i8));
3503 dag BE_A1 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 7)), i8));
3504 dag BE_A2 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 11)), i8));
3505 dag BE_A3 = (i32 (sext_inreg (i32 (vector_extract v16i8:$A, 15)), i8));
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003506}
3507
3508def ByteToDWord {
Tony Jiang9a91a182017-07-05 16:00:38 +00003509 dag LE_A0 = (i64 (sext_inreg
3510 (i64 (anyext (i32 (vector_extract v16i8:$A, 0)))), i8));
3511 dag LE_A1 = (i64 (sext_inreg
3512 (i64 (anyext (i32 (vector_extract v16i8:$A, 8)))), i8));
3513 dag BE_A0 = (i64 (sext_inreg
3514 (i64 (anyext (i32 (vector_extract v16i8:$A, 7)))), i8));
3515 dag BE_A1 = (i64 (sext_inreg
3516 (i64 (anyext (i32 (vector_extract v16i8:$A, 15)))), i8));
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003517}
3518
3519def HWordToWord {
Tony Jiang9a91a182017-07-05 16:00:38 +00003520 dag LE_A0 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 0)), i16));
3521 dag LE_A1 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 2)), i16));
3522 dag LE_A2 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 4)), i16));
3523 dag LE_A3 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 6)), i16));
3524 dag BE_A0 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 1)), i16));
3525 dag BE_A1 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 3)), i16));
3526 dag BE_A2 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 5)), i16));
3527 dag BE_A3 = (i32 (sext_inreg (i32 (vector_extract v8i16:$A, 7)), i16));
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003528}
3529
3530def HWordToDWord {
Tony Jiang9a91a182017-07-05 16:00:38 +00003531 dag LE_A0 = (i64 (sext_inreg
3532 (i64 (anyext (i32 (vector_extract v8i16:$A, 0)))), i16));
3533 dag LE_A1 = (i64 (sext_inreg
3534 (i64 (anyext (i32 (vector_extract v8i16:$A, 4)))), i16));
3535 dag BE_A0 = (i64 (sext_inreg
3536 (i64 (anyext (i32 (vector_extract v8i16:$A, 3)))), i16));
3537 dag BE_A1 = (i64 (sext_inreg
3538 (i64 (anyext (i32 (vector_extract v8i16:$A, 7)))), i16));
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003539}
3540
3541def WordToDWord {
Tony Jiang9a91a182017-07-05 16:00:38 +00003542 dag LE_A0 = (i64 (sext (i32 (vector_extract v4i32:$A, 0))));
3543 dag LE_A1 = (i64 (sext (i32 (vector_extract v4i32:$A, 2))));
3544 dag BE_A0 = (i64 (sext (i32 (vector_extract v4i32:$A, 1))));
3545 dag BE_A1 = (i64 (sext (i32 (vector_extract v4i32:$A, 3))));
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003546}
3547
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003548def FltToIntLoad {
3549 dag A = (i32 (PPCmfvsr (PPCfctiwz (f64 (extloadf32 xoaddr:$A)))));
3550}
3551def FltToUIntLoad {
3552 dag A = (i32 (PPCmfvsr (PPCfctiwuz (f64 (extloadf32 xoaddr:$A)))));
3553}
3554def FltToLongLoad {
3555 dag A = (i64 (PPCmfvsr (PPCfctidz (f64 (extloadf32 xoaddr:$A)))));
3556}
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003557def FltToLongLoadP9 {
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003558 dag A = (i64 (PPCmfvsr (PPCfctidz (f64 (extloadf32 ixaddr:$A)))));
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003559}
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003560def FltToULongLoad {
3561 dag A = (i64 (PPCmfvsr (PPCfctiduz (f64 (extloadf32 xoaddr:$A)))));
3562}
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003563def FltToULongLoadP9 {
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003564 dag A = (i64 (PPCmfvsr (PPCfctiduz (f64 (extloadf32 ixaddr:$A)))));
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003565}
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003566def FltToLong {
Lei Huangcd4f3852018-03-12 19:26:18 +00003567 dag A = (i64 (PPCmfvsr (f64 (PPCfctidz (fpextend f32:$A)))));
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003568}
3569def FltToULong {
Lei Huangcd4f3852018-03-12 19:26:18 +00003570 dag A = (i64 (PPCmfvsr (f64 (PPCfctiduz (fpextend f32:$A)))));
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003571}
3572def DblToInt {
3573 dag A = (i32 (PPCmfvsr (f64 (PPCfctiwz f64:$A))));
3574}
3575def DblToUInt {
3576 dag A = (i32 (PPCmfvsr (f64 (PPCfctiwuz f64:$A))));
3577}
3578def DblToLong {
3579 dag A = (i64 (PPCmfvsr (f64 (PPCfctidz f64:$A))));
3580}
3581def DblToULong {
3582 dag A = (i64 (PPCmfvsr (f64 (PPCfctiduz f64:$A))));
3583}
3584def DblToIntLoad {
3585 dag A = (i32 (PPCmfvsr (PPCfctiwz (f64 (load xoaddr:$A)))));
3586}
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003587def DblToIntLoadP9 {
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003588 dag A = (i32 (PPCmfvsr (PPCfctiwz (f64 (load ixaddr:$A)))));
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003589}
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003590def DblToUIntLoad {
3591 dag A = (i32 (PPCmfvsr (PPCfctiwuz (f64 (load xoaddr:$A)))));
3592}
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003593def DblToUIntLoadP9 {
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003594 dag A = (i32 (PPCmfvsr (PPCfctiwuz (f64 (load ixaddr:$A)))));
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003595}
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003596def DblToLongLoad {
3597 dag A = (i64 (PPCmfvsr (PPCfctidz (f64 (load xoaddr:$A)))));
3598}
3599def DblToULongLoad {
3600 dag A = (i64 (PPCmfvsr (PPCfctiduz (f64 (load xoaddr:$A)))));
3601}
3602
3603// FP merge dags (for f32 -> v4f32)
3604def MrgFP {
3605 dag AC = (XVCVDPSP (XXPERMDI (COPY_TO_REGCLASS $A, VSRC),
3606 (COPY_TO_REGCLASS $C, VSRC), 0));
3607 dag BD = (XVCVDPSP (XXPERMDI (COPY_TO_REGCLASS $B, VSRC),
3608 (COPY_TO_REGCLASS $D, VSRC), 0));
3609 dag ABhToFlt = (XVCVDPSP (XXPERMDI $A, $B, 0));
3610 dag ABlToFlt = (XVCVDPSP (XXPERMDI $A, $B, 3));
3611 dag BAhToFlt = (XVCVDPSP (XXPERMDI $B, $A, 0));
3612 dag BAlToFlt = (XVCVDPSP (XXPERMDI $B, $A, 3));
3613}
3614
3615// Patterns for BUILD_VECTOR nodes.
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003616let AddedComplexity = 400 in {
3617
3618 let Predicates = [HasVSX] in {
3619 // Build vectors of floating point converted to i32.
3620 def : Pat<(v4i32 (build_vector DblToInt.A, DblToInt.A,
3621 DblToInt.A, DblToInt.A)),
3622 (v4i32 (XXSPLTW (COPY_TO_REGCLASS (XSCVDPSXWS $A), VSRC), 1))>;
3623 def : Pat<(v4i32 (build_vector DblToUInt.A, DblToUInt.A,
3624 DblToUInt.A, DblToUInt.A)),
3625 (v4i32 (XXSPLTW (COPY_TO_REGCLASS (XSCVDPUXWS $A), VSRC), 1))>;
3626 def : Pat<(v2i64 (build_vector DblToLong.A, DblToLong.A)),
3627 (v2i64 (XXPERMDI (COPY_TO_REGCLASS (XSCVDPSXDS $A), VSRC),
3628 (COPY_TO_REGCLASS (XSCVDPSXDS $A), VSRC), 0))>;
3629 def : Pat<(v2i64 (build_vector DblToULong.A, DblToULong.A)),
3630 (v2i64 (XXPERMDI (COPY_TO_REGCLASS (XSCVDPUXDS $A), VSRC),
3631 (COPY_TO_REGCLASS (XSCVDPUXDS $A), VSRC), 0))>;
3632 def : Pat<(v4i32 (scalar_to_vector FltToIntLoad.A)),
3633 (v4i32 (XXSPLTW (COPY_TO_REGCLASS
Tony Jiang438bf4a2017-11-20 14:38:30 +00003634 (XSCVDPSXWSs (XFLOADf32 xoaddr:$A)), VSRC), 1))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003635 def : Pat<(v4i32 (scalar_to_vector FltToUIntLoad.A)),
3636 (v4i32 (XXSPLTW (COPY_TO_REGCLASS
Tony Jiang438bf4a2017-11-20 14:38:30 +00003637 (XSCVDPUXWSs (XFLOADf32 xoaddr:$A)), VSRC), 1))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003638 def : Pat<(v4f32 (build_vector f32:$A, f32:$A, f32:$A, f32:$A)),
3639 (v4f32 (XXSPLTW (v4f32 (XSCVDPSPN $A)), 0))>;
3640
3641 // Build vectors of floating point converted to i64.
3642 def : Pat<(v2i64 (build_vector FltToLong.A, FltToLong.A)),
Nemanja Ivanovic15748f42016-12-06 11:47:14 +00003643 (v2i64 (XXPERMDIs
3644 (COPY_TO_REGCLASS (XSCVDPSXDSs $A), VSFRC), 0))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003645 def : Pat<(v2i64 (build_vector FltToULong.A, FltToULong.A)),
Nemanja Ivanovic15748f42016-12-06 11:47:14 +00003646 (v2i64 (XXPERMDIs
3647 (COPY_TO_REGCLASS (XSCVDPUXDSs $A), VSFRC), 0))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003648 def : Pat<(v2i64 (scalar_to_vector DblToLongLoad.A)),
3649 (v2i64 (XVCVDPSXDS (LXVDSX xoaddr:$A)))>;
3650 def : Pat<(v2i64 (scalar_to_vector DblToULongLoad.A)),
3651 (v2i64 (XVCVDPUXDS (LXVDSX xoaddr:$A)))>;
3652 }
3653
3654 let Predicates = [HasVSX, NoP9Vector] in {
Tony Jiang438bf4a2017-11-20 14:38:30 +00003655 // Load-and-splat with fp-to-int conversion (using X-Form VSX/FP loads).
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003656 def : Pat<(v4i32 (scalar_to_vector DblToIntLoad.A)),
3657 (v4i32 (XXSPLTW (COPY_TO_REGCLASS
Tony Jiang438bf4a2017-11-20 14:38:30 +00003658 (XSCVDPSXWS (XFLOADf64 xoaddr:$A)), VSRC), 1))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003659 def : Pat<(v4i32 (scalar_to_vector DblToUIntLoad.A)),
3660 (v4i32 (XXSPLTW (COPY_TO_REGCLASS
Tony Jiang438bf4a2017-11-20 14:38:30 +00003661 (XSCVDPUXWS (XFLOADf64 xoaddr:$A)), VSRC), 1))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003662 def : Pat<(v2i64 (scalar_to_vector FltToLongLoad.A)),
3663 (v2i64 (XXPERMDIs (XSCVDPSXDS (COPY_TO_REGCLASS
Tony Jiang438bf4a2017-11-20 14:38:30 +00003664 (XFLOADf32 xoaddr:$A), VSFRC)), 0))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003665 def : Pat<(v2i64 (scalar_to_vector FltToULongLoad.A)),
3666 (v2i64 (XXPERMDIs (XSCVDPUXDS (COPY_TO_REGCLASS
Tony Jiang438bf4a2017-11-20 14:38:30 +00003667 (XFLOADf32 xoaddr:$A), VSFRC)), 0))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003668 }
3669
3670 // Big endian, available on all targets with VSX
3671 let Predicates = [IsBigEndian, HasVSX] in {
3672 def : Pat<(v2f64 (build_vector f64:$A, f64:$B)),
3673 (v2f64 (XXPERMDI
3674 (COPY_TO_REGCLASS $A, VSRC),
3675 (COPY_TO_REGCLASS $B, VSRC), 0))>;
3676
3677 def : Pat<(v4f32 (build_vector f32:$A, f32:$B, f32:$C, f32:$D)),
3678 (VMRGEW MrgFP.AC, MrgFP.BD)>;
3679 def : Pat<(v4f32 (build_vector DblToFlt.A0, DblToFlt.A1,
3680 DblToFlt.B0, DblToFlt.B1)),
3681 (v4f32 (VMRGEW MrgFP.ABhToFlt, MrgFP.ABlToFlt))>;
3682 }
3683
3684 let Predicates = [IsLittleEndian, HasVSX] in {
3685 // Little endian, available on all targets with VSX
3686 def : Pat<(v2f64 (build_vector f64:$A, f64:$B)),
3687 (v2f64 (XXPERMDI
3688 (COPY_TO_REGCLASS $B, VSRC),
3689 (COPY_TO_REGCLASS $A, VSRC), 0))>;
3690
3691 def : Pat<(v4f32 (build_vector f32:$D, f32:$C, f32:$B, f32:$A)),
3692 (VMRGEW MrgFP.AC, MrgFP.BD)>;
3693 def : Pat<(v4f32 (build_vector DblToFlt.A0, DblToFlt.A1,
3694 DblToFlt.B0, DblToFlt.B1)),
3695 (v4f32 (VMRGEW MrgFP.BAhToFlt, MrgFP.BAlToFlt))>;
3696 }
3697
3698 let Predicates = [HasDirectMove] in {
3699 // Endianness-neutral constant splat on P8 and newer targets. The reason
3700 // for this pattern is that on targets with direct moves, we don't expand
3701 // BUILD_VECTOR nodes for v4i32.
3702 def : Pat<(v4i32 (build_vector immSExt5NonZero:$A, immSExt5NonZero:$A,
3703 immSExt5NonZero:$A, immSExt5NonZero:$A)),
3704 (v4i32 (VSPLTISW imm:$A))>;
3705 }
3706
3707 let Predicates = [IsBigEndian, HasDirectMove, NoP9Vector] in {
3708 // Big endian integer vectors using direct moves.
3709 def : Pat<(v2i64 (build_vector i64:$A, i64:$B)),
3710 (v2i64 (XXPERMDI
3711 (COPY_TO_REGCLASS (MTVSRD $A), VSRC),
3712 (COPY_TO_REGCLASS (MTVSRD $B), VSRC), 0))>;
3713 def : Pat<(v4i32 (build_vector i32:$A, i32:$B, i32:$C, i32:$D)),
3714 (VMRGOW (XXPERMDI (COPY_TO_REGCLASS (MTVSRWZ $A), VSRC),
3715 (COPY_TO_REGCLASS (MTVSRWZ $C), VSRC), 0),
3716 (XXPERMDI (COPY_TO_REGCLASS (MTVSRWZ $B), VSRC),
3717 (COPY_TO_REGCLASS (MTVSRWZ $D), VSRC), 0))>;
3718 def : Pat<(v4i32 (build_vector i32:$A, i32:$A, i32:$A, i32:$A)),
3719 (XXSPLTW (COPY_TO_REGCLASS (MTVSRWZ $A), VSRC), 1)>;
3720 }
3721
3722 let Predicates = [IsLittleEndian, HasDirectMove, NoP9Vector] in {
3723 // Little endian integer vectors using direct moves.
3724 def : Pat<(v2i64 (build_vector i64:$A, i64:$B)),
3725 (v2i64 (XXPERMDI
3726 (COPY_TO_REGCLASS (MTVSRD $B), VSRC),
3727 (COPY_TO_REGCLASS (MTVSRD $A), VSRC), 0))>;
3728 def : Pat<(v4i32 (build_vector i32:$A, i32:$B, i32:$C, i32:$D)),
3729 (VMRGOW (XXPERMDI (COPY_TO_REGCLASS (MTVSRWZ $D), VSRC),
3730 (COPY_TO_REGCLASS (MTVSRWZ $B), VSRC), 0),
3731 (XXPERMDI (COPY_TO_REGCLASS (MTVSRWZ $C), VSRC),
3732 (COPY_TO_REGCLASS (MTVSRWZ $A), VSRC), 0))>;
3733 def : Pat<(v4i32 (build_vector i32:$A, i32:$A, i32:$A, i32:$A)),
3734 (XXSPLTW (COPY_TO_REGCLASS (MTVSRWZ $A), VSRC), 1)>;
3735 }
3736
3737 let Predicates = [HasP9Vector] in {
3738 // Endianness-neutral patterns for const splats with ISA 3.0 instructions.
3739 def : Pat<(v4i32 (scalar_to_vector i32:$A)),
3740 (v4i32 (MTVSRWS $A))>;
3741 def : Pat<(v4i32 (build_vector i32:$A, i32:$A, i32:$A, i32:$A)),
3742 (v4i32 (MTVSRWS $A))>;
Nemanja Ivanovic552c8e92016-12-15 11:16:20 +00003743 def : Pat<(v16i8 (build_vector immAnyExt8:$A, immAnyExt8:$A, immAnyExt8:$A,
3744 immAnyExt8:$A, immAnyExt8:$A, immAnyExt8:$A,
3745 immAnyExt8:$A, immAnyExt8:$A, immAnyExt8:$A,
3746 immAnyExt8:$A, immAnyExt8:$A, immAnyExt8:$A,
3747 immAnyExt8:$A, immAnyExt8:$A, immAnyExt8:$A,
3748 immAnyExt8:$A)),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003749 (v16i8 (COPY_TO_REGCLASS (XXSPLTIB imm:$A), VSRC))>;
3750 def : Pat<(v16i8 immAllOnesV),
3751 (v16i8 (COPY_TO_REGCLASS (XXSPLTIB 255), VSRC))>;
3752 def : Pat<(v8i16 immAllOnesV),
3753 (v8i16 (COPY_TO_REGCLASS (XXSPLTIB 255), VSRC))>;
3754 def : Pat<(v4i32 immAllOnesV),
3755 (v4i32 (XXSPLTIB 255))>;
3756 def : Pat<(v2i64 immAllOnesV),
3757 (v2i64 (XXSPLTIB 255))>;
3758 def : Pat<(v4i32 (scalar_to_vector FltToIntLoad.A)),
3759 (v4i32 (XVCVSPSXWS (LXVWSX xoaddr:$A)))>;
3760 def : Pat<(v4i32 (scalar_to_vector FltToUIntLoad.A)),
3761 (v4i32 (XVCVSPUXWS (LXVWSX xoaddr:$A)))>;
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003762 def : Pat<(v4i32 (scalar_to_vector DblToIntLoadP9.A)),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003763 (v4i32 (XXSPLTW (COPY_TO_REGCLASS
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003764 (XSCVDPSXWS (DFLOADf64 ixaddr:$A)), VSRC), 1))>;
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003765 def : Pat<(v4i32 (scalar_to_vector DblToUIntLoadP9.A)),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003766 (v4i32 (XXSPLTW (COPY_TO_REGCLASS
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003767 (XSCVDPUXWS (DFLOADf64 ixaddr:$A)), VSRC), 1))>;
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003768 def : Pat<(v2i64 (scalar_to_vector FltToLongLoadP9.A)),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003769 (v2i64 (XXPERMDIs (XSCVDPSXDS (COPY_TO_REGCLASS
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003770 (DFLOADf32 ixaddr:$A),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003771 VSFRC)), 0))>;
Hiroshi Inouee3c14eb2017-05-29 07:12:39 +00003772 def : Pat<(v2i64 (scalar_to_vector FltToULongLoadP9.A)),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003773 (v2i64 (XXPERMDIs (XSCVDPUXDS (COPY_TO_REGCLASS
Nemanja Ivanovic3c7e276d2017-07-13 18:17:10 +00003774 (DFLOADf32 ixaddr:$A),
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003775 VSFRC)), 0))>;
3776 }
3777
3778 let Predicates = [IsISA3_0, HasDirectMove, IsBigEndian] in {
3779 def : Pat<(i64 (extractelt v2i64:$A, 1)),
3780 (i64 (MFVSRLD $A))>;
3781 // Better way to build integer vectors if we have MTVSRDD. Big endian.
3782 def : Pat<(v2i64 (build_vector i64:$rB, i64:$rA)),
3783 (v2i64 (MTVSRDD $rB, $rA))>;
3784 def : Pat<(v4i32 (build_vector i32:$A, i32:$B, i32:$C, i32:$D)),
Lei Huangcd4f3852018-03-12 19:26:18 +00003785 (VMRGOW
3786 (v4i32 (COPY_TO_REGCLASS (MTVSRDD AnyExts.A, AnyExts.C), VSRC)),
3787 (v4i32
3788 (COPY_TO_REGCLASS (MTVSRDD AnyExts.B, AnyExts.D), VSRC)))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003789 }
3790
3791 let Predicates = [IsISA3_0, HasDirectMove, IsLittleEndian] in {
3792 def : Pat<(i64 (extractelt v2i64:$A, 0)),
3793 (i64 (MFVSRLD $A))>;
3794 // Better way to build integer vectors if we have MTVSRDD. Little endian.
3795 def : Pat<(v2i64 (build_vector i64:$rA, i64:$rB)),
3796 (v2i64 (MTVSRDD $rB, $rA))>;
3797 def : Pat<(v4i32 (build_vector i32:$A, i32:$B, i32:$C, i32:$D)),
Lei Huangcd4f3852018-03-12 19:26:18 +00003798 (VMRGOW
3799 (v4i32 (COPY_TO_REGCLASS (MTVSRDD AnyExts.D, AnyExts.B), VSRC)),
3800 (v4i32
3801 (COPY_TO_REGCLASS (MTVSRDD AnyExts.C, AnyExts.A), VSRC)))>;
Nemanja Ivanovicdf1cb522016-11-29 16:11:34 +00003802 }
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003803 // P9 Altivec instructions that can be used to build vectors.
3804 // Adding them to PPCInstrVSX.td rather than PPCAltivecVSX.td to compete
3805 // with complexities of existing build vector patterns in this file.
Tony Jiang9a91a182017-07-05 16:00:38 +00003806 let Predicates = [HasP9Altivec, IsLittleEndian] in {
3807 def : Pat<(v2i64 (build_vector WordToDWord.LE_A0, WordToDWord.LE_A1)),
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003808 (v2i64 (VEXTSW2D $A))>;
Tony Jiang9a91a182017-07-05 16:00:38 +00003809 def : Pat<(v2i64 (build_vector HWordToDWord.LE_A0, HWordToDWord.LE_A1)),
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003810 (v2i64 (VEXTSH2D $A))>;
Tony Jiang9a91a182017-07-05 16:00:38 +00003811 def : Pat<(v4i32 (build_vector HWordToWord.LE_A0, HWordToWord.LE_A1,
3812 HWordToWord.LE_A2, HWordToWord.LE_A3)),
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003813 (v4i32 (VEXTSH2W $A))>;
Tony Jiang9a91a182017-07-05 16:00:38 +00003814 def : Pat<(v4i32 (build_vector ByteToWord.LE_A0, ByteToWord.LE_A1,
3815 ByteToWord.LE_A2, ByteToWord.LE_A3)),
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003816 (v4i32 (VEXTSB2W $A))>;
Tony Jiang9a91a182017-07-05 16:00:38 +00003817 def : Pat<(v2i64 (build_vector ByteToDWord.LE_A0, ByteToDWord.LE_A1)),
Zaara Syeda79acbbe2017-06-08 17:14:36 +00003818 (v2i64 (VEXTSB2D $A))>;
3819 }
Tony Jiang9a91a182017-07-05 16:00:38 +00003820
3821 let Predicates = [HasP9Altivec, IsBigEndian] in {
3822 def : Pat<(v2i64 (build_vector WordToDWord.BE_A0, WordToDWord.BE_A1)),
3823 (v2i64 (VEXTSW2D $A))>;
3824 def : Pat<(v2i64 (build_vector HWordToDWord.BE_A0, HWordToDWord.BE_A1)),
3825 (v2i64 (VEXTSH2D $A))>;
3826 def : Pat<(v4i32 (build_vector HWordToWord.BE_A0, HWordToWord.BE_A1,
3827 HWordToWord.BE_A2, HWordToWord.BE_A3)),
3828 (v4i32 (VEXTSH2W $A))>;
3829 def : Pat<(v4i32 (build_vector ByteToWord.BE_A0, ByteToWord.BE_A1,
3830 ByteToWord.BE_A2, ByteToWord.BE_A3)),
3831 (v4i32 (VEXTSB2W $A))>;
3832 def : Pat<(v2i64 (build_vector ByteToDWord.BE_A0, ByteToDWord.BE_A1)),
3833 (v2i64 (VEXTSB2D $A))>;
3834 }
3835
3836 let Predicates = [HasP9Altivec] in {
3837 def: Pat<(v2i64 (PPCSExtVElems v16i8:$A)),
3838 (v2i64 (VEXTSB2D $A))>;
3839 def: Pat<(v2i64 (PPCSExtVElems v8i16:$A)),
3840 (v2i64 (VEXTSH2D $A))>;
3841 def: Pat<(v2i64 (PPCSExtVElems v4i32:$A)),
3842 (v2i64 (VEXTSW2D $A))>;
3843 def: Pat<(v4i32 (PPCSExtVElems v16i8:$A)),
3844 (v4i32 (VEXTSB2W $A))>;
3845 def: Pat<(v4i32 (PPCSExtVElems v8i16:$A)),
3846 (v4i32 (VEXTSH2W $A))>;
3847 }
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00003848}