blob: ff45287631f51b209ee64b9299abbabc2093e7c7 [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 {
Chris Lattnera24b7612006-06-16 21:29:41 +0000108def LWA : DSForm_1<58, 2, (ops G8RC:$rT, memrix:$src),
109 "lwa $rT, $src", LdStLWA,
Chris Lattner059ca0f2006-06-16 21:01:35 +0000110 []>, isPPC64, PPC970_DGroup_Cracked;
Chris Lattnera24b7612006-06-16 21:29:41 +0000111def LD : DSForm_2<58, 0, (ops G8RC:$rT, memrix:$src),
112 "ld $rT, $src", LdStLD,
Chris Lattner059ca0f2006-06-16 21:01:35 +0000113 []>, isPPC64;
114
Chris Lattner956f43c2006-06-16 20:22:01 +0000115def LWAX : XForm_1<31, 341, (ops G8RC:$rD, memrr:$src),
116 "lwax $rD, $src", LdStLHA,
117 [(set G8RC:$rD, (sextload xaddr:$src, i32))]>, isPPC64,
118 PPC970_DGroup_Cracked;
119def LDX : XForm_1<31, 21, (ops G8RC:$rD, memrr:$src),
120 "ldx $rD, $src", LdStLD,
121 [(set G8RC:$rD, (load xaddr:$src))]>, isPPC64;
122}
Chris Lattner956f43c2006-06-16 20:22:01 +0000123let isStore = 1, noResults = 1, PPC970_Unit = 2 in {
Chris Lattnera24b7612006-06-16 21:29:41 +0000124def STD : DSForm_2<62, 0, (ops G8RC:$rT, memrix:$src),
125 "std $rT, $src", LdStSTD,
Chris Lattner956f43c2006-06-16 20:22:01 +0000126 []>, isPPC64;
127
Chris Lattnera24b7612006-06-16 21:29:41 +0000128def STDX : XForm_8<31, 149, (ops GPRC:$rS, memrr:$dst),
129 "stdx $rS, $dst", LdStSTD,
Chris Lattner059ca0f2006-06-16 21:01:35 +0000130 []>, isPPC64, PPC970_DGroup_Cracked;
Chris Lattnera24b7612006-06-16 21:29:41 +0000131def STDUX : XForm_8<31, 181, (ops GPRC:$rS, memrr:$dst),
132 "stdux $rS, $dst", LdStSTD,
Chris Lattner059ca0f2006-06-16 21:01:35 +0000133 []>, isPPC64;
134
Chris Lattner956f43c2006-06-16 20:22:01 +0000135// STD_32/STDX_32 - Just like STD/STDX, but uses a '32-bit' input register.
136def STD_32 : DSForm_2<62, 0, (ops GPRC:$rT, memrix:$dst),
137 "std $rT, $dst", LdStSTD,
138 [(PPCstd_32 GPRC:$rT, ixaddr:$dst)]>, isPPC64;
139def STDX_32 : XForm_8<31, 149, (ops GPRC:$rT, memrr:$dst),
140 "stdx $rT, $dst", LdStSTD,
141 [(PPCstd_32 GPRC:$rT, xaddr:$dst)]>, isPPC64,
142 PPC970_DGroup_Cracked;
Chris Lattner956f43c2006-06-16 20:22:01 +0000143}
144
145
146
147//===----------------------------------------------------------------------===//
148// Floating point instructions.
149//
150
151
152let PPC970_Unit = 3 in { // FPU Operations.
153def FCFID : XForm_26<63, 846, (ops F8RC:$frD, F8RC:$frB),
154 "fcfid $frD, $frB", FPGeneral,
155 [(set F8RC:$frD, (PPCfcfid F8RC:$frB))]>, isPPC64;
156def FCTIDZ : XForm_26<63, 815, (ops F8RC:$frD, F8RC:$frB),
157 "fctidz $frD, $frB", FPGeneral,
158 [(set F8RC:$frD, (PPCfctidz F8RC:$frB))]>, isPPC64;
159}
160
161
162//===----------------------------------------------------------------------===//
163// Instruction Patterns
164//
165
166// Extensions and truncates to/from 32-bit regs.
167def : Pat<(i64 (zext GPRC:$in)),
168 (RLDICL (OR4To8 GPRC:$in, GPRC:$in), 0, 32)>;
169def : Pat<(i64 (anyext GPRC:$in)),
170 (OR4To8 GPRC:$in, GPRC:$in)>;
171def : Pat<(i32 (trunc G8RC:$in)),
172 (OR8To4 G8RC:$in, G8RC:$in)>;
173
174// SHL/SRL
175def : Pat<(shl G8RC:$in, (i64 imm:$imm)),
176 (RLDICR G8RC:$in, imm:$imm, (SHL64 imm:$imm))>;
177def : Pat<(srl G8RC:$in, (i64 imm:$imm)),
178 (RLDICL G8RC:$in, (SRL64 imm:$imm), imm:$imm)>;