1 | /* |
2 | * RAW s390x CPU feature definitions: |
3 | * |
4 | * DEF_FEAT(_FEAT, _NAME, _TYPE, _BIT, _DESC): |
5 | * - _FEAT: Feature (enum) name used internally (S390_FEAT_##_FEAT) |
6 | * - _NAME: Feature name exposed to the user. |
7 | * - _TYPE: Feature type (S390_FEAT_TYPE_##_TYPE). |
8 | * - _BIT: Feature bit number within feature type block (unused for MISC). |
9 | * - _DESC: Feature description, exposed to the user. |
10 | * |
11 | * Copyright IBM Corp. 2016, 2018 |
12 | * Copyright Red Hat, Inc. 2019 |
13 | * |
14 | * Author(s): Michael Mueller <mimu@linux.vnet.ibm.com> |
15 | * David Hildenbrand <david@redhat.com> |
16 | * |
17 | * This work is licensed under the terms of the GNU GPL, version 2 or (at |
18 | * your option) any later version. See the COPYING file in the top-level |
19 | * directory. |
20 | */ |
21 | |
22 | /* Features exposed via the STFL(E) instruction. */ |
23 | DEF_FEAT(ESAN3, "esan3" , STFL, 0, "Instructions marked as n3" ) |
24 | DEF_FEAT(ZARCH, "zarch" , STFL, 1, "z/Architecture architectural mode" ) |
25 | DEF_FEAT(DAT_ENH, "dateh" , STFL, 3, "DAT-enhancement facility" ) |
26 | DEF_FEAT(IDTE_SEGMENT, "idtes" , STFL, 4, "IDTE selective TLB segment-table clearing" ) |
27 | DEF_FEAT(IDTE_REGION, "idter" , STFL, 5, "IDTE selective TLB region-table clearing" ) |
28 | DEF_FEAT(ASN_LX_REUSE, "asnlxr" , STFL, 6, "ASN-and-LX reuse facility" ) |
29 | DEF_FEAT(STFLE, "stfle" , STFL, 7, "Store-facility-list-extended facility" ) |
30 | DEF_FEAT(EDAT, "edat" , STFL, 8, "Enhanced-DAT facility" ) |
31 | DEF_FEAT(SENSE_RUNNING_STATUS, "srs" , STFL, 9, "Sense-running-status facility" ) |
32 | DEF_FEAT(CONDITIONAL_SSKE, "csske" , STFL, 10, "Conditional-SSKE facility" ) |
33 | DEF_FEAT(CONFIGURATION_TOPOLOGY, "ctop" , STFL, 11, "Configuration-topology facility" ) |
34 | DEF_FEAT(AP_QUERY_CONFIG_INFO, "apqci" , STFL, 12, "Query AP Configuration Information facility" ) |
35 | DEF_FEAT(IPTE_RANGE, "ipter" , STFL, 13, "IPTE-range facility" ) |
36 | DEF_FEAT(NONQ_KEY_SETTING, "nonqks" , STFL, 14, "Nonquiescing key-setting facility" ) |
37 | DEF_FEAT(AP_FACILITIES_TEST, "apft" , STFL, 15, "AP Facilities Test facility" ) |
38 | DEF_FEAT(EXTENDED_TRANSLATION_2, "etf2" , STFL, 16, "Extended-translation facility 2" ) |
39 | DEF_FEAT(MSA, "msa-base" , STFL, 17, "Message-security-assist facility (excluding subfunctions)" ) |
40 | DEF_FEAT(LONG_DISPLACEMENT, "ldisp" , STFL, 18, "Long-displacement facility" ) |
41 | DEF_FEAT(LONG_DISPLACEMENT_FAST, "ldisphp" , STFL, 19, "Long-displacement facility has high performance" ) |
42 | DEF_FEAT(HFP_MADDSUB, "hfpm" , STFL, 20, "HFP-multiply-add/subtract facility" ) |
43 | DEF_FEAT(EXTENDED_IMMEDIATE, "eimm" , STFL, 21, "Extended-immediate facility" ) |
44 | DEF_FEAT(EXTENDED_TRANSLATION_3, "etf3" , STFL, 22, "Extended-translation facility 3" ) |
45 | DEF_FEAT(HFP_UNNORMALIZED_EXT, "hfpue" , STFL, 23, "HFP-unnormalized-extension facility" ) |
46 | DEF_FEAT(ETF2_ENH, "etf2eh" , STFL, 24, "ETF2-enhancement facility" ) |
47 | DEF_FEAT(STORE_CLOCK_FAST, "stckf" , STFL, 25, "Store-clock-fast facility" ) |
48 | DEF_FEAT(PARSING_ENH, "parseh" , STFL, 26, "Parsing-enhancement facility" ) |
49 | DEF_FEAT(MOVE_WITH_OPTIONAL_SPEC, "mvcos" , STFL, 27, "Move-with-optional-specification facility" ) |
50 | DEF_FEAT(TOD_CLOCK_STEERING, "tods-base" , STFL, 28, "TOD-clock-steering facility (excluding subfunctions)" ) |
51 | DEF_FEAT(ETF3_ENH, "etf3eh" , STFL, 30, "ETF3-enhancement facility" ) |
52 | DEF_FEAT(EXTRACT_CPU_TIME, "ectg" , STFL, 31, "Extract-CPU-time facility" ) |
53 | DEF_FEAT(COMPARE_AND_SWAP_AND_STORE, "csst" , STFL, 32, "Compare-and-swap-and-store facility" ) |
54 | DEF_FEAT(COMPARE_AND_SWAP_AND_STORE_2, "csst2" , STFL, 33, "Compare-and-swap-and-store facility 2" ) |
55 | DEF_FEAT(GENERAL_INSTRUCTIONS_EXT, "ginste" , STFL, 34, "General-instructions-extension facility" ) |
56 | DEF_FEAT(EXECUTE_EXT, "exrl" , STFL, 35, "Execute-extensions facility" ) |
57 | DEF_FEAT(ENHANCED_MONITOR, "emon" , STFL, 36, "Enhanced-monitor facility" ) |
58 | DEF_FEAT(FLOATING_POINT_EXT, "fpe" , STFL, 37, "Floating-point extension facility" ) |
59 | DEF_FEAT(ORDER_PRESERVING_COMPRESSION, "opc" , STFL, 38, "Order Preserving Compression facility" ) |
60 | DEF_FEAT(SET_PROGRAM_PARAMETERS, "sprogp" , STFL, 40, "Set-program-parameters facility" ) |
61 | DEF_FEAT(FLOATING_POINT_SUPPPORT_ENH, "fpseh" , STFL, 41, "Floating-point-support-enhancement facilities" ) |
62 | DEF_FEAT(DFP, "dfp" , STFL, 42, "DFP (decimal-floating-point) facility" ) |
63 | DEF_FEAT(DFP_FAST, "dfphp" , STFL, 43, "DFP (decimal-floating-point) facility has high performance" ) |
64 | DEF_FEAT(PFPO, "pfpo" , STFL, 44, "PFPO instruction" ) |
65 | DEF_FEAT(STFLE_45, "stfle45" , STFL, 45, "Various facilities introduced with z196" ) |
66 | DEF_FEAT(CMPSC_ENH, "cmpsceh" , STFL, 47, "CMPSC-enhancement facility" ) |
67 | DEF_FEAT(DFP_ZONED_CONVERSION, "dfpzc" , STFL, 48, "Decimal-floating-point zoned-conversion facility" ) |
68 | DEF_FEAT(STFLE_49, "stfle49" , STFL, 49, "Various facilities introduced with zEC12" ) |
69 | DEF_FEAT(CONSTRAINT_TRANSACTIONAL_EXE, "cte" , STFL, 50, "Constrained transactional-execution facility" ) |
70 | DEF_FEAT(LOCAL_TLB_CLEARING, "ltlbc" , STFL, 51, "Local-TLB-clearing facility" ) |
71 | DEF_FEAT(INTERLOCKED_ACCESS_2, "iacc2" , STFL, 52, "Interlocked-access facility 2" ) |
72 | DEF_FEAT(STFLE_53, "stfle53" , STFL, 53, "Various facilities introduced with z13" ) |
73 | DEF_FEAT(ENTROPY_ENC_COMP, "eec" , STFL, 54, "Entropy encoding compression facility" ) |
74 | DEF_FEAT(MSA_EXT_5, "msa5-base" , STFL, 57, "Message-security-assist-extension-5 facility (excluding subfunctions)" ) |
75 | DEF_FEAT(MISC_INSTRUCTION_EXT, "minste2" , STFL, 58, "Miscellaneous-instruction-extensions facility 2" ) |
76 | DEF_FEAT(SEMAPHORE_ASSIST, "sema" , STFL, 59, "Semaphore-assist facility" ) |
77 | DEF_FEAT(TIME_SLICE_INSTRUMENTATION, "tsi" , STFL, 60, "Time-slice Instrumentation facility" ) |
78 | DEF_FEAT(MISC_INSTRUCTION_EXT3, "minste3" , STFL, 61, "Miscellaneous-Instruction-Extensions Facility 3" ) |
79 | DEF_FEAT(RUNTIME_INSTRUMENTATION, "ri" , STFL, 64, "CPU runtime-instrumentation facility" ) |
80 | DEF_FEAT(AP_QUEUE_INTERRUPT_CONTROL, "apqi" , STFL, 65, "AP-Queue interruption facility" ) |
81 | DEF_FEAT(ZPCI, "zpci" , STFL, 69, "z/PCI facility" ) |
82 | DEF_FEAT(ADAPTER_EVENT_NOTIFICATION, "aen" , STFL, 71, "General-purpose-adapter-event-notification facility" ) |
83 | DEF_FEAT(ADAPTER_INT_SUPPRESSION, "ais" , STFL, 72, "General-purpose-adapter-interruption-suppression facility" ) |
84 | DEF_FEAT(TRANSACTIONAL_EXE, "te" , STFL, 73, "Transactional-execution facility" ) |
85 | DEF_FEAT(STORE_HYPERVISOR_INFO, "sthyi" , STFL, 74, "Store-hypervisor-information facility" ) |
86 | DEF_FEAT(ACCESS_EXCEPTION_FS_INDICATION, "aefsi" , STFL, 75, "Access-exception-fetch/store-indication facility" ) |
87 | DEF_FEAT(MSA_EXT_3, "msa3-base" , STFL, 76, "Message-security-assist-extension-3 facility (excluding subfunctions)" ) |
88 | DEF_FEAT(MSA_EXT_4, "msa4-base" , STFL, 77, "Message-security-assist-extension-4 facility (excluding subfunctions)" ) |
89 | DEF_FEAT(EDAT_2, "edat2" , STFL, 78, "Enhanced-DAT facility 2" ) |
90 | DEF_FEAT(DFP_PACKED_CONVERSION, "dfppc" , STFL, 80, "Decimal-floating-point packed-conversion facility" ) |
91 | DEF_FEAT(PPA15, "ppa15" , STFL, 81, "PPA15 is installed" ) |
92 | DEF_FEAT(BPB, "bpb" , STFL, 82, "Branch prediction blocking" ) |
93 | DEF_FEAT(VECTOR, "vx" , STFL, 129, "Vector facility" ) |
94 | DEF_FEAT(INSTRUCTION_EXEC_PROT, "iep" , STFL, 130, "Instruction-execution-protection facility" ) |
95 | DEF_FEAT(SIDE_EFFECT_ACCESS_ESOP2, "sea_esop2" , STFL, 131, "Side-effect-access facility and Enhanced-suppression-on-protection facility 2" ) |
96 | DEF_FEAT(GUARDED_STORAGE, "gs" , STFL, 133, "Guarded-storage facility" ) |
97 | DEF_FEAT(VECTOR_PACKED_DECIMAL, "vxpd" , STFL, 134, "Vector packed decimal facility" ) |
98 | DEF_FEAT(VECTOR_ENH, "vxeh" , STFL, 135, "Vector enhancements facility" ) |
99 | DEF_FEAT(MULTIPLE_EPOCH, "mepoch" , STFL, 139, "Multiple-epoch facility" ) |
100 | DEF_FEAT(TEST_PENDING_EXT_INTERRUPTION, "tpei" , STFL, 144, "Test-pending-external-interruption facility" ) |
101 | DEF_FEAT(INSERT_REFERENCE_BITS_MULT, "irbm" , STFL, 145, "Insert-reference-bits-multiple facility" ) |
102 | DEF_FEAT(MSA_EXT_8, "msa8-base" , STFL, 146, "Message-security-assist-extension-8 facility (excluding subfunctions)" ) |
103 | DEF_FEAT(CMM_NT, "cmmnt" , STFL, 147, "CMM: ESSA-enhancement (no translate) facility" ) |
104 | DEF_FEAT(VECTOR_ENH2, "vxeh2" , STFL, 148, "Vector Enhancements facility 2" ) |
105 | DEF_FEAT(ESORT_BASE, "esort-base" , STFL, 150, "Enhanced-sort facility (excluding subfunctions)" ) |
106 | DEF_FEAT(DEFLATE_BASE, "deflate-base" , STFL, 151, "Deflate-conversion facility (excluding subfunctions)" ) |
107 | DEF_FEAT(VECTOR_PACKED_DECIMAL_ENH, "vxpdeh" , STFL, 152, "Vector-Packed-Decimal-Enhancement Facility" ) |
108 | DEF_FEAT(MSA_EXT_9, "msa9-base" , STFL, 155, "Message-security-assist-extension-9 facility (excluding subfunctions)" ) |
109 | DEF_FEAT(ETOKEN, "etoken" , STFL, 156, "Etoken facility" ) |
110 | |
111 | /* Features exposed via SCLP SCCB Byte 80 - 98 (bit numbers relative to byte-80) */ |
112 | DEF_FEAT(SIE_GSLS, "gsls" , SCLP_CONF_CHAR, 40, "SIE: Guest-storage-limit-suppression facility" ) |
113 | DEF_FEAT(ESOP, "esop" , SCLP_CONF_CHAR, 46, "Enhanced-suppression-on-protection facility" ) |
114 | DEF_FEAT(HPMA2, "hpma2" , SCLP_CONF_CHAR, 90, "Host page management assist 2 Facility" ) /* 91-2 */ |
115 | DEF_FEAT(SIE_KSS, "kss" , SCLP_CONF_CHAR, 151, "SIE: Keyless-subset facility" ) /* 98-7 */ |
116 | |
117 | /* Features exposed via SCLP SCCB Byte 116 - 119 (bit numbers relative to byte-116) */ |
118 | DEF_FEAT(SIE_64BSCAO, "64bscao" , SCLP_CONF_CHAR_EXT, 0, "SIE: 64-bit-SCAO facility" ) |
119 | DEF_FEAT(SIE_CMMA, "cmma" , SCLP_CONF_CHAR_EXT, 1, "SIE: Collaborative-memory-management assist" ) |
120 | DEF_FEAT(SIE_PFMFI, "pfmfi" , SCLP_CONF_CHAR_EXT, 9, "SIE: PFMF interpretation facility" ) |
121 | DEF_FEAT(SIE_IBS, "ibs" , SCLP_CONF_CHAR_EXT, 10, "SIE: Interlock-and-broadcast-suppression facility" ) |
122 | |
123 | /* Features exposed via SCLP CPU info. */ |
124 | DEF_FEAT(SIE_F2, "sief2" , SCLP_CPU, 4, "SIE: interception format 2 (Virtual SIE)" ) |
125 | DEF_FEAT(SIE_SKEY, "skey" , SCLP_CPU, 5, "SIE: Storage-key facility" ) |
126 | DEF_FEAT(SIE_GPERE, "gpereh" , SCLP_CPU, 10, "SIE: Guest-PER enhancement facility" ) |
127 | DEF_FEAT(SIE_SIIF, "siif" , SCLP_CPU, 11, "SIE: Shared IPTE-interlock facility" ) |
128 | DEF_FEAT(SIE_SIGPIF, "sigpif" , SCLP_CPU, 12, "SIE: SIGP interpretation facility" ) |
129 | DEF_FEAT(SIE_IB, "ib" , SCLP_CPU, 42, "SIE: Intervention bypass facility" ) |
130 | DEF_FEAT(SIE_CEI, "cei" , SCLP_CPU, 43, "SIE: Conditional-external-interception facility" ) |
131 | |
132 | /* |
133 | * Features exposed via no feature bit (but e.g., instruction sensing) |
134 | * -> the feature bit number is irrelavant |
135 | */ |
136 | DEF_FEAT(DAT_ENH_2, "dateh2" , MISC, 0, "DAT-enhancement facility 2" ) |
137 | DEF_FEAT(CMM, "cmm" , MISC, 0, "Collaborative-memory-management facility" ) |
138 | DEF_FEAT(AP, "ap" , MISC, 0, "AP instructions installed" ) |
139 | |
140 | /* Features exposed via the PLO instruction. */ |
141 | DEF_FEAT(PLO_CL, "plo-cl" , PLO, 0, "PLO Compare and load (32 bit in general registers)" ) |
142 | DEF_FEAT(PLO_CLG, "plo-clg" , PLO, 1, "PLO Compare and load (64 bit in parameter list)" ) |
143 | DEF_FEAT(PLO_CLGR, "plo-clgr" , PLO, 2, "PLO Compare and load (32 bit in general registers)" ) |
144 | DEF_FEAT(PLO_CLX, "plo-clx" , PLO, 3, "PLO Compare and load (128 bit in parameter list)" ) |
145 | DEF_FEAT(PLO_CS, "plo-cs" , PLO, 4, "PLO Compare and swap (32 bit in general registers)" ) |
146 | DEF_FEAT(PLO_CSG, "plo-csg" , PLO, 5, "PLO Compare and swap (64 bit in parameter list)" ) |
147 | DEF_FEAT(PLO_CSGR, "plo-csgr" , PLO, 6, "PLO Compare and swap (32 bit in general registers)" ) |
148 | DEF_FEAT(PLO_CSX, "plo-csx" , PLO, 7, "PLO Compare and swap (128 bit in parameter list)" ) |
149 | DEF_FEAT(PLO_DCS, "plo-dcs" , PLO, 8, "PLO Double compare and swap (32 bit in general registers)" ) |
150 | DEF_FEAT(PLO_DCSG, "plo-dcsg" , PLO, 9, "PLO Double compare and swap (64 bit in parameter list)" ) |
151 | DEF_FEAT(PLO_DCSGR, "plo-dcsgr" , PLO, 10, "PLO Double compare and swap (32 bit in general registers)" ) |
152 | DEF_FEAT(PLO_DCSX, "plo-dcsx" , PLO, 11, "PLO Double compare and swap (128 bit in parameter list)" ) |
153 | DEF_FEAT(PLO_CSST, "plo-csst" , PLO, 12, "PLO Compare and swap and store (32 bit in general registers)" ) |
154 | DEF_FEAT(PLO_CSSTG, "plo-csstg" , PLO, 13, "PLO Compare and swap and store (64 bit in parameter list)" ) |
155 | DEF_FEAT(PLO_CSSTGR, "plo-csstgr" , PLO, 14, "PLO Compare and swap and store (32 bit in general registers)" ) |
156 | DEF_FEAT(PLO_CSSTX, "plo-csstx" , PLO, 15, "PLO Compare and swap and store (128 bit in parameter list)" ) |
157 | DEF_FEAT(PLO_CSDST, "plo-csdst" , PLO, 16, "PLO Compare and swap and double store (32 bit in general registers)" ) |
158 | DEF_FEAT(PLO_CSDSTG, "plo-csdstg" , PLO, 17, "PLO Compare and swap and double store (64 bit in parameter list)" ) |
159 | DEF_FEAT(PLO_CSDSTGR, "plo-csdstgr" , PLO, 18, "PLO Compare and swap and double store (32 bit in general registers)" ) |
160 | DEF_FEAT(PLO_CSDSTX, "plo-csdstx" , PLO, 19, "PLO Compare and swap and double store (128 bit in parameter list)" ) |
161 | DEF_FEAT(PLO_CSTST, "plo-cstst" , PLO, 20, "PLO Compare and swap and triple store (32 bit in general registers)" ) |
162 | DEF_FEAT(PLO_CSTSTG, "plo-cststg" , PLO, 21, "PLO Compare and swap and triple store (64 bit in parameter list)" ) |
163 | DEF_FEAT(PLO_CSTSTGR, "plo-cststgr" , PLO, 22, "PLO Compare and swap and triple store (32 bit in general registers)" ) |
164 | DEF_FEAT(PLO_CSTSTX, "plo-cststx" , PLO, 23, "PLO Compare and swap and triple store (128 bit in parameter list)" ) |
165 | |
166 | /* Features exposed via the PTFF instruction. */ |
167 | DEF_FEAT(PTFF_QTO, "ptff-qto" , PTFF, 1, "PTFF Query TOD Offset" ) |
168 | DEF_FEAT(PTFF_QSI, "ptff-qsi" , PTFF, 2, "PTFF Query Steering Information" ) |
169 | DEF_FEAT(PTFF_QPT, "ptff-qpc" , PTFF, 3, "PTFF Query Physical Clock" ) |
170 | DEF_FEAT(PTFF_QUI, "ptff-qui" , PTFF, 4, "PTFF Query UTC Information" ) |
171 | DEF_FEAT(PTFF_QTOU, "ptff-qtou" , PTFF, 5, "PTFF Query TOD Offset User" ) |
172 | DEF_FEAT(PTFF_QSIE, "ptff-qsie" , PTFF, 10, "PTFF Query Steering Information Extended" ) |
173 | DEF_FEAT(PTFF_QTOUE, "ptff-qtoue" , PTFF, 13, "PTFF Query TOD Offset User Extended" ) |
174 | DEF_FEAT(PTFF_STO, "ptff-sto" , PTFF, 65, "PTFF Set TOD Offset" ) |
175 | DEF_FEAT(PTFF_STOU, "ptff-stou" , PTFF, 69, "PTFF Set TOD Offset User" ) |
176 | DEF_FEAT(PTFF_STOE, "ptff-stoe" , PTFF, 73, "PTFF Set TOD Offset Extended" ) |
177 | DEF_FEAT(PTFF_STOUE, "ptff-stoue" , PTFF, 77, "PTFF Set TOD Offset User Extended" ) |
178 | |
179 | /* Features exposed via the KMAC instruction. */ |
180 | DEF_FEAT(KMAC_DEA, "kmac-dea" , KMAC, 1, "KMAC DEA" ) |
181 | DEF_FEAT(KMAC_TDEA_128, "kmac-tdea-128" , KMAC, 2, "KMAC TDEA-128" ) |
182 | DEF_FEAT(KMAC_TDEA_192, "kmac-tdea-192" , KMAC, 3, "KMAC TDEA-192" ) |
183 | DEF_FEAT(KMAC_EDEA, "kmac-edea" , KMAC, 9, "KMAC Encrypted-DEA" ) |
184 | DEF_FEAT(KMAC_ETDEA_128, "kmac-etdea-128" , KMAC, 10, "KMAC Encrypted-TDEA-128" ) |
185 | DEF_FEAT(KMAC_ETDEA_192, "kmac-etdea-192" , KMAC, 11, "KMAC Encrypted-TDEA-192" ) |
186 | DEF_FEAT(KMAC_AES_128, "kmac-aes-128" , KMAC, 18, "KMAC AES-128" ) |
187 | DEF_FEAT(KMAC_AES_192, "kmac-aes-192" , KMAC, 19, "KMAC AES-192" ) |
188 | DEF_FEAT(KMAC_AES_256, "kmac-aes-256" , KMAC, 20, "KMAC AES-256" ) |
189 | DEF_FEAT(KMAC_EAES_128, "kmac-eaes-128" , KMAC, 26, "KMAC Encrypted-AES-128" ) |
190 | DEF_FEAT(KMAC_EAES_192, "kmac-eaes-192" , KMAC, 27, "KMAC Encrypted-AES-192" ) |
191 | DEF_FEAT(KMAC_EAES_256, "kmac-eaes-256" , KMAC, 28, "KMAC Encrypted-AES-256" ) |
192 | |
193 | /* Features exposed via the KMC instruction. */ |
194 | DEF_FEAT(KMC_DEA, "kmc-dea" , KMC, 1, "KMC DEA" ) |
195 | DEF_FEAT(KMC_TDEA_128, "kmc-tdea-128" , KMC, 2, "KMC TDEA-128" ) |
196 | DEF_FEAT(KMC_TDEA_192, "kmc-tdea-192" , KMC, 3, "KMC TDEA-192" ) |
197 | DEF_FEAT(KMC_EDEA, "kmc-edea" , KMC, 9, "KMC Encrypted-DEA" ) |
198 | DEF_FEAT(KMC_ETDEA_128, "kmc-etdea-128" , KMC, 10, "KMC Encrypted-TDEA-128" ) |
199 | DEF_FEAT(KMC_ETDEA_192, "kmc-etdea-192" , KMC, 11, "KMC Encrypted-TDEA-192" ) |
200 | DEF_FEAT(KMC_AES_128, "kmc-aes-128" , KMC, 18, "KMC AES-128" ) |
201 | DEF_FEAT(KMC_AES_192, "kmc-aes-192" , KMC, 19, "KMC AES-192" ) |
202 | DEF_FEAT(KMC_AES_256, "kmc-aes-256" , KMC, 20, "KMC AES-256" ) |
203 | DEF_FEAT(KMC_EAES_128, "kmc-eaes-128" , KMC, 26, "KMC Encrypted-AES-128" ) |
204 | DEF_FEAT(KMC_EAES_192, "kmc-eaes-192" , KMC, 27, "KMC Encrypted-AES-192" ) |
205 | DEF_FEAT(KMC_EAES_256, "kmc-eaes-256" , KMC, 28, "KMC Encrypted-AES-256" ) |
206 | DEF_FEAT(KMC_PRNG, "kmc-prng" , KMC, 67, "KMC PRNG" ) |
207 | |
208 | /* Features exposed via the KM instruction. */ |
209 | DEF_FEAT(KM_DEA, "km-dea" , KM, 1, "KM DEA" ) |
210 | DEF_FEAT(KM_TDEA_128, "km-tdea-128" , KM, 2, "KM TDEA-128" ) |
211 | DEF_FEAT(KM_TDEA_192, "km-tdea-192" , KM, 3, "KM TDEA-192" ) |
212 | DEF_FEAT(KM_EDEA, "km-edea" , KM, 9, "KM Encrypted-DEA" ) |
213 | DEF_FEAT(KM_ETDEA_128, "km-etdea-128" , KM, 10, "KM Encrypted-TDEA-128" ) |
214 | DEF_FEAT(KM_ETDEA_192, "km-etdea-192" , KM, 11, "KM Encrypted-TDEA-192" ) |
215 | DEF_FEAT(KM_AES_128, "km-aes-128" , KM, 18, "KM AES-128" ) |
216 | DEF_FEAT(KM_AES_192, "km-aes-192" , KM, 19, "KM AES-192" ) |
217 | DEF_FEAT(KM_AES_256, "km-aes-256" , KM, 20, "KM AES-256" ) |
218 | DEF_FEAT(KM_EAES_128, "km-eaes-128" , KM, 26, "KM Encrypted-AES-128" ) |
219 | DEF_FEAT(KM_EAES_192, "km-eaes-192" , KM, 27, "KM Encrypted-AES-192" ) |
220 | DEF_FEAT(KM_EAES_256, "km-eaes-256" , KM, 28, "KM Encrypted-AES-256" ) |
221 | DEF_FEAT(KM_XTS_AES_128, "km-xts-aes-128" , KM, 50, "KM XTS-AES-128" ) |
222 | DEF_FEAT(KM_XTS_AES_256, "km-xts-aes-256" , KM, 52, "KM XTS-AES-256" ) |
223 | DEF_FEAT(KM_XTS_EAES_128, "km-xts-eaes-128" , KM, 58, "KM XTS-Encrypted-AES-128" ) |
224 | DEF_FEAT(KM_XTS_EAES_256, "km-xts-eaes-256" , KM, 60, "KM XTS-Encrypted-AES-256" ) |
225 | |
226 | /* Features exposed via the KIMD instruction. */ |
227 | DEF_FEAT(KIMD_SHA_1, "kimd-sha-1" , KIMD, 1, "KIMD SHA-1" ) |
228 | DEF_FEAT(KIMD_SHA_256, "kimd-sha-256" , KIMD, 2, "KIMD SHA-256" ) |
229 | DEF_FEAT(KIMD_SHA_512, "kimd-sha-512" , KIMD, 3, "KIMD SHA-512" ) |
230 | DEF_FEAT(KIMD_SHA3_224, "kimd-sha3-224" , KIMD, 32, "KIMD SHA3-224" ) |
231 | DEF_FEAT(KIMD_SHA3_256, "kimd-sha3-256" , KIMD, 33, "KIMD SHA3-256" ) |
232 | DEF_FEAT(KIMD_SHA3_384, "kimd-sha3-384" , KIMD, 34, "KIMD SHA3-384" ) |
233 | DEF_FEAT(KIMD_SHA3_512, "kimd-sha3-512" , KIMD, 35, "KIMD SHA3-512" ) |
234 | DEF_FEAT(KIMD_SHAKE_128, "kimd-shake-128" , KIMD, 36, "KIMD SHAKE-128" ) |
235 | DEF_FEAT(KIMD_SHAKE_256, "kimd-shake-256" , KIMD, 37, "KIMD SHAKE-256" ) |
236 | DEF_FEAT(KIMD_GHASH, "kimd-ghash" , KIMD, 65, "KIMD GHASH" ) |
237 | |
238 | /* Features exposed via the KLMD instruction. */ |
239 | DEF_FEAT(KLMD_SHA_1, "klmd-sha-1" , KLMD, 1, "KLMD SHA-1" ) |
240 | DEF_FEAT(KLMD_SHA_256, "klmd-sha-256" , KLMD, 2, "KLMD SHA-256" ) |
241 | DEF_FEAT(KLMD_SHA_512, "klmd-sha-512" , KLMD, 3, "KLMD SHA-512" ) |
242 | DEF_FEAT(KLMD_SHA3_224, "klmd-sha3-224" , KLMD, 32, "KLMD SHA3-224" ) |
243 | DEF_FEAT(KLMD_SHA3_256, "klmd-sha3-256" , KLMD, 33, "KLMD SHA3-256" ) |
244 | DEF_FEAT(KLMD_SHA3_384, "klmd-sha3-384" , KLMD, 34, "KLMD SHA3-384" ) |
245 | DEF_FEAT(KLMD_SHA3_512, "klmd-sha3-512" , KLMD, 35, "KLMD SHA3-512" ) |
246 | DEF_FEAT(KLMD_SHAKE_128, "klmd-shake-128" , KLMD, 36, "KLMD SHAKE-128" ) |
247 | DEF_FEAT(KLMD_SHAKE_256, "klmd-shake-256" , KLMD, 37, "KLMD SHAKE-256" ) |
248 | |
249 | /* Features exposed via the PCKMO instruction. */ |
250 | DEF_FEAT(PCKMO_EDEA, "pckmo-edea" , PCKMO, 1, "PCKMO Encrypted-DEA-Key" ) |
251 | DEF_FEAT(PCKMO_ETDEA_128, "pckmo-etdea-128" , PCKMO, 2, "PCKMO Encrypted-TDEA-128-Key" ) |
252 | DEF_FEAT(PCKMO_ETDEA_256, "pckmo-etdea-192" , PCKMO, 3, "PCKMO Encrypted-TDEA-192-Key" ) |
253 | DEF_FEAT(PCKMO_AES_128, "pckmo-aes-128" , PCKMO, 18, "PCKMO Encrypted-AES-128-Key" ) |
254 | DEF_FEAT(PCKMO_AES_192, "pckmo-aes-192" , PCKMO, 19, "PCKMO Encrypted-AES-192-Key" ) |
255 | DEF_FEAT(PCKMO_AES_256, "pckmo-aes-256" , PCKMO, 20, "PCKMO Encrypted-AES-256-Key" ) |
256 | DEF_FEAT(PCKMO_ECC_P256, "pckmo-ecc-p256" , PCKMO, 32, "PCKMO Encrypt-ECC-P256-Key" ) |
257 | DEF_FEAT(PCKMO_ECC_P384, "pckmo-ecc-p384" , PCKMO, 33, "PCKMO Encrypt-ECC-P384-Key" ) |
258 | DEF_FEAT(PCKMO_ECC_P521, "pckmo-ecc-p521" , PCKMO, 34, "PCKMO Encrypt-ECC-P521-Key" ) |
259 | DEF_FEAT(PCKMO_ECC_ED25519, "pckmo-ecc-ed25519" , PCKMO, 40 , "PCKMO Encrypt-ECC-Ed25519-Key" ) |
260 | DEF_FEAT(PCKMO_ECC_ED448, "pckmo-ecc-ed448" , PCKMO, 41 , "PCKMO Encrypt-ECC-Ed448-Key" ) |
261 | |
262 | /* Features exposed via the KMCTR instruction. */ |
263 | DEF_FEAT(KMCTR_DEA, "kmctr-dea" , KMCTR, 1, "KMCTR DEA" ) |
264 | DEF_FEAT(KMCTR_TDEA_128, "kmctr-tdea-128" , KMCTR, 2, "KMCTR TDEA-128" ) |
265 | DEF_FEAT(KMCTR_TDEA_192, "kmctr-tdea-192" , KMCTR, 3, "KMCTR TDEA-192" ) |
266 | DEF_FEAT(KMCTR_EDEA, "kmctr-edea" , KMCTR, 9, "KMCTR Encrypted-DEA" ) |
267 | DEF_FEAT(KMCTR_ETDEA_128, "kmctr-etdea-128" , KMCTR, 10, "KMCTR Encrypted-TDEA-128" ) |
268 | DEF_FEAT(KMCTR_ETDEA_192, "kmctr-etdea-192" , KMCTR, 11, "KMCTR Encrypted-TDEA-192" ) |
269 | DEF_FEAT(KMCTR_AES_128, "kmctr-aes-128" , KMCTR, 18, "KMCTR AES-128" ) |
270 | DEF_FEAT(KMCTR_AES_192, "kmctr-aes-192" , KMCTR, 19, "KMCTR AES-192" ) |
271 | DEF_FEAT(KMCTR_AES_256, "kmctr-aes-256" , KMCTR, 20, "KMCTR AES-256" ) |
272 | DEF_FEAT(KMCTR_EAES_128, "kmctr-eaes-128" , KMCTR, 26, "KMCTR Encrypted-AES-128" ) |
273 | DEF_FEAT(KMCTR_EAES_192, "kmctr-eaes-192" , KMCTR, 27, "KMCTR Encrypted-AES-192" ) |
274 | DEF_FEAT(KMCTR_EAES_256, "kmctr-eaes-256" , KMCTR, 28, "KMCTR Encrypted-AES-256" ) |
275 | |
276 | /* Features exposed via the KMF instruction. */ |
277 | DEF_FEAT(KMF_DEA, "kmf-dea" , KMF, 1, "KMF DEA" ) |
278 | DEF_FEAT(KMF_TDEA_128, "kmf-tdea-128" , KMF, 2, "KMF TDEA-128" ) |
279 | DEF_FEAT(KMF_TDEA_192, "kmf-tdea-192" , KMF, 3, "KMF TDEA-192" ) |
280 | DEF_FEAT(KMF_EDEA, "kmf-edea" , KMF, 9, "KMF Encrypted-DEA" ) |
281 | DEF_FEAT(KMF_ETDEA_128, "kmf-etdea-128" , KMF, 10, "KMF Encrypted-TDEA-128" ) |
282 | DEF_FEAT(KMF_ETDEA_192, "kmf-etdea-192" , KMF, 11, "KMF Encrypted-TDEA-192" ) |
283 | DEF_FEAT(KMF_AES_128, "kmf-aes-128" , KMF, 18, "KMF AES-128" ) |
284 | DEF_FEAT(KMF_AES_192, "kmf-aes-192" , KMF, 19, "KMF AES-192" ) |
285 | DEF_FEAT(KMF_AES_256, "kmf-aes-256" , KMF, 20, "KMF AES-256" ) |
286 | DEF_FEAT(KMF_EAES_128, "kmf-eaes-128" , KMF, 26, "KMF Encrypted-AES-128" ) |
287 | DEF_FEAT(KMF_EAES_192, "kmf-eaes-192" , KMF, 27, "KMF Encrypted-AES-192" ) |
288 | DEF_FEAT(KMF_EAES_256, "kmf-eaes-256" , KMF, 28, "KMF Encrypted-AES-256" ) |
289 | |
290 | /* Features exposed via the KMO instruction. */ |
291 | DEF_FEAT(KMO_DEA, "kmo-dea" , KMO, 1, "KMO DEA" ) |
292 | DEF_FEAT(KMO_TDEA_128, "kmo-tdea-128" , KMO, 2, "KMO TDEA-128" ) |
293 | DEF_FEAT(KMO_TDEA_192, "kmo-tdea-192" , KMO, 3, "KMO TDEA-192" ) |
294 | DEF_FEAT(KMO_EDEA, "kmo-edea" , KMO, 9, "KMO Encrypted-DEA" ) |
295 | DEF_FEAT(KMO_ETDEA_128, "kmo-etdea-128" , KMO, 10, "KMO Encrypted-TDEA-128" ) |
296 | DEF_FEAT(KMO_ETDEA_192, "kmo-etdea-192" , KMO, 11, "KMO Encrypted-TDEA-192" ) |
297 | DEF_FEAT(KMO_AES_128, "kmo-aes-128" , KMO, 18, "KMO AES-128" ) |
298 | DEF_FEAT(KMO_AES_192, "kmo-aes-192" , KMO, 19, "KMO AES-192" ) |
299 | DEF_FEAT(KMO_AES_256, "kmo-aes-256" , KMO, 20, "KMO AES-256" ) |
300 | DEF_FEAT(KMO_EAES_128, "kmo-eaes-128" , KMO, 26, "KMO Encrypted-AES-128" ) |
301 | DEF_FEAT(KMO_EAES_192, "kmo-eaes-192" , KMO, 27, "KMO Encrypted-AES-192" ) |
302 | DEF_FEAT(KMO_EAES_256, "kmo-eaes-256" , KMO, 28, "KMO Encrypted-AES-256" ) |
303 | |
304 | /* Features exposed via the PCC instruction. */ |
305 | DEF_FEAT(PCC_CMAC_DEA, "pcc-cmac-dea" , PCC, 1, "PCC Compute-Last-Block-CMAC-Using-DEA" ) |
306 | DEF_FEAT(PCC_CMAC_TDEA_128, "pcc-cmac-tdea-128" , PCC, 2, "PCC Compute-Last-Block-CMAC-Using-TDEA-128" ) |
307 | DEF_FEAT(PCC_CMAC_TDEA_192, "pcc-cmac-tdea-192" , PCC, 3, "PCC Compute-Last-Block-CMAC-Using-TDEA-192" ) |
308 | DEF_FEAT(PCC_CMAC_ETDEA_128, "pcc-cmac-edea" , PCC, 9, "PCC Compute-Last-Block-CMAC-Using-Encrypted-DEA" ) |
309 | DEF_FEAT(PCC_CMAC_ETDEA_192, "pcc-cmac-etdea-128" , PCC, 10, "PCC Compute-Last-Block-CMAC-Using-Encrypted-TDEA-128" ) |
310 | DEF_FEAT(PCC_CMAC_TDEA, "pcc-cmac-etdea-192" , PCC, 11, "PCC Compute-Last-Block-CMAC-Using-EncryptedTDEA-192" ) |
311 | DEF_FEAT(PCC_CMAC_AES_128, "pcc-cmac-aes-128" , PCC, 18, "PCC Compute-Last-Block-CMAC-Using-AES-128" ) |
312 | DEF_FEAT(PCC_CMAC_AES_192, "pcc-cmac-aes-192" , PCC, 19, "PCC Compute-Last-Block-CMAC-Using-AES-192" ) |
313 | DEF_FEAT(PCC_CMAC_AES_256, "pcc-cmac-eaes-256" , PCC, 20, "PCC Compute-Last-Block-CMAC-Using-AES-256" ) |
314 | DEF_FEAT(PCC_CMAC_EAES_128, "pcc-cmac-eaes-128" , PCC, 26, "PCC Compute-Last-Block-CMAC-Using-Encrypted-AES-128" ) |
315 | DEF_FEAT(PCC_CMAC_EAES_192, "pcc-cmac-eaes-192" , PCC, 27, "PCC Compute-Last-Block-CMAC-Using-Encrypted-AES-192" ) |
316 | DEF_FEAT(PCC_CMAC_EAES_256, "pcc-cmac-eaes-256" , PCC, 28, "PCC Compute-Last-Block-CMAC-Using-Encrypted-AES-256" ) |
317 | DEF_FEAT(PCC_XTS_AES_128, "pcc-xts-aes-128" , PCC, 50, "PCC Compute-XTS-Parameter-Using-AES-128" ) |
318 | DEF_FEAT(PCC_XTS_AES_256, "pcc-xts-aes-256" , PCC, 52, "PCC Compute-XTS-Parameter-Using-AES-256" ) |
319 | DEF_FEAT(PCC_XTS_EAES_128, "pcc-xts-eaes-128" , PCC, 58, "PCC Compute-XTS-Parameter-Using-Encrypted-AES-128" ) |
320 | DEF_FEAT(PCC_XTS_EAES_256, "pcc-xts-eaes-256" , PCC, 60, "PCC Compute-XTS-Parameter-Using-Encrypted-AES-256" ) |
321 | DEF_FEAT(PCC_SCALAR_MULT_P256, "pcc-scalar-mult-p256" , PCC, 64, "PCC Scalar-Multiply-P256" ) |
322 | DEF_FEAT(PCC_SCALAR_MULT_P384, "pcc-scalar-mult-p384" , PCC, 65, "PCC Scalar-Multiply-P384" ) |
323 | DEF_FEAT(PCC_SCALAR_MULT_P512, "pcc-scalar-mult-p521" , PCC, 66, "PCC Scalar-Multiply-P521" ) |
324 | DEF_FEAT(PCC_SCALAR_MULT_ED25519, "pcc-scalar-mult-ed25519" , PCC, 72, "PCC Scalar-Multiply-Ed25519" ) |
325 | DEF_FEAT(PCC_SCALAR_MULT_ED448, "pcc-scalar-mult-ed448" , PCC, 73, "PCC Scalar-Multiply-Ed448" ) |
326 | DEF_FEAT(PCC_SCALAR_MULT_X25519, "pcc-scalar-mult-x25519" , PCC, 80, "PCC Scalar-Multiply-X25519" ) |
327 | DEF_FEAT(PCC_SCALAR_MULT_X448, "pcc-scalar-mult-x448" , PCC, 81, "PCC Scalar-Multiply-X448" ) |
328 | |
329 | /* Features exposed via the PPNO/PRNO instruction. */ |
330 | DEF_FEAT(PPNO_SHA_512_DRNG, "ppno-sha-512-drng" , PPNO, 3, "PPNO SHA-512-DRNG" ) |
331 | DEF_FEAT(PRNO_TRNG_QRTCR, "prno-trng-qrtcr" , PPNO, 112, "PRNO TRNG-Query-Raw-to-Conditioned-Ratio" ) |
332 | DEF_FEAT(PRNO_TRNG, "prno-trng" , PPNO, 114, "PRNO TRNG" ) |
333 | |
334 | /* Features exposed via the KMA instruction. */ |
335 | DEF_FEAT(KMA_GCM_AES_128, "kma-gcm-aes-128" , KMA, 18, "KMA GCM-AES-128" ) |
336 | DEF_FEAT(KMA_GCM_AES_192, "kma-gcm-aes-192" , KMA, 19, "KMA GCM-AES-192" ) |
337 | DEF_FEAT(KMA_GCM_AES_256, "kma-gcm-aes-256" , KMA, 20, "KMA GCM-AES-256" ) |
338 | DEF_FEAT(KMA_GCM_EAES_128, "kma-gcm-eaes-128" , KMA, 26, "KMA GCM-Encrypted-AES-128" ) |
339 | DEF_FEAT(KMA_GCM_EAES_192, "kma-gcm-eaes-192" , KMA, 27, "KMA GCM-Encrypted-AES-192" ) |
340 | DEF_FEAT(KMA_GCM_EAES_256, "kma-gcm-eaes-256" , KMA, 28, "KMA GCM-Encrypted-AES-256" ) |
341 | |
342 | /* Features exposed via the KDSA instruction. */ |
343 | DEF_FEAT(KDSA_ECDSA_VERIFY_P256, "kdsa-ecdsa-verify-p256" , KDSA, 1, "KDSA ECDSA-Verify-P256" ) |
344 | DEF_FEAT(KDSA_ECDSA_VERIFY_P384, "kdsa-ecdsa-verify-p384" , KDSA, 2, "KDSA ECDSA-Verify-P384" ) |
345 | DEF_FEAT(KDSA_ECDSA_VERIFY_P512, "kdsa-ecdsa-verify-p521" , KDSA, 3, "KDSA ECDSA-Verify-P521" ) |
346 | DEF_FEAT(KDSA_ECDSA_SIGN_P256, "kdsa-ecdsa-sign-p256" , KDSA, 9, "KDSA ECDSA-Sign-P256" ) |
347 | DEF_FEAT(KDSA_ECDSA_SIGN_P384, "kdsa-ecdsa-sign-p384" , KDSA, 10, "KDSA ECDSA-Sign-P384" ) |
348 | DEF_FEAT(KDSA_ECDSA_SIGN_P512, "kdsa-ecdsa-sign-p521" , KDSA, 11, "KDSA ECDSA-Sign-P521" ) |
349 | DEF_FEAT(KDSA_EECDSA_SIGN_P256, "kdsa-eecdsa-sign-p256" , KDSA, 17, "KDSA Encrypted-ECDSA-Sign-P256" ) |
350 | DEF_FEAT(KDSA_EECDSA_SIGN_P384, "kdsa-eecdsa-sign-p384" , KDSA, 18, "KDSA Encrypted-ECDSA-Sign-P384" ) |
351 | DEF_FEAT(KDSA_EECDSA_SIGN_P512, "kdsa-eecdsa-sign-p521" , KDSA, 19, "KDSA Encrypted-ECDSA-Sign-P521" ) |
352 | DEF_FEAT(KDSA_EDDSA_VERIFY_ED25519, "kdsa-eddsa-verify-ed25519" , KDSA, 32, "KDSA EdDSA-Verify-Ed25519" ) |
353 | DEF_FEAT(KDSA_EDDSA_VERIFY_ED448, "kdsa-eddsa-verify-ed448" , KDSA, 36, "KDSA EdDSA-Verify-Ed448" ) |
354 | DEF_FEAT(KDSA_EDDSA_SIGN_ED25519, "kdsa-eddsa-sign-ed25519" , KDSA, 40, "KDSA EdDSA-Sign-Ed25519" ) |
355 | DEF_FEAT(KDSA_EDDSA_SIGN_ED448, "kdsa-eddsa-sign-ed448" , KDSA, 44, "KDSA EdDSA-Sign-Ed448" ) |
356 | DEF_FEAT(KDSA_EEDDSA_SIGN_ED25519, "kdsa-eeddsa-sign-ed25519" , KDSA, 48, "KDSA Encrypted-EdDSA-Sign-Ed25519" ) |
357 | DEF_FEAT(KDSA_EEDDSA_SIGN_ED448, "kdsa-eeddsa-sign-ed448" , KDSA, 52, "KDSA Encrypted-EdDSA-Sign-Ed448" ) |
358 | |
359 | /* Features exposed via the SORTL instruction. */ |
360 | DEF_FEAT(SORTL_SFLR, "sortl-sflr" , SORTL, 1, "SORTL SFLR" ) |
361 | DEF_FEAT(SORTL_SVLR, "sortl-svlr" , SORTL, 2, "SORTL SVLR" ) |
362 | DEF_FEAT(SORTL_32, "sortl-32" , SORTL, 130, "SORTL 32 input lists" ) |
363 | DEF_FEAT(SORTL_128, "sortl-128" , SORTL, 132, "SORTL 128 input lists" ) |
364 | DEF_FEAT(SORTL_F0, "sortl-f0" , SORTL, 192, "SORTL format 0 parameter-block" ) |
365 | |
366 | /* Features exposed via the DEFLATE instruction. */ |
367 | DEF_FEAT(DEFLATE_GHDT, "dfltcc-gdht" , DFLTCC, 1, "DFLTCC GDHT" ) |
368 | DEF_FEAT(DEFLATE_CMPR, "dfltcc-cmpr" , DFLTCC, 2, "DFLTCC CMPR" ) |
369 | DEF_FEAT(DEFLATE_XPND, "dfltcc-xpnd" , DFLTCC, 4, "DFLTCC XPND" ) |
370 | DEF_FEAT(DEFLATE_F0, "dfltcc-f0" , DFLTCC, 192, "DFLTCC format 0 parameter-block" ) |
371 | |