1 //===-- SystemZ.td - SystemZ processors and features ---------*- tblgen -*-===//
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
7 //===----------------------------------------------------------------------===//
9 // Feature definitions.
11 //===----------------------------------------------------------------------===//
13 class SystemZFeature<string extname, string intname, string desc>
14 : Predicate<"Subtarget->has"##intname##"()">,
15 AssemblerPredicate<"Feature"##intname, extname>,
16 SubtargetFeature<extname, "Has"##intname, "true", desc>;
18 class SystemZMissingFeature<string intname>
19 : Predicate<"!Subtarget->has"##intname##"()">;
21 class SystemZFeatureList<list<SystemZFeature> x> {
22 list<SystemZFeature> List = x;
25 class SystemZFeatureAdd<list<SystemZFeature> x, list<SystemZFeature> y>
26 : SystemZFeatureList<!listconcat(x, y)>;
28 //===----------------------------------------------------------------------===//
30 // New features added in the Ninth Edition of the z/Architecture
32 //===----------------------------------------------------------------------===//
34 def FeatureDistinctOps : SystemZFeature<
35 "distinct-ops", "DistinctOps",
36 "Assume that the distinct-operands facility is installed"
39 def FeatureFastSerialization : SystemZFeature<
40 "fast-serialization", "FastSerialization",
41 "Assume that the fast-serialization facility is installed"
44 def FeatureFPExtension : SystemZFeature<
45 "fp-extension", "FPExtension",
46 "Assume that the floating-point extension facility is installed"
49 def FeatureHighWord : SystemZFeature<
50 "high-word", "HighWord",
51 "Assume that the high-word facility is installed"
54 def FeatureInterlockedAccess1 : SystemZFeature<
55 "interlocked-access1", "InterlockedAccess1",
56 "Assume that interlocked-access facility 1 is installed"
58 def FeatureNoInterlockedAccess1 : SystemZMissingFeature<"InterlockedAccess1">;
60 def FeatureLoadStoreOnCond : SystemZFeature<
61 "load-store-on-cond", "LoadStoreOnCond",
62 "Assume that the load/store-on-condition facility is installed"
64 def FeatureNoLoadStoreOnCond : SystemZMissingFeature<"LoadStoreOnCond">;
66 def FeaturePopulationCount : SystemZFeature<
67 "population-count", "PopulationCount",
68 "Assume that the population-count facility is installed"
71 def FeatureMessageSecurityAssist3 : SystemZFeature<
72 "message-security-assist-extension3", "MessageSecurityAssist3",
73 "Assume that the message-security-assist extension facility 3 is installed"
76 def FeatureMessageSecurityAssist4 : SystemZFeature<
77 "message-security-assist-extension4", "MessageSecurityAssist4",
78 "Assume that the message-security-assist extension facility 4 is installed"
81 def FeatureResetReferenceBitsMultiple : SystemZFeature<
82 "reset-reference-bits-multiple", "ResetReferenceBitsMultiple",
83 "Assume that the reset-reference-bits-multiple facility is installed"
86 def Arch9NewFeatures : SystemZFeatureList<[
88 FeatureFastSerialization,
91 FeatureInterlockedAccess1,
92 FeatureLoadStoreOnCond,
93 FeaturePopulationCount,
94 FeatureMessageSecurityAssist3,
95 FeatureMessageSecurityAssist4,
96 FeatureResetReferenceBitsMultiple
99 //===----------------------------------------------------------------------===//
101 // New features added in the Tenth Edition of the z/Architecture
103 //===----------------------------------------------------------------------===//
105 def FeatureExecutionHint : SystemZFeature<
106 "execution-hint", "ExecutionHint",
107 "Assume that the execution-hint facility is installed"
110 def FeatureLoadAndTrap : SystemZFeature<
111 "load-and-trap", "LoadAndTrap",
112 "Assume that the load-and-trap facility is installed"
115 def FeatureMiscellaneousExtensions : SystemZFeature<
116 "miscellaneous-extensions", "MiscellaneousExtensions",
117 "Assume that the miscellaneous-extensions facility is installed"
120 def FeatureProcessorAssist : SystemZFeature<
121 "processor-assist", "ProcessorAssist",
122 "Assume that the processor-assist facility is installed"
125 def FeatureTransactionalExecution : SystemZFeature<
126 "transactional-execution", "TransactionalExecution",
127 "Assume that the transactional-execution facility is installed"
130 def FeatureDFPZonedConversion : SystemZFeature<
131 "dfp-zoned-conversion", "DFPZonedConversion",
132 "Assume that the DFP zoned-conversion facility is installed"
135 def FeatureEnhancedDAT2 : SystemZFeature<
136 "enhanced-dat-2", "EnhancedDAT2",
137 "Assume that the enhanced-DAT facility 2 is installed"
140 def Arch10NewFeatures : SystemZFeatureList<[
141 FeatureExecutionHint,
143 FeatureMiscellaneousExtensions,
144 FeatureProcessorAssist,
145 FeatureTransactionalExecution,
146 FeatureDFPZonedConversion,
150 //===----------------------------------------------------------------------===//
152 // New features added in the Eleventh Edition of the z/Architecture
154 //===----------------------------------------------------------------------===//
156 def FeatureLoadAndZeroRightmostByte : SystemZFeature<
157 "load-and-zero-rightmost-byte", "LoadAndZeroRightmostByte",
158 "Assume that the load-and-zero-rightmost-byte facility is installed"
161 def FeatureLoadStoreOnCond2 : SystemZFeature<
162 "load-store-on-cond-2", "LoadStoreOnCond2",
163 "Assume that the load/store-on-condition facility 2 is installed"
166 def FeatureMessageSecurityAssist5 : SystemZFeature<
167 "message-security-assist-extension5", "MessageSecurityAssist5",
168 "Assume that the message-security-assist extension facility 5 is installed"
171 def FeatureDFPPackedConversion : SystemZFeature<
172 "dfp-packed-conversion", "DFPPackedConversion",
173 "Assume that the DFP packed-conversion facility is installed"
176 def FeatureVector : SystemZFeature<
178 "Assume that the vectory facility is installed"
180 def FeatureNoVector : SystemZMissingFeature<"Vector">;
182 def Arch11NewFeatures : SystemZFeatureList<[
183 FeatureLoadAndZeroRightmostByte,
184 FeatureLoadStoreOnCond2,
185 FeatureMessageSecurityAssist5,
186 FeatureDFPPackedConversion,
190 //===----------------------------------------------------------------------===//
192 // New features added in the Twelvth Edition of the z/Architecture
194 //===----------------------------------------------------------------------===//
196 def FeatureMiscellaneousExtensions2 : SystemZFeature<
197 "miscellaneous-extensions-2", "MiscellaneousExtensions2",
198 "Assume that the miscellaneous-extensions facility 2 is installed"
201 def FeatureGuardedStorage : SystemZFeature<
202 "guarded-storage", "GuardedStorage",
203 "Assume that the guarded-storage facility is installed"
206 def FeatureMessageSecurityAssist7 : SystemZFeature<
207 "message-security-assist-extension7", "MessageSecurityAssist7",
208 "Assume that the message-security-assist extension facility 7 is installed"
211 def FeatureMessageSecurityAssist8 : SystemZFeature<
212 "message-security-assist-extension8", "MessageSecurityAssist8",
213 "Assume that the message-security-assist extension facility 8 is installed"
216 def FeatureVectorEnhancements1 : SystemZFeature<
217 "vector-enhancements-1", "VectorEnhancements1",
218 "Assume that the vector enhancements facility 1 is installed"
220 def FeatureNoVectorEnhancements1 : SystemZMissingFeature<"VectorEnhancements1">;
222 def FeatureVectorPackedDecimal : SystemZFeature<
223 "vector-packed-decimal", "VectorPackedDecimal",
224 "Assume that the vector packed decimal facility is installed"
227 def FeatureInsertReferenceBitsMultiple : SystemZFeature<
228 "insert-reference-bits-multiple", "InsertReferenceBitsMultiple",
229 "Assume that the insert-reference-bits-multiple facility is installed"
232 def Arch12NewFeatures : SystemZFeatureList<[
233 FeatureMiscellaneousExtensions2,
234 FeatureGuardedStorage,
235 FeatureMessageSecurityAssist7,
236 FeatureMessageSecurityAssist8,
237 FeatureVectorEnhancements1,
238 FeatureVectorPackedDecimal,
239 FeatureInsertReferenceBitsMultiple
242 //===----------------------------------------------------------------------===//
244 // New features added in the Thirteenth Edition of the z/Architecture
246 //===----------------------------------------------------------------------===//
248 def FeatureMiscellaneousExtensions3 : SystemZFeature<
249 "miscellaneous-extensions-3", "MiscellaneousExtensions3",
250 "Assume that the miscellaneous-extensions facility 3 is installed"
253 def FeatureMessageSecurityAssist9 : SystemZFeature<
254 "message-security-assist-extension9", "MessageSecurityAssist9",
255 "Assume that the message-security-assist extension facility 9 is installed"
258 def FeatureVectorEnhancements2 : SystemZFeature<
259 "vector-enhancements-2", "VectorEnhancements2",
260 "Assume that the vector enhancements facility 2 is installed"
263 def FeatureVectorPackedDecimalEnhancement : SystemZFeature<
264 "vector-packed-decimal-enhancement", "VectorPackedDecimalEnhancement",
265 "Assume that the vector packed decimal enhancement facility is installed"
268 def FeatureEnhancedSort : SystemZFeature<
269 "enhanced-sort", "EnhancedSort",
270 "Assume that the enhanced-sort facility is installed"
273 def FeatureDeflateConversion : SystemZFeature<
274 "deflate-conversion", "DeflateConversion",
275 "Assume that the deflate-conversion facility is installed"
278 def Arch13NewFeatures : SystemZFeatureList<[
279 FeatureMiscellaneousExtensions3,
280 FeatureMessageSecurityAssist9,
281 FeatureVectorEnhancements2,
282 FeatureVectorPackedDecimalEnhancement,
284 FeatureDeflateConversion
287 //===----------------------------------------------------------------------===//
289 // Cumulative supported and unsupported feature sets
291 //===----------------------------------------------------------------------===//
293 def Arch8SupportedFeatures
294 : SystemZFeatureList<[]>;
295 def Arch9SupportedFeatures
296 : SystemZFeatureAdd<Arch8SupportedFeatures.List, Arch9NewFeatures.List>;
297 def Arch10SupportedFeatures
298 : SystemZFeatureAdd<Arch9SupportedFeatures.List, Arch10NewFeatures.List>;
299 def Arch11SupportedFeatures
300 : SystemZFeatureAdd<Arch10SupportedFeatures.List, Arch11NewFeatures.List>;
301 def Arch12SupportedFeatures
302 : SystemZFeatureAdd<Arch11SupportedFeatures.List, Arch12NewFeatures.List>;
303 def Arch13SupportedFeatures
304 : SystemZFeatureAdd<Arch12SupportedFeatures.List, Arch13NewFeatures.List>;
306 def Arch13UnsupportedFeatures
307 : SystemZFeatureList<[]>;
308 def Arch12UnsupportedFeatures
309 : SystemZFeatureAdd<Arch13UnsupportedFeatures.List, Arch13NewFeatures.List>;
310 def Arch11UnsupportedFeatures
311 : SystemZFeatureAdd<Arch12UnsupportedFeatures.List, Arch12NewFeatures.List>;
312 def Arch10UnsupportedFeatures
313 : SystemZFeatureAdd<Arch11UnsupportedFeatures.List, Arch11NewFeatures.List>;
314 def Arch9UnsupportedFeatures
315 : SystemZFeatureAdd<Arch10UnsupportedFeatures.List, Arch10NewFeatures.List>;
316 def Arch8UnsupportedFeatures
317 : SystemZFeatureAdd<Arch9UnsupportedFeatures.List, Arch9NewFeatures.List>;