1 | /*===- TableGen'erated file -------------------------------------*- C++ -*-===*\ |
2 | |* *| |
3 | |* Subtarget Enumeration Source Fragment *| |
4 | |* *| |
5 | |* Automatically generated file, do not edit! *| |
6 | |* *| |
7 | \*===----------------------------------------------------------------------===*/ |
8 | |
9 | |
10 | #ifdef GET_SUBTARGETINFO_ENUM |
11 | #undef GET_SUBTARGETINFO_ENUM |
12 | |
13 | namespace llvm { |
14 | namespace Sparc { |
15 | enum { |
16 | DetectRoundChange = 0, |
17 | FeatureHardQuad = 1, |
18 | FeatureLeon = 2, |
19 | FeatureNoFMULS = 3, |
20 | FeatureNoFSMULD = 4, |
21 | FeatureOSA2011 = 5, |
22 | FeaturePWRPSR = 6, |
23 | FeatureReserveG1 = 7, |
24 | FeatureReserveG2 = 8, |
25 | FeatureReserveG3 = 9, |
26 | FeatureReserveG4 = 10, |
27 | FeatureReserveG5 = 11, |
28 | FeatureReserveG6 = 12, |
29 | FeatureReserveG7 = 13, |
30 | FeatureReserveI0 = 14, |
31 | FeatureReserveI1 = 15, |
32 | FeatureReserveI2 = 16, |
33 | FeatureReserveI3 = 17, |
34 | FeatureReserveI4 = 18, |
35 | FeatureReserveI5 = 19, |
36 | FeatureReserveL0 = 20, |
37 | FeatureReserveL1 = 21, |
38 | FeatureReserveL2 = 22, |
39 | FeatureReserveL3 = 23, |
40 | FeatureReserveL4 = 24, |
41 | FeatureReserveL5 = 25, |
42 | FeatureReserveL6 = 26, |
43 | FeatureReserveL7 = 27, |
44 | FeatureReserveO0 = 28, |
45 | FeatureReserveO1 = 29, |
46 | FeatureReserveO2 = 30, |
47 | FeatureReserveO3 = 31, |
48 | FeatureReserveO4 = 32, |
49 | FeatureReserveO5 = 33, |
50 | FeatureSoftFloat = 34, |
51 | FeatureSoftMulDiv = 35, |
52 | FeatureUA2005 = 36, |
53 | FeatureUA2007 = 37, |
54 | FeatureV8Deprecated = 38, |
55 | FeatureV8Plus = 39, |
56 | FeatureV9 = 40, |
57 | FeatureVIS = 41, |
58 | FeatureVIS2 = 42, |
59 | FeatureVIS3 = 43, |
60 | FixAllFDIVSQRT = 44, |
61 | FixTN0009 = 45, |
62 | FixTN0010 = 46, |
63 | FixTN0011 = 47, |
64 | FixTN0012 = 48, |
65 | FixTN0013 = 49, |
66 | InsertNOPLoad = 50, |
67 | LeonCASA = 51, |
68 | LeonCycleCounter = 52, |
69 | TuneSlowRDPC = 53, |
70 | UMACSMACSupport = 54, |
71 | UsePopc = 55, |
72 | NumSubtargetFeatures = 56 |
73 | }; |
74 | } // end namespace Sparc |
75 | } // end namespace llvm |
76 | |
77 | #endif // GET_SUBTARGETINFO_ENUM |
78 | |
79 | |
80 | #ifdef GET_SUBTARGETINFO_MACRO |
81 | GET_SUBTARGETINFO_MACRO(DetectRoundChange, false, detectRoundChange) |
82 | GET_SUBTARGETINFO_MACRO(FixAllFDIVSQRT, false, fixAllFDIVSQRT) |
83 | GET_SUBTARGETINFO_MACRO(FixTN0009, false, fixTN0009) |
84 | GET_SUBTARGETINFO_MACRO(FixTN0010, false, fixTN0010) |
85 | GET_SUBTARGETINFO_MACRO(FixTN0011, false, fixTN0011) |
86 | GET_SUBTARGETINFO_MACRO(FixTN0012, false, fixTN0012) |
87 | GET_SUBTARGETINFO_MACRO(FixTN0013, false, fixTN0013) |
88 | GET_SUBTARGETINFO_MACRO(HasHardQuad, false, hasHardQuad) |
89 | GET_SUBTARGETINFO_MACRO(HasLeonCasa, false, hasLeonCasa) |
90 | GET_SUBTARGETINFO_MACRO(HasLeonCycleCounter, false, hasLeonCycleCounter) |
91 | GET_SUBTARGETINFO_MACRO(HasNoFMULS, false, hasNoFMULS) |
92 | GET_SUBTARGETINFO_MACRO(HasNoFSMULD, false, hasNoFSMULD) |
93 | GET_SUBTARGETINFO_MACRO(HasPWRPSR, false, hasPWRPSR) |
94 | GET_SUBTARGETINFO_MACRO(HasSlowRDPC, false, hasSlowRDPC) |
95 | GET_SUBTARGETINFO_MACRO(HasUmacSmac, false, hasUmacSmac) |
96 | GET_SUBTARGETINFO_MACRO(InsertNOPLoad, false, insertNOPLoad) |
97 | GET_SUBTARGETINFO_MACRO(IsLeon, false, isLeon) |
98 | GET_SUBTARGETINFO_MACRO(IsOSA2011, false, isOSA2011) |
99 | GET_SUBTARGETINFO_MACRO(IsUA2005, false, isUA2005) |
100 | GET_SUBTARGETINFO_MACRO(IsUA2007, false, isUA2007) |
101 | GET_SUBTARGETINFO_MACRO(IsV8Plus, false, isV8Plus) |
102 | GET_SUBTARGETINFO_MACRO(IsV9, false, isV9) |
103 | GET_SUBTARGETINFO_MACRO(IsVIS, false, isVIS) |
104 | GET_SUBTARGETINFO_MACRO(IsVIS2, false, isVIS2) |
105 | GET_SUBTARGETINFO_MACRO(IsVIS3, false, isVIS3) |
106 | GET_SUBTARGETINFO_MACRO(UsePopc, false, usePopc) |
107 | GET_SUBTARGETINFO_MACRO(UseSoftFloat, false, useSoftFloat) |
108 | GET_SUBTARGETINFO_MACRO(UseSoftMulDiv, false, useSoftMulDiv) |
109 | GET_SUBTARGETINFO_MACRO(UseV8DeprecatedInsts, false, useV8DeprecatedInsts) |
110 | #undef GET_SUBTARGETINFO_MACRO |
111 | #endif // GET_SUBTARGETINFO_MACRO |
112 | |
113 | |
114 | #ifdef GET_SUBTARGETINFO_MC_DESC |
115 | #undef GET_SUBTARGETINFO_MC_DESC |
116 | |
117 | namespace llvm { |
118 | // Sorted (by key) array of values for CPU features. |
119 | extern const llvm::SubtargetFeatureKV SparcFeatureKV[] = { |
120 | { "deprecated-v8" , "Enable deprecated V8 instructions in V9 mode" , Sparc::FeatureV8Deprecated, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
121 | { "detectroundchange" , "LEON3 erratum detection: Detects any rounding mode change request: use only the round-to-nearest rounding mode" , Sparc::DetectRoundChange, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
122 | { "fix-tn0009" , "Enable workaround for errata described in GRLIB-TN-0009" , Sparc::FixTN0009, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
123 | { "fix-tn0010" , "Enable workaround for errata described in GRLIB-TN-0010" , Sparc::FixTN0010, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
124 | { "fix-tn0011" , "Enable workaround for errata described in GRLIB-TN-0011" , Sparc::FixTN0011, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
125 | { "fix-tn0012" , "Enable workaround for errata described in GRLIB-TN-0012" , Sparc::FixTN0012, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
126 | { "fix-tn0013" , "Enable workaround for errata described in GRLIB-TN-0013" , Sparc::FixTN0013, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
127 | { "fixallfdivsqrt" , "LEON erratum fix: Fix FDIVS/FDIVD/FSQRTS/FSQRTD instructions with NOPs and floating-point store" , Sparc::FixAllFDIVSQRT, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
128 | { "hard-quad-float" , "Enable quad-word floating point instructions" , Sparc::FeatureHardQuad, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
129 | { "hasleoncasa" , "Enable CASA instruction for LEON3 and LEON4 processors" , Sparc::LeonCASA, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
130 | { "hasumacsmac" , "Enable UMAC and SMAC for LEON3 and LEON4 processors" , Sparc::UMACSMACSupport, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
131 | { "insertnopload" , "LEON3 erratum fix: Insert a NOP instruction after every single-cycle load instruction when the next instruction is another load/store instruction" , Sparc::InsertNOPLoad, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
132 | { "leon" , "Enable LEON extensions" , Sparc::FeatureLeon, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
133 | { "leoncyclecounter" , "Use the Leon cycle counter register" , Sparc::LeonCycleCounter, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
134 | { "leonpwrpsr" , "Enable the PWRPSR instruction" , Sparc::FeaturePWRPSR, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
135 | { "no-fmuls" , "Disable the fmuls instruction." , Sparc::FeatureNoFMULS, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
136 | { "no-fsmuld" , "Disable the fsmuld instruction." , Sparc::FeatureNoFSMULD, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
137 | { "osa2011" , "Enable Oracle SPARC Architecture 2011 extensions" , Sparc::FeatureOSA2011, { { { 0xf0000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
138 | { "popc" , "Use the popc (population count) instruction" , Sparc::UsePopc, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
139 | { "reserve-g1" , "Reserve G1, making it unavailable as a GPR" , Sparc::FeatureReserveG1, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
140 | { "reserve-g2" , "Reserve G2, making it unavailable as a GPR" , Sparc::FeatureReserveG2, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
141 | { "reserve-g3" , "Reserve G3, making it unavailable as a GPR" , Sparc::FeatureReserveG3, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
142 | { "reserve-g4" , "Reserve G4, making it unavailable as a GPR" , Sparc::FeatureReserveG4, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
143 | { "reserve-g5" , "Reserve G5, making it unavailable as a GPR" , Sparc::FeatureReserveG5, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
144 | { "reserve-g6" , "Reserve G6, making it unavailable as a GPR" , Sparc::FeatureReserveG6, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
145 | { "reserve-g7" , "Reserve G7, making it unavailable as a GPR" , Sparc::FeatureReserveG7, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
146 | { "reserve-i0" , "Reserve I0, making it unavailable as a GPR" , Sparc::FeatureReserveI0, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
147 | { "reserve-i1" , "Reserve I1, making it unavailable as a GPR" , Sparc::FeatureReserveI1, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
148 | { "reserve-i2" , "Reserve I2, making it unavailable as a GPR" , Sparc::FeatureReserveI2, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
149 | { "reserve-i3" , "Reserve I3, making it unavailable as a GPR" , Sparc::FeatureReserveI3, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
150 | { "reserve-i4" , "Reserve I4, making it unavailable as a GPR" , Sparc::FeatureReserveI4, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
151 | { "reserve-i5" , "Reserve I5, making it unavailable as a GPR" , Sparc::FeatureReserveI5, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
152 | { "reserve-l0" , "Reserve L0, making it unavailable as a GPR" , Sparc::FeatureReserveL0, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
153 | { "reserve-l1" , "Reserve L1, making it unavailable as a GPR" , Sparc::FeatureReserveL1, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
154 | { "reserve-l2" , "Reserve L2, making it unavailable as a GPR" , Sparc::FeatureReserveL2, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
155 | { "reserve-l3" , "Reserve L3, making it unavailable as a GPR" , Sparc::FeatureReserveL3, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
156 | { "reserve-l4" , "Reserve L4, making it unavailable as a GPR" , Sparc::FeatureReserveL4, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
157 | { "reserve-l5" , "Reserve L5, making it unavailable as a GPR" , Sparc::FeatureReserveL5, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
158 | { "reserve-l6" , "Reserve L6, making it unavailable as a GPR" , Sparc::FeatureReserveL6, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
159 | { "reserve-l7" , "Reserve L7, making it unavailable as a GPR" , Sparc::FeatureReserveL7, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
160 | { "reserve-o0" , "Reserve O0, making it unavailable as a GPR" , Sparc::FeatureReserveO0, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
161 | { "reserve-o1" , "Reserve O1, making it unavailable as a GPR" , Sparc::FeatureReserveO1, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
162 | { "reserve-o2" , "Reserve O2, making it unavailable as a GPR" , Sparc::FeatureReserveO2, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
163 | { "reserve-o3" , "Reserve O3, making it unavailable as a GPR" , Sparc::FeatureReserveO3, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
164 | { "reserve-o4" , "Reserve O4, making it unavailable as a GPR" , Sparc::FeatureReserveO4, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
165 | { "reserve-o5" , "Reserve O5, making it unavailable as a GPR" , Sparc::FeatureReserveO5, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
166 | { "slow-rdpc" , "rd %pc, %XX is slow" , Sparc::TuneSlowRDPC, { { { 0x10000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
167 | { "soft-float" , "Use software emulation for floating point" , Sparc::FeatureSoftFloat, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
168 | { "soft-mul-div" , "Use software emulation for integer multiply and divide" , Sparc::FeatureSoftMulDiv, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
169 | { "ua2005" , "Enable UltraSPARC Architecture 2005 extensions" , Sparc::FeatureUA2005, { { { 0x70000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
170 | { "ua2007" , "Enable UltraSPARC Architecture 2007 extensions" , Sparc::FeatureUA2007, { { { 0x70000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
171 | { "v8plus" , "Enable V8+ mode, allowing use of 64-bit V9 instructions in 32-bit code" , Sparc::FeatureV8Plus, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
172 | { "v9" , "Enable SPARC-V9 instructions" , Sparc::FeatureV9, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
173 | { "vis" , "Enable UltraSPARC Visual Instruction Set extensions" , Sparc::FeatureVIS, { { { 0x10000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
174 | { "vis2" , "Enable Visual Instruction Set extensions II" , Sparc::FeatureVIS2, { { { 0x10000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
175 | { "vis3" , "Enable Visual Instruction Set extensions III" , Sparc::FeatureVIS3, { { { 0x10000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } } }, |
176 | }; |
177 | |
178 | #ifdef DBGFIELD |
179 | #error "<target>GenSubtargetInfo.inc requires a DBGFIELD macro" |
180 | #endif |
181 | #if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP) |
182 | #define DBGFIELD(x) x, |
183 | #define DBGVAL_OR_NULLPTR(x) x |
184 | #else |
185 | #define DBGFIELD(x) |
186 | #define DBGVAL_OR_NULLPTR(x) nullptr |
187 | #endif |
188 | |
189 | // Functional units for "LEON2Itineraries" |
190 | namespace LEON2ItinerariesFU { |
191 | const InstrStage::FuncUnits LEONIU = 1ULL << 0; |
192 | const InstrStage::FuncUnits LEONFPU = 1ULL << 1; |
193 | } // end namespace LEON2ItinerariesFU |
194 | |
195 | // Functional units for "LEON3Itineraries" |
196 | namespace LEON3ItinerariesFU { |
197 | const InstrStage::FuncUnits LEONIU = 1ULL << 0; |
198 | const InstrStage::FuncUnits LEONFPU = 1ULL << 1; |
199 | } // end namespace LEON3ItinerariesFU |
200 | |
201 | // Functional units for "LEON4Itineraries" |
202 | namespace LEON4ItinerariesFU { |
203 | const InstrStage::FuncUnits LEONIU = 1ULL << 0; |
204 | const InstrStage::FuncUnits LEONFPU = 1ULL << 1; |
205 | } // end namespace LEON4ItinerariesFU |
206 | |
207 | extern const llvm::InstrStage SparcStages[] = { |
208 | { 0, 0, 0, llvm::InstrStage::Required }, // No itinerary |
209 | { 1, LEON2ItinerariesFU::LEONIU, -1, (llvm::InstrStage::ReservationKinds)0 }, // 1 |
210 | { 1, LEON2ItinerariesFU::LEONFPU, -1, (llvm::InstrStage::ReservationKinds)0 }, // 2 |
211 | { 1, LEON2ItinerariesFU::LEONIU | LEON2ItinerariesFU::LEONFPU, -1, (llvm::InstrStage::ReservationKinds)0 }, // 3 |
212 | { 1, LEON3ItinerariesFU::LEONIU, -1, (llvm::InstrStage::ReservationKinds)0 }, // 4 |
213 | { 1, LEON3ItinerariesFU::LEONFPU, -1, (llvm::InstrStage::ReservationKinds)0 }, // 5 |
214 | { 1, LEON3ItinerariesFU::LEONIU | LEON3ItinerariesFU::LEONFPU, -1, (llvm::InstrStage::ReservationKinds)0 }, // 6 |
215 | { 1, LEON4ItinerariesFU::LEONIU, -1, (llvm::InstrStage::ReservationKinds)0 }, // 7 |
216 | { 1, LEON4ItinerariesFU::LEONFPU, -1, (llvm::InstrStage::ReservationKinds)0 }, // 8 |
217 | { 1, LEON4ItinerariesFU::LEONIU | LEON4ItinerariesFU::LEONFPU, -1, (llvm::InstrStage::ReservationKinds)0 }, // 9 |
218 | { 0, 0, 0, llvm::InstrStage::Required } // End stages |
219 | }; |
220 | extern const unsigned SparcOperandCycles[] = { |
221 | 0, // No itinerary |
222 | 1, 1, // 1-2 |
223 | 7, 1, // 3-4 |
224 | 2, 1, // 5-6 |
225 | 2, 1, // 7-8 |
226 | 7, 1, // 9-10 |
227 | 36, 1, // 11-12 |
228 | 20, 1, // 13-14 |
229 | 21, 1, // 15-16 |
230 | 16, 1, // 17-18 |
231 | 2, 1, // 19-20 |
232 | 65, 1, // 21-22 |
233 | 37, 1, // 23-24 |
234 | 2, 1, // 25-26 |
235 | 2, 1, // 27-28 |
236 | 1, 1, // 29-30 |
237 | 35, 1, // 31-32 |
238 | 5, 1, // 33-34 |
239 | 2, 1, // 35-36 |
240 | 3, 1, // 37-38 |
241 | 5, 1, // 39-40 |
242 | 1, 1, // 41-42 |
243 | 7, 1, // 43-44 |
244 | 3, 1, // 45-46 |
245 | 2, 1, // 47-48 |
246 | 4, 1, // 49-50 |
247 | 17, 1, // 51-52 |
248 | 16, 1, // 53-54 |
249 | 4, 1, // 55-56 |
250 | 4, 1, // 57-58 |
251 | 2, 1, // 59-60 |
252 | 25, 1, // 61-62 |
253 | 24, 1, // 63-64 |
254 | 4, 1, // 65-66 |
255 | 2, 1, // 67-68 |
256 | 1, 1, // 69-70 |
257 | 35, 1, // 71-72 |
258 | 2, 1, // 73-74 |
259 | 1, 1, // 75-76 |
260 | 4, 1, // 77-78 |
261 | 5, 1, // 79-80 |
262 | 4, 1, // 81-82 |
263 | 1, 1, // 83-84 |
264 | 7, 1, // 85-86 |
265 | 3, 1, // 87-88 |
266 | 2, 1, // 89-90 |
267 | 4, 1, // 91-92 |
268 | 17, 1, // 93-94 |
269 | 16, 1, // 95-96 |
270 | 4, 1, // 97-98 |
271 | 4, 1, // 99-100 |
272 | 2, 1, // 101-102 |
273 | 25, 1, // 103-104 |
274 | 24, 1, // 105-106 |
275 | 4, 1, // 107-108 |
276 | 1, 1, // 109-110 |
277 | 1, 1, // 111-112 |
278 | 35, 1, // 113-114 |
279 | 2, 1, // 115-116 |
280 | 1, 1, // 117-118 |
281 | 1, 1, // 119-120 |
282 | 1, 1, // 121-122 |
283 | 4, 1, // 123-124 |
284 | 0 // End operand cycles |
285 | }; |
286 | extern const unsigned SparcForwardingPaths[] = { |
287 | 0, // No itinerary |
288 | 0, 0, // 1-2 |
289 | 0, 0, // 3-4 |
290 | 0, 0, // 5-6 |
291 | 0, 0, // 7-8 |
292 | 0, 0, // 9-10 |
293 | 0, 0, // 11-12 |
294 | 0, 0, // 13-14 |
295 | 0, 0, // 15-16 |
296 | 0, 0, // 17-18 |
297 | 0, 0, // 19-20 |
298 | 0, 0, // 21-22 |
299 | 0, 0, // 23-24 |
300 | 0, 0, // 25-26 |
301 | 0, 0, // 27-28 |
302 | 0, 0, // 29-30 |
303 | 0, 0, // 31-32 |
304 | 0, 0, // 33-34 |
305 | 0, 0, // 35-36 |
306 | 0, 0, // 37-38 |
307 | 0, 0, // 39-40 |
308 | 0, 0, // 41-42 |
309 | 0, 0, // 43-44 |
310 | 0, 0, // 45-46 |
311 | 0, 0, // 47-48 |
312 | 0, 0, // 49-50 |
313 | 0, 0, // 51-52 |
314 | 0, 0, // 53-54 |
315 | 0, 0, // 55-56 |
316 | 0, 0, // 57-58 |
317 | 0, 0, // 59-60 |
318 | 0, 0, // 61-62 |
319 | 0, 0, // 63-64 |
320 | 0, 0, // 65-66 |
321 | 0, 0, // 67-68 |
322 | 0, 0, // 69-70 |
323 | 0, 0, // 71-72 |
324 | 0, 0, // 73-74 |
325 | 0, 0, // 75-76 |
326 | 0, 0, // 77-78 |
327 | 0, 0, // 79-80 |
328 | 0, 0, // 81-82 |
329 | 0, 0, // 83-84 |
330 | 0, 0, // 85-86 |
331 | 0, 0, // 87-88 |
332 | 0, 0, // 89-90 |
333 | 0, 0, // 91-92 |
334 | 0, 0, // 93-94 |
335 | 0, 0, // 95-96 |
336 | 0, 0, // 97-98 |
337 | 0, 0, // 99-100 |
338 | 0, 0, // 101-102 |
339 | 0, 0, // 103-104 |
340 | 0, 0, // 105-106 |
341 | 0, 0, // 107-108 |
342 | 0, 0, // 109-110 |
343 | 0, 0, // 111-112 |
344 | 0, 0, // 113-114 |
345 | 0, 0, // 115-116 |
346 | 0, 0, // 117-118 |
347 | 0, 0, // 119-120 |
348 | 0, 0, // 121-122 |
349 | 0, 0, // 123-124 |
350 | 0 // End bypass tables |
351 | }; |
352 | |
353 | static constexpr llvm::InstrItinerary LEON2Itineraries[] = { |
354 | { 0, 0, 0, 0, 0 }, // 0 NoInstrModel |
355 | { 1, 1, 2, 1, 3 }, // 1 IIC_iu_instr |
356 | { 1, 2, 3, 3, 5 }, // 2 IIC_fpu_normal_instr |
357 | { 1, 3, 4, 5, 7 }, // 3 IIC_jmp_or_call |
358 | { 1, 2, 3, 7, 9 }, // 4 IIC_fpu_abs |
359 | { 1, 2, 3, 9, 11 }, // 5 IIC_fpu_fast_instr |
360 | { 1, 2, 3, 11, 13 }, // 6 IIC_fpu_divd |
361 | { 1, 2, 3, 13, 15 }, // 7 IIC_fpu_divs |
362 | { 1, 2, 3, 15, 17 }, // 8 IIC_fpu_muld |
363 | { 1, 2, 3, 17, 19 }, // 9 IIC_fpu_muls |
364 | { 1, 2, 3, 19, 21 }, // 10 IIC_fpu_negs |
365 | { 1, 2, 3, 21, 23 }, // 11 IIC_fpu_sqrtd |
366 | { 1, 2, 3, 23, 25 }, // 12 IIC_fpu_sqrts |
367 | { 1, 2, 3, 25, 27 }, // 13 IIC_fpu_stod |
368 | { 1, 3, 4, 27, 29 }, // 14 IIC_ldd |
369 | { 1, 3, 4, 29, 31 }, // 15 IIC_iu_or_fpu_instr |
370 | { 1, 1, 2, 31, 33 }, // 16 IIC_iu_div |
371 | { 0, 0, 0, 0, 0 }, // 17 IIC_smac_umac |
372 | { 1, 1, 2, 33, 35 }, // 18 IIC_iu_smul |
373 | { 1, 3, 4, 35, 37 }, // 19 IIC_st |
374 | { 1, 3, 4, 37, 39 }, // 20 IIC_std |
375 | { 1, 1, 2, 39, 41 }, // 21 IIC_iu_umul |
376 | { 0, uint16_t(~0U), uint16_t(~0U), uint16_t(~0U), uint16_t(~0U) }// end marker |
377 | }; |
378 | |
379 | static constexpr llvm::InstrItinerary LEON3Itineraries[] = { |
380 | { 0, 0, 0, 0, 0 }, // 0 NoInstrModel |
381 | { 1, 4, 5, 41, 43 }, // 1 IIC_iu_instr |
382 | { 1, 5, 6, 43, 45 }, // 2 IIC_fpu_normal_instr |
383 | { 1, 6, 7, 45, 47 }, // 3 IIC_jmp_or_call |
384 | { 1, 5, 6, 47, 49 }, // 4 IIC_fpu_abs |
385 | { 1, 5, 6, 49, 51 }, // 5 IIC_fpu_fast_instr |
386 | { 1, 5, 6, 51, 53 }, // 6 IIC_fpu_divd |
387 | { 1, 5, 6, 53, 55 }, // 7 IIC_fpu_divs |
388 | { 1, 5, 6, 55, 57 }, // 8 IIC_fpu_muld |
389 | { 1, 5, 6, 57, 59 }, // 9 IIC_fpu_muls |
390 | { 1, 5, 6, 59, 61 }, // 10 IIC_fpu_negs |
391 | { 1, 5, 6, 61, 63 }, // 11 IIC_fpu_sqrtd |
392 | { 1, 5, 6, 63, 65 }, // 12 IIC_fpu_sqrts |
393 | { 1, 5, 6, 65, 67 }, // 13 IIC_fpu_stod |
394 | { 1, 6, 7, 67, 69 }, // 14 IIC_ldd |
395 | { 1, 6, 7, 69, 71 }, // 15 IIC_iu_or_fpu_instr |
396 | { 1, 4, 5, 71, 73 }, // 16 IIC_iu_div |
397 | { 1, 4, 5, 73, 75 }, // 17 IIC_smac_umac |
398 | { 1, 4, 5, 75, 77 }, // 18 IIC_iu_smul |
399 | { 1, 6, 7, 77, 79 }, // 19 IIC_st |
400 | { 1, 6, 7, 79, 81 }, // 20 IIC_std |
401 | { 1, 4, 5, 81, 83 }, // 21 IIC_iu_umul |
402 | { 0, uint16_t(~0U), uint16_t(~0U), uint16_t(~0U), uint16_t(~0U) }// end marker |
403 | }; |
404 | |
405 | static constexpr llvm::InstrItinerary LEON4Itineraries[] = { |
406 | { 0, 0, 0, 0, 0 }, // 0 NoInstrModel |
407 | { 1, 7, 8, 83, 85 }, // 1 IIC_iu_instr |
408 | { 1, 8, 9, 85, 87 }, // 2 IIC_fpu_normal_instr |
409 | { 1, 9, 10, 87, 89 }, // 3 IIC_jmp_or_call |
410 | { 1, 8, 9, 89, 91 }, // 4 IIC_fpu_abs |
411 | { 1, 8, 9, 91, 93 }, // 5 IIC_fpu_fast_instr |
412 | { 1, 8, 9, 93, 95 }, // 6 IIC_fpu_divd |
413 | { 1, 8, 9, 95, 97 }, // 7 IIC_fpu_divs |
414 | { 1, 8, 9, 97, 99 }, // 8 IIC_fpu_muld |
415 | { 1, 8, 9, 99, 101 }, // 9 IIC_fpu_muls |
416 | { 1, 8, 9, 101, 103 }, // 10 IIC_fpu_negs |
417 | { 1, 8, 9, 103, 105 }, // 11 IIC_fpu_sqrtd |
418 | { 1, 8, 9, 105, 107 }, // 12 IIC_fpu_sqrts |
419 | { 1, 8, 9, 107, 109 }, // 13 IIC_fpu_stod |
420 | { 1, 9, 10, 109, 111 }, // 14 IIC_ldd |
421 | { 1, 9, 10, 111, 113 }, // 15 IIC_iu_or_fpu_instr |
422 | { 1, 7, 8, 113, 115 }, // 16 IIC_iu_div |
423 | { 1, 7, 8, 115, 117 }, // 17 IIC_smac_umac |
424 | { 1, 7, 8, 117, 119 }, // 18 IIC_iu_smul |
425 | { 1, 9, 10, 119, 121 }, // 19 IIC_st |
426 | { 1, 9, 10, 121, 123 }, // 20 IIC_std |
427 | { 1, 7, 8, 123, 125 }, // 21 IIC_iu_umul |
428 | { 0, uint16_t(~0U), uint16_t(~0U), uint16_t(~0U), uint16_t(~0U) }// end marker |
429 | }; |
430 | |
431 | // =============================================================== |
432 | // Data tables for the new per-operand machine model. |
433 | |
434 | // {ProcResourceIdx, ReleaseAtCycle, AcquireAtCycle} |
435 | extern const llvm::MCWriteProcResEntry SparcWriteProcResTable[] = { |
436 | { 0, 0, 0 }, // Invalid |
437 | }; // SparcWriteProcResTable |
438 | |
439 | // {Cycles, WriteResourceID} |
440 | extern const llvm::MCWriteLatencyEntry SparcWriteLatencyTable[] = { |
441 | { 0, 0}, // Invalid |
442 | }; // SparcWriteLatencyTable |
443 | |
444 | // {UseIdx, WriteResourceID, Cycles} |
445 | extern const llvm::MCReadAdvanceEntry SparcReadAdvanceTable[] = { |
446 | {0, 0, 0}, // Invalid |
447 | }; // SparcReadAdvanceTable |
448 | |
449 | #ifdef __GNUC__ |
450 | #pragma GCC diagnostic push |
451 | #pragma GCC diagnostic ignored "-Woverlength-strings" |
452 | #endif |
453 | static constexpr char SparcSchedClassNamesStorage[] = |
454 | "\0" |
455 | "InvalidSchedClass\0" |
456 | ; |
457 | #ifdef __GNUC__ |
458 | #pragma GCC diagnostic pop |
459 | #endif |
460 | |
461 | static constexpr llvm::StringTable SparcSchedClassNames = |
462 | SparcSchedClassNamesStorage; |
463 | |
464 | static const llvm::MCSchedModel NoSchedModel = { |
465 | MCSchedModel::DefaultIssueWidth, |
466 | MCSchedModel::DefaultMicroOpBufferSize, |
467 | MCSchedModel::DefaultLoopMicroOpBufferSize, |
468 | MCSchedModel::DefaultLoadLatency, |
469 | MCSchedModel::DefaultHighLatency, |
470 | MCSchedModel::DefaultMispredictPenalty, |
471 | false, // PostRAScheduler |
472 | false, // CompleteModel |
473 | false, // EnableIntervals |
474 | 0, // Processor ID |
475 | nullptr, nullptr, 0, 0, // No instruction-level machine model. |
476 | DBGVAL_OR_NULLPTR(&SparcSchedClassNames), // SchedClassNames |
477 | nullptr, // No Itinerary |
478 | nullptr // No extra processor descriptor |
479 | }; |
480 | |
481 | static const llvm::MCSchedModel LEON2ItinerariesModel = { |
482 | MCSchedModel::DefaultIssueWidth, |
483 | MCSchedModel::DefaultMicroOpBufferSize, |
484 | MCSchedModel::DefaultLoopMicroOpBufferSize, |
485 | MCSchedModel::DefaultLoadLatency, |
486 | MCSchedModel::DefaultHighLatency, |
487 | MCSchedModel::DefaultMispredictPenalty, |
488 | false, // PostRAScheduler |
489 | false, // CompleteModel |
490 | false, // EnableIntervals |
491 | 1, // Processor ID |
492 | nullptr, nullptr, 0, 0, // No instruction-level machine model. |
493 | DBGVAL_OR_NULLPTR(&SparcSchedClassNames), // SchedClassNames |
494 | LEON2Itineraries, |
495 | nullptr // No extra processor descriptor |
496 | }; |
497 | |
498 | static const llvm::MCSchedModel LEON3ItinerariesModel = { |
499 | MCSchedModel::DefaultIssueWidth, |
500 | MCSchedModel::DefaultMicroOpBufferSize, |
501 | MCSchedModel::DefaultLoopMicroOpBufferSize, |
502 | MCSchedModel::DefaultLoadLatency, |
503 | MCSchedModel::DefaultHighLatency, |
504 | MCSchedModel::DefaultMispredictPenalty, |
505 | false, // PostRAScheduler |
506 | false, // CompleteModel |
507 | false, // EnableIntervals |
508 | 2, // Processor ID |
509 | nullptr, nullptr, 0, 0, // No instruction-level machine model. |
510 | DBGVAL_OR_NULLPTR(&SparcSchedClassNames), // SchedClassNames |
511 | LEON3Itineraries, |
512 | nullptr // No extra processor descriptor |
513 | }; |
514 | |
515 | static const llvm::MCSchedModel LEON4ItinerariesModel = { |
516 | MCSchedModel::DefaultIssueWidth, |
517 | MCSchedModel::DefaultMicroOpBufferSize, |
518 | MCSchedModel::DefaultLoopMicroOpBufferSize, |
519 | MCSchedModel::DefaultLoadLatency, |
520 | MCSchedModel::DefaultHighLatency, |
521 | MCSchedModel::DefaultMispredictPenalty, |
522 | false, // PostRAScheduler |
523 | false, // CompleteModel |
524 | false, // EnableIntervals |
525 | 3, // Processor ID |
526 | nullptr, nullptr, 0, 0, // No instruction-level machine model. |
527 | DBGVAL_OR_NULLPTR(&SparcSchedClassNames), // SchedClassNames |
528 | LEON4Itineraries, |
529 | nullptr // No extra processor descriptor |
530 | }; |
531 | |
532 | #undef DBGFIELD |
533 | |
534 | #undef DBGVAL_OR_NULLPTR |
535 | |
536 | // Sorted (by key) array of values for CPU subtype. |
537 | extern const llvm::SubtargetSubTypeKV SparcSubTypeKV[] = { |
538 | { "at697e" , { { { 0x4000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &LEON2ItinerariesModel }, |
539 | { "at697f" , { { { 0x4000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &LEON2ItinerariesModel }, |
540 | { "f934" , { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
541 | { "generic" , { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
542 | { "gr712rc" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &LEON3ItinerariesModel }, |
543 | { "gr740" , { { { 0x58000000000044ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &LEON4ItinerariesModel }, |
544 | { "hypersparc" , { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
545 | { "leon2" , { { { 0x4ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &LEON2ItinerariesModel }, |
546 | { "leon3" , { { { 0x40000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &LEON3ItinerariesModel }, |
547 | { "leon4" , { { { 0x48000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &LEON4ItinerariesModel }, |
548 | { "ma2080" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
549 | { "ma2085" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
550 | { "ma2100" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
551 | { "ma2150" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
552 | { "ma2155" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
553 | { "ma2450" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
554 | { "ma2455" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
555 | { "ma2480" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
556 | { "ma2485" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
557 | { "ma2x5x" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
558 | { "ma2x8x" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
559 | { "myriad2" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
560 | { "myriad2.1" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
561 | { "myriad2.2" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
562 | { "myriad2.3" , { { { 0x8000000000004ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
563 | { "niagara" , { { { 0x75000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
564 | { "niagara2" , { { { 0x80075000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
565 | { "niagara3" , { { { 0x800f7000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
566 | { "niagara4" , { { { 0x800f7000000020ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
567 | { "sparclet" , { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
568 | { "sparclite" , { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
569 | { "sparclite86x" , { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
570 | { "supersparc" , { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
571 | { "tsc701" , { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
572 | { "ultrasparc" , { { { 0x34000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x20000000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
573 | { "ultrasparc3" , { { { 0x74000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x20000000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
574 | { "ut699" , { { { 0x410000000001cULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &LEON3ItinerariesModel }, |
575 | { "v7" , { { { 0x800000010ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
576 | { "v8" , { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
577 | { "v9" , { { { 0x10000000000ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, { { { 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, 0x0ULL, } } }, &NoSchedModel }, |
578 | }; |
579 | |
580 | // Sorted array of names of CPU subtypes, including aliases. |
581 | extern const llvm::StringRef SparcNames[] = { |
582 | "at697e" , |
583 | "at697f" , |
584 | "f934" , |
585 | "generic" , |
586 | "gr712rc" , |
587 | "gr740" , |
588 | "hypersparc" , |
589 | "leon2" , |
590 | "leon3" , |
591 | "leon4" , |
592 | "ma2080" , |
593 | "ma2085" , |
594 | "ma2100" , |
595 | "ma2150" , |
596 | "ma2155" , |
597 | "ma2450" , |
598 | "ma2455" , |
599 | "ma2480" , |
600 | "ma2485" , |
601 | "ma2x5x" , |
602 | "ma2x8x" , |
603 | "myriad2" , |
604 | "myriad2.1" , |
605 | "myriad2.2" , |
606 | "myriad2.3" , |
607 | "niagara" , |
608 | "niagara2" , |
609 | "niagara3" , |
610 | "niagara4" , |
611 | "sparclet" , |
612 | "sparclite" , |
613 | "sparclite86x" , |
614 | "supersparc" , |
615 | "tsc701" , |
616 | "ultrasparc" , |
617 | "ultrasparc3" , |
618 | "ut699" , |
619 | "v7" , |
620 | "v8" , |
621 | "v9" }; |
622 | |
623 | namespace Sparc_MC { |
624 | unsigned resolveVariantSchedClassImpl(unsigned SchedClass, |
625 | const MCInst *MI, const MCInstrInfo *MCII, unsigned CPUID) { |
626 | // Don't know how to resolve this scheduling class. |
627 | return 0; |
628 | } |
629 | } // end namespace Sparc_MC |
630 | |
631 | struct SparcGenMCSubtargetInfo : public MCSubtargetInfo { |
632 | SparcGenMCSubtargetInfo(const Triple &TT, |
633 | StringRef CPU, StringRef TuneCPU, StringRef FS, |
634 | ArrayRef<StringRef> PN, |
635 | ArrayRef<SubtargetFeatureKV> PF, |
636 | ArrayRef<SubtargetSubTypeKV> PD, |
637 | const MCWriteProcResEntry *WPR, |
638 | const MCWriteLatencyEntry *WL, |
639 | const MCReadAdvanceEntry *RA, const InstrStage *IS, |
640 | const unsigned *OC, const unsigned *FP) : |
641 | MCSubtargetInfo(TT, CPU, TuneCPU, FS, PN, PF, PD, |
642 | WPR, WL, RA, IS, OC, FP) { } |
643 | |
644 | unsigned resolveVariantSchedClass(unsigned SchedClass, |
645 | const MCInst *MI, const MCInstrInfo *MCII, |
646 | unsigned CPUID) const override { |
647 | return Sparc_MC::resolveVariantSchedClassImpl(SchedClass, MI, MCII, CPUID); |
648 | } |
649 | }; |
650 | |
651 | static inline MCSubtargetInfo *createSparcMCSubtargetInfoImpl(const Triple &TT, StringRef CPU, StringRef TuneCPU, StringRef FS) { |
652 | return new SparcGenMCSubtargetInfo(TT, CPU, TuneCPU, FS, SparcNames, SparcFeatureKV, SparcSubTypeKV, |
653 | SparcWriteProcResTable, SparcWriteLatencyTable, SparcReadAdvanceTable, |
654 | SparcStages, SparcOperandCycles, SparcForwardingPaths); |
655 | } |
656 | |
657 | } // end namespace llvm |
658 | |
659 | #endif // GET_SUBTARGETINFO_MC_DESC |
660 | |
661 | |
662 | #ifdef GET_SUBTARGETINFO_TARGET_DESC |
663 | #undef GET_SUBTARGETINFO_TARGET_DESC |
664 | |
665 | #include "llvm/ADT/BitmaskEnum.h" |
666 | #include "llvm/Support/Debug.h" |
667 | #include "llvm/Support/raw_ostream.h" |
668 | |
669 | // ParseSubtargetFeatures - Parses features string setting specified |
670 | // subtarget options. |
671 | void llvm::SparcSubtarget::ParseSubtargetFeatures(StringRef CPU, StringRef TuneCPU, StringRef FS) { |
672 | LLVM_DEBUG(dbgs() << "\nFeatures:" << FS); |
673 | LLVM_DEBUG(dbgs() << "\nCPU:" << CPU); |
674 | LLVM_DEBUG(dbgs() << "\nTuneCPU:" << TuneCPU << "\n\n" ); |
675 | InitMCProcessorInfo(CPU, TuneCPU, FS); |
676 | const FeatureBitset &Bits = getFeatureBits(); |
677 | if (Bits[Sparc::DetectRoundChange]) DetectRoundChange = true; |
678 | if (Bits[Sparc::FeatureHardQuad]) HasHardQuad = true; |
679 | if (Bits[Sparc::FeatureLeon]) IsLeon = true; |
680 | if (Bits[Sparc::FeatureNoFMULS]) HasNoFMULS = true; |
681 | if (Bits[Sparc::FeatureNoFSMULD]) HasNoFSMULD = true; |
682 | if (Bits[Sparc::FeatureOSA2011]) IsOSA2011 = true; |
683 | if (Bits[Sparc::FeaturePWRPSR]) HasPWRPSR = true; |
684 | if (Bits[Sparc::FeatureReserveG1]) ReserveRegister[1 + SP::G0] = true; |
685 | if (Bits[Sparc::FeatureReserveG2]) ReserveRegister[2 + SP::G0] = true; |
686 | if (Bits[Sparc::FeatureReserveG3]) ReserveRegister[3 + SP::G0] = true; |
687 | if (Bits[Sparc::FeatureReserveG4]) ReserveRegister[4 + SP::G0] = true; |
688 | if (Bits[Sparc::FeatureReserveG5]) ReserveRegister[5 + SP::G0] = true; |
689 | if (Bits[Sparc::FeatureReserveG6]) ReserveRegister[6 + SP::G0] = true; |
690 | if (Bits[Sparc::FeatureReserveG7]) ReserveRegister[7 + SP::G0] = true; |
691 | if (Bits[Sparc::FeatureReserveI0]) ReserveRegister[0 + SP::I0] = true; |
692 | if (Bits[Sparc::FeatureReserveI1]) ReserveRegister[1 + SP::I0] = true; |
693 | if (Bits[Sparc::FeatureReserveI2]) ReserveRegister[2 + SP::I0] = true; |
694 | if (Bits[Sparc::FeatureReserveI3]) ReserveRegister[3 + SP::I0] = true; |
695 | if (Bits[Sparc::FeatureReserveI4]) ReserveRegister[4 + SP::I0] = true; |
696 | if (Bits[Sparc::FeatureReserveI5]) ReserveRegister[5 + SP::I0] = true; |
697 | if (Bits[Sparc::FeatureReserveL0]) ReserveRegister[0 + SP::L0] = true; |
698 | if (Bits[Sparc::FeatureReserveL1]) ReserveRegister[1 + SP::L0] = true; |
699 | if (Bits[Sparc::FeatureReserveL2]) ReserveRegister[2 + SP::L0] = true; |
700 | if (Bits[Sparc::FeatureReserveL3]) ReserveRegister[3 + SP::L0] = true; |
701 | if (Bits[Sparc::FeatureReserveL4]) ReserveRegister[4 + SP::L0] = true; |
702 | if (Bits[Sparc::FeatureReserveL5]) ReserveRegister[5 + SP::L0] = true; |
703 | if (Bits[Sparc::FeatureReserveL6]) ReserveRegister[6 + SP::L0] = true; |
704 | if (Bits[Sparc::FeatureReserveL7]) ReserveRegister[7 + SP::L0] = true; |
705 | if (Bits[Sparc::FeatureReserveO0]) ReserveRegister[0 + SP::O0] = true; |
706 | if (Bits[Sparc::FeatureReserveO1]) ReserveRegister[1 + SP::O0] = true; |
707 | if (Bits[Sparc::FeatureReserveO2]) ReserveRegister[2 + SP::O0] = true; |
708 | if (Bits[Sparc::FeatureReserveO3]) ReserveRegister[3 + SP::O0] = true; |
709 | if (Bits[Sparc::FeatureReserveO4]) ReserveRegister[4 + SP::O0] = true; |
710 | if (Bits[Sparc::FeatureReserveO5]) ReserveRegister[5 + SP::O0] = true; |
711 | if (Bits[Sparc::FeatureSoftFloat]) UseSoftFloat = true; |
712 | if (Bits[Sparc::FeatureSoftMulDiv]) UseSoftMulDiv = true; |
713 | if (Bits[Sparc::FeatureUA2005]) IsUA2005 = true; |
714 | if (Bits[Sparc::FeatureUA2007]) IsUA2007 = true; |
715 | if (Bits[Sparc::FeatureV8Deprecated]) UseV8DeprecatedInsts = true; |
716 | if (Bits[Sparc::FeatureV8Plus]) IsV8Plus = true; |
717 | if (Bits[Sparc::FeatureV9]) IsV9 = true; |
718 | if (Bits[Sparc::FeatureVIS]) IsVIS = true; |
719 | if (Bits[Sparc::FeatureVIS2]) IsVIS2 = true; |
720 | if (Bits[Sparc::FeatureVIS3]) IsVIS3 = true; |
721 | if (Bits[Sparc::FixAllFDIVSQRT]) FixAllFDIVSQRT = true; |
722 | if (Bits[Sparc::FixTN0009]) FixTN0009 = true; |
723 | if (Bits[Sparc::FixTN0010]) FixTN0010 = true; |
724 | if (Bits[Sparc::FixTN0011]) FixTN0011 = true; |
725 | if (Bits[Sparc::FixTN0012]) FixTN0012 = true; |
726 | if (Bits[Sparc::FixTN0013]) FixTN0013 = true; |
727 | if (Bits[Sparc::InsertNOPLoad]) InsertNOPLoad = true; |
728 | if (Bits[Sparc::LeonCASA]) HasLeonCasa = true; |
729 | if (Bits[Sparc::LeonCycleCounter]) HasLeonCycleCounter = true; |
730 | if (Bits[Sparc::TuneSlowRDPC]) HasSlowRDPC = true; |
731 | if (Bits[Sparc::UMACSMACSupport]) HasUmacSmac = true; |
732 | if (Bits[Sparc::UsePopc]) UsePopc = true; |
733 | } |
734 | #endif // GET_SUBTARGETINFO_TARGET_DESC |
735 | |
736 | |
737 | #ifdef GET_SUBTARGETINFO_HEADER |
738 | #undef GET_SUBTARGETINFO_HEADER |
739 | |
740 | namespace llvm { |
741 | class DFAPacketizer; |
742 | namespace Sparc_MC { |
743 | unsigned resolveVariantSchedClassImpl(unsigned SchedClass, const MCInst *MI, const MCInstrInfo *MCII, unsigned CPUID); |
744 | } // end namespace Sparc_MC |
745 | |
746 | struct SparcGenSubtargetInfo : public TargetSubtargetInfo { |
747 | explicit SparcGenSubtargetInfo(const Triple &TT, StringRef CPU, StringRef TuneCPU, StringRef FS); |
748 | public: |
749 | unsigned resolveSchedClass(unsigned SchedClass, const MachineInstr *DefMI, const TargetSchedModel *SchedModel) const override; |
750 | unsigned resolveVariantSchedClass(unsigned SchedClass, const MCInst *MI, const MCInstrInfo *MCII, unsigned CPUID) const override; |
751 | DFAPacketizer *createDFAPacketizer(const InstrItineraryData *IID) const; |
752 | }; |
753 | } // end namespace llvm |
754 | |
755 | #endif // GET_SUBTARGETINFO_HEADER |
756 | |
757 | |
758 | #ifdef GET_SUBTARGETINFO_CTOR |
759 | #undef GET_SUBTARGETINFO_CTOR |
760 | |
761 | #include "llvm/CodeGen/TargetSchedule.h" |
762 | |
763 | namespace llvm { |
764 | extern const llvm::StringRef SparcNames[]; |
765 | extern const llvm::SubtargetFeatureKV SparcFeatureKV[]; |
766 | extern const llvm::SubtargetSubTypeKV SparcSubTypeKV[]; |
767 | extern const llvm::MCWriteProcResEntry SparcWriteProcResTable[]; |
768 | extern const llvm::MCWriteLatencyEntry SparcWriteLatencyTable[]; |
769 | extern const llvm::MCReadAdvanceEntry SparcReadAdvanceTable[]; |
770 | extern const llvm::InstrStage SparcStages[]; |
771 | extern const unsigned SparcOperandCycles[]; |
772 | extern const unsigned SparcForwardingPaths[]; |
773 | SparcGenSubtargetInfo::SparcGenSubtargetInfo(const Triple &TT, StringRef CPU, StringRef TuneCPU, StringRef FS) |
774 | : TargetSubtargetInfo(TT, CPU, TuneCPU, FS, ArrayRef(SparcNames, 40), ArrayRef(SparcFeatureKV, 56), ArrayRef(SparcSubTypeKV, 40), |
775 | SparcWriteProcResTable, SparcWriteLatencyTable, SparcReadAdvanceTable, |
776 | SparcStages, SparcOperandCycles, SparcForwardingPaths) {} |
777 | |
778 | unsigned SparcGenSubtargetInfo |
779 | ::resolveSchedClass(unsigned SchedClass, const MachineInstr *MI, const TargetSchedModel *SchedModel) const { |
780 | report_fatal_error("Expected a variant SchedClass" ); |
781 | } // SparcGenSubtargetInfo::resolveSchedClass |
782 | |
783 | unsigned SparcGenSubtargetInfo |
784 | ::resolveVariantSchedClass(unsigned SchedClass, const MCInst *MI, const MCInstrInfo *MCII, unsigned CPUID) const { |
785 | return Sparc_MC::resolveVariantSchedClassImpl(SchedClass, MI, MCII, CPUID); |
786 | } // SparcGenSubtargetInfo::resolveVariantSchedClass |
787 | |
788 | } // end namespace llvm |
789 | |
790 | #endif // GET_SUBTARGETINFO_CTOR |
791 | |
792 | |
793 | #ifdef GET_STIPREDICATE_DECLS_FOR_MC_ANALYSIS |
794 | #undef GET_STIPREDICATE_DECLS_FOR_MC_ANALYSIS |
795 | |
796 | #endif // GET_STIPREDICATE_DECLS_FOR_MC_ANALYSIS |
797 | |
798 | |
799 | #ifdef GET_STIPREDICATE_DEFS_FOR_MC_ANALYSIS |
800 | #undef GET_STIPREDICATE_DEFS_FOR_MC_ANALYSIS |
801 | |
802 | #endif // GET_STIPREDICATE_DEFS_FOR_MC_ANALYSIS |
803 | |
804 | |