]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - contrib/llvm/lib/Target/PowerPC/PPCSchedule.td
Merge llvm, clang, compiler-rt, libc++, libunwind, lld, lldb and openmp
[FreeBSD/FreeBSD.git] / contrib / llvm / lib / Target / PowerPC / PPCSchedule.td
1 //===-- PPCSchedule.td - PowerPC Scheduling Definitions ----*- tablegen -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8
9 //===----------------------------------------------------------------------===//
10 // Instruction Itinerary classes used for PowerPC
11 //
12 def IIC_IntSimple    : InstrItinClass;
13 def IIC_IntGeneral   : InstrItinClass;
14 def IIC_IntCompare   : InstrItinClass;
15 def IIC_IntISEL      : InstrItinClass;
16 def IIC_IntDivD      : InstrItinClass;
17 def IIC_IntDivW      : InstrItinClass;
18 def IIC_IntMFFS      : InstrItinClass;
19 def IIC_IntMFVSCR    : InstrItinClass;
20 def IIC_IntMTFSB0    : InstrItinClass;
21 def IIC_IntMTSRD     : InstrItinClass;
22 def IIC_IntMulHD     : InstrItinClass;
23 def IIC_IntMulHW     : InstrItinClass;
24 def IIC_IntMulHWU    : InstrItinClass;
25 def IIC_IntMulLI     : InstrItinClass;
26 def IIC_IntRFID      : InstrItinClass;
27 def IIC_IntRotateD   : InstrItinClass;
28 def IIC_IntRotateDI  : InstrItinClass;
29 def IIC_IntRotate    : InstrItinClass;
30 def IIC_IntShift     : InstrItinClass;
31 def IIC_IntTrapD     : InstrItinClass;
32 def IIC_IntTrapW     : InstrItinClass;
33 def IIC_BrB          : InstrItinClass;
34 def IIC_BrCR         : InstrItinClass;
35 def IIC_BrMCR        : InstrItinClass;
36 def IIC_BrMCRX       : InstrItinClass;
37 def IIC_LdStDCBA     : InstrItinClass;
38 def IIC_LdStDCBF     : InstrItinClass;
39 def IIC_LdStDCBI     : InstrItinClass;
40 def IIC_LdStLoad     : InstrItinClass;
41 def IIC_LdStLoadUpd  : InstrItinClass;
42 def IIC_LdStLoadUpdX : InstrItinClass;
43 def IIC_LdStStore    : InstrItinClass;
44 def IIC_LdStDSS      : InstrItinClass;
45 def IIC_LdStICBI     : InstrItinClass;
46 def IIC_LdStLD       : InstrItinClass;
47 def IIC_LdStLDU      : InstrItinClass;
48 def IIC_LdStLDUX     : InstrItinClass;
49 def IIC_LdStLDARX    : InstrItinClass;
50 def IIC_LdStLFD      : InstrItinClass;
51 def IIC_LdStLFDU     : InstrItinClass;
52 def IIC_LdStLFDUX    : InstrItinClass;
53 def IIC_LdStLHA      : InstrItinClass;
54 def IIC_LdStLHAU     : InstrItinClass;
55 def IIC_LdStLHAUX    : InstrItinClass;
56 def IIC_LdStLMW      : InstrItinClass;
57 def IIC_LdStLVecX    : InstrItinClass;
58 def IIC_LdStLWA      : InstrItinClass;
59 def IIC_LdStLWARX    : InstrItinClass;
60 def IIC_LdStSLBIA    : InstrItinClass;
61 def IIC_LdStSLBIE    : InstrItinClass;
62 def IIC_LdStSTD      : InstrItinClass;
63 def IIC_LdStSTDCX    : InstrItinClass;
64 def IIC_LdStSTU      : InstrItinClass;
65 def IIC_LdStSTUX     : InstrItinClass;
66 def IIC_LdStSTFD     : InstrItinClass;
67 def IIC_LdStSTFDU    : InstrItinClass;
68 def IIC_LdStSTVEBX   : InstrItinClass;
69 def IIC_LdStSTWCX    : InstrItinClass;
70 def IIC_LdStSync     : InstrItinClass;
71 def IIC_LdStCOPY     : InstrItinClass;
72 def IIC_LdStPASTE    : InstrItinClass;
73 def IIC_SprISYNC     : InstrItinClass;
74 def IIC_SprMFSR      : InstrItinClass;
75 def IIC_SprMTMSR     : InstrItinClass;
76 def IIC_SprMTSR      : InstrItinClass;
77 def IIC_SprTLBSYNC   : InstrItinClass;
78 def IIC_SprMFCR      : InstrItinClass;
79 def IIC_SprMFCRF     : InstrItinClass;
80 def IIC_SprMFMSR     : InstrItinClass;
81 def IIC_SprMFSPR     : InstrItinClass;
82 def IIC_SprMFTB      : InstrItinClass;
83 def IIC_SprMTSPR     : InstrItinClass;
84 def IIC_SprMTSRIN    : InstrItinClass;
85 def IIC_SprRFI       : InstrItinClass;
86 def IIC_SprSC        : InstrItinClass;
87 def IIC_FPGeneral    : InstrItinClass;
88 def IIC_FPDGeneral   : InstrItinClass;
89 def IIC_FPSGeneral   : InstrItinClass;
90 def IIC_FPAddSub     : InstrItinClass;
91 def IIC_FPCompare    : InstrItinClass;
92 def IIC_FPDivD       : InstrItinClass;
93 def IIC_FPDivS       : InstrItinClass;
94 def IIC_FPFused      : InstrItinClass;
95 def IIC_FPRes        : InstrItinClass;
96 def IIC_FPSqrtD      : InstrItinClass;
97 def IIC_FPSqrtS      : InstrItinClass;
98 def IIC_VecGeneral   : InstrItinClass;
99 def IIC_VecFP        : InstrItinClass;
100 def IIC_VecFPCompare : InstrItinClass;
101 def IIC_VecComplex   : InstrItinClass;
102 def IIC_VecPerm      : InstrItinClass;
103 def IIC_VecFPRound   : InstrItinClass;
104 def IIC_VecVSL       : InstrItinClass;
105 def IIC_VecVSR       : InstrItinClass;
106 def IIC_SprMTMSRD    : InstrItinClass;
107 def IIC_SprSLIE      : InstrItinClass;
108 def IIC_SprSLBFEE    : InstrItinClass;
109 def IIC_SprSLBIE     : InstrItinClass;
110 def IIC_SprSLBIEG    : InstrItinClass;
111 def IIC_SprSLBMTE    : InstrItinClass;
112 def IIC_SprSLBMFEE   : InstrItinClass;
113 def IIC_SprSLBMFEV   : InstrItinClass;
114 def IIC_SprSLBIA     : InstrItinClass;
115 def IIC_SprSLBSYNC   : InstrItinClass;
116 def IIC_SprTLBIA     : InstrItinClass;
117 def IIC_SprTLBIEL    : InstrItinClass;
118 def IIC_SprTLBIE     : InstrItinClass;
119 def IIC_SprABORT     : InstrItinClass;
120 def IIC_SprMSGSYNC   : InstrItinClass;
121 def IIC_SprSTOP      : InstrItinClass;
122 def IIC_SprMFPMR     : InstrItinClass;
123 def IIC_SprMTPMR     : InstrItinClass;
124
125 //===----------------------------------------------------------------------===//
126 // Processor instruction itineraries.
127
128 include "PPCScheduleG3.td"
129 include "PPCSchedule440.td"
130 include "PPCScheduleG4.td"
131 include "PPCScheduleG4Plus.td"
132 include "PPCScheduleG5.td"
133 include "PPCScheduleP7.td"
134 include "PPCScheduleP8.td"
135 include "PPCScheduleP9.td"
136 include "PPCScheduleA2.td"
137 include "PPCScheduleE500.td"
138 include "PPCScheduleE500mc.td"
139 include "PPCScheduleE5500.td"