blob: bb272469fbc99f86de3d3ad051ef0dd5131ff785 [file] [log] [blame]
Chris Lattner956f43c2006-06-16 20:22:01 +00001//===- PPCInstr64Bit.td - The PowerPC 64-bit Support -------*- tablegen -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file was developed by Chris Lattner and is distributed under
6// the University of Illinois Open Source License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This file describes the PowerPC 64-bit instructions. These patterns are used
11// both when in ppc64 mode and when in "use 64-bit extensions in 32-bit" mode.
12//
13//===----------------------------------------------------------------------===//
14
15
16//===----------------------------------------------------------------------===//
17// Fixed point instructions.
18//
19
20let PPC970_Unit = 1 in { // FXU Operations.
21
22def OR8 : XForm_6<31, 444, (ops G8RC:$rA, G8RC:$rS, G8RC:$rB),
23 "or $rA, $rS, $rB", IntGeneral,
24 [(set G8RC:$rA, (or G8RC:$rS, G8RC:$rB))]>;
25def OR4To8 : XForm_6<31, 444, (ops G8RC:$rA, GPRC:$rS, GPRC:$rB),
26 "or $rA, $rS, $rB", IntGeneral,
27 []>;
28def OR8To4 : XForm_6<31, 444, (ops GPRC:$rA, G8RC:$rS, G8RC:$rB),
29 "or $rA, $rS, $rB", IntGeneral,
30 []>;
31
32def ADD8 : XOForm_1<31, 266, 0, (ops G8RC:$rT, G8RC:$rA, G8RC:$rB),
33 "add $rT, $rA, $rB", IntGeneral,
34 [(set G8RC:$rT, (add G8RC:$rA, G8RC:$rB))]>;
35def MULHD : XOForm_1<31, 73, 0, (ops G8RC:$rT, G8RC:$rA, G8RC:$rB),
36 "mulhd $rT, $rA, $rB", IntMulHW,
37 [(set G8RC:$rT, (mulhs G8RC:$rA, G8RC:$rB))]>;
38def MULHDU : XOForm_1<31, 9, 0, (ops G8RC:$rT, G8RC:$rA, G8RC:$rB),
39 "mulhdu $rT, $rA, $rB", IntMulHWU,
40 [(set G8RC:$rT, (mulhu G8RC:$rA, G8RC:$rB))]>;
41
42def CMPDI : DForm_5_ext<11, (ops CRRC:$crD, GPRC:$rA, s16imm:$imm),
43 "cmpdi $crD, $rA, $imm", IntCompare>, isPPC64;
44
45def CMPLDI : DForm_6_ext<10, (ops CRRC:$dst, GPRC:$src1, u16imm:$src2),
46 "cmpldi $dst, $src1, $src2", IntCompare>, isPPC64;
47def CMPD : XForm_16_ext<31, 0, (ops CRRC:$crD, GPRC:$rA, GPRC:$rB),
48 "cmpd $crD, $rA, $rB", IntCompare>, isPPC64;
49def CMPLD : XForm_16_ext<31, 32, (ops CRRC:$crD, GPRC:$rA, GPRC:$rB),
50 "cmpld $crD, $rA, $rB", IntCompare>, isPPC64;
51
52def SLD : XForm_6<31, 27, (ops G8RC:$rA, G8RC:$rS, G8RC:$rB),
53 "sld $rA, $rS, $rB", IntRotateD,
54 [(set G8RC:$rA, (shl G8RC:$rS, G8RC:$rB))]>, isPPC64;
55def SRD : XForm_6<31, 539, (ops G8RC:$rA, G8RC:$rS, G8RC:$rB),
56 "srd $rA, $rS, $rB", IntRotateD,
57 [(set G8RC:$rA, (srl G8RC:$rS, G8RC:$rB))]>, isPPC64;
58def SRAD : XForm_6<31, 794, (ops G8RC:$rA, G8RC:$rS, G8RC:$rB),
59 "srad $rA, $rS, $rB", IntRotateD,
60 [(set G8RC:$rA, (sra G8RC:$rS, G8RC:$rB))]>, isPPC64;
61def EXTSW : XForm_11<31, 986, (ops G8RC:$rA, G8RC:$rS),
62 "extsw $rA, $rS", IntGeneral,
63 [(set G8RC:$rA, (sext_inreg G8RC:$rS, i32))]>, isPPC64;
64/// EXTSW_32 - Just like EXTSW, but works on '32-bit' registers.
65def EXTSW_32 : XForm_11<31, 986, (ops GPRC:$rA, GPRC:$rS),
66 "extsw $rA, $rS", IntGeneral,
67 [(set GPRC:$rA, (PPCextsw_32 GPRC:$rS))]>, isPPC64;
68
69def SRADI : XSForm_1<31, 413, (ops GPRC:$rA, GPRC:$rS, u6imm:$SH),
70 "sradi $rA, $rS, $SH", IntRotateD>, isPPC64;
71def DIVD : XOForm_1<31, 489, 0, (ops G8RC:$rT, G8RC:$rA, G8RC:$rB),
72 "divd $rT, $rA, $rB", IntDivD,
73 [(set G8RC:$rT, (sdiv G8RC:$rA, G8RC:$rB))]>, isPPC64,
74 PPC970_DGroup_First, PPC970_DGroup_Cracked;
75def DIVDU : XOForm_1<31, 457, 0, (ops G8RC:$rT, G8RC:$rA, G8RC:$rB),
76 "divdu $rT, $rA, $rB", IntDivD,
77 [(set G8RC:$rT, (udiv G8RC:$rA, G8RC:$rB))]>, isPPC64,
78 PPC970_DGroup_First, PPC970_DGroup_Cracked;
79def MULLD : XOForm_1<31, 233, 0, (ops G8RC:$rT, G8RC:$rA, G8RC:$rB),
80 "mulld $rT, $rA, $rB", IntMulHD,
81 [(set G8RC:$rT, (mul G8RC:$rA, G8RC:$rB))]>, isPPC64;
82
83let isTwoAddress = 1, isCommutable = 1 in {
84def RLDIMI : MDForm_1<30, 3,
85 (ops G8RC:$rA, G8RC:$rSi, G8RC:$rS, u6imm:$SH, u6imm:$MB),
86 "rldimi $rA, $rS, $SH, $MB", IntRotateD,
87 []>, isPPC64;
88}
89
90// Rotate instructions.
91def RLDICL : MDForm_1<30, 0,
92 (ops G8RC:$rA, G8RC:$rS, u6imm:$SH, u6imm:$MB),
93 "rldicl $rA, $rS, $SH, $MB", IntRotateD,
94 []>, isPPC64;
95def RLDICR : MDForm_1<30, 1,
96 (ops G8RC:$rA, G8RC:$rS, u6imm:$SH, u6imm:$ME),
97 "rldicr $rA, $rS, $SH, $ME", IntRotateD,
98 []>, isPPC64;
99}
100
101
102//===----------------------------------------------------------------------===//
103// Load/Store instructions.
104//
105
106
107let isLoad = 1, PPC970_Unit = 2 in {
108def LWAX : XForm_1<31, 341, (ops G8RC:$rD, memrr:$src),
109 "lwax $rD, $src", LdStLHA,
110 [(set G8RC:$rD, (sextload xaddr:$src, i32))]>, isPPC64,
111 PPC970_DGroup_Cracked;
112def LDX : XForm_1<31, 21, (ops G8RC:$rD, memrr:$src),
113 "ldx $rD, $src", LdStLD,
114 [(set G8RC:$rD, (load xaddr:$src))]>, isPPC64;
115}
116
117
118// DS-Form instructions. Load/Store instructions available in PPC-64
119//
120let isLoad = 1, PPC970_Unit = 2 in {
121def LWA : DSForm_1<58, 2, (ops GPRC:$rT, s16immX4:$DS, GPRC:$rA),
122 "lwa $rT, $DS($rA)", LdStLWA,
123 []>, isPPC64, PPC970_DGroup_Cracked;
124def LD : DSForm_2<58, 0, (ops GPRC:$rT, s16immX4:$DS, GPRC:$rA),
125 "ld $rT, $DS($rA)", LdStLD,
126 []>, isPPC64;
127}
128let isStore = 1, noResults = 1, PPC970_Unit = 2 in {
129def STD : DSForm_2<62, 0, (ops GPRC:$rT, s16immX4:$DS, GPRC:$rA),
130 "std $rT, $DS($rA)", LdStSTD,
131 []>, isPPC64;
132
133// STD_32/STDX_32 - Just like STD/STDX, but uses a '32-bit' input register.
134def STD_32 : DSForm_2<62, 0, (ops GPRC:$rT, memrix:$dst),
135 "std $rT, $dst", LdStSTD,
136 [(PPCstd_32 GPRC:$rT, ixaddr:$dst)]>, isPPC64;
137def STDX_32 : XForm_8<31, 149, (ops GPRC:$rT, memrr:$dst),
138 "stdx $rT, $dst", LdStSTD,
139 [(PPCstd_32 GPRC:$rT, xaddr:$dst)]>, isPPC64,
140 PPC970_DGroup_Cracked;
141
142def STDX : XForm_8<31, 149, (ops GPRC:$rS, GPRC:$rA, GPRC:$rB),
143 "stdx $rS, $rA, $rB", LdStSTD,
144 []>, isPPC64, PPC970_DGroup_Cracked;
145def STDUX : XForm_8<31, 181, (ops GPRC:$rS, GPRC:$rA, GPRC:$rB),
146 "stdux $rS, $rA, $rB", LdStSTD,
147 []>, isPPC64;
148}
149
150
151
152//===----------------------------------------------------------------------===//
153// Floating point instructions.
154//
155
156
157let PPC970_Unit = 3 in { // FPU Operations.
158def FCFID : XForm_26<63, 846, (ops F8RC:$frD, F8RC:$frB),
159 "fcfid $frD, $frB", FPGeneral,
160 [(set F8RC:$frD, (PPCfcfid F8RC:$frB))]>, isPPC64;
161def FCTIDZ : XForm_26<63, 815, (ops F8RC:$frD, F8RC:$frB),
162 "fctidz $frD, $frB", FPGeneral,
163 [(set F8RC:$frD, (PPCfctidz F8RC:$frB))]>, isPPC64;
164}
165
166
167//===----------------------------------------------------------------------===//
168// Instruction Patterns
169//
170
171// Extensions and truncates to/from 32-bit regs.
172def : Pat<(i64 (zext GPRC:$in)),
173 (RLDICL (OR4To8 GPRC:$in, GPRC:$in), 0, 32)>;
174def : Pat<(i64 (anyext GPRC:$in)),
175 (OR4To8 GPRC:$in, GPRC:$in)>;
176def : Pat<(i32 (trunc G8RC:$in)),
177 (OR8To4 G8RC:$in, G8RC:$in)>;
178
179// SHL/SRL
180def : Pat<(shl G8RC:$in, (i64 imm:$imm)),
181 (RLDICR G8RC:$in, imm:$imm, (SHL64 imm:$imm))>;
182def : Pat<(srl G8RC:$in, (i64 imm:$imm)),
183 (RLDICL G8RC:$in, (SRL64 imm:$imm), imm:$imm)>;