1fcf5ef2aSThomas Huth /*
2fcf5ef2aSThomas Huth * S390 feature list generator
3fcf5ef2aSThomas Huth *
427e84d4eSChristian Borntraeger * Copyright IBM Corp. 2016, 2018
5fcf5ef2aSThomas Huth *
6fcf5ef2aSThomas Huth * Author(s): Michael Mueller <mimu@linux.vnet.ibm.com>
7fcf5ef2aSThomas Huth * David Hildenbrand <dahi@linux.vnet.ibm.com>
8fcf5ef2aSThomas Huth *
9fcf5ef2aSThomas Huth * This work is licensed under the terms of the GNU GPL, version 2 or (at
10fcf5ef2aSThomas Huth * your option) any later version. See the COPYING file in the top-level
11fcf5ef2aSThomas Huth * directory.
12fcf5ef2aSThomas Huth */
13fcf5ef2aSThomas Huth
14d8e39b70SMarkus Armbruster #include <inttypes.h>
15d8e39b70SMarkus Armbruster #include <stdio.h>
16caef6243SChristian Borntraeger #include <string.h>
17fcf5ef2aSThomas Huth #include "cpu_features_def.h"
18fcf5ef2aSThomas Huth
19fcf5ef2aSThomas Huth #define ARRAY_SIZE(array) (sizeof(array) / sizeof(array[0]))
20fcf5ef2aSThomas Huth
21fcf5ef2aSThomas Huth /***** BEGIN FEATURE DEFS *****/
22fcf5ef2aSThomas Huth
23fcf5ef2aSThomas Huth #define S390_FEAT_GROUP_PLO \
24fcf5ef2aSThomas Huth S390_FEAT_PLO_CL, \
25fcf5ef2aSThomas Huth S390_FEAT_PLO_CLG, \
26fcf5ef2aSThomas Huth S390_FEAT_PLO_CLGR, \
27fcf5ef2aSThomas Huth S390_FEAT_PLO_CLX, \
28fcf5ef2aSThomas Huth S390_FEAT_PLO_CS, \
29fcf5ef2aSThomas Huth S390_FEAT_PLO_CSG, \
30fcf5ef2aSThomas Huth S390_FEAT_PLO_CSGR, \
31fcf5ef2aSThomas Huth S390_FEAT_PLO_CSX, \
32fcf5ef2aSThomas Huth S390_FEAT_PLO_DCS, \
33fcf5ef2aSThomas Huth S390_FEAT_PLO_DCSG, \
34fcf5ef2aSThomas Huth S390_FEAT_PLO_DCSGR, \
35fcf5ef2aSThomas Huth S390_FEAT_PLO_DCSX, \
36fcf5ef2aSThomas Huth S390_FEAT_PLO_CSST, \
37fcf5ef2aSThomas Huth S390_FEAT_PLO_CSSTG, \
38fcf5ef2aSThomas Huth S390_FEAT_PLO_CSSTGR, \
39fcf5ef2aSThomas Huth S390_FEAT_PLO_CSSTX, \
40fcf5ef2aSThomas Huth S390_FEAT_PLO_CSDST, \
41fcf5ef2aSThomas Huth S390_FEAT_PLO_CSDSTG, \
42fcf5ef2aSThomas Huth S390_FEAT_PLO_CSDSTGR, \
43fcf5ef2aSThomas Huth S390_FEAT_PLO_CSDSTX, \
44fcf5ef2aSThomas Huth S390_FEAT_PLO_CSTST, \
45fcf5ef2aSThomas Huth S390_FEAT_PLO_CSTSTG, \
46fcf5ef2aSThomas Huth S390_FEAT_PLO_CSTSTGR, \
47fcf5ef2aSThomas Huth S390_FEAT_PLO_CSTSTX
48fcf5ef2aSThomas Huth
49fcf5ef2aSThomas Huth #define S390_FEAT_GROUP_TOD_CLOCK_STEERING \
50fcf5ef2aSThomas Huth S390_FEAT_TOD_CLOCK_STEERING, \
51fcf5ef2aSThomas Huth S390_FEAT_PTFF_QTO, \
52fcf5ef2aSThomas Huth S390_FEAT_PTFF_QSI, \
53fcf5ef2aSThomas Huth S390_FEAT_PTFF_QPT, \
54fcf5ef2aSThomas Huth S390_FEAT_PTFF_STO
55fcf5ef2aSThomas Huth
56fcf5ef2aSThomas Huth #define S390_FEAT_GROUP_GEN13_PTFF \
57fcf5ef2aSThomas Huth S390_FEAT_PTFF_QUI, \
58fcf5ef2aSThomas Huth S390_FEAT_PTFF_QTOU, \
59fcf5ef2aSThomas Huth S390_FEAT_PTFF_STOU
60fcf5ef2aSThomas Huth
6146a99c9fSDavid Hildenbrand #define S390_FEAT_GROUP_MULTIPLE_EPOCH_PTFF \
6246a99c9fSDavid Hildenbrand S390_FEAT_PTFF_QSIE, \
6346a99c9fSDavid Hildenbrand S390_FEAT_PTFF_QTOUE, \
6446a99c9fSDavid Hildenbrand S390_FEAT_PTFF_STOE, \
6546a99c9fSDavid Hildenbrand S390_FEAT_PTFF_STOUE
6646a99c9fSDavid Hildenbrand
67fcf5ef2aSThomas Huth #define S390_FEAT_GROUP_MSA \
68fcf5ef2aSThomas Huth S390_FEAT_MSA, \
69fcf5ef2aSThomas Huth S390_FEAT_KMAC_DEA, \
70fcf5ef2aSThomas Huth S390_FEAT_KMAC_TDEA_128, \
71fcf5ef2aSThomas Huth S390_FEAT_KMAC_TDEA_192, \
72fcf5ef2aSThomas Huth S390_FEAT_KMC_DEA, \
73fcf5ef2aSThomas Huth S390_FEAT_KMC_TDEA_128, \
74fcf5ef2aSThomas Huth S390_FEAT_KMC_TDEA_192, \
75fcf5ef2aSThomas Huth S390_FEAT_KM_DEA, \
76fcf5ef2aSThomas Huth S390_FEAT_KM_TDEA_128, \
77fcf5ef2aSThomas Huth S390_FEAT_KM_TDEA_192, \
78fcf5ef2aSThomas Huth S390_FEAT_KIMD_SHA_1, \
79fcf5ef2aSThomas Huth S390_FEAT_KLMD_SHA_1
80fcf5ef2aSThomas Huth
81fcf5ef2aSThomas Huth #define S390_FEAT_GROUP_MSA_EXT_1 \
82fcf5ef2aSThomas Huth S390_FEAT_KMC_AES_128, \
83fcf5ef2aSThomas Huth S390_FEAT_KM_AES_128, \
84fcf5ef2aSThomas Huth S390_FEAT_KIMD_SHA_256, \
85fcf5ef2aSThomas Huth S390_FEAT_KLMD_SHA_256
86fcf5ef2aSThomas Huth
87fcf5ef2aSThomas Huth #define S390_FEAT_GROUP_MSA_EXT_2 \
88fcf5ef2aSThomas Huth S390_FEAT_KMC_AES_192, \
89fcf5ef2aSThomas Huth S390_FEAT_KMC_AES_256, \
90fcf5ef2aSThomas Huth S390_FEAT_KMC_PRNG, \
91fcf5ef2aSThomas Huth S390_FEAT_KM_AES_192, \
92fcf5ef2aSThomas Huth S390_FEAT_KM_AES_256, \
93fcf5ef2aSThomas Huth S390_FEAT_KIMD_SHA_512, \
94fcf5ef2aSThomas Huth S390_FEAT_KLMD_SHA_512
95fcf5ef2aSThomas Huth
96fcf5ef2aSThomas Huth #define S390_FEAT_GROUP_MSA_EXT_3 \
97fcf5ef2aSThomas Huth S390_FEAT_MSA_EXT_3, \
98fcf5ef2aSThomas Huth S390_FEAT_KMAC_EDEA, \
99fcf5ef2aSThomas Huth S390_FEAT_KMAC_ETDEA_128, \
100fcf5ef2aSThomas Huth S390_FEAT_KMAC_ETDEA_192, \
101fcf5ef2aSThomas Huth S390_FEAT_KMC_EAES_128, \
102fcf5ef2aSThomas Huth S390_FEAT_KMC_EAES_192, \
103fcf5ef2aSThomas Huth S390_FEAT_KMC_EAES_256, \
104fcf5ef2aSThomas Huth S390_FEAT_KMC_EDEA, \
105fcf5ef2aSThomas Huth S390_FEAT_KMC_ETDEA_128, \
106fcf5ef2aSThomas Huth S390_FEAT_KMC_ETDEA_192, \
107fcf5ef2aSThomas Huth S390_FEAT_KM_EDEA, \
108fcf5ef2aSThomas Huth S390_FEAT_KM_ETDEA_128, \
109fcf5ef2aSThomas Huth S390_FEAT_KM_ETDEA_192, \
110fcf5ef2aSThomas Huth S390_FEAT_KM_EAES_128, \
111fcf5ef2aSThomas Huth S390_FEAT_KM_EAES_192, \
112fcf5ef2aSThomas Huth S390_FEAT_KM_EAES_256, \
113fcf5ef2aSThomas Huth S390_FEAT_PCKMO_EDEA, \
114fcf5ef2aSThomas Huth S390_FEAT_PCKMO_ETDEA_128, \
115fcf5ef2aSThomas Huth S390_FEAT_PCKMO_ETDEA_256, \
116fcf5ef2aSThomas Huth S390_FEAT_PCKMO_AES_128, \
117fcf5ef2aSThomas Huth S390_FEAT_PCKMO_AES_192, \
118fcf5ef2aSThomas Huth S390_FEAT_PCKMO_AES_256
119fcf5ef2aSThomas Huth
120fcf5ef2aSThomas Huth #define S390_FEAT_GROUP_MSA_EXT_4 \
121fcf5ef2aSThomas Huth S390_FEAT_MSA_EXT_4, \
122fcf5ef2aSThomas Huth S390_FEAT_KMAC_AES_128, \
123fcf5ef2aSThomas Huth S390_FEAT_KMAC_AES_192, \
124fcf5ef2aSThomas Huth S390_FEAT_KMAC_AES_256, \
125fcf5ef2aSThomas Huth S390_FEAT_KMAC_EAES_128, \
126fcf5ef2aSThomas Huth S390_FEAT_KMAC_EAES_192, \
127fcf5ef2aSThomas Huth S390_FEAT_KMAC_EAES_256, \
128fcf5ef2aSThomas Huth S390_FEAT_KM_XTS_AES_128, \
129fcf5ef2aSThomas Huth S390_FEAT_KM_XTS_AES_256, \
130fcf5ef2aSThomas Huth S390_FEAT_KM_XTS_EAES_128, \
131fcf5ef2aSThomas Huth S390_FEAT_KM_XTS_EAES_256, \
132fcf5ef2aSThomas Huth S390_FEAT_KIMD_GHASH, \
133fcf5ef2aSThomas Huth S390_FEAT_KMCTR_DEA, \
134fcf5ef2aSThomas Huth S390_FEAT_KMCTR_TDEA_128, \
135fcf5ef2aSThomas Huth S390_FEAT_KMCTR_TDEA_192, \
136fcf5ef2aSThomas Huth S390_FEAT_KMCTR_EDEA, \
137fcf5ef2aSThomas Huth S390_FEAT_KMCTR_ETDEA_128, \
138fcf5ef2aSThomas Huth S390_FEAT_KMCTR_ETDEA_192, \
139fcf5ef2aSThomas Huth S390_FEAT_KMCTR_AES_128, \
140fcf5ef2aSThomas Huth S390_FEAT_KMCTR_AES_192, \
141fcf5ef2aSThomas Huth S390_FEAT_KMCTR_AES_256, \
142fcf5ef2aSThomas Huth S390_FEAT_KMCTR_EAES_128, \
143fcf5ef2aSThomas Huth S390_FEAT_KMCTR_EAES_192, \
144fcf5ef2aSThomas Huth S390_FEAT_KMCTR_EAES_256, \
145fcf5ef2aSThomas Huth S390_FEAT_KMF_DEA, \
146fcf5ef2aSThomas Huth S390_FEAT_KMF_TDEA_128, \
147fcf5ef2aSThomas Huth S390_FEAT_KMF_TDEA_192, \
148fcf5ef2aSThomas Huth S390_FEAT_KMF_EDEA, \
149fcf5ef2aSThomas Huth S390_FEAT_KMF_ETDEA_128, \
150fcf5ef2aSThomas Huth S390_FEAT_KMF_ETDEA_192, \
151fcf5ef2aSThomas Huth S390_FEAT_KMF_AES_128, \
152fcf5ef2aSThomas Huth S390_FEAT_KMF_AES_192, \
153fcf5ef2aSThomas Huth S390_FEAT_KMF_AES_256, \
154fcf5ef2aSThomas Huth S390_FEAT_KMF_EAES_128, \
155fcf5ef2aSThomas Huth S390_FEAT_KMF_EAES_192, \
156fcf5ef2aSThomas Huth S390_FEAT_KMF_EAES_256, \
157fcf5ef2aSThomas Huth S390_FEAT_KMO_DEA, \
158fcf5ef2aSThomas Huth S390_FEAT_KMO_TDEA_128, \
159fcf5ef2aSThomas Huth S390_FEAT_KMO_TDEA_192, \
160fcf5ef2aSThomas Huth S390_FEAT_KMO_EDEA, \
161fcf5ef2aSThomas Huth S390_FEAT_KMO_ETDEA_128, \
162fcf5ef2aSThomas Huth S390_FEAT_KMO_ETDEA_192, \
163fcf5ef2aSThomas Huth S390_FEAT_KMO_AES_128, \
164fcf5ef2aSThomas Huth S390_FEAT_KMO_AES_192, \
165fcf5ef2aSThomas Huth S390_FEAT_KMO_AES_256, \
166fcf5ef2aSThomas Huth S390_FEAT_KMO_EAES_128, \
167fcf5ef2aSThomas Huth S390_FEAT_KMO_EAES_192, \
168fcf5ef2aSThomas Huth S390_FEAT_KMO_EAES_256, \
169fcf5ef2aSThomas Huth S390_FEAT_PCC_CMAC_DEA, \
170fcf5ef2aSThomas Huth S390_FEAT_PCC_CMAC_TDEA_128, \
171fcf5ef2aSThomas Huth S390_FEAT_PCC_CMAC_TDEA_192, \
172fcf5ef2aSThomas Huth S390_FEAT_PCC_CMAC_ETDEA_128, \
173fcf5ef2aSThomas Huth S390_FEAT_PCC_CMAC_ETDEA_192, \
174fcf5ef2aSThomas Huth S390_FEAT_PCC_CMAC_TDEA, \
175fcf5ef2aSThomas Huth S390_FEAT_PCC_CMAC_AES_128, \
176fcf5ef2aSThomas Huth S390_FEAT_PCC_CMAC_AES_192, \
177fcf5ef2aSThomas Huth S390_FEAT_PCC_CMAC_AES_256, \
178fcf5ef2aSThomas Huth S390_FEAT_PCC_CMAC_EAES_128, \
179fcf5ef2aSThomas Huth S390_FEAT_PCC_CMAC_EAES_192, \
180fcf5ef2aSThomas Huth S390_FEAT_PCC_CMAC_EAES_256, \
181fcf5ef2aSThomas Huth S390_FEAT_PCC_XTS_AES_128, \
182fcf5ef2aSThomas Huth S390_FEAT_PCC_XTS_AES_256, \
183fcf5ef2aSThomas Huth S390_FEAT_PCC_XTS_EAES_128, \
184fcf5ef2aSThomas Huth S390_FEAT_PCC_XTS_EAES_256
185fcf5ef2aSThomas Huth
186fcf5ef2aSThomas Huth #define S390_FEAT_GROUP_MSA_EXT_5 \
187fcf5ef2aSThomas Huth S390_FEAT_MSA_EXT_5, \
188fcf5ef2aSThomas Huth S390_FEAT_PPNO_SHA_512_DRNG
189fcf5ef2aSThomas Huth
1906da5c593SJason J. Herne #define S390_FEAT_GROUP_MSA_EXT_6 \
1916da5c593SJason J. Herne S390_FEAT_KIMD_SHA3_224, \
1926da5c593SJason J. Herne S390_FEAT_KIMD_SHA3_256, \
1936da5c593SJason J. Herne S390_FEAT_KIMD_SHA3_384, \
1946da5c593SJason J. Herne S390_FEAT_KIMD_SHA3_512, \
1956da5c593SJason J. Herne S390_FEAT_KIMD_SHAKE_128, \
1966da5c593SJason J. Herne S390_FEAT_KIMD_SHAKE_256, \
1976da5c593SJason J. Herne S390_FEAT_KLMD_SHA3_224, \
1986da5c593SJason J. Herne S390_FEAT_KLMD_SHA3_256, \
1996da5c593SJason J. Herne S390_FEAT_KLMD_SHA3_384, \
2006da5c593SJason J. Herne S390_FEAT_KLMD_SHA3_512, \
2016da5c593SJason J. Herne S390_FEAT_KLMD_SHAKE_128, \
2026da5c593SJason J. Herne S390_FEAT_KLMD_SHAKE_256
2036da5c593SJason J. Herne
2046da5c593SJason J. Herne #define S390_FEAT_GROUP_MSA_EXT_7 \
2056da5c593SJason J. Herne S390_FEAT_PRNO_TRNG_QRTCR, \
2066da5c593SJason J. Herne S390_FEAT_PRNO_TRNG
2076da5c593SJason J. Herne
2086da5c593SJason J. Herne #define S390_FEAT_GROUP_MSA_EXT_8 \
2096da5c593SJason J. Herne S390_FEAT_MSA_EXT_8, \
2106da5c593SJason J. Herne S390_FEAT_KMA_GCM_AES_128, \
2116da5c593SJason J. Herne S390_FEAT_KMA_GCM_AES_192, \
2126da5c593SJason J. Herne S390_FEAT_KMA_GCM_AES_256 , \
2136da5c593SJason J. Herne S390_FEAT_KMA_GCM_EAES_128, \
2146da5c593SJason J. Herne S390_FEAT_KMA_GCM_EAES_192, \
2156da5c593SJason J. Herne S390_FEAT_KMA_GCM_EAES_256
2166da5c593SJason J. Herne
2175dacbe23SChristian Borntraeger #define S390_FEAT_GROUP_MSA_EXT_9 \
2185dacbe23SChristian Borntraeger S390_FEAT_MSA_EXT_9, \
219ef506f80SDavid Hildenbrand S390_FEAT_KDSA_ECDSA_VERIFY_P256, \
220ef506f80SDavid Hildenbrand S390_FEAT_KDSA_ECDSA_VERIFY_P384, \
221ef506f80SDavid Hildenbrand S390_FEAT_KDSA_ECDSA_VERIFY_P512, \
222ef506f80SDavid Hildenbrand S390_FEAT_KDSA_ECDSA_SIGN_P256, \
223ef506f80SDavid Hildenbrand S390_FEAT_KDSA_ECDSA_SIGN_P384, \
224ef506f80SDavid Hildenbrand S390_FEAT_KDSA_ECDSA_SIGN_P512, \
225ef506f80SDavid Hildenbrand S390_FEAT_KDSA_EECDSA_SIGN_P256, \
226ef506f80SDavid Hildenbrand S390_FEAT_KDSA_EECDSA_SIGN_P384, \
227ef506f80SDavid Hildenbrand S390_FEAT_KDSA_EECDSA_SIGN_P512, \
228ef506f80SDavid Hildenbrand S390_FEAT_KDSA_EDDSA_VERIFY_ED25519, \
229ef506f80SDavid Hildenbrand S390_FEAT_KDSA_EDDSA_VERIFY_ED448, \
230ef506f80SDavid Hildenbrand S390_FEAT_KDSA_EDDSA_SIGN_ED25519, \
231ef506f80SDavid Hildenbrand S390_FEAT_KDSA_EDDSA_SIGN_ED448, \
232ef506f80SDavid Hildenbrand S390_FEAT_KDSA_EEDDSA_SIGN_ED25519, \
233ef506f80SDavid Hildenbrand S390_FEAT_KDSA_EEDDSA_SIGN_ED448, \
2345dacbe23SChristian Borntraeger S390_FEAT_PCC_SCALAR_MULT_P256, \
2355dacbe23SChristian Borntraeger S390_FEAT_PCC_SCALAR_MULT_P384, \
2365dacbe23SChristian Borntraeger S390_FEAT_PCC_SCALAR_MULT_P512, \
2375dacbe23SChristian Borntraeger S390_FEAT_PCC_SCALAR_MULT_ED25519, \
2385dacbe23SChristian Borntraeger S390_FEAT_PCC_SCALAR_MULT_ED448, \
2395dacbe23SChristian Borntraeger S390_FEAT_PCC_SCALAR_MULT_X25519, \
2405dacbe23SChristian Borntraeger S390_FEAT_PCC_SCALAR_MULT_X448
2415dacbe23SChristian Borntraeger
2425dacbe23SChristian Borntraeger #define S390_FEAT_GROUP_MSA_EXT_9_PCKMO \
2435dacbe23SChristian Borntraeger S390_FEAT_PCKMO_ECC_P256, \
2445dacbe23SChristian Borntraeger S390_FEAT_PCKMO_ECC_P384, \
2455dacbe23SChristian Borntraeger S390_FEAT_PCKMO_ECC_P521, \
2465dacbe23SChristian Borntraeger S390_FEAT_PCKMO_ECC_ED25519, \
2475dacbe23SChristian Borntraeger S390_FEAT_PCKMO_ECC_ED448
2485dacbe23SChristian Borntraeger
249d220fabfSChristian Borntraeger #define S390_FEAT_GROUP_ENH_SORT \
250d220fabfSChristian Borntraeger S390_FEAT_ESORT_BASE, \
251d220fabfSChristian Borntraeger S390_FEAT_SORTL_SFLR, \
252d220fabfSChristian Borntraeger S390_FEAT_SORTL_SVLR, \
253d220fabfSChristian Borntraeger S390_FEAT_SORTL_32, \
254d220fabfSChristian Borntraeger S390_FEAT_SORTL_128, \
255d220fabfSChristian Borntraeger S390_FEAT_SORTL_F0
256d220fabfSChristian Borntraeger
257d220fabfSChristian Borntraeger
258afc7b866SChristian Borntraeger #define S390_FEAT_GROUP_DEFLATE_CONVERSION \
259afc7b866SChristian Borntraeger S390_FEAT_DEFLATE_BASE, \
260afc7b866SChristian Borntraeger S390_FEAT_DEFLATE_GHDT, \
261afc7b866SChristian Borntraeger S390_FEAT_DEFLATE_CMPR, \
262afc7b866SChristian Borntraeger S390_FEAT_DEFLATE_XPND, \
263afc7b866SChristian Borntraeger S390_FEAT_DEFLATE_F0
264afc7b866SChristian Borntraeger
265fcf5ef2aSThomas Huth /* cpu feature groups */
266fcf5ef2aSThomas Huth static uint16_t group_PLO[] = {
267fcf5ef2aSThomas Huth S390_FEAT_GROUP_PLO,
268fcf5ef2aSThomas Huth };
269fcf5ef2aSThomas Huth static uint16_t group_TOD_CLOCK_STEERING[] = {
270fcf5ef2aSThomas Huth S390_FEAT_GROUP_TOD_CLOCK_STEERING,
271fcf5ef2aSThomas Huth };
272fcf5ef2aSThomas Huth static uint16_t group_GEN13_PTFF[] = {
273fcf5ef2aSThomas Huth S390_FEAT_GROUP_GEN13_PTFF,
274fcf5ef2aSThomas Huth };
27546a99c9fSDavid Hildenbrand static uint16_t group_MULTIPLE_EPOCH_PTFF[] = {
27646a99c9fSDavid Hildenbrand S390_FEAT_GROUP_MULTIPLE_EPOCH_PTFF,
27746a99c9fSDavid Hildenbrand };
278fcf5ef2aSThomas Huth static uint16_t group_MSA[] = {
279fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA,
280fcf5ef2aSThomas Huth };
281fcf5ef2aSThomas Huth static uint16_t group_MSA_EXT_1[] = {
282fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_1,
283fcf5ef2aSThomas Huth };
284fcf5ef2aSThomas Huth static uint16_t group_MSA_EXT_2[] = {
285fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_2,
286fcf5ef2aSThomas Huth };
287fcf5ef2aSThomas Huth static uint16_t group_MSA_EXT_3[] = {
288fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_3,
289fcf5ef2aSThomas Huth };
290fcf5ef2aSThomas Huth static uint16_t group_MSA_EXT_4[] = {
291fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_4,
292fcf5ef2aSThomas Huth };
293fcf5ef2aSThomas Huth static uint16_t group_MSA_EXT_5[] = {
294fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_5,
295fcf5ef2aSThomas Huth };
2966da5c593SJason J. Herne static uint16_t group_MSA_EXT_6[] = {
2976da5c593SJason J. Herne S390_FEAT_GROUP_MSA_EXT_6,
2986da5c593SJason J. Herne };
2996da5c593SJason J. Herne static uint16_t group_MSA_EXT_7[] = {
3006da5c593SJason J. Herne S390_FEAT_GROUP_MSA_EXT_7,
3016da5c593SJason J. Herne };
3026da5c593SJason J. Herne static uint16_t group_MSA_EXT_8[] = {
3036da5c593SJason J. Herne S390_FEAT_GROUP_MSA_EXT_8,
3046da5c593SJason J. Herne };
305fcf5ef2aSThomas Huth
3065dacbe23SChristian Borntraeger static uint16_t group_MSA_EXT_9[] = {
3075dacbe23SChristian Borntraeger S390_FEAT_GROUP_MSA_EXT_9,
3085dacbe23SChristian Borntraeger };
3095dacbe23SChristian Borntraeger
3105dacbe23SChristian Borntraeger static uint16_t group_MSA_EXT_9_PCKMO[] = {
3115dacbe23SChristian Borntraeger S390_FEAT_GROUP_MSA_EXT_9_PCKMO,
3125dacbe23SChristian Borntraeger };
3135dacbe23SChristian Borntraeger
314d220fabfSChristian Borntraeger static uint16_t group_ENH_SORT[] = {
315d220fabfSChristian Borntraeger S390_FEAT_GROUP_ENH_SORT,
316d220fabfSChristian Borntraeger };
317d220fabfSChristian Borntraeger
318afc7b866SChristian Borntraeger static uint16_t group_DEFLATE_CONVERSION[] = {
319afc7b866SChristian Borntraeger S390_FEAT_GROUP_DEFLATE_CONVERSION,
320afc7b866SChristian Borntraeger };
321afc7b866SChristian Borntraeger
322ec3aadb1SJason J. Herne /* Base features (in order of release)
323ec3aadb1SJason J. Herne * Only non-hypervisor managed features belong here.
324ec3aadb1SJason J. Herne * Base feature sets are static meaning they do not change in future QEMU
325ec3aadb1SJason J. Herne * releases.
326ec3aadb1SJason J. Herne */
327fcf5ef2aSThomas Huth static uint16_t base_GEN7_GA1[] = {
328fcf5ef2aSThomas Huth S390_FEAT_GROUP_PLO,
329fcf5ef2aSThomas Huth S390_FEAT_ESAN3,
330fcf5ef2aSThomas Huth S390_FEAT_ZARCH,
331fcf5ef2aSThomas Huth };
332ec3aadb1SJason J. Herne
333fcf5ef2aSThomas Huth #define base_GEN7_GA2 EmptyFeat
334fcf5ef2aSThomas Huth #define base_GEN7_GA3 EmptyFeat
335ec3aadb1SJason J. Herne
336fcf5ef2aSThomas Huth static uint16_t base_GEN8_GA1[] = {
337fcf5ef2aSThomas Huth S390_FEAT_DAT_ENH,
338fcf5ef2aSThomas Huth S390_FEAT_EXTENDED_TRANSLATION_2,
339fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA,
340fcf5ef2aSThomas Huth S390_FEAT_LONG_DISPLACEMENT,
341fcf5ef2aSThomas Huth S390_FEAT_LONG_DISPLACEMENT_FAST,
342fcf5ef2aSThomas Huth S390_FEAT_HFP_MADDSUB,
343fcf5ef2aSThomas Huth };
344ec3aadb1SJason J. Herne
345fcf5ef2aSThomas Huth #define base_GEN8_GA2 EmptyFeat
346fcf5ef2aSThomas Huth #define base_GEN8_GA3 EmptyFeat
347fcf5ef2aSThomas Huth #define base_GEN8_GA4 EmptyFeat
348fcf5ef2aSThomas Huth #define base_GEN8_GA5 EmptyFeat
349ec3aadb1SJason J. Herne
350fcf5ef2aSThomas Huth static uint16_t base_GEN9_GA1[] = {
351fcf5ef2aSThomas Huth S390_FEAT_IDTE_SEGMENT,
352fcf5ef2aSThomas Huth S390_FEAT_ASN_LX_REUSE,
353fcf5ef2aSThomas Huth S390_FEAT_STFLE,
354fcf5ef2aSThomas Huth S390_FEAT_SENSE_RUNNING_STATUS,
355fcf5ef2aSThomas Huth S390_FEAT_EXTENDED_IMMEDIATE,
356fcf5ef2aSThomas Huth S390_FEAT_EXTENDED_TRANSLATION_3,
357fcf5ef2aSThomas Huth S390_FEAT_HFP_UNNORMALIZED_EXT,
358fcf5ef2aSThomas Huth S390_FEAT_ETF2_ENH,
359fcf5ef2aSThomas Huth S390_FEAT_STORE_CLOCK_FAST,
360fcf5ef2aSThomas Huth S390_FEAT_GROUP_TOD_CLOCK_STEERING,
361fcf5ef2aSThomas Huth S390_FEAT_ETF3_ENH,
362fcf5ef2aSThomas Huth S390_FEAT_DAT_ENH_2,
363fcf5ef2aSThomas Huth };
364ec3aadb1SJason J. Herne
365fcf5ef2aSThomas Huth #define base_GEN9_GA2 EmptyFeat
366fcf5ef2aSThomas Huth #define base_GEN9_GA3 EmptyFeat
367ec3aadb1SJason J. Herne
368fcf5ef2aSThomas Huth static uint16_t base_GEN10_GA1[] = {
369fcf5ef2aSThomas Huth S390_FEAT_CONDITIONAL_SSKE,
370fcf5ef2aSThomas Huth S390_FEAT_PARSING_ENH,
371fcf5ef2aSThomas Huth S390_FEAT_MOVE_WITH_OPTIONAL_SPEC,
372fcf5ef2aSThomas Huth S390_FEAT_EXTRACT_CPU_TIME,
373fcf5ef2aSThomas Huth S390_FEAT_COMPARE_AND_SWAP_AND_STORE,
374fcf5ef2aSThomas Huth S390_FEAT_COMPARE_AND_SWAP_AND_STORE_2,
375fcf5ef2aSThomas Huth S390_FEAT_GENERAL_INSTRUCTIONS_EXT,
376fcf5ef2aSThomas Huth S390_FEAT_EXECUTE_EXT,
37700011706SDr. David Alan Gilbert S390_FEAT_FLOATING_POINT_SUPPORT_ENH,
378fcf5ef2aSThomas Huth S390_FEAT_DFP,
379fcf5ef2aSThomas Huth S390_FEAT_DFP_FAST,
380fcf5ef2aSThomas Huth S390_FEAT_PFPO,
381fcf5ef2aSThomas Huth };
382fcf5ef2aSThomas Huth #define base_GEN10_GA2 EmptyFeat
383fcf5ef2aSThomas Huth #define base_GEN10_GA3 EmptyFeat
384ec3aadb1SJason J. Herne
385fcf5ef2aSThomas Huth static uint16_t base_GEN11_GA1[] = {
386fcf5ef2aSThomas Huth S390_FEAT_NONQ_KEY_SETTING,
387fcf5ef2aSThomas Huth S390_FEAT_ENHANCED_MONITOR,
388fcf5ef2aSThomas Huth S390_FEAT_FLOATING_POINT_EXT,
389fcf5ef2aSThomas Huth S390_FEAT_SET_PROGRAM_PARAMETERS,
390fcf5ef2aSThomas Huth S390_FEAT_STFLE_45,
391fcf5ef2aSThomas Huth S390_FEAT_CMPSC_ENH,
392fcf5ef2aSThomas Huth S390_FEAT_INTERLOCKED_ACCESS_2,
393fcf5ef2aSThomas Huth };
394ec3aadb1SJason J. Herne
395fcf5ef2aSThomas Huth #define base_GEN11_GA2 EmptyFeat
396ec3aadb1SJason J. Herne
397fcf5ef2aSThomas Huth static uint16_t base_GEN12_GA1[] = {
398fcf5ef2aSThomas Huth S390_FEAT_DFP_ZONED_CONVERSION,
399fcf5ef2aSThomas Huth S390_FEAT_STFLE_49,
400fcf5ef2aSThomas Huth S390_FEAT_LOCAL_TLB_CLEARING,
401fcf5ef2aSThomas Huth };
402ec3aadb1SJason J. Herne
403fcf5ef2aSThomas Huth #define base_GEN12_GA2 EmptyFeat
404ec3aadb1SJason J. Herne
405fcf5ef2aSThomas Huth static uint16_t base_GEN13_GA1[] = {
406fcf5ef2aSThomas Huth S390_FEAT_STFLE_53,
407fcf5ef2aSThomas Huth S390_FEAT_DFP_PACKED_CONVERSION,
408fcf5ef2aSThomas Huth S390_FEAT_GROUP_GEN13_PTFF,
409fcf5ef2aSThomas Huth };
410ec3aadb1SJason J. Herne
411fcf5ef2aSThomas Huth #define base_GEN13_GA2 EmptyFeat
412fcf5ef2aSThomas Huth
413cc28a594SJason J. Herne static uint16_t base_GEN14_GA1[] = {
414cc28a594SJason J. Herne S390_FEAT_ENTROPY_ENC_COMP,
41598998cdaSDavid Hildenbrand S390_FEAT_MISC_INSTRUCTION_EXT2,
416cc28a594SJason J. Herne S390_FEAT_SEMAPHORE_ASSIST,
417cc28a594SJason J. Herne S390_FEAT_TIME_SLICE_INSTRUMENTATION,
418cc28a594SJason J. Herne S390_FEAT_ORDER_PRESERVING_COMPRESSION,
419cc28a594SJason J. Herne };
420cc28a594SJason J. Herne
421f2a7d157SCollin Walling #define base_GEN14_GA2 EmptyFeat
422f2a7d157SCollin Walling
423caef6243SChristian Borntraeger static uint16_t base_GEN15_GA1[] = {
424caef6243SChristian Borntraeger S390_FEAT_MISC_INSTRUCTION_EXT3,
425caef6243SChristian Borntraeger };
426caef6243SChristian Borntraeger
427fb4a0812SChristian Borntraeger #define base_GEN16_GA1 EmptyFeat
428fb4a0812SChristian Borntraeger
429ec3aadb1SJason J. Herne /* Full features (in order of release)
430ec3aadb1SJason J. Herne * Automatically includes corresponding base features.
431ec3aadb1SJason J. Herne * Full features are all features this hardware supports even if kvm/QEMU do not
432ec3aadb1SJason J. Herne * support these features yet.
433ec3aadb1SJason J. Herne */
434fcf5ef2aSThomas Huth static uint16_t full_GEN7_GA1[] = {
4359f0d13f4SChristian Borntraeger S390_FEAT_PPA15,
436b073c875SChristian Borntraeger S390_FEAT_BPB,
437fcf5ef2aSThomas Huth S390_FEAT_SIE_F2,
438fcf5ef2aSThomas Huth S390_FEAT_SIE_SKEY,
439fcf5ef2aSThomas Huth S390_FEAT_SIE_GPERE,
440fcf5ef2aSThomas Huth S390_FEAT_SIE_IB,
441fcf5ef2aSThomas Huth S390_FEAT_SIE_CEI,
442fcf5ef2aSThomas Huth };
443ec3aadb1SJason J. Herne
444fcf5ef2aSThomas Huth static uint16_t full_GEN7_GA2[] = {
445fcf5ef2aSThomas Huth S390_FEAT_EXTENDED_TRANSLATION_2,
446fcf5ef2aSThomas Huth };
447ec3aadb1SJason J. Herne
448fcf5ef2aSThomas Huth static uint16_t full_GEN7_GA3[] = {
449fcf5ef2aSThomas Huth S390_FEAT_LONG_DISPLACEMENT,
450fcf5ef2aSThomas Huth S390_FEAT_SIE_SIIF,
451fcf5ef2aSThomas Huth };
452ec3aadb1SJason J. Herne
453fcf5ef2aSThomas Huth static uint16_t full_GEN8_GA1[] = {
454fcf5ef2aSThomas Huth S390_FEAT_SIE_GSLS,
455fcf5ef2aSThomas Huth S390_FEAT_SIE_64BSCAO,
456fcf5ef2aSThomas Huth };
457ec3aadb1SJason J. Herne
458fcf5ef2aSThomas Huth #define full_GEN8_GA2 EmptyFeat
459ec3aadb1SJason J. Herne
460fcf5ef2aSThomas Huth static uint16_t full_GEN8_GA3[] = {
461fcf5ef2aSThomas Huth S390_FEAT_ASN_LX_REUSE,
462fcf5ef2aSThomas Huth S390_FEAT_EXTENDED_TRANSLATION_3,
463fcf5ef2aSThomas Huth };
464ec3aadb1SJason J. Herne
465fcf5ef2aSThomas Huth #define full_GEN8_GA4 EmptyFeat
466fcf5ef2aSThomas Huth #define full_GEN8_GA5 EmptyFeat
467ec3aadb1SJason J. Herne
468fcf5ef2aSThomas Huth static uint16_t full_GEN9_GA1[] = {
469fcf5ef2aSThomas Huth S390_FEAT_STORE_HYPERVISOR_INFO,
470fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_1,
471fcf5ef2aSThomas Huth S390_FEAT_CMM,
472fcf5ef2aSThomas Huth S390_FEAT_SIE_CMMA,
473fcf5ef2aSThomas Huth };
474ec3aadb1SJason J. Herne
475fcf5ef2aSThomas Huth static uint16_t full_GEN9_GA2[] = {
476fcf5ef2aSThomas Huth S390_FEAT_MOVE_WITH_OPTIONAL_SPEC,
477fcf5ef2aSThomas Huth S390_FEAT_EXTRACT_CPU_TIME,
478fcf5ef2aSThomas Huth S390_FEAT_COMPARE_AND_SWAP_AND_STORE,
47900011706SDr. David Alan Gilbert S390_FEAT_FLOATING_POINT_SUPPORT_ENH,
480fcf5ef2aSThomas Huth S390_FEAT_DFP,
481fcf5ef2aSThomas Huth };
482ec3aadb1SJason J. Herne
483fcf5ef2aSThomas Huth static uint16_t full_GEN9_GA3[] = {
484fcf5ef2aSThomas Huth S390_FEAT_CONDITIONAL_SSKE,
485fcf5ef2aSThomas Huth S390_FEAT_PFPO,
486fcf5ef2aSThomas Huth };
487ec3aadb1SJason J. Herne
488fcf5ef2aSThomas Huth static uint16_t full_GEN10_GA1[] = {
489fcf5ef2aSThomas Huth S390_FEAT_EDAT,
490fcf5ef2aSThomas Huth S390_FEAT_CONFIGURATION_TOPOLOGY,
491fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_2,
492fcf5ef2aSThomas Huth S390_FEAT_ESOP,
493fcf5ef2aSThomas Huth S390_FEAT_SIE_PFMFI,
494fcf5ef2aSThomas Huth S390_FEAT_SIE_SIGPIF,
495fcf5ef2aSThomas Huth };
496ec3aadb1SJason J. Herne
497fcf5ef2aSThomas Huth static uint16_t full_GEN10_GA2[] = {
498fcf5ef2aSThomas Huth S390_FEAT_SET_PROGRAM_PARAMETERS,
499fcf5ef2aSThomas Huth S390_FEAT_SIE_IBS,
500fcf5ef2aSThomas Huth };
501ec3aadb1SJason J. Herne
502fcf5ef2aSThomas Huth static uint16_t full_GEN10_GA3[] = {
503fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_3,
504fcf5ef2aSThomas Huth };
505ec3aadb1SJason J. Herne
506fcf5ef2aSThomas Huth static uint16_t full_GEN11_GA1[] = {
507fcf5ef2aSThomas Huth S390_FEAT_IPTE_RANGE,
508fcf5ef2aSThomas Huth S390_FEAT_ACCESS_EXCEPTION_FS_INDICATION,
509fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_4,
510fcf5ef2aSThomas Huth };
511ec3aadb1SJason J. Herne
512fcf5ef2aSThomas Huth #define full_GEN11_GA2 EmptyFeat
513ec3aadb1SJason J. Herne
514fcf5ef2aSThomas Huth static uint16_t full_GEN12_GA1[] = {
515fcf5ef2aSThomas Huth S390_FEAT_CONSTRAINT_TRANSACTIONAL_EXE,
516fcf5ef2aSThomas Huth S390_FEAT_TRANSACTIONAL_EXE,
517fcf5ef2aSThomas Huth S390_FEAT_RUNTIME_INSTRUMENTATION,
5183b00f702SYi Min Zhao S390_FEAT_ZPCI,
5193b00f702SYi Min Zhao S390_FEAT_ADAPTER_EVENT_NOTIFICATION,
5203b00f702SYi Min Zhao S390_FEAT_ADAPTER_INT_SUPPRESSION,
521fcf5ef2aSThomas Huth S390_FEAT_EDAT_2,
5227223bcceSJason J. Herne S390_FEAT_SIDE_EFFECT_ACCESS_ESOP2,
523c5cd17afSTony Krowiak S390_FEAT_AP_QUERY_CONFIG_INFO,
5249ef2d19eSPierre Morel S390_FEAT_AP_QUEUE_INTERRUPT_CONTROL,
525c5cd17afSTony Krowiak S390_FEAT_AP_FACILITIES_TEST,
526c5cd17afSTony Krowiak S390_FEAT_AP,
5271ecd6078SCollin Walling S390_FEAT_EXTENDED_LENGTH_SCCB,
528fabdada9SCollin Walling S390_FEAT_DIAG_318,
529fcf5ef2aSThomas Huth };
530ec3aadb1SJason J. Herne
531fcf5ef2aSThomas Huth static uint16_t full_GEN12_GA2[] = {
532fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_5,
533fcf5ef2aSThomas Huth };
534ec3aadb1SJason J. Herne
535fcf5ef2aSThomas Huth static uint16_t full_GEN13_GA1[] = {
536fcf5ef2aSThomas Huth S390_FEAT_VECTOR,
537fcf5ef2aSThomas Huth };
538ec3aadb1SJason J. Herne
539fcf5ef2aSThomas Huth #define full_GEN13_GA2 EmptyFeat
540fcf5ef2aSThomas Huth
541cc28a594SJason J. Herne static uint16_t full_GEN14_GA1[] = {
542cc28a594SJason J. Herne S390_FEAT_INSTRUCTION_EXEC_PROT,
543cc28a594SJason J. Herne S390_FEAT_GUARDED_STORAGE,
544cc28a594SJason J. Herne S390_FEAT_VECTOR_PACKED_DECIMAL,
545cc28a594SJason J. Herne S390_FEAT_VECTOR_ENH,
546cc28a594SJason J. Herne S390_FEAT_MULTIPLE_EPOCH,
547cc28a594SJason J. Herne S390_FEAT_TEST_PENDING_EXT_INTERRUPTION,
548cc28a594SJason J. Herne S390_FEAT_INSERT_REFERENCE_BITS_MULT,
549cc28a594SJason J. Herne S390_FEAT_GROUP_MSA_EXT_6,
550cc28a594SJason J. Herne S390_FEAT_GROUP_MSA_EXT_7,
551cc28a594SJason J. Herne S390_FEAT_GROUP_MSA_EXT_8,
552cc28a594SJason J. Herne S390_FEAT_CMM_NT,
55327e84d4eSChristian Borntraeger S390_FEAT_ETOKEN,
554cc28a594SJason J. Herne S390_FEAT_HPMA2,
555cc28a594SJason J. Herne S390_FEAT_SIE_KSS,
55646a99c9fSDavid Hildenbrand S390_FEAT_GROUP_MULTIPLE_EPOCH_PTFF,
557cc28a594SJason J. Herne };
558cc28a594SJason J. Herne
559f2a7d157SCollin Walling #define full_GEN14_GA2 EmptyFeat
560f2a7d157SCollin Walling
561caef6243SChristian Borntraeger static uint16_t full_GEN15_GA1[] = {
562caef6243SChristian Borntraeger S390_FEAT_VECTOR_ENH2,
563caef6243SChristian Borntraeger S390_FEAT_GROUP_ENH_SORT,
564caef6243SChristian Borntraeger S390_FEAT_GROUP_DEFLATE_CONVERSION,
5655d8866c8SChristian Borntraeger S390_FEAT_VECTOR_PACKED_DECIMAL_ENH,
566caef6243SChristian Borntraeger S390_FEAT_GROUP_MSA_EXT_9,
567caef6243SChristian Borntraeger S390_FEAT_GROUP_MSA_EXT_9_PCKMO,
568caef6243SChristian Borntraeger S390_FEAT_ETOKEN,
569572c0826SChristian Borntraeger S390_FEAT_UNPACK,
570caef6243SChristian Borntraeger };
571caef6243SChristian Borntraeger
572fb4a0812SChristian Borntraeger static uint16_t full_GEN16_GA1[] = {
573fb4a0812SChristian Borntraeger S390_FEAT_NNPA,
574fb4a0812SChristian Borntraeger S390_FEAT_VECTOR_PACKED_DECIMAL_ENH2,
575fb4a0812SChristian Borntraeger S390_FEAT_BEAR_ENH,
576fb4a0812SChristian Borntraeger S390_FEAT_RDP,
577fb4a0812SChristian Borntraeger S390_FEAT_PAI,
5781d41de5fSChristian Borntraeger S390_FEAT_PAIE,
579*5ac95151SSteffen Eiden S390_FEAT_UV_FEAT_AP,
580*5ac95151SSteffen Eiden S390_FEAT_UV_FEAT_AP_INTR,
581fb4a0812SChristian Borntraeger };
582fb4a0812SChristian Borntraeger
583fb4a0812SChristian Borntraeger
584ec3aadb1SJason J. Herne /* Default features (in order of release)
585ec3aadb1SJason J. Herne * Automatically includes corresponding base features.
586ec3aadb1SJason J. Herne * Default features are all features this version of QEMU supports for this
587ec3aadb1SJason J. Herne * hardware model. Default feature sets can grow with new QEMU releases.
588ec3aadb1SJason J. Herne */
589fcf5ef2aSThomas Huth #define default_GEN7_GA1 EmptyFeat
590fcf5ef2aSThomas Huth #define default_GEN7_GA2 EmptyFeat
591fcf5ef2aSThomas Huth #define default_GEN7_GA3 EmptyFeat
592fcf5ef2aSThomas Huth #define default_GEN8_GA1 EmptyFeat
593fcf5ef2aSThomas Huth #define default_GEN8_GA2 EmptyFeat
594fcf5ef2aSThomas Huth #define default_GEN8_GA3 EmptyFeat
595fcf5ef2aSThomas Huth #define default_GEN8_GA4 EmptyFeat
596fcf5ef2aSThomas Huth #define default_GEN8_GA5 EmptyFeat
597ec3aadb1SJason J. Herne
598fcf5ef2aSThomas Huth static uint16_t default_GEN9_GA1[] = {
599fcf5ef2aSThomas Huth S390_FEAT_STORE_HYPERVISOR_INFO,
600fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_1,
601fcf5ef2aSThomas Huth S390_FEAT_CMM,
602fcf5ef2aSThomas Huth };
603ec3aadb1SJason J. Herne
604fcf5ef2aSThomas Huth #define default_GEN9_GA2 EmptyFeat
605fcf5ef2aSThomas Huth #define default_GEN9_GA3 EmptyFeat
606ec3aadb1SJason J. Herne
607fcf5ef2aSThomas Huth static uint16_t default_GEN10_GA1[] = {
608fcf5ef2aSThomas Huth S390_FEAT_EDAT,
609fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_2,
610fcf5ef2aSThomas Huth };
611ec3aadb1SJason J. Herne
612fcf5ef2aSThomas Huth #define default_GEN10_GA2 EmptyFeat
613fcf5ef2aSThomas Huth #define default_GEN10_GA3 EmptyFeat
614ec3aadb1SJason J. Herne
615fcf5ef2aSThomas Huth static uint16_t default_GEN11_GA1[] = {
616fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_3,
617fcf5ef2aSThomas Huth S390_FEAT_IPTE_RANGE,
618fcf5ef2aSThomas Huth S390_FEAT_ACCESS_EXCEPTION_FS_INDICATION,
619fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_4,
62087273151SChristian Borntraeger S390_FEAT_PPA15,
62187273151SChristian Borntraeger S390_FEAT_BPB,
622fcf5ef2aSThomas Huth };
623ec3aadb1SJason J. Herne
624fcf5ef2aSThomas Huth #define default_GEN11_GA2 EmptyFeat
625ec3aadb1SJason J. Herne
626fcf5ef2aSThomas Huth static uint16_t default_GEN12_GA1[] = {
627fcf5ef2aSThomas Huth S390_FEAT_CONSTRAINT_TRANSACTIONAL_EXE,
628fcf5ef2aSThomas Huth S390_FEAT_TRANSACTIONAL_EXE,
629fcf5ef2aSThomas Huth S390_FEAT_RUNTIME_INSTRUMENTATION,
6303b00f702SYi Min Zhao S390_FEAT_ZPCI,
6313b00f702SYi Min Zhao S390_FEAT_ADAPTER_EVENT_NOTIFICATION,
632fcf5ef2aSThomas Huth S390_FEAT_EDAT_2,
6337223bcceSJason J. Herne S390_FEAT_ESOP,
6347223bcceSJason J. Herne S390_FEAT_SIDE_EFFECT_ACCESS_ESOP2,
635fcf5ef2aSThomas Huth };
636ec3aadb1SJason J. Herne
637fcf5ef2aSThomas Huth #define default_GEN12_GA2 EmptyFeat
638ec3aadb1SJason J. Herne
639fcf5ef2aSThomas Huth static uint16_t default_GEN13_GA1[] = {
640fcf5ef2aSThomas Huth S390_FEAT_GROUP_MSA_EXT_5,
641fcf5ef2aSThomas Huth S390_FEAT_VECTOR,
642fcf5ef2aSThomas Huth };
643ec3aadb1SJason J. Herne
644fcf5ef2aSThomas Huth #define default_GEN13_GA2 EmptyFeat
645fcf5ef2aSThomas Huth
646cc28a594SJason J. Herne static uint16_t default_GEN14_GA1[] = {
647cc28a594SJason J. Herne S390_FEAT_INSTRUCTION_EXEC_PROT,
648cc28a594SJason J. Herne S390_FEAT_GUARDED_STORAGE,
649cc28a594SJason J. Herne S390_FEAT_VECTOR_PACKED_DECIMAL,
650cc28a594SJason J. Herne S390_FEAT_VECTOR_ENH,
651cc28a594SJason J. Herne S390_FEAT_GROUP_MSA_EXT_6,
652cc28a594SJason J. Herne S390_FEAT_GROUP_MSA_EXT_7,
653cc28a594SJason J. Herne S390_FEAT_GROUP_MSA_EXT_8,
65484176c79SCollin Walling S390_FEAT_MULTIPLE_EPOCH,
65584176c79SCollin Walling S390_FEAT_GROUP_MULTIPLE_EPOCH_PTFF,
656cc28a594SJason J. Herne };
657cc28a594SJason J. Herne
658f2a7d157SCollin Walling #define default_GEN14_GA2 EmptyFeat
659f2a7d157SCollin Walling
660caef6243SChristian Borntraeger static uint16_t default_GEN15_GA1[] = {
661caef6243SChristian Borntraeger S390_FEAT_VECTOR_ENH2,
662caef6243SChristian Borntraeger S390_FEAT_GROUP_DEFLATE_CONVERSION,
6635d8866c8SChristian Borntraeger S390_FEAT_VECTOR_PACKED_DECIMAL_ENH,
664caef6243SChristian Borntraeger S390_FEAT_GROUP_MSA_EXT_9,
665caef6243SChristian Borntraeger S390_FEAT_GROUP_MSA_EXT_9_PCKMO,
666caef6243SChristian Borntraeger S390_FEAT_ETOKEN,
667caef6243SChristian Borntraeger };
668caef6243SChristian Borntraeger
66930e398f7SChristian Borntraeger static uint16_t default_GEN16_GA1[] = {
67030e398f7SChristian Borntraeger S390_FEAT_NNPA,
67130e398f7SChristian Borntraeger S390_FEAT_VECTOR_PACKED_DECIMAL_ENH2,
67230e398f7SChristian Borntraeger S390_FEAT_BEAR_ENH,
67330e398f7SChristian Borntraeger S390_FEAT_RDP,
67430e398f7SChristian Borntraeger S390_FEAT_PAI,
6751d41de5fSChristian Borntraeger S390_FEAT_PAIE,
67630e398f7SChristian Borntraeger };
677fb4a0812SChristian Borntraeger
67835b4df64SDavid Hildenbrand /* QEMU (CPU model) features */
67935b4df64SDavid Hildenbrand
68035b4df64SDavid Hildenbrand static uint16_t qemu_V2_11[] = {
68135b4df64SDavid Hildenbrand S390_FEAT_GROUP_PLO,
68235b4df64SDavid Hildenbrand S390_FEAT_ESAN3,
68335b4df64SDavid Hildenbrand S390_FEAT_ZARCH,
68435b4df64SDavid Hildenbrand };
68535b4df64SDavid Hildenbrand
686d646b16bSDavid Hildenbrand static uint16_t qemu_V3_1[] = {
68735b4df64SDavid Hildenbrand S390_FEAT_DAT_ENH,
68835b4df64SDavid Hildenbrand S390_FEAT_IDTE_SEGMENT,
68935b4df64SDavid Hildenbrand S390_FEAT_STFLE,
69035b4df64SDavid Hildenbrand S390_FEAT_SENSE_RUNNING_STATUS,
69135b4df64SDavid Hildenbrand S390_FEAT_EXTENDED_TRANSLATION_2,
69235b4df64SDavid Hildenbrand S390_FEAT_MSA,
69335b4df64SDavid Hildenbrand S390_FEAT_LONG_DISPLACEMENT,
69435b4df64SDavid Hildenbrand S390_FEAT_LONG_DISPLACEMENT_FAST,
69535b4df64SDavid Hildenbrand S390_FEAT_EXTENDED_IMMEDIATE,
69635b4df64SDavid Hildenbrand S390_FEAT_EXTENDED_TRANSLATION_3,
69735b4df64SDavid Hildenbrand S390_FEAT_ETF2_ENH,
69835b4df64SDavid Hildenbrand S390_FEAT_STORE_CLOCK_FAST,
69935b4df64SDavid Hildenbrand S390_FEAT_MOVE_WITH_OPTIONAL_SPEC,
70035b4df64SDavid Hildenbrand S390_FEAT_ETF3_ENH,
70135b4df64SDavid Hildenbrand S390_FEAT_EXTRACT_CPU_TIME,
70235b4df64SDavid Hildenbrand S390_FEAT_COMPARE_AND_SWAP_AND_STORE,
70335b4df64SDavid Hildenbrand S390_FEAT_COMPARE_AND_SWAP_AND_STORE_2,
70435b4df64SDavid Hildenbrand S390_FEAT_GENERAL_INSTRUCTIONS_EXT,
70535b4df64SDavid Hildenbrand S390_FEAT_EXECUTE_EXT,
70635b4df64SDavid Hildenbrand S390_FEAT_SET_PROGRAM_PARAMETERS,
70700011706SDr. David Alan Gilbert S390_FEAT_FLOATING_POINT_SUPPORT_ENH,
70835b4df64SDavid Hildenbrand S390_FEAT_STFLE_45,
70935b4df64SDavid Hildenbrand S390_FEAT_STFLE_49,
71035b4df64SDavid Hildenbrand S390_FEAT_LOCAL_TLB_CLEARING,
71135b4df64SDavid Hildenbrand S390_FEAT_INTERLOCKED_ACCESS_2,
712e3fd586dSCornelia Huck S390_FEAT_ADAPTER_EVENT_NOTIFICATION,
713e3fd586dSCornelia Huck S390_FEAT_ADAPTER_INT_SUPPRESSION,
71435b4df64SDavid Hildenbrand S390_FEAT_MSA_EXT_3,
715e3fd586dSCornelia Huck S390_FEAT_MSA_EXT_4,
71635b4df64SDavid Hildenbrand };
71735b4df64SDavid Hildenbrand
71808ef92d5SDavid Hildenbrand static uint16_t qemu_V4_0[] = {
719df192fbcSDavid Hildenbrand /*
720df192fbcSDavid Hildenbrand * Only BFP bits are implemented (HFP, DFP, PFPO and DIVIDE TO INTEGER not
721df192fbcSDavid Hildenbrand * implemented yet).
722df192fbcSDavid Hildenbrand */
723df192fbcSDavid Hildenbrand S390_FEAT_FLOATING_POINT_EXT,
724d646b16bSDavid Hildenbrand S390_FEAT_ZPCI,
725d646b16bSDavid Hildenbrand };
726d646b16bSDavid Hildenbrand
727faa40177SDavid Hildenbrand static uint16_t qemu_V4_1[] = {
72835b4df64SDavid Hildenbrand S390_FEAT_STFLE_53,
729c7f22b31SDavid Hildenbrand S390_FEAT_VECTOR,
73008ef92d5SDavid Hildenbrand };
73108ef92d5SDavid Hildenbrand
732463e50daSDavid Hildenbrand static uint16_t qemu_V6_0[] = {
733b580b6eeSDavid Hildenbrand S390_FEAT_ACCESS_EXCEPTION_FS_INDICATION,
734b580b6eeSDavid Hildenbrand S390_FEAT_SIDE_EFFECT_ACCESS_ESOP2,
735b580b6eeSDavid Hildenbrand S390_FEAT_ESOP,
736faa40177SDavid Hildenbrand };
737faa40177SDavid Hildenbrand
7388a4eafb6SDavid Miller static uint16_t qemu_V6_2[] = {
739463e50daSDavid Hildenbrand S390_FEAT_INSTRUCTION_EXEC_PROT,
740463e50daSDavid Hildenbrand S390_FEAT_MISC_INSTRUCTION_EXT2,
741463e50daSDavid Hildenbrand S390_FEAT_MSA_EXT_8,
742463e50daSDavid Hildenbrand S390_FEAT_VECTOR_ENH,
743463e50daSDavid Hildenbrand };
744463e50daSDavid Hildenbrand
7454f9b6c7dSDavid Miller static uint16_t qemu_V7_0[] = {
7464f9b6c7dSDavid Miller S390_FEAT_MISC_INSTRUCTION_EXT3,
7474f9b6c7dSDavid Miller };
7484f9b6c7dSDavid Miller
7499f17bfdaSJason A. Donenfeld static uint16_t qemu_V7_1[] = {
7509f17bfdaSJason A. Donenfeld S390_FEAT_VECTOR_ENH2,
7519f17bfdaSJason A. Donenfeld };
7529f17bfdaSJason A. Donenfeld
753d98ed7d9SDavid Hildenbrand /*
754d98ed7d9SDavid Hildenbrand * Features for the "qemu" CPU model of the latest QEMU machine and the "max"
755d98ed7d9SDavid Hildenbrand * CPU model under TCG. Don't include features that are not part of the full
756d98ed7d9SDavid Hildenbrand * feature set of the current "max" CPU model generation.
757d98ed7d9SDavid Hildenbrand */
75808ef92d5SDavid Hildenbrand static uint16_t qemu_MAX[] = {
7599f17bfdaSJason A. Donenfeld S390_FEAT_MSA_EXT_5,
7609f17bfdaSJason A. Donenfeld S390_FEAT_KIMD_SHA_512,
7619f17bfdaSJason A. Donenfeld S390_FEAT_KLMD_SHA_512,
7623dbc5fdaSJason A. Donenfeld S390_FEAT_PRNO_TRNG,
76335b4df64SDavid Hildenbrand };
76435b4df64SDavid Hildenbrand
765fcf5ef2aSThomas Huth /****** END FEATURE DEFS ******/
766fcf5ef2aSThomas Huth
767fcf5ef2aSThomas Huth #define _YEARS "2016"
768fcf5ef2aSThomas Huth #define _NAME_H "TARGET_S390X_GEN_FEATURES_H"
769fcf5ef2aSThomas Huth
770fcf5ef2aSThomas Huth #define CPU_FEAT_INITIALIZER(_name) \
771fcf5ef2aSThomas Huth { \
772fcf5ef2aSThomas Huth .name = "S390_FEAT_LIST_" #_name, \
773fcf5ef2aSThomas Huth .base_bits = \
774fcf5ef2aSThomas Huth { .data = base_##_name, \
775fcf5ef2aSThomas Huth .len = ARRAY_SIZE(base_##_name) }, \
776fcf5ef2aSThomas Huth .default_bits = \
777fcf5ef2aSThomas Huth { .data = default_##_name, \
778fcf5ef2aSThomas Huth .len = ARRAY_SIZE(default_##_name) }, \
779fcf5ef2aSThomas Huth .full_bits = \
780fcf5ef2aSThomas Huth { .data = full_##_name, \
781fcf5ef2aSThomas Huth .len = ARRAY_SIZE(full_##_name) }, \
782fcf5ef2aSThomas Huth }
783fcf5ef2aSThomas Huth
784fcf5ef2aSThomas Huth typedef struct BitSpec {
785fcf5ef2aSThomas Huth uint16_t *data;
786fcf5ef2aSThomas Huth uint32_t len;
787fcf5ef2aSThomas Huth } BitSpec;
788fcf5ef2aSThomas Huth
789fcf5ef2aSThomas Huth typedef struct {
790fcf5ef2aSThomas Huth const char *name;
791fcf5ef2aSThomas Huth BitSpec base_bits;
792fcf5ef2aSThomas Huth BitSpec default_bits;
793fcf5ef2aSThomas Huth BitSpec full_bits;
794fcf5ef2aSThomas Huth } CpuFeatDefSpec;
795fcf5ef2aSThomas Huth
796fcf5ef2aSThomas Huth static uint16_t EmptyFeat[] = {};
797fcf5ef2aSThomas Huth
798fcf5ef2aSThomas Huth /*******************************
799fcf5ef2aSThomas Huth * processor GA series
800fcf5ef2aSThomas Huth *******************************/
801fcf5ef2aSThomas Huth static CpuFeatDefSpec CpuFeatDef[] = {
802fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN7_GA1),
803fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN7_GA2),
804fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN7_GA3),
805fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN8_GA1),
806fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN8_GA2),
807fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN8_GA3),
808fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN8_GA4),
809fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN8_GA5),
810fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN9_GA1),
811fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN9_GA2),
812fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN9_GA3),
813fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN10_GA1),
814fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN10_GA2),
815fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN10_GA3),
816fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN11_GA1),
817fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN11_GA2),
818fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN12_GA1),
819fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN12_GA2),
820fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN13_GA1),
821fcf5ef2aSThomas Huth CPU_FEAT_INITIALIZER(GEN13_GA2),
822cc28a594SJason J. Herne CPU_FEAT_INITIALIZER(GEN14_GA1),
823f2a7d157SCollin Walling CPU_FEAT_INITIALIZER(GEN14_GA2),
824caef6243SChristian Borntraeger CPU_FEAT_INITIALIZER(GEN15_GA1),
825fb4a0812SChristian Borntraeger CPU_FEAT_INITIALIZER(GEN16_GA1),
826fcf5ef2aSThomas Huth };
827fcf5ef2aSThomas Huth
828fcf5ef2aSThomas Huth #define FEAT_GROUP_INITIALIZER(_name) \
829fcf5ef2aSThomas Huth { \
830fcf5ef2aSThomas Huth .name = "S390_FEAT_GROUP_LIST_" #_name, \
831a5f9ecc4SMichael Mueller .enum_name = "S390_FEAT_GROUP_" #_name, \
832fcf5ef2aSThomas Huth .bits = \
833fcf5ef2aSThomas Huth { .data = group_##_name, \
834fcf5ef2aSThomas Huth .len = ARRAY_SIZE(group_##_name) }, \
835fcf5ef2aSThomas Huth }
836fcf5ef2aSThomas Huth
837fcf5ef2aSThomas Huth typedef struct {
838fcf5ef2aSThomas Huth const char *name;
839a5f9ecc4SMichael Mueller const char *enum_name;
840fcf5ef2aSThomas Huth BitSpec bits;
841fcf5ef2aSThomas Huth } FeatGroupDefSpec;
842fcf5ef2aSThomas Huth
843fcf5ef2aSThomas Huth /*******************************
844fcf5ef2aSThomas Huth * feature groups
845fcf5ef2aSThomas Huth *******************************/
846fcf5ef2aSThomas Huth static FeatGroupDefSpec FeatGroupDef[] = {
847fcf5ef2aSThomas Huth FEAT_GROUP_INITIALIZER(PLO),
848fcf5ef2aSThomas Huth FEAT_GROUP_INITIALIZER(TOD_CLOCK_STEERING),
849fcf5ef2aSThomas Huth FEAT_GROUP_INITIALIZER(GEN13_PTFF),
850fcf5ef2aSThomas Huth FEAT_GROUP_INITIALIZER(MSA),
851fcf5ef2aSThomas Huth FEAT_GROUP_INITIALIZER(MSA_EXT_1),
852fcf5ef2aSThomas Huth FEAT_GROUP_INITIALIZER(MSA_EXT_2),
853fcf5ef2aSThomas Huth FEAT_GROUP_INITIALIZER(MSA_EXT_3),
854fcf5ef2aSThomas Huth FEAT_GROUP_INITIALIZER(MSA_EXT_4),
855fcf5ef2aSThomas Huth FEAT_GROUP_INITIALIZER(MSA_EXT_5),
8566da5c593SJason J. Herne FEAT_GROUP_INITIALIZER(MSA_EXT_6),
8576da5c593SJason J. Herne FEAT_GROUP_INITIALIZER(MSA_EXT_7),
8586da5c593SJason J. Herne FEAT_GROUP_INITIALIZER(MSA_EXT_8),
8595dacbe23SChristian Borntraeger FEAT_GROUP_INITIALIZER(MSA_EXT_9),
8605dacbe23SChristian Borntraeger FEAT_GROUP_INITIALIZER(MSA_EXT_9_PCKMO),
861a5f9ecc4SMichael Mueller FEAT_GROUP_INITIALIZER(MULTIPLE_EPOCH_PTFF),
862d220fabfSChristian Borntraeger FEAT_GROUP_INITIALIZER(ENH_SORT),
863afc7b866SChristian Borntraeger FEAT_GROUP_INITIALIZER(DEFLATE_CONVERSION),
864fcf5ef2aSThomas Huth };
865fcf5ef2aSThomas Huth
86635b4df64SDavid Hildenbrand #define QEMU_FEAT_INITIALIZER(_name) \
86735b4df64SDavid Hildenbrand { \
86835b4df64SDavid Hildenbrand .name = "S390_FEAT_LIST_QEMU_" #_name, \
86935b4df64SDavid Hildenbrand .bits = \
87035b4df64SDavid Hildenbrand { .data = qemu_##_name, \
87135b4df64SDavid Hildenbrand .len = ARRAY_SIZE(qemu_##_name) }, \
87235b4df64SDavid Hildenbrand }
87335b4df64SDavid Hildenbrand
87435b4df64SDavid Hildenbrand /*******************************
87535b4df64SDavid Hildenbrand * QEMU (CPU model) features
87635b4df64SDavid Hildenbrand *******************************/
87735b4df64SDavid Hildenbrand static FeatGroupDefSpec QemuFeatDef[] = {
87835b4df64SDavid Hildenbrand QEMU_FEAT_INITIALIZER(V2_11),
879d646b16bSDavid Hildenbrand QEMU_FEAT_INITIALIZER(V3_1),
88008ef92d5SDavid Hildenbrand QEMU_FEAT_INITIALIZER(V4_0),
881faa40177SDavid Hildenbrand QEMU_FEAT_INITIALIZER(V4_1),
882463e50daSDavid Hildenbrand QEMU_FEAT_INITIALIZER(V6_0),
8838a4eafb6SDavid Miller QEMU_FEAT_INITIALIZER(V6_2),
8844f9b6c7dSDavid Miller QEMU_FEAT_INITIALIZER(V7_0),
8859f17bfdaSJason A. Donenfeld QEMU_FEAT_INITIALIZER(V7_1),
88635b4df64SDavid Hildenbrand QEMU_FEAT_INITIALIZER(MAX),
88735b4df64SDavid Hildenbrand };
88835b4df64SDavid Hildenbrand
88935b4df64SDavid Hildenbrand
set_bits(uint64_t list[],BitSpec bits)890fcf5ef2aSThomas Huth static void set_bits(uint64_t list[], BitSpec bits)
891fcf5ef2aSThomas Huth {
892fcf5ef2aSThomas Huth uint32_t i;
893fcf5ef2aSThomas Huth
894fcf5ef2aSThomas Huth for (i = 0; i < bits.len; i++) {
895fcf5ef2aSThomas Huth list[bits.data[i] / 64] |= 1ULL << (bits.data[i] % 64);
896fcf5ef2aSThomas Huth }
897fcf5ef2aSThomas Huth }
898fcf5ef2aSThomas Huth
clear_bit(uint64_t list[],unsigned long nr)899caef6243SChristian Borntraeger static inline void clear_bit(uint64_t list[], unsigned long nr)
900caef6243SChristian Borntraeger {
901caef6243SChristian Borntraeger list[nr / 64] &= ~(1ULL << (nr % 64));
902caef6243SChristian Borntraeger }
903caef6243SChristian Borntraeger
print_feature_defs(void)904fcf5ef2aSThomas Huth static void print_feature_defs(void)
905fcf5ef2aSThomas Huth {
906fcf5ef2aSThomas Huth uint64_t base_feat[S390_FEAT_MAX / 64 + 1] = {};
907fcf5ef2aSThomas Huth uint64_t default_feat[S390_FEAT_MAX / 64 + 1] = {};
908fcf5ef2aSThomas Huth uint64_t full_feat[S390_FEAT_MAX / 64 + 1] = {};
909fcf5ef2aSThomas Huth int i, j;
910fcf5ef2aSThomas Huth
911fcf5ef2aSThomas Huth printf("\n/* CPU model feature list data */\n");
912fcf5ef2aSThomas Huth
913fcf5ef2aSThomas Huth for (i = 0; i < ARRAY_SIZE(CpuFeatDef); i++) {
914caef6243SChristian Borntraeger /* With gen15 CSSKE and BPB are deprecated */
915caef6243SChristian Borntraeger if (strcmp(CpuFeatDef[i].name, "S390_FEAT_LIST_GEN15_GA1") == 0) {
916caef6243SChristian Borntraeger clear_bit(base_feat, S390_FEAT_CONDITIONAL_SSKE);
917caef6243SChristian Borntraeger clear_bit(default_feat, S390_FEAT_CONDITIONAL_SSKE);
918caef6243SChristian Borntraeger clear_bit(default_feat, S390_FEAT_BPB);
919caef6243SChristian Borntraeger }
920fcf5ef2aSThomas Huth set_bits(base_feat, CpuFeatDef[i].base_bits);
921fcf5ef2aSThomas Huth /* add the base to the default features */
922fcf5ef2aSThomas Huth set_bits(default_feat, CpuFeatDef[i].base_bits);
923fcf5ef2aSThomas Huth set_bits(default_feat, CpuFeatDef[i].default_bits);
924fcf5ef2aSThomas Huth /* add the base to the full features */
925fcf5ef2aSThomas Huth set_bits(full_feat, CpuFeatDef[i].base_bits);
926fcf5ef2aSThomas Huth set_bits(full_feat, CpuFeatDef[i].full_bits);
927fcf5ef2aSThomas Huth
928fcf5ef2aSThomas Huth printf("#define %s_BASE\t", CpuFeatDef[i].name);
929fcf5ef2aSThomas Huth for (j = 0; j < ARRAY_SIZE(base_feat); j++) {
930fcf5ef2aSThomas Huth printf("0x%016"PRIx64"ULL", base_feat[j]);
931fcf5ef2aSThomas Huth if (j < ARRAY_SIZE(base_feat) - 1) {
932fcf5ef2aSThomas Huth printf(",");
933fcf5ef2aSThomas Huth } else {
934fcf5ef2aSThomas Huth printf("\n");
935fcf5ef2aSThomas Huth }
936fcf5ef2aSThomas Huth }
937fcf5ef2aSThomas Huth printf("#define %s_DEFAULT\t", CpuFeatDef[i].name);
938fcf5ef2aSThomas Huth for (j = 0; j < ARRAY_SIZE(default_feat); j++) {
939fcf5ef2aSThomas Huth printf("0x%016"PRIx64"ULL", default_feat[j]);
940fcf5ef2aSThomas Huth if (j < ARRAY_SIZE(default_feat) - 1) {
941fcf5ef2aSThomas Huth printf(",");
942fcf5ef2aSThomas Huth } else {
943fcf5ef2aSThomas Huth printf("\n");
944fcf5ef2aSThomas Huth }
945fcf5ef2aSThomas Huth }
946fcf5ef2aSThomas Huth printf("#define %s_FULL\t\t", CpuFeatDef[i].name);
947fcf5ef2aSThomas Huth for (j = 0; j < ARRAY_SIZE(full_feat); j++) {
948fcf5ef2aSThomas Huth printf("0x%016"PRIx64"ULL", full_feat[j]);
949fcf5ef2aSThomas Huth if (j < ARRAY_SIZE(full_feat) - 1) {
950fcf5ef2aSThomas Huth printf(",");
951fcf5ef2aSThomas Huth } else {
952fcf5ef2aSThomas Huth printf("\n");
953fcf5ef2aSThomas Huth }
954fcf5ef2aSThomas Huth }
955fcf5ef2aSThomas Huth }
956fcf5ef2aSThomas Huth }
957fcf5ef2aSThomas Huth
print_qemu_feature_defs(void)95835b4df64SDavid Hildenbrand static void print_qemu_feature_defs(void)
95935b4df64SDavid Hildenbrand {
96035b4df64SDavid Hildenbrand uint64_t feat[S390_FEAT_MAX / 64 + 1] = {};
96135b4df64SDavid Hildenbrand int i, j;
96235b4df64SDavid Hildenbrand
96335b4df64SDavid Hildenbrand printf("\n/* QEMU (CPU model) feature list data */\n");
96435b4df64SDavid Hildenbrand
96535b4df64SDavid Hildenbrand /* for now we assume that we only add new features */
96635b4df64SDavid Hildenbrand for (i = 0; i < ARRAY_SIZE(QemuFeatDef); i++) {
96735b4df64SDavid Hildenbrand set_bits(feat, QemuFeatDef[i].bits);
96835b4df64SDavid Hildenbrand
96935b4df64SDavid Hildenbrand printf("#define %s\t", QemuFeatDef[i].name);
97035b4df64SDavid Hildenbrand for (j = 0; j < ARRAY_SIZE(feat); j++) {
97135b4df64SDavid Hildenbrand printf("0x%016"PRIx64"ULL", feat[j]);
97235b4df64SDavid Hildenbrand if (j < ARRAY_SIZE(feat) - 1) {
97335b4df64SDavid Hildenbrand printf(",");
97435b4df64SDavid Hildenbrand } else {
97535b4df64SDavid Hildenbrand printf("\n");
97635b4df64SDavid Hildenbrand }
97735b4df64SDavid Hildenbrand }
97835b4df64SDavid Hildenbrand }
97935b4df64SDavid Hildenbrand }
98035b4df64SDavid Hildenbrand
print_feature_group_defs(void)981fcf5ef2aSThomas Huth static void print_feature_group_defs(void)
982fcf5ef2aSThomas Huth {
983fcf5ef2aSThomas Huth int i, j;
984fcf5ef2aSThomas Huth
985fcf5ef2aSThomas Huth printf("\n/* CPU feature group list data */\n");
986fcf5ef2aSThomas Huth
987fcf5ef2aSThomas Huth for (i = 0; i < ARRAY_SIZE(FeatGroupDef); i++) {
988fcf5ef2aSThomas Huth uint64_t feat[S390_FEAT_MAX / 64 + 1] = {};
989fcf5ef2aSThomas Huth
990fcf5ef2aSThomas Huth set_bits(feat, FeatGroupDef[i].bits);
991fcf5ef2aSThomas Huth printf("#define %s\t", FeatGroupDef[i].name);
992fcf5ef2aSThomas Huth for (j = 0; j < ARRAY_SIZE(feat); j++) {
993fcf5ef2aSThomas Huth printf("0x%016"PRIx64"ULL", feat[j]);
994fcf5ef2aSThomas Huth if (j < ARRAY_SIZE(feat) - 1) {
995fcf5ef2aSThomas Huth printf(",");
996fcf5ef2aSThomas Huth } else {
997fcf5ef2aSThomas Huth printf("\n");
998fcf5ef2aSThomas Huth }
999fcf5ef2aSThomas Huth }
1000fcf5ef2aSThomas Huth }
1001fcf5ef2aSThomas Huth }
1002fcf5ef2aSThomas Huth
print_feature_group_enum_type(void)1003a5f9ecc4SMichael Mueller static void print_feature_group_enum_type(void)
1004a5f9ecc4SMichael Mueller {
1005a5f9ecc4SMichael Mueller int i;
1006a5f9ecc4SMichael Mueller
1007a5f9ecc4SMichael Mueller printf("\n/* CPU feature group enum type */\n"
1008a5f9ecc4SMichael Mueller "typedef enum {\n");
1009a5f9ecc4SMichael Mueller for (i = 0; i < ARRAY_SIZE(FeatGroupDef); i++) {
1010a5f9ecc4SMichael Mueller printf("\t%s,\n", FeatGroupDef[i].enum_name);
1011a5f9ecc4SMichael Mueller }
1012a5f9ecc4SMichael Mueller printf("\tS390_FEAT_GROUP_MAX,\n"
1013a5f9ecc4SMichael Mueller "} S390FeatGroup;\n");
1014a5f9ecc4SMichael Mueller }
1015a5f9ecc4SMichael Mueller
main(int argc,char * argv[])1016fcf5ef2aSThomas Huth int main(int argc, char *argv[])
1017fcf5ef2aSThomas Huth {
1018fcf5ef2aSThomas Huth printf("/*\n"
1019fcf5ef2aSThomas Huth " * AUTOMATICALLY GENERATED, DO NOT MODIFY HERE, EDIT\n"
1020fcf5ef2aSThomas Huth " * SOURCE FILE \"%s\" INSTEAD.\n"
1021fcf5ef2aSThomas Huth " *\n"
1022fcf5ef2aSThomas Huth " * Copyright %s IBM Corp.\n"
1023fcf5ef2aSThomas Huth " *\n"
1024fcf5ef2aSThomas Huth " * This work is licensed under the terms of the GNU GPL, "
1025fcf5ef2aSThomas Huth "version 2 or (at\n * your option) any later version. See "
1026fcf5ef2aSThomas Huth "the COPYING file in the top-level\n * directory.\n"
1027fcf5ef2aSThomas Huth " */\n\n"
1028fcf5ef2aSThomas Huth "#ifndef %s\n#define %s\n", __FILE__, _YEARS, _NAME_H, _NAME_H);
1029fcf5ef2aSThomas Huth print_feature_defs();
1030fcf5ef2aSThomas Huth print_feature_group_defs();
103135b4df64SDavid Hildenbrand print_qemu_feature_defs();
1032a5f9ecc4SMichael Mueller print_feature_group_enum_type();
1033fcf5ef2aSThomas Huth printf("\n#endif\n");
1034fcf5ef2aSThomas Huth return 0;
1035fcf5ef2aSThomas Huth }
1036