blob: deaecbd9c5b79c07c90d1c95e8d30ebc711f1184 [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
Bill Schmidtfae5d712014-12-09 16:35:51 +000050// Little-endian-specific nodes.
51def SDT_PPClxvd2x : SDTypeProfile<1, 1, [
52 SDTCisVT<0, v2f64>, SDTCisPtrTy<1>
53]>;
54def SDT_PPCstxvd2x : SDTypeProfile<0, 2, [
55 SDTCisVT<0, v2f64>, SDTCisPtrTy<1>
56]>;
57def SDT_PPCxxswapd : SDTypeProfile<1, 1, [
58 SDTCisSameAs<0, 1>
59]>;
Nemanja Ivanovic44513e52016-07-05 09:22:29 +000060def SDTVecConv : SDTypeProfile<1, 2, [
61 SDTCisVec<0>, SDTCisVec<1>, SDTCisPtrTy<2>
62]>;
Bill Schmidtfae5d712014-12-09 16:35:51 +000063
64def PPClxvd2x : SDNode<"PPCISD::LXVD2X", SDT_PPClxvd2x,
65 [SDNPHasChain, SDNPMayLoad]>;
66def PPCstxvd2x : SDNode<"PPCISD::STXVD2X", SDT_PPCstxvd2x,
67 [SDNPHasChain, SDNPMayStore]>;
68def PPCxxswapd : SDNode<"PPCISD::XXSWAPD", SDT_PPCxxswapd, [SDNPHasChain]>;
Nemanja Ivanovicc38b5312015-04-11 10:40:42 +000069def PPCmfvsr : SDNode<"PPCISD::MFVSR", SDTUnaryOp, []>;
70def PPCmtvsra : SDNode<"PPCISD::MTVSRA", SDTUnaryOp, []>;
71def PPCmtvsrz : SDNode<"PPCISD::MTVSRZ", SDTUnaryOp, []>;
Nemanja Ivanovic44513e52016-07-05 09:22:29 +000072def PPCsvec2fp : SDNode<"PPCISD::SINT_VEC_TO_FP", SDTVecConv, []>;
73def PPCuvec2fp: SDNode<"PPCISD::UINT_VEC_TO_FP", SDTVecConv, []>;
Nemanja Ivanoviceebbcb62016-07-12 12:16:27 +000074def PPCswapNoChain : SDNode<"PPCISD::SWAP_NO_CHAIN", SDT_PPCxxswapd>;
Bill Schmidtfae5d712014-12-09 16:35:51 +000075
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +000076multiclass XX3Form_Rcr<bits<6> opcode, bits<7> xo, string asmbase,
77 string asmstr, InstrItinClass itin, Intrinsic Int,
78 ValueType OutTy, ValueType InTy> {
Hal Finkel27774d92014-03-13 07:58:58 +000079 let BaseName = asmbase in {
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +000080 def NAME : XX3Form_Rc<opcode, xo, (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +000081 !strconcat(asmbase, !strconcat(" ", asmstr)), itin,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +000082 [(set OutTy:$XT, (Int InTy:$XA, InTy:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +000083 let Defs = [CR6] in
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +000084 def o : XX3Form_Rc<opcode, xo, (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +000085 !strconcat(asmbase, !strconcat(". ", asmstr)), itin,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +000086 [(set InTy:$XT,
87 (InTy (PPCvcmp_o InTy:$XA, InTy:$XB, xo)))]>,
88 isDOT;
Hal Finkel27774d92014-03-13 07:58:58 +000089 }
90}
91
Nemanja Ivanovic11049f82016-10-04 06:59:23 +000092// Instruction form with a single input register for instructions such as
93// XXPERMDI. The reason for defining this is that specifying multiple chained
94// operands (such as loads) to an instruction will perform both chained
95// operations rather than coalescing them into a single register - even though
96// the source memory location is the same. This simply forces the instruction
97// to use the same register for both inputs.
98// For example, an output DAG such as this:
99// (XXPERMDI (LXSIBZX xoaddr:$src), (LXSIBZX xoaddr:$src ), 0))
100// would result in two load instructions emitted and used as separate inputs
101// to the XXPERMDI instruction.
102class XX3Form_2s<bits<6> opcode, bits<5> xo, dag OOL, dag IOL, string asmstr,
103 InstrItinClass itin, list<dag> pattern>
104 : XX3Form_2<opcode, xo, OOL, IOL, asmstr, itin, pattern> {
105 let XB = XA;
106}
107
Eric Christopher1b8e7632014-05-22 01:07:24 +0000108def HasVSX : Predicate<"PPCSubTarget->hasVSX()">;
Bill Schmidtfae5d712014-12-09 16:35:51 +0000109def IsLittleEndian : Predicate<"PPCSubTarget->isLittleEndian()">;
110def IsBigEndian : Predicate<"!PPCSubTarget->isLittleEndian()">;
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +0000111def HasOnlySwappingMemOps : Predicate<"!PPCSubTarget->hasP9Vector()">;
Bill Schmidtfae5d712014-12-09 16:35:51 +0000112
Hal Finkel27774d92014-03-13 07:58:58 +0000113let Predicates = [HasVSX] in {
114let AddedComplexity = 400 in { // Prefer VSX patterns over non-VSX patterns.
Nemanja Ivanovic11049f82016-10-04 06:59:23 +0000115let UseVSXReg = 1 in {
Craig Topperc50d64b2014-11-26 00:46:26 +0000116let hasSideEffects = 0 in { // VSX instructions don't have side effects.
Hal Finkel27774d92014-03-13 07:58:58 +0000117let Uses = [RM] in {
118
119 // Load indexed instructions
Hal Finkel6a778fb2015-03-11 23:28:38 +0000120 let mayLoad = 1 in {
Nemanja Ivanovic6354d232016-10-04 11:25:52 +0000121 let CodeSize = 3 in
Bill Schmidtcb34fd02014-10-09 17:51:35 +0000122 def LXSDX : XX1Form<31, 588,
Hal Finkel19be5062014-03-29 05:29:01 +0000123 (outs vsfrc:$XT), (ins memrr:$src),
Hal Finkel27774d92014-03-13 07:58:58 +0000124 "lxsdx $XT, $src", IIC_LdStLFD,
125 [(set f64:$XT, (load xoaddr:$src))]>;
126
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +0000127 let Predicates = [HasVSX, HasOnlySwappingMemOps] in
Bill Schmidtcb34fd02014-10-09 17:51:35 +0000128 def LXVD2X : XX1Form<31, 844,
Hal Finkel27774d92014-03-13 07:58:58 +0000129 (outs vsrc:$XT), (ins memrr:$src),
130 "lxvd2x $XT, $src", IIC_LdStLFD,
Bill Schmidt72954782014-11-12 04:19:40 +0000131 [(set v2f64:$XT, (int_ppc_vsx_lxvd2x xoaddr:$src))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000132
Bill Schmidtcb34fd02014-10-09 17:51:35 +0000133 def LXVDSX : XX1Form<31, 332,
Hal Finkel27774d92014-03-13 07:58:58 +0000134 (outs vsrc:$XT), (ins memrr:$src),
135 "lxvdsx $XT, $src", IIC_LdStLFD, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000136
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +0000137 let Predicates = [HasVSX, HasOnlySwappingMemOps] in
Bill Schmidtcb34fd02014-10-09 17:51:35 +0000138 def LXVW4X : XX1Form<31, 780,
Hal Finkel27774d92014-03-13 07:58:58 +0000139 (outs vsrc:$XT), (ins memrr:$src),
Bill Schmidt2d1128a2014-10-17 15:13:38 +0000140 "lxvw4x $XT, $src", IIC_LdStLFD,
Bill Schmidt72954782014-11-12 04:19:40 +0000141 [(set v4i32:$XT, (int_ppc_vsx_lxvw4x xoaddr:$src))]>;
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +0000142 } // mayLoad
Hal Finkel27774d92014-03-13 07:58:58 +0000143
144 // Store indexed instructions
145 let mayStore = 1 in {
Nemanja Ivanovic6354d232016-10-04 11:25:52 +0000146 let CodeSize = 3 in
Hal Finkel27774d92014-03-13 07:58:58 +0000147 def STXSDX : XX1Form<31, 716,
Hal Finkel19be5062014-03-29 05:29:01 +0000148 (outs), (ins vsfrc:$XT, memrr:$dst),
Hal Finkel27774d92014-03-13 07:58:58 +0000149 "stxsdx $XT, $dst", IIC_LdStSTFD,
150 [(store f64:$XT, xoaddr:$dst)]>;
151
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +0000152 let Predicates = [HasVSX, HasOnlySwappingMemOps] in {
Nemanja Ivanovice78ffed2016-09-22 10:32:03 +0000153 // The behaviour of this instruction is endianness-specific so we provide no
154 // pattern to match it without considering endianness.
Hal Finkel27774d92014-03-13 07:58:58 +0000155 def STXVD2X : XX1Form<31, 972,
156 (outs), (ins vsrc:$XT, memrr:$dst),
157 "stxvd2x $XT, $dst", IIC_LdStSTFD,
Nemanja Ivanovice78ffed2016-09-22 10:32:03 +0000158 []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000159
160 def STXVW4X : XX1Form<31, 908,
161 (outs), (ins vsrc:$XT, memrr:$dst),
Bill Schmidt2d1128a2014-10-17 15:13:38 +0000162 "stxvw4x $XT, $dst", IIC_LdStSTFD,
Hal Finkele3d2b202015-02-01 19:07:41 +0000163 [(store v4i32:$XT, xoaddr:$dst)]>;
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +0000164 }
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +0000165 } // mayStore
Hal Finkel27774d92014-03-13 07:58:58 +0000166
167 // Add/Mul Instructions
168 let isCommutable = 1 in {
169 def XSADDDP : XX3Form<60, 32,
Hal Finkel19be5062014-03-29 05:29:01 +0000170 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000171 "xsadddp $XT, $XA, $XB", IIC_VecFP,
172 [(set f64:$XT, (fadd f64:$XA, f64:$XB))]>;
173 def XSMULDP : XX3Form<60, 48,
Hal Finkel19be5062014-03-29 05:29:01 +0000174 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000175 "xsmuldp $XT, $XA, $XB", IIC_VecFP,
176 [(set f64:$XT, (fmul f64:$XA, f64:$XB))]>;
177
178 def XVADDDP : XX3Form<60, 96,
179 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
180 "xvadddp $XT, $XA, $XB", IIC_VecFP,
181 [(set v2f64:$XT, (fadd v2f64:$XA, v2f64:$XB))]>;
182
183 def XVADDSP : XX3Form<60, 64,
184 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
185 "xvaddsp $XT, $XA, $XB", IIC_VecFP,
186 [(set v4f32:$XT, (fadd v4f32:$XA, v4f32:$XB))]>;
187
188 def XVMULDP : XX3Form<60, 112,
189 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
190 "xvmuldp $XT, $XA, $XB", IIC_VecFP,
191 [(set v2f64:$XT, (fmul v2f64:$XA, v2f64:$XB))]>;
192
193 def XVMULSP : XX3Form<60, 80,
194 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
195 "xvmulsp $XT, $XA, $XB", IIC_VecFP,
196 [(set v4f32:$XT, (fmul v4f32:$XA, v4f32:$XB))]>;
197 }
198
199 // Subtract Instructions
200 def XSSUBDP : XX3Form<60, 40,
Hal Finkel19be5062014-03-29 05:29:01 +0000201 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000202 "xssubdp $XT, $XA, $XB", IIC_VecFP,
203 [(set f64:$XT, (fsub f64:$XA, f64:$XB))]>;
204
205 def XVSUBDP : XX3Form<60, 104,
206 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
207 "xvsubdp $XT, $XA, $XB", IIC_VecFP,
208 [(set v2f64:$XT, (fsub v2f64:$XA, v2f64:$XB))]>;
209 def XVSUBSP : XX3Form<60, 72,
210 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
211 "xvsubsp $XT, $XA, $XB", IIC_VecFP,
212 [(set v4f32:$XT, (fsub v4f32:$XA, v4f32:$XB))]>;
213
214 // FMA Instructions
Hal Finkel25e04542014-03-25 18:55:11 +0000215 let BaseName = "XSMADDADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000216 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000217 def XSMADDADP : XX3Form<60, 33,
Hal Finkel19be5062014-03-29 05:29:01 +0000218 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000219 "xsmaddadp $XT, $XA, $XB", IIC_VecFP,
220 [(set f64:$XT, (fma f64:$XA, f64:$XB, f64:$XTi))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000221 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
222 AltVSXFMARel;
223 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000224 def XSMADDMDP : XX3Form<60, 41,
Hal Finkel19be5062014-03-29 05:29:01 +0000225 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000226 "xsmaddmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000227 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
228 AltVSXFMARel;
229 }
Hal Finkel27774d92014-03-13 07:58:58 +0000230
Hal Finkel25e04542014-03-25 18:55:11 +0000231 let BaseName = "XSMSUBADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000232 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000233 def XSMSUBADP : XX3Form<60, 49,
Hal Finkel19be5062014-03-29 05:29:01 +0000234 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000235 "xsmsubadp $XT, $XA, $XB", IIC_VecFP,
236 [(set f64:$XT, (fma f64:$XA, f64:$XB, (fneg f64:$XTi)))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000237 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
238 AltVSXFMARel;
239 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000240 def XSMSUBMDP : XX3Form<60, 57,
Hal Finkel19be5062014-03-29 05:29:01 +0000241 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000242 "xsmsubmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000243 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
244 AltVSXFMARel;
245 }
Hal Finkel27774d92014-03-13 07:58:58 +0000246
Hal Finkel25e04542014-03-25 18:55:11 +0000247 let BaseName = "XSNMADDADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000248 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000249 def XSNMADDADP : XX3Form<60, 161,
Hal Finkel19be5062014-03-29 05:29:01 +0000250 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000251 "xsnmaddadp $XT, $XA, $XB", IIC_VecFP,
252 [(set f64:$XT, (fneg (fma f64:$XA, f64:$XB, f64:$XTi)))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000253 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
254 AltVSXFMARel;
255 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000256 def XSNMADDMDP : XX3Form<60, 169,
Hal Finkel19be5062014-03-29 05:29:01 +0000257 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000258 "xsnmaddmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000259 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
260 AltVSXFMARel;
261 }
Hal Finkel27774d92014-03-13 07:58:58 +0000262
Hal Finkel25e04542014-03-25 18:55:11 +0000263 let BaseName = "XSNMSUBADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000264 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000265 def XSNMSUBADP : XX3Form<60, 177,
Hal Finkel19be5062014-03-29 05:29:01 +0000266 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000267 "xsnmsubadp $XT, $XA, $XB", IIC_VecFP,
268 [(set f64:$XT, (fneg (fma f64:$XA, f64:$XB, (fneg f64:$XTi))))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000269 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
270 AltVSXFMARel;
271 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000272 def XSNMSUBMDP : XX3Form<60, 185,
Hal Finkel19be5062014-03-29 05:29:01 +0000273 (outs vsfrc:$XT), (ins vsfrc:$XTi, vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000274 "xsnmsubmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000275 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
276 AltVSXFMARel;
277 }
Hal Finkel27774d92014-03-13 07:58:58 +0000278
Hal Finkel25e04542014-03-25 18:55:11 +0000279 let BaseName = "XVMADDADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000280 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000281 def XVMADDADP : XX3Form<60, 97,
282 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
283 "xvmaddadp $XT, $XA, $XB", IIC_VecFP,
284 [(set v2f64:$XT, (fma v2f64:$XA, v2f64:$XB, v2f64:$XTi))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000285 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
286 AltVSXFMARel;
287 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000288 def XVMADDMDP : XX3Form<60, 105,
289 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
290 "xvmaddmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000291 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
292 AltVSXFMARel;
293 }
Hal Finkel27774d92014-03-13 07:58:58 +0000294
Hal Finkel25e04542014-03-25 18:55:11 +0000295 let BaseName = "XVMADDASP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000296 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000297 def XVMADDASP : XX3Form<60, 65,
298 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
299 "xvmaddasp $XT, $XA, $XB", IIC_VecFP,
300 [(set v4f32:$XT, (fma v4f32:$XA, v4f32:$XB, v4f32:$XTi))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000301 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
302 AltVSXFMARel;
303 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000304 def XVMADDMSP : XX3Form<60, 73,
305 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
306 "xvmaddmsp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000307 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
308 AltVSXFMARel;
309 }
Hal Finkel27774d92014-03-13 07:58:58 +0000310
Hal Finkel25e04542014-03-25 18:55:11 +0000311 let BaseName = "XVMSUBADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000312 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000313 def XVMSUBADP : XX3Form<60, 113,
314 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
315 "xvmsubadp $XT, $XA, $XB", IIC_VecFP,
316 [(set v2f64:$XT, (fma v2f64:$XA, v2f64:$XB, (fneg v2f64:$XTi)))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000317 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
318 AltVSXFMARel;
319 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000320 def XVMSUBMDP : XX3Form<60, 121,
321 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
322 "xvmsubmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000323 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
324 AltVSXFMARel;
325 }
Hal Finkel27774d92014-03-13 07:58:58 +0000326
Hal Finkel25e04542014-03-25 18:55:11 +0000327 let BaseName = "XVMSUBASP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000328 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000329 def XVMSUBASP : XX3Form<60, 81,
330 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
331 "xvmsubasp $XT, $XA, $XB", IIC_VecFP,
332 [(set v4f32:$XT, (fma v4f32:$XA, v4f32:$XB, (fneg v4f32:$XTi)))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000333 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
334 AltVSXFMARel;
335 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000336 def XVMSUBMSP : XX3Form<60, 89,
337 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
338 "xvmsubmsp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000339 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
340 AltVSXFMARel;
341 }
Hal Finkel27774d92014-03-13 07:58:58 +0000342
Hal Finkel25e04542014-03-25 18:55:11 +0000343 let BaseName = "XVNMADDADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000344 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000345 def XVNMADDADP : XX3Form<60, 225,
346 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
347 "xvnmaddadp $XT, $XA, $XB", IIC_VecFP,
348 [(set v2f64:$XT, (fneg (fma v2f64:$XA, v2f64:$XB, v2f64:$XTi)))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000349 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
350 AltVSXFMARel;
351 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000352 def XVNMADDMDP : XX3Form<60, 233,
353 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
354 "xvnmaddmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000355 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
356 AltVSXFMARel;
357 }
Hal Finkel27774d92014-03-13 07:58:58 +0000358
Hal Finkel25e04542014-03-25 18:55:11 +0000359 let BaseName = "XVNMADDASP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000360 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000361 def XVNMADDASP : XX3Form<60, 193,
362 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
363 "xvnmaddasp $XT, $XA, $XB", IIC_VecFP,
364 [(set v4f32:$XT, (fneg (fma v4f32:$XA, v4f32:$XB, v4f32:$XTi)))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000365 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
366 AltVSXFMARel;
367 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000368 def XVNMADDMSP : XX3Form<60, 201,
369 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
370 "xvnmaddmsp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000371 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
372 AltVSXFMARel;
373 }
Hal Finkel27774d92014-03-13 07:58:58 +0000374
Hal Finkel25e04542014-03-25 18:55:11 +0000375 let BaseName = "XVNMSUBADP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000376 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000377 def XVNMSUBADP : XX3Form<60, 241,
378 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
379 "xvnmsubadp $XT, $XA, $XB", IIC_VecFP,
380 [(set v2f64:$XT, (fneg (fma v2f64:$XA, v2f64:$XB, (fneg v2f64:$XTi))))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000381 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
382 AltVSXFMARel;
383 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000384 def XVNMSUBMDP : XX3Form<60, 249,
385 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
386 "xvnmsubmdp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000387 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
388 AltVSXFMARel;
389 }
Hal Finkel27774d92014-03-13 07:58:58 +0000390
Hal Finkel25e04542014-03-25 18:55:11 +0000391 let BaseName = "XVNMSUBASP" in {
Hal Finkele01d3212014-03-24 15:07:28 +0000392 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000393 def XVNMSUBASP : XX3Form<60, 209,
394 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
395 "xvnmsubasp $XT, $XA, $XB", IIC_VecFP,
396 [(set v4f32:$XT, (fneg (fma v4f32:$XA, v4f32:$XB, (fneg v4f32:$XTi))))]>,
Hal Finkel25e04542014-03-25 18:55:11 +0000397 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
398 AltVSXFMARel;
399 let IsVSXFMAAlt = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000400 def XVNMSUBMSP : XX3Form<60, 217,
401 (outs vsrc:$XT), (ins vsrc:$XTi, vsrc:$XA, vsrc:$XB),
402 "xvnmsubmsp $XT, $XA, $XB", IIC_VecFP, []>,
Hal Finkel25e04542014-03-25 18:55:11 +0000403 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
404 AltVSXFMARel;
405 }
Hal Finkel27774d92014-03-13 07:58:58 +0000406
407 // Division Instructions
408 def XSDIVDP : XX3Form<60, 56,
Hal Finkel19be5062014-03-29 05:29:01 +0000409 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000410 "xsdivdp $XT, $XA, $XB", IIC_FPDivD,
Hal Finkel27774d92014-03-13 07:58:58 +0000411 [(set f64:$XT, (fdiv f64:$XA, f64:$XB))]>;
412 def XSSQRTDP : XX2Form<60, 75,
Hal Finkel19be5062014-03-29 05:29:01 +0000413 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000414 "xssqrtdp $XT, $XB", IIC_FPSqrtD,
Hal Finkel27774d92014-03-13 07:58:58 +0000415 [(set f64:$XT, (fsqrt f64:$XB))]>;
416
417 def XSREDP : XX2Form<60, 90,
Hal Finkel19be5062014-03-29 05:29:01 +0000418 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000419 "xsredp $XT, $XB", IIC_VecFP,
420 [(set f64:$XT, (PPCfre f64:$XB))]>;
421 def XSRSQRTEDP : XX2Form<60, 74,
Hal Finkel19be5062014-03-29 05:29:01 +0000422 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000423 "xsrsqrtedp $XT, $XB", IIC_VecFP,
424 [(set f64:$XT, (PPCfrsqrte f64:$XB))]>;
425
426 def XSTDIVDP : XX3Form_1<60, 61,
Hal Finkel19be5062014-03-29 05:29:01 +0000427 (outs crrc:$crD), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000428 "xstdivdp $crD, $XA, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000429 def XSTSQRTDP : XX2Form_1<60, 106,
Hal Finkel19be5062014-03-29 05:29:01 +0000430 (outs crrc:$crD), (ins vsfrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000431 "xstsqrtdp $crD, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000432
433 def XVDIVDP : XX3Form<60, 120,
434 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000435 "xvdivdp $XT, $XA, $XB", IIC_FPDivD,
Hal Finkel27774d92014-03-13 07:58:58 +0000436 [(set v2f64:$XT, (fdiv v2f64:$XA, v2f64:$XB))]>;
437 def XVDIVSP : XX3Form<60, 88,
438 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000439 "xvdivsp $XT, $XA, $XB", IIC_FPDivS,
Hal Finkel27774d92014-03-13 07:58:58 +0000440 [(set v4f32:$XT, (fdiv v4f32:$XA, v4f32:$XB))]>;
441
442 def XVSQRTDP : XX2Form<60, 203,
443 (outs vsrc:$XT), (ins vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000444 "xvsqrtdp $XT, $XB", IIC_FPSqrtD,
Hal Finkel27774d92014-03-13 07:58:58 +0000445 [(set v2f64:$XT, (fsqrt v2f64:$XB))]>;
446 def XVSQRTSP : XX2Form<60, 139,
447 (outs vsrc:$XT), (ins vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000448 "xvsqrtsp $XT, $XB", IIC_FPSqrtS,
Hal Finkel27774d92014-03-13 07:58:58 +0000449 [(set v4f32:$XT, (fsqrt v4f32:$XB))]>;
450
451 def XVTDIVDP : XX3Form_1<60, 125,
452 (outs crrc:$crD), (ins vsrc:$XA, vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000453 "xvtdivdp $crD, $XA, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000454 def XVTDIVSP : XX3Form_1<60, 93,
455 (outs crrc:$crD), (ins vsrc:$XA, vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000456 "xvtdivsp $crD, $XA, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000457
458 def XVTSQRTDP : XX2Form_1<60, 234,
459 (outs crrc:$crD), (ins vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000460 "xvtsqrtdp $crD, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000461 def XVTSQRTSP : XX2Form_1<60, 170,
462 (outs crrc:$crD), (ins vsrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000463 "xvtsqrtsp $crD, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000464
465 def XVREDP : XX2Form<60, 218,
466 (outs vsrc:$XT), (ins vsrc:$XB),
467 "xvredp $XT, $XB", IIC_VecFP,
468 [(set v2f64:$XT, (PPCfre v2f64:$XB))]>;
469 def XVRESP : XX2Form<60, 154,
470 (outs vsrc:$XT), (ins vsrc:$XB),
471 "xvresp $XT, $XB", IIC_VecFP,
472 [(set v4f32:$XT, (PPCfre v4f32:$XB))]>;
473
474 def XVRSQRTEDP : XX2Form<60, 202,
475 (outs vsrc:$XT), (ins vsrc:$XB),
476 "xvrsqrtedp $XT, $XB", IIC_VecFP,
477 [(set v2f64:$XT, (PPCfrsqrte v2f64:$XB))]>;
478 def XVRSQRTESP : XX2Form<60, 138,
479 (outs vsrc:$XT), (ins vsrc:$XB),
480 "xvrsqrtesp $XT, $XB", IIC_VecFP,
481 [(set v4f32:$XT, (PPCfrsqrte v4f32:$XB))]>;
482
483 // Compare Instructions
484 def XSCMPODP : XX3Form_1<60, 43,
Hal Finkel19be5062014-03-29 05:29:01 +0000485 (outs crrc:$crD), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000486 "xscmpodp $crD, $XA, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000487 def XSCMPUDP : XX3Form_1<60, 35,
Hal Finkel19be5062014-03-29 05:29:01 +0000488 (outs crrc:$crD), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkele8fba982014-03-29 13:20:31 +0000489 "xscmpudp $crD, $XA, $XB", IIC_FPCompare, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000490
491 defm XVCMPEQDP : XX3Form_Rcr<60, 99,
Nemanja Ivanovicf502a422015-06-26 19:26:53 +0000492 "xvcmpeqdp", "$XT, $XA, $XB", IIC_VecFPCompare,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +0000493 int_ppc_vsx_xvcmpeqdp, v2i64, v2f64>;
Hal Finkel27774d92014-03-13 07:58:58 +0000494 defm XVCMPEQSP : XX3Form_Rcr<60, 67,
Nemanja Ivanovicf502a422015-06-26 19:26:53 +0000495 "xvcmpeqsp", "$XT, $XA, $XB", IIC_VecFPCompare,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +0000496 int_ppc_vsx_xvcmpeqsp, v4i32, v4f32>;
Hal Finkel27774d92014-03-13 07:58:58 +0000497 defm XVCMPGEDP : XX3Form_Rcr<60, 115,
Nemanja Ivanovicf502a422015-06-26 19:26:53 +0000498 "xvcmpgedp", "$XT, $XA, $XB", IIC_VecFPCompare,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +0000499 int_ppc_vsx_xvcmpgedp, v2i64, v2f64>;
Hal Finkel27774d92014-03-13 07:58:58 +0000500 defm XVCMPGESP : XX3Form_Rcr<60, 83,
Nemanja Ivanovicf502a422015-06-26 19:26:53 +0000501 "xvcmpgesp", "$XT, $XA, $XB", IIC_VecFPCompare,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +0000502 int_ppc_vsx_xvcmpgesp, v4i32, v4f32>;
Hal Finkel27774d92014-03-13 07:58:58 +0000503 defm XVCMPGTDP : XX3Form_Rcr<60, 107,
Nemanja Ivanovicf502a422015-06-26 19:26:53 +0000504 "xvcmpgtdp", "$XT, $XA, $XB", IIC_VecFPCompare,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +0000505 int_ppc_vsx_xvcmpgtdp, v2i64, v2f64>;
Hal Finkel27774d92014-03-13 07:58:58 +0000506 defm XVCMPGTSP : XX3Form_Rcr<60, 75,
Nemanja Ivanovicf502a422015-06-26 19:26:53 +0000507 "xvcmpgtsp", "$XT, $XA, $XB", IIC_VecFPCompare,
Nemanja Ivanovic2c84b292015-09-29 17:41:53 +0000508 int_ppc_vsx_xvcmpgtsp, v4i32, v4f32>;
Hal Finkel27774d92014-03-13 07:58:58 +0000509
510 // Move Instructions
511 def XSABSDP : XX2Form<60, 345,
Hal Finkel19be5062014-03-29 05:29:01 +0000512 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000513 "xsabsdp $XT, $XB", IIC_VecFP,
514 [(set f64:$XT, (fabs f64:$XB))]>;
515 def XSNABSDP : XX2Form<60, 361,
Hal Finkel19be5062014-03-29 05:29:01 +0000516 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000517 "xsnabsdp $XT, $XB", IIC_VecFP,
518 [(set f64:$XT, (fneg (fabs f64:$XB)))]>;
519 def XSNEGDP : XX2Form<60, 377,
Hal Finkel19be5062014-03-29 05:29:01 +0000520 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000521 "xsnegdp $XT, $XB", IIC_VecFP,
522 [(set f64:$XT, (fneg f64:$XB))]>;
523 def XSCPSGNDP : XX3Form<60, 176,
Hal Finkel19be5062014-03-29 05:29:01 +0000524 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000525 "xscpsgndp $XT, $XA, $XB", IIC_VecFP,
526 [(set f64:$XT, (fcopysign f64:$XB, f64:$XA))]>;
527
528 def XVABSDP : XX2Form<60, 473,
529 (outs vsrc:$XT), (ins vsrc:$XB),
530 "xvabsdp $XT, $XB", IIC_VecFP,
531 [(set v2f64:$XT, (fabs v2f64:$XB))]>;
532
533 def XVABSSP : XX2Form<60, 409,
534 (outs vsrc:$XT), (ins vsrc:$XB),
535 "xvabssp $XT, $XB", IIC_VecFP,
536 [(set v4f32:$XT, (fabs v4f32:$XB))]>;
537
538 def XVCPSGNDP : XX3Form<60, 240,
539 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
540 "xvcpsgndp $XT, $XA, $XB", IIC_VecFP,
541 [(set v2f64:$XT, (fcopysign v2f64:$XB, v2f64:$XA))]>;
542 def XVCPSGNSP : XX3Form<60, 208,
543 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
544 "xvcpsgnsp $XT, $XA, $XB", IIC_VecFP,
545 [(set v4f32:$XT, (fcopysign v4f32:$XB, v4f32:$XA))]>;
546
547 def XVNABSDP : XX2Form<60, 489,
548 (outs vsrc:$XT), (ins vsrc:$XB),
549 "xvnabsdp $XT, $XB", IIC_VecFP,
550 [(set v2f64:$XT, (fneg (fabs v2f64:$XB)))]>;
551 def XVNABSSP : XX2Form<60, 425,
552 (outs vsrc:$XT), (ins vsrc:$XB),
553 "xvnabssp $XT, $XB", IIC_VecFP,
554 [(set v4f32:$XT, (fneg (fabs v4f32:$XB)))]>;
555
556 def XVNEGDP : XX2Form<60, 505,
557 (outs vsrc:$XT), (ins vsrc:$XB),
558 "xvnegdp $XT, $XB", IIC_VecFP,
559 [(set v2f64:$XT, (fneg v2f64:$XB))]>;
560 def XVNEGSP : XX2Form<60, 441,
561 (outs vsrc:$XT), (ins vsrc:$XB),
562 "xvnegsp $XT, $XB", IIC_VecFP,
563 [(set v4f32:$XT, (fneg v4f32:$XB))]>;
564
565 // Conversion Instructions
566 def XSCVDPSP : XX2Form<60, 265,
Hal Finkel19be5062014-03-29 05:29:01 +0000567 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000568 "xscvdpsp $XT, $XB", IIC_VecFP, []>;
569 def XSCVDPSXDS : XX2Form<60, 344,
Hal Finkel19be5062014-03-29 05:29:01 +0000570 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel4a912252014-03-23 05:35:00 +0000571 "xscvdpsxds $XT, $XB", IIC_VecFP,
572 [(set f64:$XT, (PPCfctidz f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000573 def XSCVDPSXWS : XX2Form<60, 88,
Hal Finkel19be5062014-03-29 05:29:01 +0000574 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel4a912252014-03-23 05:35:00 +0000575 "xscvdpsxws $XT, $XB", IIC_VecFP,
576 [(set f64:$XT, (PPCfctiwz f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000577 def XSCVDPUXDS : XX2Form<60, 328,
Hal Finkel19be5062014-03-29 05:29:01 +0000578 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel4a912252014-03-23 05:35:00 +0000579 "xscvdpuxds $XT, $XB", IIC_VecFP,
580 [(set f64:$XT, (PPCfctiduz f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000581 def XSCVDPUXWS : XX2Form<60, 72,
Hal Finkel19be5062014-03-29 05:29:01 +0000582 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel4a912252014-03-23 05:35:00 +0000583 "xscvdpuxws $XT, $XB", IIC_VecFP,
584 [(set f64:$XT, (PPCfctiwuz f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000585 def XSCVSPDP : XX2Form<60, 329,
Hal Finkel19be5062014-03-29 05:29:01 +0000586 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000587 "xscvspdp $XT, $XB", IIC_VecFP, []>;
588 def XSCVSXDDP : XX2Form<60, 376,
Hal Finkel19be5062014-03-29 05:29:01 +0000589 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel4a912252014-03-23 05:35:00 +0000590 "xscvsxddp $XT, $XB", IIC_VecFP,
591 [(set f64:$XT, (PPCfcfid f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000592 def XSCVUXDDP : XX2Form<60, 360,
Hal Finkel19be5062014-03-29 05:29:01 +0000593 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel4a912252014-03-23 05:35:00 +0000594 "xscvuxddp $XT, $XB", IIC_VecFP,
595 [(set f64:$XT, (PPCfcfidu f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000596
597 def XVCVDPSP : XX2Form<60, 393,
598 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000599 "xvcvdpsp $XT, $XB", IIC_VecFP,
600 [(set v4f32:$XT, (int_ppc_vsx_xvcvdpsp v2f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000601 def XVCVDPSXDS : XX2Form<60, 472,
602 (outs vsrc:$XT), (ins vsrc:$XB),
Hal Finkel7279f4b2014-03-26 19:13:54 +0000603 "xvcvdpsxds $XT, $XB", IIC_VecFP,
604 [(set v2i64:$XT, (fp_to_sint v2f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000605 def XVCVDPSXWS : XX2Form<60, 216,
606 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000607 "xvcvdpsxws $XT, $XB", IIC_VecFP,
608 [(set v4i32:$XT, (int_ppc_vsx_xvcvdpsxws v2f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000609 def XVCVDPUXDS : XX2Form<60, 456,
610 (outs vsrc:$XT), (ins vsrc:$XB),
Hal Finkel7279f4b2014-03-26 19:13:54 +0000611 "xvcvdpuxds $XT, $XB", IIC_VecFP,
612 [(set v2i64:$XT, (fp_to_uint v2f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000613 def XVCVDPUXWS : XX2Form<60, 200,
614 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000615 "xvcvdpuxws $XT, $XB", IIC_VecFP,
616 [(set v4i32:$XT, (int_ppc_vsx_xvcvdpuxws v2f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000617
618 def XVCVSPDP : XX2Form<60, 457,
619 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000620 "xvcvspdp $XT, $XB", IIC_VecFP,
621 [(set v2f64:$XT, (int_ppc_vsx_xvcvspdp v4f32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000622 def XVCVSPSXDS : XX2Form<60, 408,
623 (outs vsrc:$XT), (ins vsrc:$XB),
624 "xvcvspsxds $XT, $XB", IIC_VecFP, []>;
625 def XVCVSPSXWS : XX2Form<60, 152,
626 (outs vsrc:$XT), (ins vsrc:$XB),
627 "xvcvspsxws $XT, $XB", IIC_VecFP, []>;
628 def XVCVSPUXDS : XX2Form<60, 392,
629 (outs vsrc:$XT), (ins vsrc:$XB),
630 "xvcvspuxds $XT, $XB", IIC_VecFP, []>;
631 def XVCVSPUXWS : XX2Form<60, 136,
632 (outs vsrc:$XT), (ins vsrc:$XB),
633 "xvcvspuxws $XT, $XB", IIC_VecFP, []>;
634 def XVCVSXDDP : XX2Form<60, 504,
635 (outs vsrc:$XT), (ins vsrc:$XB),
Hal Finkel7279f4b2014-03-26 19:13:54 +0000636 "xvcvsxddp $XT, $XB", IIC_VecFP,
637 [(set v2f64:$XT, (sint_to_fp v2i64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000638 def XVCVSXDSP : XX2Form<60, 440,
639 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000640 "xvcvsxdsp $XT, $XB", IIC_VecFP,
641 [(set v4f32:$XT, (int_ppc_vsx_xvcvsxdsp v2i64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000642 def XVCVSXWDP : XX2Form<60, 248,
643 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000644 "xvcvsxwdp $XT, $XB", IIC_VecFP,
645 [(set v2f64:$XT, (int_ppc_vsx_xvcvsxwdp v4i32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000646 def XVCVSXWSP : XX2Form<60, 184,
647 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic44513e52016-07-05 09:22:29 +0000648 "xvcvsxwsp $XT, $XB", IIC_VecFP,
649 [(set v4f32:$XT, (sint_to_fp v4i32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000650 def XVCVUXDDP : XX2Form<60, 488,
651 (outs vsrc:$XT), (ins vsrc:$XB),
Hal Finkel7279f4b2014-03-26 19:13:54 +0000652 "xvcvuxddp $XT, $XB", IIC_VecFP,
653 [(set v2f64:$XT, (uint_to_fp v2i64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000654 def XVCVUXDSP : XX2Form<60, 424,
655 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000656 "xvcvuxdsp $XT, $XB", IIC_VecFP,
657 [(set v4f32:$XT, (int_ppc_vsx_xvcvuxdsp v2i64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000658 def XVCVUXWDP : XX2Form<60, 232,
659 (outs vsrc:$XT), (ins vsrc:$XB),
Nemanja Ivanovic2efc3cb2016-11-11 14:41:19 +0000660 "xvcvuxwdp $XT, $XB", IIC_VecFP,
661 [(set v2f64:$XT, (int_ppc_vsx_xvcvuxwdp v4i32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000662 def XVCVUXWSP : XX2Form<60, 168,
663 (outs vsrc:$XT), (ins vsrc:$XB),
664 "xvcvuxwsp $XT, $XB", IIC_VecFP, []>;
665
666 // Rounding Instructions
667 def XSRDPI : XX2Form<60, 73,
Hal Finkel19be5062014-03-29 05:29:01 +0000668 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000669 "xsrdpi $XT, $XB", IIC_VecFP,
Michael Kuperstein2bc3d4d2016-08-18 20:08:15 +0000670 [(set f64:$XT, (fround f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000671 def XSRDPIC : XX2Form<60, 107,
Hal Finkel19be5062014-03-29 05:29:01 +0000672 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000673 "xsrdpic $XT, $XB", IIC_VecFP,
674 [(set f64:$XT, (fnearbyint f64:$XB))]>;
675 def XSRDPIM : XX2Form<60, 121,
Hal Finkel19be5062014-03-29 05:29:01 +0000676 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000677 "xsrdpim $XT, $XB", IIC_VecFP,
678 [(set f64:$XT, (ffloor f64:$XB))]>;
679 def XSRDPIP : XX2Form<60, 105,
Hal Finkel19be5062014-03-29 05:29:01 +0000680 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000681 "xsrdpip $XT, $XB", IIC_VecFP,
682 [(set f64:$XT, (fceil f64:$XB))]>;
683 def XSRDPIZ : XX2Form<60, 89,
Hal Finkel19be5062014-03-29 05:29:01 +0000684 (outs vsfrc:$XT), (ins vsfrc:$XB),
Hal Finkel27774d92014-03-13 07:58:58 +0000685 "xsrdpiz $XT, $XB", IIC_VecFP,
686 [(set f64:$XT, (ftrunc f64:$XB))]>;
687
688 def XVRDPI : XX2Form<60, 201,
689 (outs vsrc:$XT), (ins vsrc:$XB),
690 "xvrdpi $XT, $XB", IIC_VecFP,
Michael Kuperstein2bc3d4d2016-08-18 20:08:15 +0000691 [(set v2f64:$XT, (fround v2f64:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000692 def XVRDPIC : XX2Form<60, 235,
693 (outs vsrc:$XT), (ins vsrc:$XB),
694 "xvrdpic $XT, $XB", IIC_VecFP,
695 [(set v2f64:$XT, (fnearbyint v2f64:$XB))]>;
696 def XVRDPIM : XX2Form<60, 249,
697 (outs vsrc:$XT), (ins vsrc:$XB),
698 "xvrdpim $XT, $XB", IIC_VecFP,
699 [(set v2f64:$XT, (ffloor v2f64:$XB))]>;
700 def XVRDPIP : XX2Form<60, 233,
701 (outs vsrc:$XT), (ins vsrc:$XB),
702 "xvrdpip $XT, $XB", IIC_VecFP,
703 [(set v2f64:$XT, (fceil v2f64:$XB))]>;
704 def XVRDPIZ : XX2Form<60, 217,
705 (outs vsrc:$XT), (ins vsrc:$XB),
706 "xvrdpiz $XT, $XB", IIC_VecFP,
707 [(set v2f64:$XT, (ftrunc v2f64:$XB))]>;
708
709 def XVRSPI : XX2Form<60, 137,
710 (outs vsrc:$XT), (ins vsrc:$XB),
711 "xvrspi $XT, $XB", IIC_VecFP,
Michael Kuperstein2bc3d4d2016-08-18 20:08:15 +0000712 [(set v4f32:$XT, (fround v4f32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000713 def XVRSPIC : XX2Form<60, 171,
714 (outs vsrc:$XT), (ins vsrc:$XB),
715 "xvrspic $XT, $XB", IIC_VecFP,
716 [(set v4f32:$XT, (fnearbyint v4f32:$XB))]>;
717 def XVRSPIM : XX2Form<60, 185,
718 (outs vsrc:$XT), (ins vsrc:$XB),
719 "xvrspim $XT, $XB", IIC_VecFP,
720 [(set v4f32:$XT, (ffloor v4f32:$XB))]>;
721 def XVRSPIP : XX2Form<60, 169,
722 (outs vsrc:$XT), (ins vsrc:$XB),
723 "xvrspip $XT, $XB", IIC_VecFP,
724 [(set v4f32:$XT, (fceil v4f32:$XB))]>;
725 def XVRSPIZ : XX2Form<60, 153,
726 (outs vsrc:$XT), (ins vsrc:$XB),
727 "xvrspiz $XT, $XB", IIC_VecFP,
728 [(set v4f32:$XT, (ftrunc v4f32:$XB))]>;
729
730 // Max/Min Instructions
Hal Finkele01d3212014-03-24 15:07:28 +0000731 let isCommutable = 1 in {
Hal Finkel27774d92014-03-13 07:58:58 +0000732 def XSMAXDP : XX3Form<60, 160,
Hal Finkel19be5062014-03-29 05:29:01 +0000733 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
Bill Schmidt1ca69fa2014-10-31 19:19:07 +0000734 "xsmaxdp $XT, $XA, $XB", IIC_VecFP,
735 [(set vsfrc:$XT,
736 (int_ppc_vsx_xsmaxdp vsfrc:$XA, vsfrc:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000737 def XSMINDP : XX3Form<60, 168,
Hal Finkel19be5062014-03-29 05:29:01 +0000738 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
Bill Schmidt1ca69fa2014-10-31 19:19:07 +0000739 "xsmindp $XT, $XA, $XB", IIC_VecFP,
740 [(set vsfrc:$XT,
741 (int_ppc_vsx_xsmindp vsfrc:$XA, vsfrc:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000742
743 def XVMAXDP : XX3Form<60, 224,
744 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Bill Schmidt1ca69fa2014-10-31 19:19:07 +0000745 "xvmaxdp $XT, $XA, $XB", IIC_VecFP,
746 [(set vsrc:$XT,
747 (int_ppc_vsx_xvmaxdp vsrc:$XA, vsrc:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000748 def XVMINDP : XX3Form<60, 232,
749 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Bill Schmidt1ca69fa2014-10-31 19:19:07 +0000750 "xvmindp $XT, $XA, $XB", IIC_VecFP,
751 [(set vsrc:$XT,
752 (int_ppc_vsx_xvmindp vsrc:$XA, vsrc:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000753
754 def XVMAXSP : XX3Form<60, 192,
755 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Bill Schmidt1ca69fa2014-10-31 19:19:07 +0000756 "xvmaxsp $XT, $XA, $XB", IIC_VecFP,
757 [(set vsrc:$XT,
758 (int_ppc_vsx_xvmaxsp vsrc:$XA, vsrc:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000759 def XVMINSP : XX3Form<60, 200,
760 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Bill Schmidt1ca69fa2014-10-31 19:19:07 +0000761 "xvminsp $XT, $XA, $XB", IIC_VecFP,
762 [(set vsrc:$XT,
763 (int_ppc_vsx_xvminsp vsrc:$XA, vsrc:$XB))]>;
Hal Finkele01d3212014-03-24 15:07:28 +0000764 } // isCommutable
Hal Finkel27774d92014-03-13 07:58:58 +0000765} // Uses = [RM]
766
767 // Logical Instructions
Hal Finkele01d3212014-03-24 15:07:28 +0000768 let isCommutable = 1 in
Hal Finkel27774d92014-03-13 07:58:58 +0000769 def XXLAND : XX3Form<60, 130,
770 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkelbd4de9d2014-03-26 04:55:40 +0000771 "xxland $XT, $XA, $XB", IIC_VecGeneral,
772 [(set v4i32:$XT, (and v4i32:$XA, v4i32:$XB))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000773 def XXLANDC : XX3Form<60, 138,
774 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkelbd4de9d2014-03-26 04:55:40 +0000775 "xxlandc $XT, $XA, $XB", IIC_VecGeneral,
776 [(set v4i32:$XT, (and v4i32:$XA,
777 (vnot_ppc v4i32:$XB)))]>;
Hal Finkele01d3212014-03-24 15:07:28 +0000778 let isCommutable = 1 in {
Hal Finkel27774d92014-03-13 07:58:58 +0000779 def XXLNOR : XX3Form<60, 162,
780 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkelbd4de9d2014-03-26 04:55:40 +0000781 "xxlnor $XT, $XA, $XB", IIC_VecGeneral,
782 [(set v4i32:$XT, (vnot_ppc (or v4i32:$XA,
783 v4i32:$XB)))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000784 def XXLOR : XX3Form<60, 146,
785 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkelbd4de9d2014-03-26 04:55:40 +0000786 "xxlor $XT, $XA, $XB", IIC_VecGeneral,
787 [(set v4i32:$XT, (or v4i32:$XA, v4i32:$XB))]>;
Hal Finkel19be5062014-03-29 05:29:01 +0000788 let isCodeGenOnly = 1 in
789 def XXLORf: XX3Form<60, 146,
790 (outs vsfrc:$XT), (ins vsfrc:$XA, vsfrc:$XB),
791 "xxlor $XT, $XA, $XB", IIC_VecGeneral, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000792 def XXLXOR : XX3Form<60, 154,
793 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
Hal Finkelbd4de9d2014-03-26 04:55:40 +0000794 "xxlxor $XT, $XA, $XB", IIC_VecGeneral,
795 [(set v4i32:$XT, (xor v4i32:$XA, v4i32:$XB))]>;
Hal Finkele01d3212014-03-24 15:07:28 +0000796 } // isCommutable
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +0000797 let isCodeGenOnly = 1 in
798 def XXLXORz : XX3Form_Zero<60, 154, (outs vsrc:$XT), (ins),
799 "xxlxor $XT, $XT, $XT", IIC_VecGeneral,
800 [(set v4i32:$XT, (v4i32 immAllZerosV))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000801
Ehsan Amiric90b02c2016-10-24 17:31:09 +0000802 let isCodeGenOnly = 1 in {
803 def XXLXORdpz : XX3Form_SetZero<60, 154,
804 (outs vsfrc:$XT), (ins),
805 "xxlxor $XT, $XT, $XT", IIC_VecGeneral,
806 [(set f64:$XT, (fpimm0))]>;
807 def XXLXORspz : XX3Form_SetZero<60, 154,
808 (outs vssrc:$XT), (ins),
809 "xxlxor $XT, $XT, $XT", IIC_VecGeneral,
810 [(set f32:$XT, (fpimm0))]>;
811 }
812
Hal Finkel27774d92014-03-13 07:58:58 +0000813 // Permutation Instructions
814 def XXMRGHW : XX3Form<60, 18,
815 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
816 "xxmrghw $XT, $XA, $XB", IIC_VecPerm, []>;
817 def XXMRGLW : XX3Form<60, 50,
818 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
819 "xxmrglw $XT, $XA, $XB", IIC_VecPerm, []>;
820
821 def XXPERMDI : XX3Form_2<60, 10,
822 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB, u2imm:$DM),
823 "xxpermdi $XT, $XA, $XB, $DM", IIC_VecPerm, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +0000824 let isCodeGenOnly = 1 in
825 def XXPERMDIs : XX3Form_2s<60, 10, (outs vsrc:$XT), (ins vfrc:$XA, u2imm:$DM),
826 "xxpermdi $XT, $XA, $XA, $DM", IIC_VecPerm, []>;
Hal Finkel27774d92014-03-13 07:58:58 +0000827 def XXSEL : XX4Form<60, 3,
828 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB, vsrc:$XC),
829 "xxsel $XT, $XA, $XB, $XC", IIC_VecPerm, []>;
830
831 def XXSLDWI : XX3Form_2<60, 2,
832 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB, u2imm:$SHW),
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +0000833 "xxsldwi $XT, $XA, $XB, $SHW", IIC_VecPerm,
834 [(set v4i32:$XT, (PPCvecshl v4i32:$XA, v4i32:$XB,
835 imm32SExt16:$SHW))]>;
Hal Finkel27774d92014-03-13 07:58:58 +0000836 def XXSPLTW : XX2Form_2<60, 164,
837 (outs vsrc:$XT), (ins vsrc:$XB, u2imm:$UIM),
Nemanja Ivanovic1a2b2f02016-05-04 16:04:02 +0000838 "xxspltw $XT, $XB, $UIM", IIC_VecPerm,
839 [(set v4i32:$XT,
840 (PPCxxsplt v4i32:$XB, imm32SExt16:$UIM))]>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +0000841 let isCodeGenOnly = 1 in
842 def XXSPLTWs : XX2Form_2<60, 164,
843 (outs vsrc:$XT), (ins vfrc:$XB, u2imm:$UIM),
844 "xxspltw $XT, $XB, $UIM", IIC_VecPerm, []>;
Craig Topperc50d64b2014-11-26 00:46:26 +0000845} // hasSideEffects
Nemanja Ivanovic11049f82016-10-04 06:59:23 +0000846} // UseVSXReg = 1
Hal Finkel27774d92014-03-13 07:58:58 +0000847
Bill Schmidt61e65232014-10-22 13:13:40 +0000848// SELECT_CC_* - Used to implement the SELECT_CC DAG operation. Expanded after
849// instruction selection into a branch sequence.
850let usesCustomInserter = 1, // Expanded after instruction selection.
851 PPC970_Single = 1 in {
852
853 def SELECT_CC_VSRC: Pseudo<(outs vsrc:$dst),
854 (ins crrc:$cond, vsrc:$T, vsrc:$F, i32imm:$BROPC),
855 "#SELECT_CC_VSRC",
856 []>;
Bill Schmidt9c54bbd2014-10-22 16:58:20 +0000857 def SELECT_VSRC: Pseudo<(outs vsrc:$dst),
858 (ins crbitrc:$cond, vsrc:$T, vsrc:$F),
859 "#SELECT_VSRC",
Bill Schmidt61e65232014-10-22 13:13:40 +0000860 [(set v2f64:$dst,
861 (select i1:$cond, v2f64:$T, v2f64:$F))]>;
Bill Schmidt9c54bbd2014-10-22 16:58:20 +0000862 def SELECT_CC_VSFRC: Pseudo<(outs f8rc:$dst),
863 (ins crrc:$cond, f8rc:$T, f8rc:$F,
864 i32imm:$BROPC), "#SELECT_CC_VSFRC",
865 []>;
866 def SELECT_VSFRC: Pseudo<(outs f8rc:$dst),
867 (ins crbitrc:$cond, f8rc:$T, f8rc:$F),
868 "#SELECT_VSFRC",
869 [(set f64:$dst,
870 (select i1:$cond, f64:$T, f64:$F))]>;
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +0000871 def SELECT_CC_VSSRC: Pseudo<(outs f4rc:$dst),
872 (ins crrc:$cond, f4rc:$T, f4rc:$F,
873 i32imm:$BROPC), "#SELECT_CC_VSSRC",
874 []>;
875 def SELECT_VSSRC: Pseudo<(outs f4rc:$dst),
876 (ins crbitrc:$cond, f4rc:$T, f4rc:$F),
877 "#SELECT_VSSRC",
878 [(set f32:$dst,
879 (select i1:$cond, f32:$T, f32:$F))]>;
Bill Schmidt9c54bbd2014-10-22 16:58:20 +0000880} // usesCustomInserter
881} // AddedComplexity
Bill Schmidt61e65232014-10-22 13:13:40 +0000882
Hal Finkel27774d92014-03-13 07:58:58 +0000883def : InstAlias<"xvmovdp $XT, $XB",
884 (XVCPSGNDP vsrc:$XT, vsrc:$XB, vsrc:$XB)>;
885def : InstAlias<"xvmovsp $XT, $XB",
886 (XVCPSGNSP vsrc:$XT, vsrc:$XB, vsrc:$XB)>;
887
888def : InstAlias<"xxspltd $XT, $XB, 0",
889 (XXPERMDI vsrc:$XT, vsrc:$XB, vsrc:$XB, 0)>;
890def : InstAlias<"xxspltd $XT, $XB, 1",
891 (XXPERMDI vsrc:$XT, vsrc:$XB, vsrc:$XB, 3)>;
892def : InstAlias<"xxmrghd $XT, $XA, $XB",
893 (XXPERMDI vsrc:$XT, vsrc:$XA, vsrc:$XB, 0)>;
894def : InstAlias<"xxmrgld $XT, $XA, $XB",
895 (XXPERMDI vsrc:$XT, vsrc:$XA, vsrc:$XB, 3)>;
896def : InstAlias<"xxswapd $XT, $XB",
897 (XXPERMDI vsrc:$XT, vsrc:$XB, vsrc:$XB, 2)>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +0000898def : InstAlias<"xxspltd $XT, $XB, 0",
899 (XXPERMDIs vsrc:$XT, vfrc:$XB, 0)>;
900def : InstAlias<"xxspltd $XT, $XB, 1",
901 (XXPERMDIs vsrc:$XT, vfrc:$XB, 3)>;
902def : InstAlias<"xxswapd $XT, $XB",
903 (XXPERMDIs vsrc:$XT, vfrc:$XB, 2)>;
Hal Finkel27774d92014-03-13 07:58:58 +0000904
905let AddedComplexity = 400 in { // Prefer VSX patterns over non-VSX patterns.
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000906
Nemanja Ivanovic6f22b412016-09-27 08:42:12 +0000907def : Pat<(v4i32 (vnot_ppc v4i32:$A)),
908 (v4i32 (XXLNOR $A, $A))>;
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000909let Predicates = [IsBigEndian] in {
Hal Finkel27774d92014-03-13 07:58:58 +0000910def : Pat<(v2f64 (scalar_to_vector f64:$A)),
Hal Finkel19be5062014-03-29 05:29:01 +0000911 (v2f64 (SUBREG_TO_REG (i64 1), $A, sub_64))>;
Hal Finkel27774d92014-03-13 07:58:58 +0000912
Matt Arsenaultfbd9bbf2015-12-11 19:20:16 +0000913def : Pat<(f64 (extractelt v2f64:$S, 0)),
Hal Finkel19be5062014-03-29 05:29:01 +0000914 (f64 (EXTRACT_SUBREG $S, sub_64))>;
Matt Arsenaultfbd9bbf2015-12-11 19:20:16 +0000915def : Pat<(f64 (extractelt v2f64:$S, 1)),
Hal Finkel19be5062014-03-29 05:29:01 +0000916 (f64 (EXTRACT_SUBREG (XXPERMDI $S, $S, 2), sub_64))>;
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000917}
918
919let Predicates = [IsLittleEndian] in {
920def : Pat<(v2f64 (scalar_to_vector f64:$A)),
921 (v2f64 (XXPERMDI (SUBREG_TO_REG (i64 1), $A, sub_64),
922 (SUBREG_TO_REG (i64 1), $A, sub_64), 0))>;
923
Matt Arsenaultfbd9bbf2015-12-11 19:20:16 +0000924def : Pat<(f64 (extractelt v2f64:$S, 0)),
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000925 (f64 (EXTRACT_SUBREG (XXPERMDI $S, $S, 2), sub_64))>;
Matt Arsenaultfbd9bbf2015-12-11 19:20:16 +0000926def : Pat<(f64 (extractelt v2f64:$S, 1)),
Bill Schmidt10f6eb92014-12-09 16:43:32 +0000927 (f64 (EXTRACT_SUBREG $S, sub_64))>;
928}
Hal Finkel27774d92014-03-13 07:58:58 +0000929
930// Additional fnmsub patterns: -a*c + b == -(a*c - b)
931def : Pat<(fma (fneg f64:$A), f64:$C, f64:$B),
932 (XSNMSUBADP $B, $C, $A)>;
933def : Pat<(fma f64:$A, (fneg f64:$C), f64:$B),
934 (XSNMSUBADP $B, $C, $A)>;
935
936def : Pat<(fma (fneg v2f64:$A), v2f64:$C, v2f64:$B),
937 (XVNMSUBADP $B, $C, $A)>;
938def : Pat<(fma v2f64:$A, (fneg v2f64:$C), v2f64:$B),
939 (XVNMSUBADP $B, $C, $A)>;
940
941def : Pat<(fma (fneg v4f32:$A), v4f32:$C, v4f32:$B),
942 (XVNMSUBASP $B, $C, $A)>;
943def : Pat<(fma v4f32:$A, (fneg v4f32:$C), v4f32:$B),
944 (XVNMSUBASP $B, $C, $A)>;
945
Hal Finkel9e0baa62014-04-01 19:24:27 +0000946def : Pat<(v2f64 (bitconvert v4f32:$A)),
947 (COPY_TO_REGCLASS $A, VSRC)>;
Hal Finkel27774d92014-03-13 07:58:58 +0000948def : Pat<(v2f64 (bitconvert v4i32:$A)),
949 (COPY_TO_REGCLASS $A, VSRC)>;
950def : Pat<(v2f64 (bitconvert v8i16:$A)),
951 (COPY_TO_REGCLASS $A, VSRC)>;
952def : Pat<(v2f64 (bitconvert v16i8:$A)),
953 (COPY_TO_REGCLASS $A, VSRC)>;
954
Hal Finkel9e0baa62014-04-01 19:24:27 +0000955def : Pat<(v4f32 (bitconvert v2f64:$A)),
956 (COPY_TO_REGCLASS $A, VRRC)>;
Hal Finkel27774d92014-03-13 07:58:58 +0000957def : Pat<(v4i32 (bitconvert v2f64:$A)),
958 (COPY_TO_REGCLASS $A, VRRC)>;
959def : Pat<(v8i16 (bitconvert v2f64:$A)),
960 (COPY_TO_REGCLASS $A, VRRC)>;
961def : Pat<(v16i8 (bitconvert v2f64:$A)),
962 (COPY_TO_REGCLASS $A, VRRC)>;
963
Hal Finkel9e0baa62014-04-01 19:24:27 +0000964def : Pat<(v2i64 (bitconvert v4f32:$A)),
965 (COPY_TO_REGCLASS $A, VSRC)>;
Hal Finkela6c8b512014-03-26 16:12:58 +0000966def : Pat<(v2i64 (bitconvert v4i32:$A)),
967 (COPY_TO_REGCLASS $A, VSRC)>;
968def : Pat<(v2i64 (bitconvert v8i16:$A)),
969 (COPY_TO_REGCLASS $A, VSRC)>;
970def : Pat<(v2i64 (bitconvert v16i8:$A)),
971 (COPY_TO_REGCLASS $A, VSRC)>;
972
Hal Finkel9e0baa62014-04-01 19:24:27 +0000973def : Pat<(v4f32 (bitconvert v2i64:$A)),
974 (COPY_TO_REGCLASS $A, VRRC)>;
Hal Finkela6c8b512014-03-26 16:12:58 +0000975def : Pat<(v4i32 (bitconvert v2i64:$A)),
976 (COPY_TO_REGCLASS $A, VRRC)>;
977def : Pat<(v8i16 (bitconvert v2i64:$A)),
978 (COPY_TO_REGCLASS $A, VRRC)>;
979def : Pat<(v16i8 (bitconvert v2i64:$A)),
980 (COPY_TO_REGCLASS $A, VRRC)>;
981
Hal Finkel9281c9a2014-03-26 18:26:30 +0000982def : Pat<(v2f64 (bitconvert v2i64:$A)),
983 (COPY_TO_REGCLASS $A, VRRC)>;
984def : Pat<(v2i64 (bitconvert v2f64:$A)),
985 (COPY_TO_REGCLASS $A, VRRC)>;
986
Kit Bartond4eb73c2015-05-05 16:10:44 +0000987def : Pat<(v2f64 (bitconvert v1i128:$A)),
988 (COPY_TO_REGCLASS $A, VRRC)>;
989def : Pat<(v1i128 (bitconvert v2f64:$A)),
990 (COPY_TO_REGCLASS $A, VRRC)>;
991
Hal Finkel5c0d1452014-03-30 13:22:59 +0000992// sign extension patterns
993// To extend "in place" from v2i32 to v2i64, we have input data like:
994// | undef | i32 | undef | i32 |
995// but xvcvsxwdp expects the input in big-Endian format:
996// | i32 | undef | i32 | undef |
997// so we need to shift everything to the left by one i32 (word) before
998// the conversion.
999def : Pat<(sext_inreg v2i64:$C, v2i32),
1000 (XVCVDPSXDS (XVCVSXWDP (XXSLDWI $C, $C, 1)))>;
1001def : Pat<(v2f64 (sint_to_fp (sext_inreg v2i64:$C, v2i32))),
1002 (XVCVSXWDP (XXSLDWI $C, $C, 1))>;
1003
Nemanja Ivanovic44513e52016-07-05 09:22:29 +00001004def : Pat<(v2f64 (PPCsvec2fp v4i32:$C, 0)),
1005 (v2f64 (XVCVSXWDP (v2i64 (XXMRGHW $C, $C))))>;
1006def : Pat<(v2f64 (PPCsvec2fp v4i32:$C, 1)),
1007 (v2f64 (XVCVSXWDP (v2i64 (XXMRGLW $C, $C))))>;
1008
1009def : Pat<(v2f64 (PPCuvec2fp v4i32:$C, 0)),
1010 (v2f64 (XVCVUXWDP (v2i64 (XXMRGHW $C, $C))))>;
1011def : Pat<(v2f64 (PPCuvec2fp v4i32:$C, 1)),
1012 (v2f64 (XVCVUXWDP (v2i64 (XXMRGLW $C, $C))))>;
1013
Bill Schmidt2d1128a2014-10-17 15:13:38 +00001014// Loads.
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00001015let Predicates = [HasVSX, HasOnlySwappingMemOps] in {
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00001016 def : Pat<(v2f64 (PPClxvd2x xoaddr:$src)), (LXVD2X xoaddr:$src)>;
Bill Schmidt2d1128a2014-10-17 15:13:38 +00001017
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00001018 // Stores.
1019 def : Pat<(int_ppc_vsx_stxvd2x v2f64:$rS, xoaddr:$dst),
1020 (STXVD2X $rS, xoaddr:$dst)>;
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00001021 def : Pat<(int_ppc_vsx_stxvw4x v4i32:$rS, xoaddr:$dst),
1022 (STXVW4X $rS, xoaddr:$dst)>;
Tony Jiang5f850cd2016-11-15 14:25:56 +00001023 def : Pat<(int_ppc_vsx_stxvd2x_be v2f64:$rS, xoaddr:$dst),
1024 (STXVD2X $rS, xoaddr:$dst)>;
1025 def : Pat<(int_ppc_vsx_stxvw4x_be v4i32:$rS, xoaddr:$dst),
1026 (STXVW4X $rS, xoaddr:$dst)>;
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00001027 def : Pat<(PPCstxvd2x v2f64:$rS, xoaddr:$dst), (STXVD2X $rS, xoaddr:$dst)>;
1028}
Nemanja Ivanovice78ffed2016-09-22 10:32:03 +00001029let Predicates = [IsBigEndian, HasVSX, HasOnlySwappingMemOps] in {
1030 def : Pat<(v2f64 (load xoaddr:$src)), (LXVD2X xoaddr:$src)>;
1031 def : Pat<(v2i64 (load xoaddr:$src)), (LXVD2X xoaddr:$src)>;
1032 def : Pat<(v4i32 (load xoaddr:$src)), (LXVW4X xoaddr:$src)>;
1033 def : Pat<(store v2f64:$rS, xoaddr:$dst), (STXVD2X $rS, xoaddr:$dst)>;
1034 def : Pat<(store v2i64:$rS, xoaddr:$dst), (STXVD2X $rS, xoaddr:$dst)>;
1035}
Bill Schmidtfae5d712014-12-09 16:35:51 +00001036
1037// Permutes.
1038def : Pat<(v2f64 (PPCxxswapd v2f64:$src)), (XXPERMDI $src, $src, 2)>;
1039def : Pat<(v2i64 (PPCxxswapd v2i64:$src)), (XXPERMDI $src, $src, 2)>;
1040def : Pat<(v4f32 (PPCxxswapd v4f32:$src)), (XXPERMDI $src, $src, 2)>;
1041def : Pat<(v4i32 (PPCxxswapd v4i32:$src)), (XXPERMDI $src, $src, 2)>;
Nemanja Ivanoviceebbcb62016-07-12 12:16:27 +00001042def : Pat<(v2f64 (PPCswapNoChain v2f64:$src)), (XXPERMDI $src, $src, 2)>;
Bill Schmidt2d1128a2014-10-17 15:13:38 +00001043
Bill Schmidt61e65232014-10-22 13:13:40 +00001044// Selects.
1045def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETLT)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001046 (SELECT_VSRC (CRANDC $lhs, $rhs), $tval, $fval)>;
1047def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETULT)),
Bill Schmidt61e65232014-10-22 13:13:40 +00001048 (SELECT_VSRC (CRANDC $rhs, $lhs), $tval, $fval)>;
1049def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETLE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001050 (SELECT_VSRC (CRORC $lhs, $rhs), $tval, $fval)>;
1051def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETULE)),
Bill Schmidt61e65232014-10-22 13:13:40 +00001052 (SELECT_VSRC (CRORC $rhs, $lhs), $tval, $fval)>;
1053def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETEQ)),
1054 (SELECT_VSRC (CREQV $lhs, $rhs), $tval, $fval)>;
1055def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETGE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001056 (SELECT_VSRC (CRORC $rhs, $lhs), $tval, $fval)>;
1057def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETUGE)),
Bill Schmidt61e65232014-10-22 13:13:40 +00001058 (SELECT_VSRC (CRORC $lhs, $rhs), $tval, $fval)>;
1059def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETGT)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001060 (SELECT_VSRC (CRANDC $rhs, $lhs), $tval, $fval)>;
1061def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETUGT)),
Bill Schmidt61e65232014-10-22 13:13:40 +00001062 (SELECT_VSRC (CRANDC $lhs, $rhs), $tval, $fval)>;
1063def : Pat<(v2f64 (selectcc i1:$lhs, i1:$rhs, v2f64:$tval, v2f64:$fval, SETNE)),
1064 (SELECT_VSRC (CRXOR $lhs, $rhs), $tval, $fval)>;
1065
Bill Schmidt9c54bbd2014-10-22 16:58:20 +00001066def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETLT)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001067 (SELECT_VSFRC (CRANDC $lhs, $rhs), $tval, $fval)>;
1068def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETULT)),
Bill Schmidt9c54bbd2014-10-22 16:58:20 +00001069 (SELECT_VSFRC (CRANDC $rhs, $lhs), $tval, $fval)>;
1070def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETLE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001071 (SELECT_VSFRC (CRORC $lhs, $rhs), $tval, $fval)>;
1072def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETULE)),
Bill Schmidt9c54bbd2014-10-22 16:58:20 +00001073 (SELECT_VSFRC (CRORC $rhs, $lhs), $tval, $fval)>;
1074def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETEQ)),
1075 (SELECT_VSFRC (CREQV $lhs, $rhs), $tval, $fval)>;
1076def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETGE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001077 (SELECT_VSFRC (CRORC $rhs, $lhs), $tval, $fval)>;
1078def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETUGE)),
Bill Schmidt9c54bbd2014-10-22 16:58:20 +00001079 (SELECT_VSFRC (CRORC $lhs, $rhs), $tval, $fval)>;
1080def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETGT)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001081 (SELECT_VSFRC (CRANDC $rhs, $lhs), $tval, $fval)>;
1082def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETUGT)),
Bill Schmidt9c54bbd2014-10-22 16:58:20 +00001083 (SELECT_VSFRC (CRANDC $lhs, $rhs), $tval, $fval)>;
1084def : Pat<(f64 (selectcc i1:$lhs, i1:$rhs, f64:$tval, f64:$fval, SETNE)),
1085 (SELECT_VSFRC (CRXOR $lhs, $rhs), $tval, $fval)>;
1086
Bill Schmidt76746922014-11-14 12:10:40 +00001087// Divides.
1088def : Pat<(int_ppc_vsx_xvdivsp v4f32:$A, v4f32:$B),
1089 (XVDIVSP $A, $B)>;
1090def : Pat<(int_ppc_vsx_xvdivdp v2f64:$A, v2f64:$B),
1091 (XVDIVDP $A, $B)>;
1092
Nemanja Ivanovic984a3612015-07-14 17:25:20 +00001093// Reciprocal estimate
1094def : Pat<(int_ppc_vsx_xvresp v4f32:$A),
1095 (XVRESP $A)>;
1096def : Pat<(int_ppc_vsx_xvredp v2f64:$A),
1097 (XVREDP $A)>;
1098
Nemanja Ivanovicd358b8f2015-07-05 06:03:51 +00001099// Recip. square root estimate
1100def : Pat<(int_ppc_vsx_xvrsqrtesp v4f32:$A),
1101 (XVRSQRTESP $A)>;
1102def : Pat<(int_ppc_vsx_xvrsqrtedp v2f64:$A),
1103 (XVRSQRTEDP $A)>;
1104
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001105let Predicates = [IsLittleEndian] in {
1106def : Pat<(f64 (PPCfcfid (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1107 (f64 (XSCVSXDDP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1108def : Pat<(f64 (PPCfcfid (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1109 (f64 (XSCVSXDDP (COPY_TO_REGCLASS (f64 (COPY_TO_REGCLASS $S, VSRC)), VSFRC)))>;
1110def : Pat<(f64 (PPCfcfidu (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1111 (f64 (XSCVUXDDP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1112def : Pat<(f64 (PPCfcfidu (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1113 (f64 (XSCVUXDDP (COPY_TO_REGCLASS (f64 (COPY_TO_REGCLASS $S, VSRC)), VSFRC)))>;
1114} // IsLittleEndian
1115
1116let Predicates = [IsBigEndian] in {
1117def : Pat<(f64 (PPCfcfid (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1118 (f64 (XSCVSXDDP (COPY_TO_REGCLASS $S, VSFRC)))>;
1119def : Pat<(f64 (PPCfcfid (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1120 (f64 (XSCVSXDDP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1121def : Pat<(f64 (PPCfcfidu (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1122 (f64 (XSCVUXDDP (COPY_TO_REGCLASS $S, VSFRC)))>;
1123def : Pat<(f64 (PPCfcfidu (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1124 (f64 (XSCVUXDDP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1125} // IsBigEndian
1126
Hal Finkel27774d92014-03-13 07:58:58 +00001127} // AddedComplexity
1128} // HasVSX
1129
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001130def ScalarLoads {
1131 dag Li8 = (i32 (extloadi8 xoaddr:$src));
1132 dag ZELi8 = (i32 (zextloadi8 xoaddr:$src));
1133 dag ZELi8i64 = (i64 (zextloadi8 xoaddr:$src));
1134 dag SELi8 = (i32 (sext_inreg (extloadi8 xoaddr:$src), i8));
1135 dag SELi8i64 = (i64 (sext_inreg (extloadi8 xoaddr:$src), i8));
1136
1137 dag Li16 = (i32 (extloadi16 xoaddr:$src));
1138 dag ZELi16 = (i32 (zextloadi16 xoaddr:$src));
1139 dag ZELi16i64 = (i64 (zextloadi16 xoaddr:$src));
1140 dag SELi16 = (i32 (sextloadi16 xoaddr:$src));
1141 dag SELi16i64 = (i64 (sextloadi16 xoaddr:$src));
1142
1143 dag Li32 = (i32 (load xoaddr:$src));
1144}
1145
Kit Barton298beb52015-02-18 16:21:46 +00001146// The following VSX instructions were introduced in Power ISA 2.07
1147/* FIXME: if the operands are v2i64, these patterns will not match.
1148 we should define new patterns or otherwise match the same patterns
1149 when the elements are larger than i32.
1150*/
1151def HasP8Vector : Predicate<"PPCSubTarget->hasP8Vector()">;
Nemanja Ivanovicc38b5312015-04-11 10:40:42 +00001152def HasDirectMove : Predicate<"PPCSubTarget->hasDirectMove()">;
Kit Barton298beb52015-02-18 16:21:46 +00001153let Predicates = [HasP8Vector] in {
1154let AddedComplexity = 400 in { // Prefer VSX patterns over non-VSX patterns.
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001155 let isCommutable = 1, UseVSXReg = 1 in {
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001156 def XXLEQV : XX3Form<60, 186,
1157 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
1158 "xxleqv $XT, $XA, $XB", IIC_VecGeneral,
1159 [(set v4i32:$XT, (vnot_ppc (xor v4i32:$XA, v4i32:$XB)))]>;
1160 def XXLNAND : XX3Form<60, 178,
1161 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
1162 "xxlnand $XT, $XA, $XB", IIC_VecGeneral,
1163 [(set v4i32:$XT, (vnot_ppc (and v4i32:$XA,
Kit Barton298beb52015-02-18 16:21:46 +00001164 v4i32:$XB)))]>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001165 } // isCommutable, UseVSXReg
Nemanja Ivanovicd9e4b4f2015-07-10 14:25:17 +00001166
Nemanja Ivanovic5655fb32015-07-10 12:38:08 +00001167 def : Pat<(int_ppc_vsx_xxleqv v4i32:$A, v4i32:$B),
1168 (XXLEQV $A, $B)>;
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001169
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001170 let UseVSXReg = 1 in {
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001171 def XXLORC : XX3Form<60, 170,
1172 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
1173 "xxlorc $XT, $XA, $XB", IIC_VecGeneral,
1174 [(set v4i32:$XT, (or v4i32:$XA, (vnot_ppc v4i32:$XB)))]>;
1175
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +00001176 // VSX scalar loads introduced in ISA 2.07
1177 let mayLoad = 1 in {
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00001178 let CodeSize = 3 in
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +00001179 def LXSSPX : XX1Form<31, 524, (outs vssrc:$XT), (ins memrr:$src),
1180 "lxsspx $XT, $src", IIC_LdStLFD,
1181 [(set f32:$XT, (load xoaddr:$src))]>;
1182 def LXSIWAX : XX1Form<31, 76, (outs vsfrc:$XT), (ins memrr:$src),
1183 "lxsiwax $XT, $src", IIC_LdStLFD,
1184 [(set f64:$XT, (PPClfiwax xoaddr:$src))]>;
1185 def LXSIWZX : XX1Form<31, 12, (outs vsfrc:$XT), (ins memrr:$src),
1186 "lxsiwzx $XT, $src", IIC_LdStLFD,
1187 [(set f64:$XT, (PPClfiwzx xoaddr:$src))]>;
1188 } // mayLoad
1189
1190 // VSX scalar stores introduced in ISA 2.07
1191 let mayStore = 1 in {
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00001192 let CodeSize = 3 in
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +00001193 def STXSSPX : XX1Form<31, 652, (outs), (ins vssrc:$XT, memrr:$dst),
1194 "stxsspx $XT, $dst", IIC_LdStSTFD,
1195 [(store f32:$XT, xoaddr:$dst)]>;
1196 def STXSIWX : XX1Form<31, 140, (outs), (ins vsfrc:$XT, memrr:$dst),
1197 "stxsiwx $XT, $dst", IIC_LdStSTFD,
1198 [(PPCstfiwx f64:$XT, xoaddr:$dst)]>;
1199 } // mayStore
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001200 } // UseVSXReg = 1
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001201
1202 def : Pat<(f64 (extloadf32 xoaddr:$src)),
1203 (COPY_TO_REGCLASS (LXSSPX xoaddr:$src), VSFRC)>;
Michael Kuperstein2bc3d4d2016-08-18 20:08:15 +00001204 def : Pat<(f64 (fpextend f32:$src)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001205 (COPY_TO_REGCLASS $src, VSFRC)>;
Hal Finkela2cdbce2015-08-30 22:12:50 +00001206
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001207 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETLT)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001208 (SELECT_VSSRC (CRANDC $lhs, $rhs), $tval, $fval)>;
1209 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETULT)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001210 (SELECT_VSSRC (CRANDC $rhs, $lhs), $tval, $fval)>;
1211 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETLE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001212 (SELECT_VSSRC (CRORC $lhs, $rhs), $tval, $fval)>;
1213 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETULE)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001214 (SELECT_VSSRC (CRORC $rhs, $lhs), $tval, $fval)>;
1215 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETEQ)),
1216 (SELECT_VSSRC (CREQV $lhs, $rhs), $tval, $fval)>;
1217 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETGE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001218 (SELECT_VSSRC (CRORC $rhs, $lhs), $tval, $fval)>;
1219 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETUGE)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001220 (SELECT_VSSRC (CRORC $lhs, $rhs), $tval, $fval)>;
1221 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETGT)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001222 (SELECT_VSSRC (CRANDC $rhs, $lhs), $tval, $fval)>;
1223 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETUGT)),
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001224 (SELECT_VSSRC (CRANDC $lhs, $rhs), $tval, $fval)>;
1225 def : Pat<(f32 (selectcc i1:$lhs, i1:$rhs, f32:$tval, f32:$fval, SETNE)),
Hal Finkela2cdbce2015-08-30 22:12:50 +00001226 (SELECT_VSSRC (CRXOR $lhs, $rhs), $tval, $fval)>;
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001227
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001228 let UseVSXReg = 1 in {
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001229 // VSX Elementary Scalar FP arithmetic (SP)
1230 let isCommutable = 1 in {
1231 def XSADDSP : XX3Form<60, 0,
1232 (outs vssrc:$XT), (ins vssrc:$XA, vssrc:$XB),
1233 "xsaddsp $XT, $XA, $XB", IIC_VecFP,
1234 [(set f32:$XT, (fadd f32:$XA, f32:$XB))]>;
1235 def XSMULSP : XX3Form<60, 16,
1236 (outs vssrc:$XT), (ins vssrc:$XA, vssrc:$XB),
1237 "xsmulsp $XT, $XA, $XB", IIC_VecFP,
1238 [(set f32:$XT, (fmul f32:$XA, f32:$XB))]>;
1239 } // isCommutable
1240
1241 def XSDIVSP : XX3Form<60, 24,
1242 (outs vssrc:$XT), (ins vssrc:$XA, vssrc:$XB),
1243 "xsdivsp $XT, $XA, $XB", IIC_FPDivS,
1244 [(set f32:$XT, (fdiv f32:$XA, f32:$XB))]>;
1245 def XSRESP : XX2Form<60, 26,
1246 (outs vssrc:$XT), (ins vssrc:$XB),
1247 "xsresp $XT, $XB", IIC_VecFP,
1248 [(set f32:$XT, (PPCfre f32:$XB))]>;
1249 def XSSQRTSP : XX2Form<60, 11,
1250 (outs vssrc:$XT), (ins vssrc:$XB),
1251 "xssqrtsp $XT, $XB", IIC_FPSqrtS,
1252 [(set f32:$XT, (fsqrt f32:$XB))]>;
1253 def XSRSQRTESP : XX2Form<60, 10,
1254 (outs vssrc:$XT), (ins vssrc:$XB),
1255 "xsrsqrtesp $XT, $XB", IIC_VecFP,
1256 [(set f32:$XT, (PPCfrsqrte f32:$XB))]>;
1257 def XSSUBSP : XX3Form<60, 8,
1258 (outs vssrc:$XT), (ins vssrc:$XA, vssrc:$XB),
1259 "xssubsp $XT, $XA, $XB", IIC_VecFP,
1260 [(set f32:$XT, (fsub f32:$XA, f32:$XB))]>;
Nemanja Ivanovic376e1732015-05-29 17:13:25 +00001261
1262 // FMA Instructions
1263 let BaseName = "XSMADDASP" in {
1264 let isCommutable = 1 in
1265 def XSMADDASP : XX3Form<60, 1,
1266 (outs vssrc:$XT),
1267 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1268 "xsmaddasp $XT, $XA, $XB", IIC_VecFP,
1269 [(set f32:$XT, (fma f32:$XA, f32:$XB, f32:$XTi))]>,
1270 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1271 AltVSXFMARel;
1272 let IsVSXFMAAlt = 1 in
1273 def XSMADDMSP : XX3Form<60, 9,
1274 (outs vssrc:$XT),
1275 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1276 "xsmaddmsp $XT, $XA, $XB", IIC_VecFP, []>,
1277 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1278 AltVSXFMARel;
1279 }
1280
1281 let BaseName = "XSMSUBASP" in {
1282 let isCommutable = 1 in
1283 def XSMSUBASP : XX3Form<60, 17,
1284 (outs vssrc:$XT),
1285 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1286 "xsmsubasp $XT, $XA, $XB", IIC_VecFP,
1287 [(set f32:$XT, (fma f32:$XA, f32:$XB,
1288 (fneg f32:$XTi)))]>,
1289 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1290 AltVSXFMARel;
1291 let IsVSXFMAAlt = 1 in
1292 def XSMSUBMSP : XX3Form<60, 25,
1293 (outs vssrc:$XT),
1294 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1295 "xsmsubmsp $XT, $XA, $XB", IIC_VecFP, []>,
1296 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1297 AltVSXFMARel;
1298 }
1299
1300 let BaseName = "XSNMADDASP" in {
1301 let isCommutable = 1 in
1302 def XSNMADDASP : XX3Form<60, 129,
1303 (outs vssrc:$XT),
1304 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1305 "xsnmaddasp $XT, $XA, $XB", IIC_VecFP,
1306 [(set f32:$XT, (fneg (fma f32:$XA, f32:$XB,
1307 f32:$XTi)))]>,
1308 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1309 AltVSXFMARel;
1310 let IsVSXFMAAlt = 1 in
1311 def XSNMADDMSP : XX3Form<60, 137,
1312 (outs vssrc:$XT),
1313 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1314 "xsnmaddmsp $XT, $XA, $XB", IIC_VecFP, []>,
1315 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1316 AltVSXFMARel;
1317 }
1318
1319 let BaseName = "XSNMSUBASP" in {
1320 let isCommutable = 1 in
1321 def XSNMSUBASP : XX3Form<60, 145,
1322 (outs vssrc:$XT),
1323 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1324 "xsnmsubasp $XT, $XA, $XB", IIC_VecFP,
1325 [(set f32:$XT, (fneg (fma f32:$XA, f32:$XB,
1326 (fneg f32:$XTi))))]>,
1327 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1328 AltVSXFMARel;
1329 let IsVSXFMAAlt = 1 in
1330 def XSNMSUBMSP : XX3Form<60, 153,
1331 (outs vssrc:$XT),
1332 (ins vssrc:$XTi, vssrc:$XA, vssrc:$XB),
1333 "xsnmsubmsp $XT, $XA, $XB", IIC_VecFP, []>,
1334 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">,
1335 AltVSXFMARel;
1336 }
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001337
1338 // Single Precision Conversions (FP <-> INT)
1339 def XSCVSXDSP : XX2Form<60, 312,
1340 (outs vssrc:$XT), (ins vsfrc:$XB),
1341 "xscvsxdsp $XT, $XB", IIC_VecFP,
1342 [(set f32:$XT, (PPCfcfids f64:$XB))]>;
1343 def XSCVUXDSP : XX2Form<60, 296,
1344 (outs vssrc:$XT), (ins vsfrc:$XB),
1345 "xscvuxdsp $XT, $XB", IIC_VecFP,
1346 [(set f32:$XT, (PPCfcfidus f64:$XB))]>;
1347
1348 // Conversions between vector and scalar single precision
1349 def XSCVDPSPN : XX2Form<60, 267, (outs vsrc:$XT), (ins vssrc:$XB),
1350 "xscvdpspn $XT, $XB", IIC_VecFP, []>;
1351 def XSCVSPDPN : XX2Form<60, 331, (outs vssrc:$XT), (ins vsrc:$XB),
1352 "xscvspdpn $XT, $XB", IIC_VecFP, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001353 } // UseVSXReg = 1
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001354
Nemanja Ivanovicd3c284f2016-07-18 15:30:00 +00001355 let Predicates = [IsLittleEndian] in {
1356 def : Pat<(f32 (PPCfcfids (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1357 (f32 (XSCVSXDSP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1358 def : Pat<(f32 (PPCfcfids (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1359 (f32 (XSCVSXDSP (COPY_TO_REGCLASS (f64 (COPY_TO_REGCLASS $S, VSRC)), VSFRC)))>;
1360 def : Pat<(f32 (PPCfcfidus (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1361 (f32 (XSCVUXDSP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1362 def : Pat<(f32 (PPCfcfidus (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1363 (f32 (XSCVUXDSP (COPY_TO_REGCLASS (f64 (COPY_TO_REGCLASS $S, VSRC)), VSFRC)))>;
1364 }
1365
1366 let Predicates = [IsBigEndian] in {
1367 def : Pat<(f32 (PPCfcfids (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1368 (f32 (XSCVSXDSP (COPY_TO_REGCLASS $S, VSFRC)))>;
1369 def : Pat<(f32 (PPCfcfids (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1370 (f32 (XSCVSXDSP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1371 def : Pat<(f32 (PPCfcfidus (PPCmtvsra (i64 (vector_extract v2i64:$S, 0))))),
1372 (f32 (XSCVUXDSP (COPY_TO_REGCLASS $S, VSFRC)))>;
1373 def : Pat<(f32 (PPCfcfidus (PPCmtvsra (i64 (vector_extract v2i64:$S, 1))))),
1374 (f32 (XSCVUXDSP (COPY_TO_REGCLASS (XXPERMDI $S, $S, 2), VSFRC)))>;
1375 }
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001376 def : Pat<(v4i32 (scalar_to_vector ScalarLoads.Li32)),
1377 (v4i32 (XXSPLTWs (LXSIWAX xoaddr:$src), 1))>;
Nemanja Ivanovicf3c94b12015-05-07 18:24:05 +00001378} // AddedComplexity = 400
Kit Barton298beb52015-02-18 16:21:46 +00001379} // HasP8Vector
Nemanja Ivanovicc38b5312015-04-11 10:40:42 +00001380
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001381let UseVSXReg = 1 in {
Ehsan Amiri99b017a2016-03-31 17:47:17 +00001382let Predicates = [HasDirectMove] in {
Nemanja Ivanovicf02def62015-05-21 19:32:49 +00001383 // VSX direct move instructions
1384 def MFVSRD : XX1_RS6_RD5_XO<31, 51, (outs g8rc:$rA), (ins vsfrc:$XT),
1385 "mfvsrd $rA, $XT", IIC_VecGeneral,
1386 [(set i64:$rA, (PPCmfvsr f64:$XT))]>,
1387 Requires<[In64BitMode]>;
1388 def MFVSRWZ : XX1_RS6_RD5_XO<31, 115, (outs gprc:$rA), (ins vsfrc:$XT),
1389 "mfvsrwz $rA, $XT", IIC_VecGeneral,
1390 [(set i32:$rA, (PPCmfvsr f64:$XT))]>;
1391 def MTVSRD : XX1_RS6_RD5_XO<31, 179, (outs vsfrc:$XT), (ins g8rc:$rA),
1392 "mtvsrd $XT, $rA", IIC_VecGeneral,
1393 [(set f64:$XT, (PPCmtvsra i64:$rA))]>,
1394 Requires<[In64BitMode]>;
1395 def MTVSRWA : XX1_RS6_RD5_XO<31, 211, (outs vsfrc:$XT), (ins gprc:$rA),
1396 "mtvsrwa $XT, $rA", IIC_VecGeneral,
1397 [(set f64:$XT, (PPCmtvsra i32:$rA))]>;
1398 def MTVSRWZ : XX1_RS6_RD5_XO<31, 243, (outs vsfrc:$XT), (ins gprc:$rA),
1399 "mtvsrwz $XT, $rA", IIC_VecGeneral,
1400 [(set f64:$XT, (PPCmtvsrz i32:$rA))]>;
Ehsan Amiri99b017a2016-03-31 17:47:17 +00001401} // HasDirectMove
1402
1403let Predicates = [IsISA3_0, HasDirectMove] in {
1404 def MTVSRWS: XX1_RS6_RD5_XO<31, 403, (outs vsrc:$XT), (ins gprc:$rA),
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00001405 "mtvsrws $XT, $rA", IIC_VecGeneral, []>;
Ehsan Amiri99b017a2016-03-31 17:47:17 +00001406
1407 def MTVSRDD: XX1Form<31, 435, (outs vsrc:$XT), (ins g8rc:$rA, g8rc:$rB),
1408 "mtvsrdd $XT, $rA, $rB", IIC_VecGeneral,
1409 []>, Requires<[In64BitMode]>;
1410
1411 def MFVSRLD: XX1_RS6_RD5_XO<31, 307, (outs g8rc:$rA), (ins vsrc:$XT),
1412 "mfvsrld $rA, $XT", IIC_VecGeneral,
1413 []>, Requires<[In64BitMode]>;
1414
1415} // IsISA3_0, HasDirectMove
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001416} // UseVSXReg = 1
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001417
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001418/* Direct moves of various widths from GPR's into VSR's. Each move lines
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001419 the value up into element 0 (both BE and LE). Namely, entities smaller than
1420 a doubleword are shifted left and moved for BE. For LE, they're moved, then
1421 swapped to go into the least significant element of the VSR.
1422*/
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001423def MovesToVSR {
1424 dag BE_BYTE_0 =
1425 (MTVSRD
1426 (RLDICR
1427 (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $A, sub_32), 56, 7));
1428 dag BE_HALF_0 =
1429 (MTVSRD
1430 (RLDICR
1431 (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $A, sub_32), 48, 15));
1432 dag BE_WORD_0 =
1433 (MTVSRD
1434 (RLDICR
1435 (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $A, sub_32), 32, 31));
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001436 dag BE_DWORD_0 = (MTVSRD $A);
1437
1438 dag LE_MTVSRW = (MTVSRD (INSERT_SUBREG (i64 (IMPLICIT_DEF)), $A, sub_32));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001439 dag LE_WORD_1 = (v2i64 (INSERT_SUBREG (v2i64 (IMPLICIT_DEF)),
1440 LE_MTVSRW, sub_64));
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001441 dag LE_WORD_0 = (XXPERMDI LE_WORD_1, LE_WORD_1, 2);
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001442 dag LE_DWORD_1 = (v2i64 (INSERT_SUBREG (v2i64 (IMPLICIT_DEF)),
1443 BE_DWORD_0, sub_64));
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001444 dag LE_DWORD_0 = (XXPERMDI LE_DWORD_1, LE_DWORD_1, 2);
1445}
1446
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001447/* Patterns for extracting elements out of vectors. Integer elements are
1448 extracted using direct move operations. Patterns for extracting elements
1449 whose indices are not available at compile time are also provided with
1450 various _VARIABLE_ patterns.
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001451 The numbering for the DAG's is for LE, but when used on BE, the correct
1452 LE element can just be used (i.e. LE_BYTE_2 == BE_BYTE_13).
1453*/
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001454def VectorExtractions {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001455 // Doubleword extraction
1456 dag LE_DWORD_0 =
1457 (MFVSRD
1458 (EXTRACT_SUBREG
1459 (XXPERMDI (COPY_TO_REGCLASS $S, VSRC),
1460 (COPY_TO_REGCLASS $S, VSRC), 2), sub_64));
1461 dag LE_DWORD_1 = (MFVSRD
1462 (EXTRACT_SUBREG
1463 (v2i64 (COPY_TO_REGCLASS $S, VSRC)), sub_64));
1464
1465 // Word extraction
Nemanja Ivanoviceebbcb62016-07-12 12:16:27 +00001466 dag LE_WORD_0 = (MFVSRWZ (EXTRACT_SUBREG (XXPERMDI $S, $S, 2), sub_64));
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001467 dag LE_WORD_1 = (MFVSRWZ (EXTRACT_SUBREG (XXSLDWI $S, $S, 1), sub_64));
1468 dag LE_WORD_2 = (MFVSRWZ (EXTRACT_SUBREG
1469 (v2i64 (COPY_TO_REGCLASS $S, VSRC)), sub_64));
1470 dag LE_WORD_3 = (MFVSRWZ (EXTRACT_SUBREG (XXSLDWI $S, $S, 3), sub_64));
1471
1472 // Halfword extraction
1473 dag LE_HALF_0 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 0, 48), sub_32));
1474 dag LE_HALF_1 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 48, 48), sub_32));
1475 dag LE_HALF_2 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 32, 48), sub_32));
1476 dag LE_HALF_3 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 16, 48), sub_32));
1477 dag LE_HALF_4 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 0, 48), sub_32));
1478 dag LE_HALF_5 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 48, 48), sub_32));
1479 dag LE_HALF_6 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 32, 48), sub_32));
1480 dag LE_HALF_7 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 16, 48), sub_32));
1481
1482 // Byte extraction
1483 dag LE_BYTE_0 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 0, 56), sub_32));
1484 dag LE_BYTE_1 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 56, 56), sub_32));
1485 dag LE_BYTE_2 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 48, 56), sub_32));
1486 dag LE_BYTE_3 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 40, 56), sub_32));
1487 dag LE_BYTE_4 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 32, 56), sub_32));
1488 dag LE_BYTE_5 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 24, 56), sub_32));
1489 dag LE_BYTE_6 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 16, 56), sub_32));
1490 dag LE_BYTE_7 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_0, 8, 56), sub_32));
1491 dag LE_BYTE_8 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 0, 56), sub_32));
1492 dag LE_BYTE_9 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 56, 56), sub_32));
1493 dag LE_BYTE_10 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 48, 56), sub_32));
1494 dag LE_BYTE_11 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 40, 56), sub_32));
1495 dag LE_BYTE_12 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 32, 56), sub_32));
1496 dag LE_BYTE_13 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 24, 56), sub_32));
1497 dag LE_BYTE_14 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 16, 56), sub_32));
1498 dag LE_BYTE_15 = (i32 (EXTRACT_SUBREG (RLDICL LE_DWORD_1, 8, 56), sub_32));
1499
1500 /* Variable element number (BE and LE patterns must be specified separately)
1501 This is a rather involved process.
1502
1503 Conceptually, this is how the move is accomplished:
1504 1. Identify which doubleword contains the element
1505 2. Shift in the VMX register so that the correct doubleword is correctly
1506 lined up for the MFVSRD
1507 3. Perform the move so that the element (along with some extra stuff)
1508 is in the GPR
1509 4. Right shift within the GPR so that the element is right-justified
1510
1511 Of course, the index is an element number which has a different meaning
1512 on LE/BE so the patterns have to be specified separately.
1513
1514 Note: The final result will be the element right-justified with high
1515 order bits being arbitrarily defined (namely, whatever was in the
1516 vector register to the left of the value originally).
1517 */
1518
1519 /* LE variable byte
1520 Number 1. above:
1521 - For elements 0-7, we shift left by 8 bytes since they're on the right
1522 - For elements 8-15, we need not shift (shift left by zero bytes)
1523 This is accomplished by inverting the bits of the index and AND-ing
1524 with 0x8 (i.e. clearing all bits of the index and inverting bit 60).
1525 */
1526 dag LE_VBYTE_PERM_VEC = (LVSL ZERO8, (ANDC8 (LI8 8), $Idx));
1527
1528 // Number 2. above:
1529 // - Now that we set up the shift amount, we shift in the VMX register
1530 dag LE_VBYTE_PERMUTE = (VPERM $S, $S, LE_VBYTE_PERM_VEC);
1531
1532 // Number 3. above:
1533 // - The doubleword containing our element is moved to a GPR
1534 dag LE_MV_VBYTE = (MFVSRD
1535 (EXTRACT_SUBREG
1536 (v2i64 (COPY_TO_REGCLASS LE_VBYTE_PERMUTE, VSRC)),
1537 sub_64));
1538
1539 /* Number 4. above:
1540 - Truncate the element number to the range 0-7 (8-15 are symmetrical
1541 and out of range values are truncated accordingly)
1542 - Multiply by 8 as we need to shift right by the number of bits, not bytes
1543 - Shift right in the GPR by the calculated value
1544 */
1545 dag LE_VBYTE_SHIFT = (EXTRACT_SUBREG (RLDICR (AND8 (LI8 7), $Idx), 3, 60),
1546 sub_32);
1547 dag LE_VARIABLE_BYTE = (EXTRACT_SUBREG (SRD LE_MV_VBYTE, LE_VBYTE_SHIFT),
1548 sub_32);
1549
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001550 /* LE variable halfword
1551 Number 1. above:
1552 - For elements 0-3, we shift left by 8 since they're on the right
1553 - For elements 4-7, we need not shift (shift left by zero bytes)
1554 Similarly to the byte pattern, we invert the bits of the index, but we
1555 AND with 0x4 (i.e. clear all bits of the index and invert bit 61).
1556 Of course, the shift is still by 8 bytes, so we must multiply by 2.
1557 */
1558 dag LE_VHALF_PERM_VEC = (LVSL ZERO8, (RLDICR (ANDC8 (LI8 4), $Idx), 1, 62));
1559
1560 // Number 2. above:
1561 // - Now that we set up the shift amount, we shift in the VMX register
1562 dag LE_VHALF_PERMUTE = (VPERM $S, $S, LE_VHALF_PERM_VEC);
1563
1564 // Number 3. above:
1565 // - The doubleword containing our element is moved to a GPR
1566 dag LE_MV_VHALF = (MFVSRD
1567 (EXTRACT_SUBREG
1568 (v2i64 (COPY_TO_REGCLASS LE_VHALF_PERMUTE, VSRC)),
1569 sub_64));
1570
1571 /* Number 4. above:
1572 - Truncate the element number to the range 0-3 (4-7 are symmetrical
1573 and out of range values are truncated accordingly)
1574 - Multiply by 16 as we need to shift right by the number of bits
1575 - Shift right in the GPR by the calculated value
1576 */
1577 dag LE_VHALF_SHIFT = (EXTRACT_SUBREG (RLDICR (AND8 (LI8 3), $Idx), 4, 59),
1578 sub_32);
1579 dag LE_VARIABLE_HALF = (EXTRACT_SUBREG (SRD LE_MV_VHALF, LE_VHALF_SHIFT),
1580 sub_32);
1581
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001582 /* LE variable word
1583 Number 1. above:
1584 - For elements 0-1, we shift left by 8 since they're on the right
1585 - For elements 2-3, we need not shift
1586 */
1587 dag LE_VWORD_PERM_VEC = (LVSL ZERO8, (RLDICR (ANDC8 (LI8 2), $Idx), 2, 61));
1588
1589 // Number 2. above:
1590 // - Now that we set up the shift amount, we shift in the VMX register
1591 dag LE_VWORD_PERMUTE = (VPERM $S, $S, LE_VWORD_PERM_VEC);
1592
1593 // Number 3. above:
1594 // - The doubleword containing our element is moved to a GPR
1595 dag LE_MV_VWORD = (MFVSRD
1596 (EXTRACT_SUBREG
1597 (v2i64 (COPY_TO_REGCLASS LE_VWORD_PERMUTE, VSRC)),
1598 sub_64));
1599
1600 /* Number 4. above:
1601 - Truncate the element number to the range 0-1 (2-3 are symmetrical
1602 and out of range values are truncated accordingly)
1603 - Multiply by 32 as we need to shift right by the number of bits
1604 - Shift right in the GPR by the calculated value
1605 */
1606 dag LE_VWORD_SHIFT = (EXTRACT_SUBREG (RLDICR (AND8 (LI8 1), $Idx), 5, 58),
1607 sub_32);
1608 dag LE_VARIABLE_WORD = (EXTRACT_SUBREG (SRD LE_MV_VWORD, LE_VWORD_SHIFT),
1609 sub_32);
1610
1611 /* LE variable doubleword
1612 Number 1. above:
1613 - For element 0, we shift left by 8 since it's on the right
1614 - For element 1, we need not shift
1615 */
1616 dag LE_VDWORD_PERM_VEC = (LVSL ZERO8, (RLDICR (ANDC8 (LI8 1), $Idx), 3, 60));
1617
1618 // Number 2. above:
1619 // - Now that we set up the shift amount, we shift in the VMX register
1620 dag LE_VDWORD_PERMUTE = (VPERM $S, $S, LE_VDWORD_PERM_VEC);
1621
1622 // Number 3. above:
1623 // - The doubleword containing our element is moved to a GPR
1624 // - Number 4. is not needed for the doubleword as the value is 64-bits
1625 dag LE_VARIABLE_DWORD =
1626 (MFVSRD (EXTRACT_SUBREG
1627 (v2i64 (COPY_TO_REGCLASS LE_VDWORD_PERMUTE, VSRC)),
1628 sub_64));
1629
1630 /* LE variable float
1631 - Shift the vector to line up the desired element to BE Word 0
1632 - Convert 32-bit float to a 64-bit single precision float
1633 */
1634 dag LE_VFLOAT_PERM_VEC = (LVSL ZERO8, (RLDICR (XOR8 (LI8 3), $Idx), 2, 61));
1635 dag LE_VFLOAT_PERMUTE = (VPERM $S, $S, LE_VFLOAT_PERM_VEC);
1636 dag LE_VARIABLE_FLOAT = (XSCVSPDPN LE_VFLOAT_PERMUTE);
1637
1638 /* LE variable double
1639 Same as the LE doubleword except there is no move.
1640 */
1641 dag LE_VDOUBLE_PERMUTE = (VPERM (COPY_TO_REGCLASS $S, VRRC),
1642 (COPY_TO_REGCLASS $S, VRRC),
1643 LE_VDWORD_PERM_VEC);
1644 dag LE_VARIABLE_DOUBLE = (COPY_TO_REGCLASS LE_VDOUBLE_PERMUTE, VSRC);
1645
1646 /* BE variable byte
1647 The algorithm here is the same as the LE variable byte except:
1648 - The shift in the VMX register is by 0/8 for opposite element numbers so
1649 we simply AND the element number with 0x8
1650 - The order of elements after the move to GPR is reversed, so we invert
1651 the bits of the index prior to truncating to the range 0-7
1652 */
1653 dag BE_VBYTE_PERM_VEC = (LVSL ZERO8, (ANDIo8 $Idx, 8));
1654 dag BE_VBYTE_PERMUTE = (VPERM $S, $S, BE_VBYTE_PERM_VEC);
1655 dag BE_MV_VBYTE = (MFVSRD
1656 (EXTRACT_SUBREG
1657 (v2i64 (COPY_TO_REGCLASS BE_VBYTE_PERMUTE, VSRC)),
1658 sub_64));
1659 dag BE_VBYTE_SHIFT = (EXTRACT_SUBREG (RLDICR (ANDC8 (LI8 7), $Idx), 3, 60),
1660 sub_32);
1661 dag BE_VARIABLE_BYTE = (EXTRACT_SUBREG (SRD BE_MV_VBYTE, BE_VBYTE_SHIFT),
1662 sub_32);
1663
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001664 /* BE variable halfword
1665 The algorithm here is the same as the LE variable halfword except:
1666 - The shift in the VMX register is by 0/8 for opposite element numbers so
1667 we simply AND the element number with 0x4 and multiply by 2
1668 - The order of elements after the move to GPR is reversed, so we invert
1669 the bits of the index prior to truncating to the range 0-3
1670 */
1671 dag BE_VHALF_PERM_VEC = (LVSL ZERO8, (RLDICR (ANDIo8 $Idx, 4), 1, 62));
1672 dag BE_VHALF_PERMUTE = (VPERM $S, $S, BE_VHALF_PERM_VEC);
1673 dag BE_MV_VHALF = (MFVSRD
1674 (EXTRACT_SUBREG
1675 (v2i64 (COPY_TO_REGCLASS BE_VHALF_PERMUTE, VSRC)),
1676 sub_64));
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001677 dag BE_VHALF_SHIFT = (EXTRACT_SUBREG (RLDICR (ANDC8 (LI8 3), $Idx), 4, 59),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001678 sub_32);
1679 dag BE_VARIABLE_HALF = (EXTRACT_SUBREG (SRD BE_MV_VHALF, BE_VHALF_SHIFT),
1680 sub_32);
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001681
1682 /* BE variable word
1683 The algorithm is the same as the LE variable word except:
1684 - The shift in the VMX register happens for opposite element numbers
1685 - The order of elements after the move to GPR is reversed, so we invert
1686 the bits of the index prior to truncating to the range 0-1
1687 */
1688 dag BE_VWORD_PERM_VEC = (LVSL ZERO8, (RLDICR (ANDIo8 $Idx, 2), 2, 61));
1689 dag BE_VWORD_PERMUTE = (VPERM $S, $S, BE_VWORD_PERM_VEC);
1690 dag BE_MV_VWORD = (MFVSRD
1691 (EXTRACT_SUBREG
1692 (v2i64 (COPY_TO_REGCLASS BE_VWORD_PERMUTE, VSRC)),
1693 sub_64));
1694 dag BE_VWORD_SHIFT = (EXTRACT_SUBREG (RLDICR (ANDC8 (LI8 1), $Idx), 5, 58),
1695 sub_32);
1696 dag BE_VARIABLE_WORD = (EXTRACT_SUBREG (SRD BE_MV_VWORD, BE_VWORD_SHIFT),
1697 sub_32);
1698
1699 /* BE variable doubleword
1700 Same as the LE doubleword except we shift in the VMX register for opposite
1701 element indices.
1702 */
1703 dag BE_VDWORD_PERM_VEC = (LVSL ZERO8, (RLDICR (ANDIo8 $Idx, 1), 3, 60));
1704 dag BE_VDWORD_PERMUTE = (VPERM $S, $S, BE_VDWORD_PERM_VEC);
1705 dag BE_VARIABLE_DWORD =
1706 (MFVSRD (EXTRACT_SUBREG
1707 (v2i64 (COPY_TO_REGCLASS BE_VDWORD_PERMUTE, VSRC)),
1708 sub_64));
1709
1710 /* BE variable float
1711 - Shift the vector to line up the desired element to BE Word 0
1712 - Convert 32-bit float to a 64-bit single precision float
1713 */
1714 dag BE_VFLOAT_PERM_VEC = (LVSL ZERO8, (RLDICR $Idx, 2, 61));
1715 dag BE_VFLOAT_PERMUTE = (VPERM $S, $S, BE_VFLOAT_PERM_VEC);
1716 dag BE_VARIABLE_FLOAT = (XSCVSPDPN BE_VFLOAT_PERMUTE);
1717
1718 /* BE variable double
1719 Same as the BE doubleword except there is no move.
1720 */
1721 dag BE_VDOUBLE_PERMUTE = (VPERM (COPY_TO_REGCLASS $S, VRRC),
1722 (COPY_TO_REGCLASS $S, VRRC),
1723 BE_VDWORD_PERM_VEC);
1724 dag BE_VARIABLE_DOUBLE = (COPY_TO_REGCLASS BE_VDOUBLE_PERMUTE, VSRC);
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001725}
1726
1727// v4f32 scalar <-> vector conversions (BE)
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001728let Predicates = [IsBigEndian, HasP8Vector] in {
1729 def : Pat<(v4f32 (scalar_to_vector f32:$A)),
1730 (v4f32 (XSCVDPSPN $A))>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001731 def : Pat<(f32 (vector_extract v4f32:$S, 0)),
1732 (f32 (XSCVSPDPN $S))>;
1733 def : Pat<(f32 (vector_extract v4f32:$S, 1)),
1734 (f32 (XSCVSPDPN (XXSLDWI $S, $S, 1)))>;
1735 def : Pat<(f32 (vector_extract v4f32:$S, 2)),
Nemanja Ivanoviceebbcb62016-07-12 12:16:27 +00001736 (f32 (XSCVSPDPN (XXPERMDI $S, $S, 2)))>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001737 def : Pat<(f32 (vector_extract v4f32:$S, 3)),
1738 (f32 (XSCVSPDPN (XXSLDWI $S, $S, 3)))>;
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001739 def : Pat<(f32 (vector_extract v4f32:$S, i64:$Idx)),
1740 (f32 VectorExtractions.BE_VARIABLE_FLOAT)>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001741} // IsBigEndian, HasP8Vector
1742
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001743// Variable index vector_extract for v2f64 does not require P8Vector
1744let Predicates = [IsBigEndian, HasVSX] in
1745 def : Pat<(f64 (vector_extract v2f64:$S, i64:$Idx)),
1746 (f64 VectorExtractions.BE_VARIABLE_DOUBLE)>;
1747
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001748let Predicates = [IsBigEndian, HasDirectMove] in {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001749 // v16i8 scalar <-> vector conversions (BE)
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001750 def : Pat<(v16i8 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001751 (v16i8 (SUBREG_TO_REG (i64 1), MovesToVSR.BE_BYTE_0, sub_64))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001752 def : Pat<(v8i16 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001753 (v8i16 (SUBREG_TO_REG (i64 1), MovesToVSR.BE_HALF_0, sub_64))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001754 def : Pat<(v4i32 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001755 (v4i32 (SUBREG_TO_REG (i64 1), MovesToVSR.BE_WORD_0, sub_64))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001756 def : Pat<(v2i64 (scalar_to_vector i64:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001757 (v2i64 (SUBREG_TO_REG (i64 1), MovesToVSR.BE_DWORD_0, sub_64))>;
1758 def : Pat<(i32 (vector_extract v16i8:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001759 (i32 VectorExtractions.LE_BYTE_15)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001760 def : Pat<(i32 (vector_extract v16i8:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001761 (i32 VectorExtractions.LE_BYTE_14)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001762 def : Pat<(i32 (vector_extract v16i8:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001763 (i32 VectorExtractions.LE_BYTE_13)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001764 def : Pat<(i32 (vector_extract v16i8:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001765 (i32 VectorExtractions.LE_BYTE_12)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001766 def : Pat<(i32 (vector_extract v16i8:$S, 4)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001767 (i32 VectorExtractions.LE_BYTE_11)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001768 def : Pat<(i32 (vector_extract v16i8:$S, 5)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001769 (i32 VectorExtractions.LE_BYTE_10)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001770 def : Pat<(i32 (vector_extract v16i8:$S, 6)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001771 (i32 VectorExtractions.LE_BYTE_9)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001772 def : Pat<(i32 (vector_extract v16i8:$S, 7)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001773 (i32 VectorExtractions.LE_BYTE_8)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001774 def : Pat<(i32 (vector_extract v16i8:$S, 8)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001775 (i32 VectorExtractions.LE_BYTE_7)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001776 def : Pat<(i32 (vector_extract v16i8:$S, 9)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001777 (i32 VectorExtractions.LE_BYTE_6)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001778 def : Pat<(i32 (vector_extract v16i8:$S, 10)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001779 (i32 VectorExtractions.LE_BYTE_5)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001780 def : Pat<(i32 (vector_extract v16i8:$S, 11)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001781 (i32 VectorExtractions.LE_BYTE_4)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001782 def : Pat<(i32 (vector_extract v16i8:$S, 12)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001783 (i32 VectorExtractions.LE_BYTE_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001784 def : Pat<(i32 (vector_extract v16i8:$S, 13)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001785 (i32 VectorExtractions.LE_BYTE_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001786 def : Pat<(i32 (vector_extract v16i8:$S, 14)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001787 (i32 VectorExtractions.LE_BYTE_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001788 def : Pat<(i32 (vector_extract v16i8:$S, 15)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001789 (i32 VectorExtractions.LE_BYTE_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001790 def : Pat<(i32 (vector_extract v16i8:$S, i64:$Idx)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001791 (i32 VectorExtractions.BE_VARIABLE_BYTE)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001792
1793 // v8i16 scalar <-> vector conversions (BE)
1794 def : Pat<(i32 (vector_extract v8i16:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001795 (i32 VectorExtractions.LE_HALF_7)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001796 def : Pat<(i32 (vector_extract v8i16:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001797 (i32 VectorExtractions.LE_HALF_6)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001798 def : Pat<(i32 (vector_extract v8i16:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001799 (i32 VectorExtractions.LE_HALF_5)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001800 def : Pat<(i32 (vector_extract v8i16:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001801 (i32 VectorExtractions.LE_HALF_4)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001802 def : Pat<(i32 (vector_extract v8i16:$S, 4)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001803 (i32 VectorExtractions.LE_HALF_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001804 def : Pat<(i32 (vector_extract v8i16:$S, 5)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001805 (i32 VectorExtractions.LE_HALF_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001806 def : Pat<(i32 (vector_extract v8i16:$S, 6)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001807 (i32 VectorExtractions.LE_HALF_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001808 def : Pat<(i32 (vector_extract v8i16:$S, 7)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001809 (i32 VectorExtractions.LE_HALF_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001810 def : Pat<(i32 (vector_extract v8i16:$S, i64:$Idx)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001811 (i32 VectorExtractions.BE_VARIABLE_HALF)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001812
1813 // v4i32 scalar <-> vector conversions (BE)
1814 def : Pat<(i32 (vector_extract v4i32:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001815 (i32 VectorExtractions.LE_WORD_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001816 def : Pat<(i32 (vector_extract v4i32:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001817 (i32 VectorExtractions.LE_WORD_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001818 def : Pat<(i32 (vector_extract v4i32:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001819 (i32 VectorExtractions.LE_WORD_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001820 def : Pat<(i32 (vector_extract v4i32:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001821 (i32 VectorExtractions.LE_WORD_0)>;
1822 def : Pat<(i32 (vector_extract v4i32:$S, i64:$Idx)),
1823 (i32 VectorExtractions.BE_VARIABLE_WORD)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001824
1825 // v2i64 scalar <-> vector conversions (BE)
1826 def : Pat<(i64 (vector_extract v2i64:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001827 (i64 VectorExtractions.LE_DWORD_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001828 def : Pat<(i64 (vector_extract v2i64:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001829 (i64 VectorExtractions.LE_DWORD_0)>;
1830 def : Pat<(i64 (vector_extract v2i64:$S, i64:$Idx)),
1831 (i64 VectorExtractions.BE_VARIABLE_DWORD)>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001832} // IsBigEndian, HasDirectMove
1833
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001834// v4f32 scalar <-> vector conversions (LE)
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001835let Predicates = [IsLittleEndian, HasP8Vector] in {
1836 def : Pat<(v4f32 (scalar_to_vector f32:$A)),
1837 (v4f32 (XXSLDWI (XSCVDPSPN $A), (XSCVDPSPN $A), 1))>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001838 def : Pat<(f32 (vector_extract v4f32:$S, 0)),
1839 (f32 (XSCVSPDPN (XXSLDWI $S, $S, 3)))>;
1840 def : Pat<(f32 (vector_extract v4f32:$S, 1)),
Nemanja Ivanoviceebbcb62016-07-12 12:16:27 +00001841 (f32 (XSCVSPDPN (XXPERMDI $S, $S, 2)))>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001842 def : Pat<(f32 (vector_extract v4f32:$S, 2)),
1843 (f32 (XSCVSPDPN (XXSLDWI $S, $S, 1)))>;
1844 def : Pat<(f32 (vector_extract v4f32:$S, 3)),
1845 (f32 (XSCVSPDPN $S))>;
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001846 def : Pat<(f32 (vector_extract v4f32:$S, i64:$Idx)),
1847 (f32 VectorExtractions.LE_VARIABLE_FLOAT)>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001848} // IsLittleEndian, HasP8Vector
1849
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001850// Variable index vector_extract for v2f64 does not require P8Vector
1851let Predicates = [IsLittleEndian, HasVSX] in
1852 def : Pat<(f64 (vector_extract v2f64:$S, i64:$Idx)),
1853 (f64 VectorExtractions.LE_VARIABLE_DOUBLE)>;
1854
Tony Jiang5f850cd2016-11-15 14:25:56 +00001855 def : Pat<(v4i32 (int_ppc_vsx_lxvw4x_be xoaddr:$src)), (LXVW4X xoaddr:$src)>;
1856 def : Pat<(v2f64 (int_ppc_vsx_lxvd2x_be xoaddr:$src)), (LXVD2X xoaddr:$src)>;
1857
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001858let Predicates = [IsLittleEndian, HasDirectMove] in {
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001859 // v16i8 scalar <-> vector conversions (LE)
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001860 def : Pat<(v16i8 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001861 (v16i8 (COPY_TO_REGCLASS MovesToVSR.LE_WORD_0, VSRC))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001862 def : Pat<(v8i16 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001863 (v8i16 (COPY_TO_REGCLASS MovesToVSR.LE_WORD_0, VSRC))>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001864 def : Pat<(v4i32 (scalar_to_vector i32:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001865 (v4i32 MovesToVSR.LE_WORD_0)>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001866 def : Pat<(v2i64 (scalar_to_vector i64:$A)),
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001867 (v2i64 MovesToVSR.LE_DWORD_0)>;
1868 def : Pat<(i32 (vector_extract v16i8:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001869 (i32 VectorExtractions.LE_BYTE_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001870 def : Pat<(i32 (vector_extract v16i8:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001871 (i32 VectorExtractions.LE_BYTE_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001872 def : Pat<(i32 (vector_extract v16i8:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001873 (i32 VectorExtractions.LE_BYTE_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001874 def : Pat<(i32 (vector_extract v16i8:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001875 (i32 VectorExtractions.LE_BYTE_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001876 def : Pat<(i32 (vector_extract v16i8:$S, 4)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001877 (i32 VectorExtractions.LE_BYTE_4)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001878 def : Pat<(i32 (vector_extract v16i8:$S, 5)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001879 (i32 VectorExtractions.LE_BYTE_5)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001880 def : Pat<(i32 (vector_extract v16i8:$S, 6)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001881 (i32 VectorExtractions.LE_BYTE_6)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001882 def : Pat<(i32 (vector_extract v16i8:$S, 7)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001883 (i32 VectorExtractions.LE_BYTE_7)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001884 def : Pat<(i32 (vector_extract v16i8:$S, 8)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001885 (i32 VectorExtractions.LE_BYTE_8)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001886 def : Pat<(i32 (vector_extract v16i8:$S, 9)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001887 (i32 VectorExtractions.LE_BYTE_9)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001888 def : Pat<(i32 (vector_extract v16i8:$S, 10)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001889 (i32 VectorExtractions.LE_BYTE_10)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001890 def : Pat<(i32 (vector_extract v16i8:$S, 11)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001891 (i32 VectorExtractions.LE_BYTE_11)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001892 def : Pat<(i32 (vector_extract v16i8:$S, 12)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001893 (i32 VectorExtractions.LE_BYTE_12)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001894 def : Pat<(i32 (vector_extract v16i8:$S, 13)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001895 (i32 VectorExtractions.LE_BYTE_13)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001896 def : Pat<(i32 (vector_extract v16i8:$S, 14)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001897 (i32 VectorExtractions.LE_BYTE_14)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001898 def : Pat<(i32 (vector_extract v16i8:$S, 15)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001899 (i32 VectorExtractions.LE_BYTE_15)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001900 def : Pat<(i32 (vector_extract v16i8:$S, i64:$Idx)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001901 (i32 VectorExtractions.LE_VARIABLE_BYTE)>;
Nemanja Ivanovic1c39ca62015-08-13 17:40:44 +00001902
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001903 // v8i16 scalar <-> vector conversions (LE)
1904 def : Pat<(i32 (vector_extract v8i16:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001905 (i32 VectorExtractions.LE_HALF_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001906 def : Pat<(i32 (vector_extract v8i16:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001907 (i32 VectorExtractions.LE_HALF_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001908 def : Pat<(i32 (vector_extract v8i16:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001909 (i32 VectorExtractions.LE_HALF_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001910 def : Pat<(i32 (vector_extract v8i16:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001911 (i32 VectorExtractions.LE_HALF_3)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001912 def : Pat<(i32 (vector_extract v8i16:$S, 4)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001913 (i32 VectorExtractions.LE_HALF_4)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001914 def : Pat<(i32 (vector_extract v8i16:$S, 5)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001915 (i32 VectorExtractions.LE_HALF_5)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001916 def : Pat<(i32 (vector_extract v8i16:$S, 6)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001917 (i32 VectorExtractions.LE_HALF_6)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001918 def : Pat<(i32 (vector_extract v8i16:$S, 7)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001919 (i32 VectorExtractions.LE_HALF_7)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001920 def : Pat<(i32 (vector_extract v8i16:$S, i64:$Idx)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001921 (i32 VectorExtractions.LE_VARIABLE_HALF)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001922
1923 // v4i32 scalar <-> vector conversions (LE)
1924 def : Pat<(i32 (vector_extract v4i32:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001925 (i32 VectorExtractions.LE_WORD_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001926 def : Pat<(i32 (vector_extract v4i32:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001927 (i32 VectorExtractions.LE_WORD_1)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001928 def : Pat<(i32 (vector_extract v4i32:$S, 2)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001929 (i32 VectorExtractions.LE_WORD_2)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001930 def : Pat<(i32 (vector_extract v4i32:$S, 3)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001931 (i32 VectorExtractions.LE_WORD_3)>;
1932 def : Pat<(i32 (vector_extract v4i32:$S, i64:$Idx)),
1933 (i32 VectorExtractions.LE_VARIABLE_WORD)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001934
1935 // v2i64 scalar <-> vector conversions (LE)
1936 def : Pat<(i64 (vector_extract v2i64:$S, 0)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001937 (i64 VectorExtractions.LE_DWORD_0)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001938 def : Pat<(i64 (vector_extract v2i64:$S, 1)),
Nemanja Ivanovicac8d01a2015-12-10 13:35:28 +00001939 (i64 VectorExtractions.LE_DWORD_1)>;
1940 def : Pat<(i64 (vector_extract v2i64:$S, i64:$Idx)),
1941 (i64 VectorExtractions.LE_VARIABLE_DWORD)>;
Nemanja Ivanovicd3896572015-10-09 11:12:18 +00001942} // IsLittleEndian, HasDirectMove
Nemanja Ivanovic89224762015-12-15 14:50:34 +00001943
1944let Predicates = [HasDirectMove, HasVSX] in {
1945// bitconvert f32 -> i32
1946// (convert to 32-bit fp single, shift right 1 word, move to GPR)
1947def : Pat<(i32 (bitconvert f32:$S)),
1948 (i32 (MFVSRWZ (EXTRACT_SUBREG
1949 (XXSLDWI (XSCVDPSPN $S),(XSCVDPSPN $S), 3),
1950 sub_64)))>;
1951// bitconvert i32 -> f32
1952// (move to FPR, shift left 1 word, convert to 64-bit fp single)
1953def : Pat<(f32 (bitconvert i32:$A)),
1954 (f32 (XSCVSPDPN
1955 (XXSLDWI MovesToVSR.LE_WORD_1, MovesToVSR.LE_WORD_1, 1)))>;
1956
1957// bitconvert f64 -> i64
1958// (move to GPR, nothing else needed)
1959def : Pat<(i64 (bitconvert f64:$S)),
1960 (i64 (MFVSRD $S))>;
1961
1962// bitconvert i64 -> f64
1963// (move to FPR, nothing else needed)
1964def : Pat<(f64 (bitconvert i64:$S)),
1965 (f64 (MTVSRD $S))>;
1966}
Kit Barton93612ec2016-02-26 21:11:55 +00001967
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00001968def AlignValues {
1969 dag F32_TO_BE_WORD1 = (v4f32 (XXSLDWI (XSCVDPSPN $B), (XSCVDPSPN $B), 3));
1970 dag I32_TO_BE_WORD1 = (COPY_TO_REGCLASS (MTVSRWZ $B), VSRC);
1971}
1972
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00001973// Materialize a zero-vector of long long
1974def : Pat<(v2i64 immAllZerosV),
1975 (v2i64 (XXLXORz))>;
1976
Kit Barton93612ec2016-02-26 21:11:55 +00001977// The following VSX instructions were introduced in Power ISA 3.0
1978def HasP9Vector : Predicate<"PPCSubTarget->hasP9Vector()">;
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00001979let AddedComplexity = 400, Predicates = [HasP9Vector] in {
Kit Barton93612ec2016-02-26 21:11:55 +00001980
1981 // [PO VRT XO VRB XO /]
1982 class X_VT5_XO5_VB5<bits<6> opcode, bits<5> xo2, bits<10> xo, string opc,
1983 list<dag> pattern>
1984 : X_RD5_XO5_RS5<opcode, xo2, xo, (outs vrrc:$vT), (ins vrrc:$vB),
1985 !strconcat(opc, " $vT, $vB"), IIC_VecFP, pattern>;
1986
1987 // [PO VRT XO VRB XO RO], Round to Odd version of [PO VRT XO VRB XO /]
1988 class X_VT5_XO5_VB5_Ro<bits<6> opcode, bits<5> xo2, bits<10> xo, string opc,
1989 list<dag> pattern>
1990 : X_VT5_XO5_VB5<opcode, xo2, xo, opc, pattern>, isDOT;
1991
1992 // [PO VRT XO VRB XO /], but the VRB is only used the left 64 bits (or less),
1993 // So we use different operand class for VRB
1994 class X_VT5_XO5_VB5_TyVB<bits<6> opcode, bits<5> xo2, bits<10> xo, string opc,
1995 RegisterOperand vbtype, list<dag> pattern>
1996 : X_RD5_XO5_RS5<opcode, xo2, xo, (outs vrrc:$vT), (ins vbtype:$vB),
1997 !strconcat(opc, " $vT, $vB"), IIC_VecFP, pattern>;
1998
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00001999 let UseVSXReg = 1 in {
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002000 // [PO T XO B XO BX /]
2001 class XX2_RT5_XO5_XB6<bits<6> opcode, bits<5> xo2, bits<9> xo, string opc,
2002 list<dag> pattern>
2003 : XX2_RD5_XO5_RS6<opcode, xo2, xo, (outs g8rc:$rT), (ins vsfrc:$XB),
2004 !strconcat(opc, " $rT, $XB"), IIC_VecFP, pattern>;
2005
Kit Barton93612ec2016-02-26 21:11:55 +00002006 // [PO T XO B XO BX TX]
2007 class XX2_XT6_XO5_XB6<bits<6> opcode, bits<5> xo2, bits<9> xo, string opc,
2008 RegisterOperand vtype, list<dag> pattern>
2009 : XX2_RD6_XO5_RS6<opcode, xo2, xo, (outs vtype:$XT), (ins vtype:$XB),
2010 !strconcat(opc, " $XT, $XB"), IIC_VecFP, pattern>;
2011
2012 // [PO T A B XO AX BX TX], src and dest register use different operand class
2013 class XX3_XT5_XA5_XB5<bits<6> opcode, bits<8> xo, string opc,
2014 RegisterOperand xty, RegisterOperand aty, RegisterOperand bty,
2015 InstrItinClass itin, list<dag> pattern>
2016 : XX3Form<opcode, xo, (outs xty:$XT), (ins aty:$XA, bty:$XB),
2017 !strconcat(opc, " $XT, $XA, $XB"), itin, pattern>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002018 } // UseVSXReg = 1
Kit Barton93612ec2016-02-26 21:11:55 +00002019
Chuang-Yu Cheng56638482016-03-28 07:38:01 +00002020 // [PO VRT VRA VRB XO /]
2021 class X_VT5_VA5_VB5<bits<6> opcode, bits<10> xo, string opc,
2022 list<dag> pattern>
2023 : XForm_1<opcode, xo, (outs vrrc:$vT), (ins vrrc:$vA, vrrc:$vB),
2024 !strconcat(opc, " $vT, $vA, $vB"), IIC_VecFP, pattern>;
2025
2026 // [PO VRT VRA VRB XO RO], Round to Odd version of [PO VRT VRA VRB XO /]
2027 class X_VT5_VA5_VB5_Ro<bits<6> opcode, bits<10> xo, string opc,
2028 list<dag> pattern>
2029 : X_VT5_VA5_VB5<opcode, xo, opc, pattern>, isDOT;
2030
2031 //===--------------------------------------------------------------------===//
2032 // Quad-Precision Scalar Move Instructions:
2033
2034 // Copy Sign
2035 def XSCPSGNQP : X_VT5_VA5_VB5<63, 100, "xscpsgnqp", []>;
2036
2037 // Absolute/Negative-Absolute/Negate
2038 def XSABSQP : X_VT5_XO5_VB5<63, 0, 804, "xsabsqp" , []>;
2039 def XSNABSQP : X_VT5_XO5_VB5<63, 8, 804, "xsnabsqp", []>;
2040 def XSNEGQP : X_VT5_XO5_VB5<63, 16, 804, "xsnegqp" , []>;
2041
2042 //===--------------------------------------------------------------------===//
2043 // Quad-Precision Scalar Floating-Point Arithmetic Instructions:
2044
2045 // Add/Divide/Multiply/Subtract
2046 def XSADDQP : X_VT5_VA5_VB5 <63, 4, "xsaddqp" , []>;
2047 def XSADDQPO : X_VT5_VA5_VB5_Ro<63, 4, "xsaddqpo", []>;
2048 def XSDIVQP : X_VT5_VA5_VB5 <63, 548, "xsdivqp" , []>;
2049 def XSDIVQPO : X_VT5_VA5_VB5_Ro<63, 548, "xsdivqpo", []>;
2050 def XSMULQP : X_VT5_VA5_VB5 <63, 36, "xsmulqp" , []>;
2051 def XSMULQPO : X_VT5_VA5_VB5_Ro<63, 36, "xsmulqpo", []>;
2052 def XSSUBQP : X_VT5_VA5_VB5 <63, 516, "xssubqp" , []>;
2053 def XSSUBQPO : X_VT5_VA5_VB5_Ro<63, 516, "xssubqpo", []>;
2054
2055 // Square-Root
2056 def XSSQRTQP : X_VT5_XO5_VB5 <63, 27, 804, "xssqrtqp" , []>;
2057 def XSSQRTQPO : X_VT5_XO5_VB5_Ro<63, 27, 804, "xssqrtqpo", []>;
2058
2059 // (Negative) Multiply-{Add/Subtract}
2060 def XSMADDQP : X_VT5_VA5_VB5 <63, 388, "xsmaddqp" , []>;
2061 def XSMADDQPO : X_VT5_VA5_VB5_Ro<63, 388, "xsmaddqpo" , []>;
2062 def XSMSUBQP : X_VT5_VA5_VB5 <63, 420, "xsmsubqp" , []>;
2063 def XSMSUBQPO : X_VT5_VA5_VB5_Ro<63, 420, "xsmsubqpo" , []>;
2064 def XSNMADDQP : X_VT5_VA5_VB5 <63, 452, "xsnmaddqp" , []>;
2065 def XSNMADDQPO: X_VT5_VA5_VB5_Ro<63, 452, "xsnmaddqpo", []>;
2066 def XSNMSUBQP : X_VT5_VA5_VB5 <63, 484, "xsnmsubqp" , []>;
2067 def XSNMSUBQPO: X_VT5_VA5_VB5_Ro<63, 484, "xsnmsubqpo", []>;
2068
Kit Barton93612ec2016-02-26 21:11:55 +00002069 //===--------------------------------------------------------------------===//
2070 // Quad/Double-Precision Compare Instructions:
2071
2072 // [PO BF // VRA VRB XO /]
2073 class X_BF3_VA5_VB5<bits<6> opcode, bits<10> xo, string opc,
2074 list<dag> pattern>
2075 : XForm_17<opcode, xo, (outs crrc:$crD), (ins vrrc:$VA, vrrc:$VB),
2076 !strconcat(opc, " $crD, $VA, $VB"), IIC_FPCompare> {
2077 let Pattern = pattern;
2078 }
2079
2080 // QP Compare Ordered/Unordered
2081 def XSCMPOQP : X_BF3_VA5_VB5<63, 132, "xscmpoqp", []>;
2082 def XSCMPUQP : X_BF3_VA5_VB5<63, 644, "xscmpuqp", []>;
2083
2084 // DP/QP Compare Exponents
2085 def XSCMPEXPDP : XX3Form_1<60, 59,
2086 (outs crrc:$crD), (ins vsfrc:$XA, vsfrc:$XB),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002087 "xscmpexpdp $crD, $XA, $XB", IIC_FPCompare, []>,
2088 UseVSXReg;
Kit Barton93612ec2016-02-26 21:11:55 +00002089 def XSCMPEXPQP : X_BF3_VA5_VB5<63, 164, "xscmpexpqp", []>;
2090
2091 // DP Compare ==, >=, >, !=
2092 // Use vsrc for XT, because the entire register of XT is set.
2093 // XT.dword[1] = 0x0000_0000_0000_0000
2094 def XSCMPEQDP : XX3_XT5_XA5_XB5<60, 3, "xscmpeqdp", vsrc, vsfrc, vsfrc,
2095 IIC_FPCompare, []>;
2096 def XSCMPGEDP : XX3_XT5_XA5_XB5<60, 19, "xscmpgedp", vsrc, vsfrc, vsfrc,
2097 IIC_FPCompare, []>;
2098 def XSCMPGTDP : XX3_XT5_XA5_XB5<60, 11, "xscmpgtdp", vsrc, vsfrc, vsfrc,
2099 IIC_FPCompare, []>;
2100 def XSCMPNEDP : XX3_XT5_XA5_XB5<60, 27, "xscmpnedp", vsrc, vsfrc, vsfrc,
2101 IIC_FPCompare, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002102 let UseVSXReg = 1 in {
Kit Barton93612ec2016-02-26 21:11:55 +00002103 // Vector Compare Not Equal
2104 def XVCMPNEDP : XX3Form_Rc<60, 123,
2105 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
2106 "xvcmpnedp $XT, $XA, $XB", IIC_VecFPCompare, []>;
2107 let Defs = [CR6] in
2108 def XVCMPNEDPo : XX3Form_Rc<60, 123,
2109 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
2110 "xvcmpnedp. $XT, $XA, $XB", IIC_VecFPCompare, []>,
2111 isDOT;
2112 def XVCMPNESP : XX3Form_Rc<60, 91,
2113 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
2114 "xvcmpnesp $XT, $XA, $XB", IIC_VecFPCompare, []>;
2115 let Defs = [CR6] in
2116 def XVCMPNESPo : XX3Form_Rc<60, 91,
2117 (outs vsrc:$XT), (ins vsrc:$XA, vsrc:$XB),
2118 "xvcmpnesp. $XT, $XA, $XB", IIC_VecFPCompare, []>,
2119 isDOT;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002120 } // UseVSXReg = 1
Kit Barton93612ec2016-02-26 21:11:55 +00002121
2122 //===--------------------------------------------------------------------===//
2123 // Quad-Precision Floating-Point Conversion Instructions:
2124
2125 // Convert DP -> QP
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002126 def XSCVDPQP : X_VT5_XO5_VB5_TyVB<63, 22, 836, "xscvdpqp", vfrc, []>;
Kit Barton93612ec2016-02-26 21:11:55 +00002127
2128 // Round & Convert QP -> DP (dword[1] is set to zero)
2129 def XSCVQPDP : X_VT5_XO5_VB5 <63, 20, 836, "xscvqpdp" , []>;
2130 def XSCVQPDPO : X_VT5_XO5_VB5_Ro<63, 20, 836, "xscvqpdpo", []>;
2131
2132 // Truncate & Convert QP -> (Un)Signed (D)Word (dword[1] is set to zero)
2133 def XSCVQPSDZ : X_VT5_XO5_VB5<63, 25, 836, "xscvqpsdz", []>;
2134 def XSCVQPSWZ : X_VT5_XO5_VB5<63, 9, 836, "xscvqpswz", []>;
2135 def XSCVQPUDZ : X_VT5_XO5_VB5<63, 17, 836, "xscvqpudz", []>;
2136 def XSCVQPUWZ : X_VT5_XO5_VB5<63, 1, 836, "xscvqpuwz", []>;
2137
2138 // Convert (Un)Signed DWord -> QP
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002139 def XSCVSDQP : X_VT5_XO5_VB5_TyVB<63, 10, 836, "xscvsdqp", vfrc, []>;
2140 def XSCVUDQP : X_VT5_XO5_VB5_TyVB<63, 2, 836, "xscvudqp", vfrc, []>;
Kit Barton93612ec2016-02-26 21:11:55 +00002141
Sean Fertilea435e072016-11-14 18:43:59 +00002142 let UseVSXReg = 1 in {
Kit Barton93612ec2016-02-26 21:11:55 +00002143 //===--------------------------------------------------------------------===//
2144 // Round to Floating-Point Integer Instructions
2145
2146 // (Round &) Convert DP <-> HP
2147 // Note! xscvdphp's src and dest register both use the left 64 bits, so we use
2148 // vsfrc for src and dest register. xscvhpdp's src only use the left 16 bits,
2149 // but we still use vsfrc for it.
2150 def XSCVDPHP : XX2_XT6_XO5_XB6<60, 17, 347, "xscvdphp", vsfrc, []>;
2151 def XSCVHPDP : XX2_XT6_XO5_XB6<60, 16, 347, "xscvhpdp", vsfrc, []>;
2152
2153 // Vector HP -> SP
2154 def XVCVHPSP : XX2_XT6_XO5_XB6<60, 24, 475, "xvcvhpsp", vsrc, []>;
Nemanja Ivanovicec4b0c32016-11-11 21:42:01 +00002155 def XVCVSPHP : XX2_XT6_XO5_XB6<60, 25, 475, "xvcvsphp", vsrc,
2156 [(set v4f32:$XT,
2157 (int_ppc_vsx_xvcvsphp v4f32:$XB))]>;
Kit Barton93612ec2016-02-26 21:11:55 +00002158
Sean Fertilea435e072016-11-14 18:43:59 +00002159 } // UseVSXReg = 1
2160
2161 // Pattern for matching Vector HP -> Vector SP intrinsic. Defined as a
2162 // seperate pattern so that it can convert the input register class from
2163 // VRRC(v8i16) to VSRC.
2164 def : Pat<(v4f32 (int_ppc_vsx_xvcvhpsp v8i16:$A)),
2165 (v4f32 (XVCVHPSP (COPY_TO_REGCLASS $A, VSRC)))>;
2166
Kit Barton93612ec2016-02-26 21:11:55 +00002167 class Z23_VT5_R1_VB5_RMC2_EX1<bits<6> opcode, bits<8> xo, bit ex, string opc,
2168 list<dag> pattern>
2169 : Z23Form_1<opcode, xo,
2170 (outs vrrc:$vT), (ins u1imm:$r, vrrc:$vB, u2imm:$rmc),
2171 !strconcat(opc, " $r, $vT, $vB, $rmc"), IIC_VecFP, pattern> {
2172 let RC = ex;
2173 }
2174
2175 // Round to Quad-Precision Integer [with Inexact]
2176 def XSRQPI : Z23_VT5_R1_VB5_RMC2_EX1<63, 5, 0, "xsrqpi" , []>;
2177 def XSRQPIX : Z23_VT5_R1_VB5_RMC2_EX1<63, 5, 1, "xsrqpix", []>;
2178
2179 // Round Quad-Precision to Double-Extended Precision (fp80)
2180 def XSRQPXP : Z23_VT5_R1_VB5_RMC2_EX1<63, 37, 0, "xsrqpxp", []>;
Kit Bartonba532dc2016-03-08 03:49:13 +00002181
2182 //===--------------------------------------------------------------------===//
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002183 // Insert/Extract Instructions
2184
2185 // Insert Exponent DP/QP
2186 // XT NOTE: XT.dword[1] = 0xUUUU_UUUU_UUUU_UUUU
2187 def XSIEXPDP : XX1Form <60, 918, (outs vsrc:$XT), (ins g8rc:$rA, g8rc:$rB),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002188 "xsiexpdp $XT, $rA, $rB", IIC_VecFP, []>, UseVSXReg;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002189 // vB NOTE: only vB.dword[0] is used, that's why we don't use
2190 // X_VT5_VA5_VB5 form
2191 def XSIEXPQP : XForm_18<63, 868, (outs vrrc:$vT), (ins vrrc:$vA, vsfrc:$vB),
2192 "xsiexpqp $vT, $vA, $vB", IIC_VecFP, []>;
2193
2194 // Extract Exponent/Significand DP/QP
2195 def XSXEXPDP : XX2_RT5_XO5_XB6<60, 0, 347, "xsxexpdp", []>;
2196 def XSXSIGDP : XX2_RT5_XO5_XB6<60, 1, 347, "xsxsigdp", []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002197
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002198 def XSXEXPQP : X_VT5_XO5_VB5 <63, 2, 804, "xsxexpqp", []>;
2199 def XSXSIGQP : X_VT5_XO5_VB5 <63, 18, 804, "xsxsigqp", []>;
2200
2201 // Vector Insert Word
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002202 let UseVSXReg = 1 in {
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002203 // XB NOTE: Only XB.dword[1] is used, but we use vsrc on XB.
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002204 def XXINSERTW :
2205 XX2_RD6_UIM5_RS6<60, 181, (outs vsrc:$XT),
2206 (ins vsrc:$XTi, vsrc:$XB, u4imm:$UIM),
2207 "xxinsertw $XT, $XB, $UIM", IIC_VecFP,
2208 [(set v4i32:$XT, (PPCxxinsert v4i32:$XTi, v4i32:$XB,
2209 imm32SExt16:$UIM))]>,
2210 RegConstraint<"$XTi = $XT">, NoEncode<"$XTi">;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002211
2212 // Vector Extract Unsigned Word
2213 def XXEXTRACTUW : XX2_RD6_UIM5_RS6<60, 165,
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002214 (outs vsfrc:$XT), (ins vsrc:$XB, u4imm:$UIMM),
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002215 "xxextractuw $XT, $XB, $UIMM", IIC_VecFP, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002216 } // UseVSXReg = 1
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002217
2218 // Vector Insert Exponent DP/SP
2219 def XVIEXPDP : XX3_XT5_XA5_XB5<60, 248, "xviexpdp", vsrc, vsrc, vsrc,
Nemanja Ivanovic0f459982016-10-26 19:03:40 +00002220 IIC_VecFP, [(set v2f64: $XT,(int_ppc_vsx_xviexpdp v2i64:$XA, v2i64:$XB))]>;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002221 def XVIEXPSP : XX3_XT5_XA5_XB5<60, 216, "xviexpsp", vsrc, vsrc, vsrc,
Nemanja Ivanovic0f459982016-10-26 19:03:40 +00002222 IIC_VecFP, [(set v4f32: $XT,(int_ppc_vsx_xviexpsp v4i32:$XA, v4i32:$XB))]>;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002223
2224 // Vector Extract Exponent/Significand DP/SP
Sean Fertileadda5b22016-11-14 14:42:37 +00002225 def XVXEXPDP : XX2_XT6_XO5_XB6<60, 0, 475, "xvxexpdp", vsrc,
2226 [(set v2i64: $XT,
2227 (int_ppc_vsx_xvxexpdp v2f64:$XB))]>;
2228 def XVXEXPSP : XX2_XT6_XO5_XB6<60, 8, 475, "xvxexpsp", vsrc,
2229 [(set v4i32: $XT,
2230 (int_ppc_vsx_xvxexpsp v4f32:$XB))]>;
2231 def XVXSIGDP : XX2_XT6_XO5_XB6<60, 1, 475, "xvxsigdp", vsrc,
2232 [(set v2i64: $XT,
2233 (int_ppc_vsx_xvxsigdp v2f64:$XB))]>;
2234 def XVXSIGSP : XX2_XT6_XO5_XB6<60, 9, 475, "xvxsigsp", vsrc,
2235 [(set v4i32: $XT,
2236 (int_ppc_vsx_xvxsigsp v4f32:$XB))]>;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002237
2238 //===--------------------------------------------------------------------===//
2239
2240 // Test Data Class SP/DP/QP
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002241 let UseVSXReg = 1 in {
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002242 def XSTSTDCSP : XX2_BF3_DCMX7_RS6<60, 298,
2243 (outs crrc:$BF), (ins u7imm:$DCMX, vsfrc:$XB),
2244 "xststdcsp $BF, $XB, $DCMX", IIC_VecFP, []>;
2245 def XSTSTDCDP : XX2_BF3_DCMX7_RS6<60, 362,
2246 (outs crrc:$BF), (ins u7imm:$DCMX, vsfrc:$XB),
2247 "xststdcdp $BF, $XB, $DCMX", IIC_VecFP, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002248 } // UseVSXReg = 1
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002249 def XSTSTDCQP : X_BF3_DCMX7_RS5 <63, 708,
2250 (outs crrc:$BF), (ins u7imm:$DCMX, vrrc:$vB),
2251 "xststdcqp $BF, $vB, $DCMX", IIC_VecFP, []>;
2252
2253 // Vector Test Data Class SP/DP
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002254 let UseVSXReg = 1 in {
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002255 def XVTSTDCSP : XX2_RD6_DCMX7_RS6<60, 13, 5,
2256 (outs vsrc:$XT), (ins u7imm:$DCMX, vsrc:$XB),
Sean Fertileadda5b22016-11-14 14:42:37 +00002257 "xvtstdcsp $XT, $XB, $DCMX", IIC_VecFP,
2258 [(set v4i32: $XT,
2259 (int_ppc_vsx_xvtstdcsp v4f32:$XB, imm:$DCMX))]>;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002260 def XVTSTDCDP : XX2_RD6_DCMX7_RS6<60, 15, 5,
2261 (outs vsrc:$XT), (ins u7imm:$DCMX, vsrc:$XB),
Sean Fertileadda5b22016-11-14 14:42:37 +00002262 "xvtstdcdp $XT, $XB, $DCMX", IIC_VecFP,
2263 [(set v2i64: $XT,
2264 (int_ppc_vsx_xvtstdcdp v2f64:$XB, imm:$DCMX))]>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002265 } // UseVSXReg = 1
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002266
2267 //===--------------------------------------------------------------------===//
2268
2269 // Maximum/Minimum Type-C/Type-J DP
2270 // XT.dword[1] = 0xUUUU_UUUU_UUUU_UUUU, so we use vsrc for XT
2271 def XSMAXCDP : XX3_XT5_XA5_XB5<60, 128, "xsmaxcdp", vsrc, vsfrc, vsfrc,
2272 IIC_VecFP, []>;
2273 def XSMAXJDP : XX3_XT5_XA5_XB5<60, 144, "xsmaxjdp", vsrc, vsfrc, vsfrc,
2274 IIC_VecFP, []>;
2275 def XSMINCDP : XX3_XT5_XA5_XB5<60, 136, "xsmincdp", vsrc, vsfrc, vsfrc,
2276 IIC_VecFP, []>;
2277 def XSMINJDP : XX3_XT5_XA5_XB5<60, 152, "xsminjdp", vsrc, vsfrc, vsfrc,
2278 IIC_VecFP, []>;
2279
2280 //===--------------------------------------------------------------------===//
2281
2282 // Vector Byte-Reverse H/W/D/Q Word
2283 def XXBRH : XX2_XT6_XO5_XB6<60, 7, 475, "xxbrh", vsrc, []>;
2284 def XXBRW : XX2_XT6_XO5_XB6<60, 15, 475, "xxbrw", vsrc, []>;
2285 def XXBRD : XX2_XT6_XO5_XB6<60, 23, 475, "xxbrd", vsrc, []>;
2286 def XXBRQ : XX2_XT6_XO5_XB6<60, 31, 475, "xxbrq", vsrc, []>;
2287
2288 // Vector Permute
2289 def XXPERM : XX3_XT5_XA5_XB5<60, 26, "xxperm" , vsrc, vsrc, vsrc,
2290 IIC_VecPerm, []>;
2291 def XXPERMR : XX3_XT5_XA5_XB5<60, 58, "xxpermr", vsrc, vsrc, vsrc,
2292 IIC_VecPerm, []>;
2293
2294 // Vector Splat Immediate Byte
2295 def XXSPLTIB : X_RD6_IMM8<60, 360, (outs vsrc:$XT), (ins u8imm:$IMM8),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002296 "xxspltib $XT, $IMM8", IIC_VecPerm, []>, UseVSXReg;
Chuang-Yu Cheng80722712016-03-28 08:34:28 +00002297
2298 //===--------------------------------------------------------------------===//
Kit Bartonba532dc2016-03-08 03:49:13 +00002299 // Vector/Scalar Load/Store Instructions
2300
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00002301 // When adding new D-Form loads/stores, be sure to update the ImmToIdxMap in
2302 // PPCRegisterInfo::PPCRegisterInfo and maybe save yourself some debugging.
Kit Bartonba532dc2016-03-08 03:49:13 +00002303 let mayLoad = 1 in {
2304 // Load Vector
2305 def LXV : DQ_RD6_RS5_DQ12<61, 1, (outs vsrc:$XT), (ins memrix16:$src),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002306 "lxv $XT, $src", IIC_LdStLFD, []>, UseVSXReg;
Kit Bartonba532dc2016-03-08 03:49:13 +00002307 // Load DWord
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002308 def LXSD : DSForm_1<57, 2, (outs vfrc:$vD), (ins memrix:$src),
Kit Bartonba532dc2016-03-08 03:49:13 +00002309 "lxsd $vD, $src", IIC_LdStLFD, []>;
2310 // Load SP from src, convert it to DP, and place in dword[0]
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002311 def LXSSP : DSForm_1<57, 3, (outs vfrc:$vD), (ins memrix:$src),
Kit Bartonba532dc2016-03-08 03:49:13 +00002312 "lxssp $vD, $src", IIC_LdStLFD, []>;
2313
2314 // [PO T RA RB XO TX] almost equal to [PO S RA RB XO SX], but has different
2315 // "out" and "in" dag
2316 class X_XT6_RA5_RB5<bits<6> opcode, bits<10> xo, string opc,
2317 RegisterOperand vtype, list<dag> pattern>
2318 : XX1Form<opcode, xo, (outs vtype:$XT), (ins memrr:$src),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002319 !strconcat(opc, " $XT, $src"), IIC_LdStLFD, pattern>, UseVSXReg;
Kit Bartonba532dc2016-03-08 03:49:13 +00002320
2321 // Load as Integer Byte/Halfword & Zero Indexed
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002322 def LXSIBZX : X_XT6_RA5_RB5<31, 781, "lxsibzx", vsfrc,
2323 [(set f64:$XT, (PPClxsizx xoaddr:$src, 1))]>;
2324 def LXSIHZX : X_XT6_RA5_RB5<31, 813, "lxsihzx", vsfrc,
2325 [(set f64:$XT, (PPClxsizx xoaddr:$src, 2))]>;
Kit Bartonba532dc2016-03-08 03:49:13 +00002326
2327 // Load Vector Halfword*8/Byte*16 Indexed
2328 def LXVH8X : X_XT6_RA5_RB5<31, 812, "lxvh8x" , vsrc, []>;
2329 def LXVB16X : X_XT6_RA5_RB5<31, 876, "lxvb16x", vsrc, []>;
2330
2331 // Load Vector Indexed
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00002332 def LXVX : X_XT6_RA5_RB5<31, 268, "lxvx" , vsrc,
2333 [(set v2f64:$XT, (load xoaddr:$src))]>;
Kit Bartonba532dc2016-03-08 03:49:13 +00002334
2335 // Load Vector (Left-justified) with Length
2336 def LXVL : X_XT6_RA5_RB5<31, 269, "lxvl" , vsrc, []>;
2337 def LXVLL : X_XT6_RA5_RB5<31, 301, "lxvll" , vsrc, []>;
2338
2339 // Load Vector Word & Splat Indexed
2340 def LXVWSX : X_XT6_RA5_RB5<31, 364, "lxvwsx" , vsrc, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002341 } // mayLoad
Kit Bartonba532dc2016-03-08 03:49:13 +00002342
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00002343 // When adding new D-Form loads/stores, be sure to update the ImmToIdxMap in
2344 // PPCRegisterInfo::PPCRegisterInfo and maybe save yourself some debugging.
Kit Bartonba532dc2016-03-08 03:49:13 +00002345 let mayStore = 1 in {
2346 // Store Vector
2347 def STXV : DQ_RD6_RS5_DQ12<61, 5, (outs), (ins vsrc:$XT, memrix16:$dst),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002348 "stxv $XT, $dst", IIC_LdStSTFD, []>, UseVSXReg;
Kit Bartonba532dc2016-03-08 03:49:13 +00002349 // Store DWord
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002350 def STXSD : DSForm_1<61, 2, (outs), (ins vfrc:$vS, memrix:$dst),
Kit Bartonba532dc2016-03-08 03:49:13 +00002351 "stxsd $vS, $dst", IIC_LdStSTFD, []>;
2352 // Convert DP of dword[0] to SP, and Store to dst
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002353 def STXSSP : DSForm_1<61, 3, (outs), (ins vfrc:$vS, memrix:$dst),
Kit Bartonba532dc2016-03-08 03:49:13 +00002354 "stxssp $vS, $dst", IIC_LdStSTFD, []>;
2355
2356 // [PO S RA RB XO SX]
2357 class X_XS6_RA5_RB5<bits<6> opcode, bits<10> xo, string opc,
2358 RegisterOperand vtype, list<dag> pattern>
2359 : XX1Form<opcode, xo, (outs), (ins vtype:$XT, memrr:$dst),
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002360 !strconcat(opc, " $XT, $dst"), IIC_LdStSTFD, pattern>, UseVSXReg;
Kit Bartonba532dc2016-03-08 03:49:13 +00002361
2362 // Store as Integer Byte/Halfword Indexed
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002363 def STXSIBX : X_XS6_RA5_RB5<31, 909, "stxsibx" , vsfrc,
2364 [(PPCstxsix f64:$XT, xoaddr:$dst, 1)]>;
2365 def STXSIHX : X_XS6_RA5_RB5<31, 941, "stxsihx" , vsfrc,
2366 [(PPCstxsix f64:$XT, xoaddr:$dst, 2)]>;
2367 let isCodeGenOnly = 1 in {
2368 def STXSIBXv : X_XS6_RA5_RB5<31, 909, "stxsibx" , vrrc, []>;
2369 def STXSIHXv : X_XS6_RA5_RB5<31, 941, "stxsihx" , vrrc, []>;
2370 }
Kit Bartonba532dc2016-03-08 03:49:13 +00002371
2372 // Store Vector Halfword*8/Byte*16 Indexed
2373 def STXVH8X : X_XS6_RA5_RB5<31, 940, "stxvh8x" , vsrc, []>;
2374 def STXVB16X : X_XS6_RA5_RB5<31, 1004, "stxvb16x", vsrc, []>;
2375
2376 // Store Vector Indexed
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00002377 def STXVX : X_XS6_RA5_RB5<31, 396, "stxvx" , vsrc,
2378 [(store v2f64:$XT, xoaddr:$dst)]>;
Kit Bartonba532dc2016-03-08 03:49:13 +00002379
2380 // Store Vector (Left-justified) with Length
2381 def STXVL : X_XS6_RA5_RB5<31, 397, "stxvl" , vsrc, []>;
2382 def STXVLL : X_XS6_RA5_RB5<31, 429, "stxvll" , vsrc, []>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002383 } // mayStore
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002384
2385 // Patterns for which instructions from ISA 3.0 are a better match
2386 let Predicates = [IsLittleEndian, HasP9Vector] in {
2387 def : Pat<(f32 (PPCfcfidus (PPCmtvsrz (i32 (extractelt v4i32:$A, 0))))),
2388 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 12)))>;
2389 def : Pat<(f32 (PPCfcfidus (PPCmtvsrz (i32 (extractelt v4i32:$A, 1))))),
2390 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 8)))>;
2391 def : Pat<(f32 (PPCfcfidus (PPCmtvsrz (i32 (extractelt v4i32:$A, 2))))),
2392 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 4)))>;
2393 def : Pat<(f32 (PPCfcfidus (PPCmtvsrz (i32 (extractelt v4i32:$A, 3))))),
2394 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 0)))>;
2395 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 0)),
2396 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 12))>;
2397 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 1)),
2398 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 8))>;
2399 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 2)),
2400 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 4))>;
2401 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 3)),
2402 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 0))>;
2403 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 0)),
2404 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 12))>;
2405 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 1)),
2406 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 8))>;
2407 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 2)),
2408 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 4))>;
2409 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 3)),
2410 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 0))>;
2411 } // IsLittleEndian, HasP9Vector
2412
2413 let Predicates = [IsBigEndian, HasP9Vector] in {
2414 def : Pat<(f32 (PPCfcfidus (PPCmtvsrz (i32 (extractelt v4i32:$A, 0))))),
2415 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 0)))>;
2416 def : Pat<(f32 (PPCfcfidus (PPCmtvsrz (i32 (extractelt v4i32:$A, 1))))),
2417 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 4)))>;
2418 def : Pat<(f32 (PPCfcfidus (PPCmtvsrz (i32 (extractelt v4i32:$A, 2))))),
2419 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 8)))>;
2420 def : Pat<(f32 (PPCfcfidus (PPCmtvsrz (i32 (extractelt v4i32:$A, 3))))),
2421 (f32 (XSCVUXDSP (XXEXTRACTUW $A, 12)))>;
2422 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 0)),
2423 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 0))>;
2424 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 1)),
2425 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 4))>;
2426 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 2)),
2427 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 8))>;
2428 def : Pat<(v4i32 (insertelt v4i32:$A, i32:$B, 3)),
2429 (v4i32 (XXINSERTW v4i32:$A, AlignValues.I32_TO_BE_WORD1, 12))>;
2430 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 0)),
2431 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 0))>;
2432 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 1)),
2433 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 4))>;
2434 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 2)),
2435 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 8))>;
2436 def : Pat<(v4f32 (insertelt v4f32:$A, f32:$B, 3)),
2437 (v4f32 (XXINSERTW v4f32:$A, AlignValues.F32_TO_BE_WORD1, 12))>;
2438 } // IsLittleEndian, HasP9Vector
Nemanja Ivanovic6e7879c2016-09-22 09:52:19 +00002439
2440 def : Pat<(v2f64 (load xoaddr:$src)), (LXVX xoaddr:$src)>;
2441 def : Pat<(v2i64 (load xoaddr:$src)), (LXVX xoaddr:$src)>;
2442 def : Pat<(v4f32 (load xoaddr:$src)), (LXVX xoaddr:$src)>;
2443 def : Pat<(v4i32 (load xoaddr:$src)), (LXVX xoaddr:$src)>;
2444 def : Pat<(v4i32 (int_ppc_vsx_lxvw4x xoaddr:$src)), (LXVX xoaddr:$src)>;
2445 def : Pat<(v2f64 (int_ppc_vsx_lxvd2x xoaddr:$src)), (LXVX xoaddr:$src)>;
2446 def : Pat<(store v2f64:$rS, xoaddr:$dst), (STXVX $rS, xoaddr:$dst)>;
2447 def : Pat<(store v2i64:$rS, xoaddr:$dst), (STXVX $rS, xoaddr:$dst)>;
2448 def : Pat<(store v4f32:$rS, xoaddr:$dst), (STXVX $rS, xoaddr:$dst)>;
2449 def : Pat<(store v4i32:$rS, xoaddr:$dst), (STXVX $rS, xoaddr:$dst)>;
2450 def : Pat<(int_ppc_vsx_stxvw4x v4i32:$rS, xoaddr:$dst),
2451 (STXVX $rS, xoaddr:$dst)>;
2452 def : Pat<(int_ppc_vsx_stxvd2x v2f64:$rS, xoaddr:$dst),
2453 (STXVX $rS, xoaddr:$dst)>;
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00002454
2455 def : Pat<(v4i32 (scalar_to_vector (i32 (load xoaddr:$src)))),
2456 (v4i32 (LXVWSX xoaddr:$src))>;
2457 def : Pat<(v4f32 (scalar_to_vector (f32 (load xoaddr:$src)))),
2458 (v4f32 (LXVWSX xoaddr:$src))>;
2459 def : Pat<(v4i32 (build_vector i32:$A, i32:$A, i32:$A, i32:$A)),
2460 (v4i32 (MTVSRWS $A))>;
2461 def : Pat<(v16i8 (build_vector immSExt8:$A, immSExt8:$A, immSExt8:$A,
2462 immSExt8:$A, immSExt8:$A, immSExt8:$A,
2463 immSExt8:$A, immSExt8:$A, immSExt8:$A,
2464 immSExt8:$A, immSExt8:$A, immSExt8:$A,
2465 immSExt8:$A, immSExt8:$A, immSExt8:$A,
2466 immSExt8:$A)),
2467 (v16i8 (COPY_TO_REGCLASS (XXSPLTIB imm:$A), VSRC))>;
2468 def : Pat<(v16i8 immAllOnesV),
2469 (v16i8 (COPY_TO_REGCLASS (XXSPLTIB 255), VSRC))>;
2470 def : Pat<(v8i16 immAllOnesV),
2471 (v8i16 (COPY_TO_REGCLASS (XXSPLTIB 255), VSRC))>;
2472 def : Pat<(v4i32 immAllOnesV),
2473 (v4i32 (XXSPLTIB 255))>;
2474 def : Pat<(v2i64 immAllOnesV),
2475 (v2i64 (XXSPLTIB 255))>;
Nemanja Ivanovic11049f82016-10-04 06:59:23 +00002476
2477 // Build vectors from i8 loads
2478 def : Pat<(v16i8 (scalar_to_vector ScalarLoads.Li8)),
2479 (v16i8 (VSPLTBs 7, (LXSIBZX xoaddr:$src)))>;
2480 def : Pat<(v8i16 (scalar_to_vector ScalarLoads.ZELi8)),
2481 (v8i16 (VSPLTHs 3, (LXSIBZX xoaddr:$src)))>;
2482 def : Pat<(v4i32 (scalar_to_vector ScalarLoads.ZELi8)),
2483 (v4i32 (XXSPLTWs (LXSIBZX xoaddr:$src), 1))>;
2484 def : Pat<(v2i64 (scalar_to_vector ScalarLoads.ZELi8i64)),
2485 (v2i64 (XXPERMDIs (LXSIBZX xoaddr:$src), 0))>;
2486 def : Pat<(v4i32 (scalar_to_vector ScalarLoads.SELi8)),
2487 (v4i32 (XXSPLTWs (VEXTSB2Ws (LXSIBZX xoaddr:$src)), 1))>;
2488 def : Pat<(v2i64 (scalar_to_vector ScalarLoads.SELi8i64)),
2489 (v2i64 (XXPERMDIs (VEXTSB2Ds (LXSIBZX xoaddr:$src)), 0))>;
2490
2491 // Build vectors from i16 loads
2492 def : Pat<(v8i16 (scalar_to_vector ScalarLoads.Li16)),
2493 (v8i16 (VSPLTHs 3, (LXSIHZX xoaddr:$src)))>;
2494 def : Pat<(v4i32 (scalar_to_vector ScalarLoads.ZELi16)),
2495 (v4i32 (XXSPLTWs (LXSIHZX xoaddr:$src), 1))>;
2496 def : Pat<(v2i64 (scalar_to_vector ScalarLoads.ZELi16i64)),
2497 (v2i64 (XXPERMDIs (LXSIHZX xoaddr:$src), 0))>;
2498 def : Pat<(v4i32 (scalar_to_vector ScalarLoads.SELi16)),
2499 (v4i32 (XXSPLTWs (VEXTSH2Ws (LXSIHZX xoaddr:$src)), 1))>;
2500 def : Pat<(v2i64 (scalar_to_vector ScalarLoads.SELi16i64)),
2501 (v2i64 (XXPERMDIs (VEXTSH2Ds (LXSIHZX xoaddr:$src)), 0))>;
2502
2503 let Predicates = [IsBigEndian, HasP9Vector] in {
2504 // Scalar stores of i8
2505 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 0)), xoaddr:$dst),
2506 (STXSIBXv (VSLDOI $S, $S, 9), xoaddr:$dst)>;
2507 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 1)), xoaddr:$dst),
2508 (STXSIBXv (VSLDOI $S, $S, 10), xoaddr:$dst)>;
2509 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 2)), xoaddr:$dst),
2510 (STXSIBXv (VSLDOI $S, $S, 11), xoaddr:$dst)>;
2511 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 3)), xoaddr:$dst),
2512 (STXSIBXv (VSLDOI $S, $S, 12), xoaddr:$dst)>;
2513 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 4)), xoaddr:$dst),
2514 (STXSIBXv (VSLDOI $S, $S, 13), xoaddr:$dst)>;
2515 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 5)), xoaddr:$dst),
2516 (STXSIBXv (VSLDOI $S, $S, 14), xoaddr:$dst)>;
2517 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 6)), xoaddr:$dst),
2518 (STXSIBXv (VSLDOI $S, $S, 15), xoaddr:$dst)>;
2519 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 7)), xoaddr:$dst),
2520 (STXSIBXv $S, xoaddr:$dst)>;
2521 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 8)), xoaddr:$dst),
2522 (STXSIBXv (VSLDOI $S, $S, 1), xoaddr:$dst)>;
2523 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 9)), xoaddr:$dst),
2524 (STXSIBXv (VSLDOI $S, $S, 2), xoaddr:$dst)>;
2525 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 10)), xoaddr:$dst),
2526 (STXSIBXv (VSLDOI $S, $S, 3), xoaddr:$dst)>;
2527 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 11)), xoaddr:$dst),
2528 (STXSIBXv (VSLDOI $S, $S, 4), xoaddr:$dst)>;
2529 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 12)), xoaddr:$dst),
2530 (STXSIBXv (VSLDOI $S, $S, 5), xoaddr:$dst)>;
2531 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 13)), xoaddr:$dst),
2532 (STXSIBXv (VSLDOI $S, $S, 6), xoaddr:$dst)>;
2533 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 14)), xoaddr:$dst),
2534 (STXSIBXv (VSLDOI $S, $S, 7), xoaddr:$dst)>;
2535 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 15)), xoaddr:$dst),
2536 (STXSIBXv (VSLDOI $S, $S, 8), xoaddr:$dst)>;
2537
2538 // Scalar stores of i16
2539 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 0)), xoaddr:$dst),
2540 (STXSIHXv (VSLDOI $S, $S, 10), xoaddr:$dst)>;
2541 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 1)), xoaddr:$dst),
2542 (STXSIHXv (VSLDOI $S, $S, 12), xoaddr:$dst)>;
2543 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 2)), xoaddr:$dst),
2544 (STXSIHXv (VSLDOI $S, $S, 14), xoaddr:$dst)>;
2545 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 3)), xoaddr:$dst),
2546 (STXSIHXv $S, xoaddr:$dst)>;
2547 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 4)), xoaddr:$dst),
2548 (STXSIHXv (VSLDOI $S, $S, 2), xoaddr:$dst)>;
2549 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 5)), xoaddr:$dst),
2550 (STXSIHXv (VSLDOI $S, $S, 4), xoaddr:$dst)>;
2551 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 6)), xoaddr:$dst),
2552 (STXSIHXv (VSLDOI $S, $S, 6), xoaddr:$dst)>;
2553 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 7)), xoaddr:$dst),
2554 (STXSIHXv (VSLDOI $S, $S, 8), xoaddr:$dst)>;
2555 } // IsBigEndian, HasP9Vector
2556
2557 let Predicates = [IsLittleEndian, HasP9Vector] in {
2558 // Scalar stores of i8
2559 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 0)), xoaddr:$dst),
2560 (STXSIBXv (VSLDOI $S, $S, 8), xoaddr:$dst)>;
2561 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 1)), xoaddr:$dst),
2562 (STXSIBXv (VSLDOI $S, $S, 7), xoaddr:$dst)>;
2563 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 2)), xoaddr:$dst),
2564 (STXSIBXv (VSLDOI $S, $S, 6), xoaddr:$dst)>;
2565 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 3)), xoaddr:$dst),
2566 (STXSIBXv (VSLDOI $S, $S, 5), xoaddr:$dst)>;
2567 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 4)), xoaddr:$dst),
2568 (STXSIBXv (VSLDOI $S, $S, 4), xoaddr:$dst)>;
2569 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 5)), xoaddr:$dst),
2570 (STXSIBXv (VSLDOI $S, $S, 3), xoaddr:$dst)>;
2571 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 6)), xoaddr:$dst),
2572 (STXSIBXv (VSLDOI $S, $S, 2), xoaddr:$dst)>;
2573 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 7)), xoaddr:$dst),
2574 (STXSIBXv (VSLDOI $S, $S, 1), xoaddr:$dst)>;
2575 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 8)), xoaddr:$dst),
2576 (STXSIBXv $S, xoaddr:$dst)>;
2577 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 9)), xoaddr:$dst),
2578 (STXSIBXv (VSLDOI $S, $S, 15), xoaddr:$dst)>;
2579 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 10)), xoaddr:$dst),
2580 (STXSIBXv (VSLDOI $S, $S, 14), xoaddr:$dst)>;
2581 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 11)), xoaddr:$dst),
2582 (STXSIBXv (VSLDOI $S, $S, 13), xoaddr:$dst)>;
2583 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 12)), xoaddr:$dst),
2584 (STXSIBXv (VSLDOI $S, $S, 12), xoaddr:$dst)>;
2585 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 13)), xoaddr:$dst),
2586 (STXSIBXv (VSLDOI $S, $S, 11), xoaddr:$dst)>;
2587 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 14)), xoaddr:$dst),
2588 (STXSIBXv (VSLDOI $S, $S, 10), xoaddr:$dst)>;
2589 def : Pat<(truncstorei8 (i32 (vector_extract v16i8:$S, 15)), xoaddr:$dst),
2590 (STXSIBXv (VSLDOI $S, $S, 9), xoaddr:$dst)>;
2591
2592 // Scalar stores of i16
2593 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 0)), xoaddr:$dst),
2594 (STXSIHXv (VSLDOI $S, $S, 8), xoaddr:$dst)>;
2595 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 1)), xoaddr:$dst),
2596 (STXSIHXv (VSLDOI $S, $S, 6), xoaddr:$dst)>;
2597 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 2)), xoaddr:$dst),
2598 (STXSIHXv (VSLDOI $S, $S, 4), xoaddr:$dst)>;
2599 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 3)), xoaddr:$dst),
2600 (STXSIHXv (VSLDOI $S, $S, 2), xoaddr:$dst)>;
2601 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 4)), xoaddr:$dst),
2602 (STXSIHXv $S, xoaddr:$dst)>;
2603 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 5)), xoaddr:$dst),
2604 (STXSIHXv (VSLDOI $S, $S, 14), xoaddr:$dst)>;
2605 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 6)), xoaddr:$dst),
2606 (STXSIHXv (VSLDOI $S, $S, 12), xoaddr:$dst)>;
2607 def : Pat<(truncstorei16 (i32 (vector_extract v8i16:$S, 7)), xoaddr:$dst),
2608 (STXSIHXv (VSLDOI $S, $S, 10), xoaddr:$dst)>;
2609 } // IsLittleEndian, HasP9Vector
2610
2611 // Vector sign extensions
2612 def : Pat<(f64 (PPCVexts f64:$A, 1)),
2613 (f64 (COPY_TO_REGCLASS (VEXTSB2Ds $A), VSFRC))>;
2614 def : Pat<(f64 (PPCVexts f64:$A, 2)),
2615 (f64 (COPY_TO_REGCLASS (VEXTSH2Ds $A), VSFRC))>;
Nemanja Ivanovic6354d232016-10-04 11:25:52 +00002616 let isPseudo = 1 in {
2617 def DFLOADf32 : Pseudo<(outs vssrc:$XT), (ins memrix:$src),
2618 "#DFLOADf32",
2619 [(set f32:$XT, (load iaddr:$src))]>;
2620 def DFLOADf64 : Pseudo<(outs vsfrc:$XT), (ins memrix:$src),
2621 "#DFLOADf64",
2622 [(set f64:$XT, (load iaddr:$src))]>;
2623 def DFSTOREf32 : Pseudo<(outs), (ins vssrc:$XT, memrix:$dst),
2624 "#DFSTOREf32",
2625 [(store f32:$XT, iaddr:$dst)]>;
2626 def DFSTOREf64 : Pseudo<(outs), (ins vsfrc:$XT, memrix:$dst),
2627 "#DFSTOREf64",
2628 [(store f64:$XT, iaddr:$dst)]>;
2629 }
2630 def : Pat<(f64 (extloadf32 iaddr:$src)),
2631 (COPY_TO_REGCLASS (DFLOADf32 iaddr:$src), VSFRC)>;
Nemanja Ivanovicb43bb612016-07-12 21:00:10 +00002632} // end HasP9Vector, AddedComplexity
Nemanja Ivanovicd2c3c512016-09-23 13:25:31 +00002633
2634let Predicates = [IsISA3_0, HasDirectMove, IsLittleEndian] in {
2635def : Pat<(v2i64 (build_vector i64:$rA, i64:$rB)),
2636 (v2i64 (MTVSRDD $rB, $rA))>;
2637def : Pat<(i64 (extractelt v2i64:$A, 0)),
2638 (i64 (MFVSRLD $A))>;
2639}
2640
2641let Predicates = [IsISA3_0, HasDirectMove, IsBigEndian] in {
2642def : Pat<(v2i64 (build_vector i64:$rB, i64:$rA)),
2643 (v2i64 (MTVSRDD $rB, $rA))>;
2644def : Pat<(i64 (extractelt v2i64:$A, 1)),
2645 (i64 (MFVSRLD $A))>;
2646}