2 * RAW s390x CPU feature definitions:
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.
11 * Copyright IBM Corp. 2016, 2018
12 * Copyright Red Hat, Inc. 2019
14 * Author(s): Michael Mueller <mimu@linux.vnet.ibm.com>
15 * David Hildenbrand <david@redhat.com>
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
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 DEF_FEAT(UNPACK
, "unpack", STFL
, 161, "Unpack facility")
112 /* Features exposed via SCLP SCCB Byte 80 - 98 (bit numbers relative to byte-80) */
113 DEF_FEAT(SIE_GSLS
, "gsls", SCLP_CONF_CHAR
, 40, "SIE: Guest-storage-limit-suppression facility")
114 DEF_FEAT(ESOP
, "esop", SCLP_CONF_CHAR
, 46, "Enhanced-suppression-on-protection facility")
115 DEF_FEAT(HPMA2
, "hpma2", SCLP_CONF_CHAR
, 90, "Host page management assist 2 Facility") /* 91-2 */
116 DEF_FEAT(SIE_KSS
, "kss", SCLP_CONF_CHAR
, 151, "SIE: Keyless-subset facility") /* 98-7 */
118 /* Features exposed via SCLP SCCB Byte 116 - 119 (bit numbers relative to byte-116) */
119 DEF_FEAT(SIE_64BSCAO
, "64bscao", SCLP_CONF_CHAR_EXT
, 0, "SIE: 64-bit-SCAO facility")
120 DEF_FEAT(SIE_CMMA
, "cmma", SCLP_CONF_CHAR_EXT
, 1, "SIE: Collaborative-memory-management assist")
121 DEF_FEAT(SIE_PFMFI
, "pfmfi", SCLP_CONF_CHAR_EXT
, 9, "SIE: PFMF interpretation facility")
122 DEF_FEAT(SIE_IBS
, "ibs", SCLP_CONF_CHAR_EXT
, 10, "SIE: Interlock-and-broadcast-suppression facility")
124 /* Features exposed via SCLP CPU info. */
125 DEF_FEAT(SIE_F2
, "sief2", SCLP_CPU
, 4, "SIE: interception format 2 (Virtual SIE)")
126 DEF_FEAT(SIE_SKEY
, "skey", SCLP_CPU
, 5, "SIE: Storage-key facility")
127 DEF_FEAT(SIE_GPERE
, "gpereh", SCLP_CPU
, 10, "SIE: Guest-PER enhancement facility")
128 DEF_FEAT(SIE_SIIF
, "siif", SCLP_CPU
, 11, "SIE: Shared IPTE-interlock facility")
129 DEF_FEAT(SIE_SIGPIF
, "sigpif", SCLP_CPU
, 12, "SIE: SIGP interpretation facility")
130 DEF_FEAT(SIE_IB
, "ib", SCLP_CPU
, 42, "SIE: Intervention bypass facility")
131 DEF_FEAT(SIE_CEI
, "cei", SCLP_CPU
, 43, "SIE: Conditional-external-interception facility")
134 * Features exposed via no feature bit (but e.g., instruction sensing)
135 * -> the feature bit number is irrelavant
137 DEF_FEAT(DAT_ENH_2
, "dateh2", MISC
, 0, "DAT-enhancement facility 2")
138 DEF_FEAT(CMM
, "cmm", MISC
, 0, "Collaborative-memory-management facility")
139 DEF_FEAT(AP
, "ap", MISC
, 0, "AP instructions installed")
141 /* Features exposed via the PLO instruction. */
142 DEF_FEAT(PLO_CL
, "plo-cl", PLO
, 0, "PLO Compare and load (32 bit in general registers)")
143 DEF_FEAT(PLO_CLG
, "plo-clg", PLO
, 1, "PLO Compare and load (64 bit in parameter list)")
144 DEF_FEAT(PLO_CLGR
, "plo-clgr", PLO
, 2, "PLO Compare and load (32 bit in general registers)")
145 DEF_FEAT(PLO_CLX
, "plo-clx", PLO
, 3, "PLO Compare and load (128 bit in parameter list)")
146 DEF_FEAT(PLO_CS
, "plo-cs", PLO
, 4, "PLO Compare and swap (32 bit in general registers)")
147 DEF_FEAT(PLO_CSG
, "plo-csg", PLO
, 5, "PLO Compare and swap (64 bit in parameter list)")
148 DEF_FEAT(PLO_CSGR
, "plo-csgr", PLO
, 6, "PLO Compare and swap (32 bit in general registers)")
149 DEF_FEAT(PLO_CSX
, "plo-csx", PLO
, 7, "PLO Compare and swap (128 bit in parameter list)")
150 DEF_FEAT(PLO_DCS
, "plo-dcs", PLO
, 8, "PLO Double compare and swap (32 bit in general registers)")
151 DEF_FEAT(PLO_DCSG
, "plo-dcsg", PLO
, 9, "PLO Double compare and swap (64 bit in parameter list)")
152 DEF_FEAT(PLO_DCSGR
, "plo-dcsgr", PLO
, 10, "PLO Double compare and swap (32 bit in general registers)")
153 DEF_FEAT(PLO_DCSX
, "plo-dcsx", PLO
, 11, "PLO Double compare and swap (128 bit in parameter list)")
154 DEF_FEAT(PLO_CSST
, "plo-csst", PLO
, 12, "PLO Compare and swap and store (32 bit in general registers)")
155 DEF_FEAT(PLO_CSSTG
, "plo-csstg", PLO
, 13, "PLO Compare and swap and store (64 bit in parameter list)")
156 DEF_FEAT(PLO_CSSTGR
, "plo-csstgr", PLO
, 14, "PLO Compare and swap and store (32 bit in general registers)")
157 DEF_FEAT(PLO_CSSTX
, "plo-csstx", PLO
, 15, "PLO Compare and swap and store (128 bit in parameter list)")
158 DEF_FEAT(PLO_CSDST
, "plo-csdst", PLO
, 16, "PLO Compare and swap and double store (32 bit in general registers)")
159 DEF_FEAT(PLO_CSDSTG
, "plo-csdstg", PLO
, 17, "PLO Compare and swap and double store (64 bit in parameter list)")
160 DEF_FEAT(PLO_CSDSTGR
, "plo-csdstgr", PLO
, 18, "PLO Compare and swap and double store (32 bit in general registers)")
161 DEF_FEAT(PLO_CSDSTX
, "plo-csdstx", PLO
, 19, "PLO Compare and swap and double store (128 bit in parameter list)")
162 DEF_FEAT(PLO_CSTST
, "plo-cstst", PLO
, 20, "PLO Compare and swap and triple store (32 bit in general registers)")
163 DEF_FEAT(PLO_CSTSTG
, "plo-cststg", PLO
, 21, "PLO Compare and swap and triple store (64 bit in parameter list)")
164 DEF_FEAT(PLO_CSTSTGR
, "plo-cststgr", PLO
, 22, "PLO Compare and swap and triple store (32 bit in general registers)")
165 DEF_FEAT(PLO_CSTSTX
, "plo-cststx", PLO
, 23, "PLO Compare and swap and triple store (128 bit in parameter list)")
167 /* Features exposed via the PTFF instruction. */
168 DEF_FEAT(PTFF_QTO
, "ptff-qto", PTFF
, 1, "PTFF Query TOD Offset")
169 DEF_FEAT(PTFF_QSI
, "ptff-qsi", PTFF
, 2, "PTFF Query Steering Information")
170 DEF_FEAT(PTFF_QPT
, "ptff-qpc", PTFF
, 3, "PTFF Query Physical Clock")
171 DEF_FEAT(PTFF_QUI
, "ptff-qui", PTFF
, 4, "PTFF Query UTC Information")
172 DEF_FEAT(PTFF_QTOU
, "ptff-qtou", PTFF
, 5, "PTFF Query TOD Offset User")
173 DEF_FEAT(PTFF_QSIE
, "ptff-qsie", PTFF
, 10, "PTFF Query Steering Information Extended")
174 DEF_FEAT(PTFF_QTOUE
, "ptff-qtoue", PTFF
, 13, "PTFF Query TOD Offset User Extended")
175 DEF_FEAT(PTFF_STO
, "ptff-sto", PTFF
, 65, "PTFF Set TOD Offset")
176 DEF_FEAT(PTFF_STOU
, "ptff-stou", PTFF
, 69, "PTFF Set TOD Offset User")
177 DEF_FEAT(PTFF_STOE
, "ptff-stoe", PTFF
, 73, "PTFF Set TOD Offset Extended")
178 DEF_FEAT(PTFF_STOUE
, "ptff-stoue", PTFF
, 77, "PTFF Set TOD Offset User Extended")
180 /* Features exposed via the KMAC instruction. */
181 DEF_FEAT(KMAC_DEA
, "kmac-dea", KMAC
, 1, "KMAC DEA")
182 DEF_FEAT(KMAC_TDEA_128
, "kmac-tdea-128", KMAC
, 2, "KMAC TDEA-128")
183 DEF_FEAT(KMAC_TDEA_192
, "kmac-tdea-192", KMAC
, 3, "KMAC TDEA-192")
184 DEF_FEAT(KMAC_EDEA
, "kmac-edea", KMAC
, 9, "KMAC Encrypted-DEA")
185 DEF_FEAT(KMAC_ETDEA_128
, "kmac-etdea-128", KMAC
, 10, "KMAC Encrypted-TDEA-128")
186 DEF_FEAT(KMAC_ETDEA_192
, "kmac-etdea-192", KMAC
, 11, "KMAC Encrypted-TDEA-192")
187 DEF_FEAT(KMAC_AES_128
, "kmac-aes-128", KMAC
, 18, "KMAC AES-128")
188 DEF_FEAT(KMAC_AES_192
, "kmac-aes-192", KMAC
, 19, "KMAC AES-192")
189 DEF_FEAT(KMAC_AES_256
, "kmac-aes-256", KMAC
, 20, "KMAC AES-256")
190 DEF_FEAT(KMAC_EAES_128
, "kmac-eaes-128", KMAC
, 26, "KMAC Encrypted-AES-128")
191 DEF_FEAT(KMAC_EAES_192
, "kmac-eaes-192", KMAC
, 27, "KMAC Encrypted-AES-192")
192 DEF_FEAT(KMAC_EAES_256
, "kmac-eaes-256", KMAC
, 28, "KMAC Encrypted-AES-256")
194 /* Features exposed via the KMC instruction. */
195 DEF_FEAT(KMC_DEA
, "kmc-dea", KMC
, 1, "KMC DEA")
196 DEF_FEAT(KMC_TDEA_128
, "kmc-tdea-128", KMC
, 2, "KMC TDEA-128")
197 DEF_FEAT(KMC_TDEA_192
, "kmc-tdea-192", KMC
, 3, "KMC TDEA-192")
198 DEF_FEAT(KMC_EDEA
, "kmc-edea", KMC
, 9, "KMC Encrypted-DEA")
199 DEF_FEAT(KMC_ETDEA_128
, "kmc-etdea-128", KMC
, 10, "KMC Encrypted-TDEA-128")
200 DEF_FEAT(KMC_ETDEA_192
, "kmc-etdea-192", KMC
, 11, "KMC Encrypted-TDEA-192")
201 DEF_FEAT(KMC_AES_128
, "kmc-aes-128", KMC
, 18, "KMC AES-128")
202 DEF_FEAT(KMC_AES_192
, "kmc-aes-192", KMC
, 19, "KMC AES-192")
203 DEF_FEAT(KMC_AES_256
, "kmc-aes-256", KMC
, 20, "KMC AES-256")
204 DEF_FEAT(KMC_EAES_128
, "kmc-eaes-128", KMC
, 26, "KMC Encrypted-AES-128")
205 DEF_FEAT(KMC_EAES_192
, "kmc-eaes-192", KMC
, 27, "KMC Encrypted-AES-192")
206 DEF_FEAT(KMC_EAES_256
, "kmc-eaes-256", KMC
, 28, "KMC Encrypted-AES-256")
207 DEF_FEAT(KMC_PRNG
, "kmc-prng", KMC
, 67, "KMC PRNG")
209 /* Features exposed via the KM instruction. */
210 DEF_FEAT(KM_DEA
, "km-dea", KM
, 1, "KM DEA")
211 DEF_FEAT(KM_TDEA_128
, "km-tdea-128", KM
, 2, "KM TDEA-128")
212 DEF_FEAT(KM_TDEA_192
, "km-tdea-192", KM
, 3, "KM TDEA-192")
213 DEF_FEAT(KM_EDEA
, "km-edea", KM
, 9, "KM Encrypted-DEA")
214 DEF_FEAT(KM_ETDEA_128
, "km-etdea-128", KM
, 10, "KM Encrypted-TDEA-128")
215 DEF_FEAT(KM_ETDEA_192
, "km-etdea-192", KM
, 11, "KM Encrypted-TDEA-192")
216 DEF_FEAT(KM_AES_128
, "km-aes-128", KM
, 18, "KM AES-128")
217 DEF_FEAT(KM_AES_192
, "km-aes-192", KM
, 19, "KM AES-192")
218 DEF_FEAT(KM_AES_256
, "km-aes-256", KM
, 20, "KM AES-256")
219 DEF_FEAT(KM_EAES_128
, "km-eaes-128", KM
, 26, "KM Encrypted-AES-128")
220 DEF_FEAT(KM_EAES_192
, "km-eaes-192", KM
, 27, "KM Encrypted-AES-192")
221 DEF_FEAT(KM_EAES_256
, "km-eaes-256", KM
, 28, "KM Encrypted-AES-256")
222 DEF_FEAT(KM_XTS_AES_128
, "km-xts-aes-128", KM
, 50, "KM XTS-AES-128")
223 DEF_FEAT(KM_XTS_AES_256
, "km-xts-aes-256", KM
, 52, "KM XTS-AES-256")
224 DEF_FEAT(KM_XTS_EAES_128
, "km-xts-eaes-128", KM
, 58, "KM XTS-Encrypted-AES-128")
225 DEF_FEAT(KM_XTS_EAES_256
, "km-xts-eaes-256", KM
, 60, "KM XTS-Encrypted-AES-256")
227 /* Features exposed via the KIMD instruction. */
228 DEF_FEAT(KIMD_SHA_1
, "kimd-sha-1", KIMD
, 1, "KIMD SHA-1")
229 DEF_FEAT(KIMD_SHA_256
, "kimd-sha-256", KIMD
, 2, "KIMD SHA-256")
230 DEF_FEAT(KIMD_SHA_512
, "kimd-sha-512", KIMD
, 3, "KIMD SHA-512")
231 DEF_FEAT(KIMD_SHA3_224
, "kimd-sha3-224", KIMD
, 32, "KIMD SHA3-224")
232 DEF_FEAT(KIMD_SHA3_256
, "kimd-sha3-256", KIMD
, 33, "KIMD SHA3-256")
233 DEF_FEAT(KIMD_SHA3_384
, "kimd-sha3-384", KIMD
, 34, "KIMD SHA3-384")
234 DEF_FEAT(KIMD_SHA3_512
, "kimd-sha3-512", KIMD
, 35, "KIMD SHA3-512")
235 DEF_FEAT(KIMD_SHAKE_128
, "kimd-shake-128", KIMD
, 36, "KIMD SHAKE-128")
236 DEF_FEAT(KIMD_SHAKE_256
, "kimd-shake-256", KIMD
, 37, "KIMD SHAKE-256")
237 DEF_FEAT(KIMD_GHASH
, "kimd-ghash", KIMD
, 65, "KIMD GHASH")
239 /* Features exposed via the KLMD instruction. */
240 DEF_FEAT(KLMD_SHA_1
, "klmd-sha-1", KLMD
, 1, "KLMD SHA-1")
241 DEF_FEAT(KLMD_SHA_256
, "klmd-sha-256", KLMD
, 2, "KLMD SHA-256")
242 DEF_FEAT(KLMD_SHA_512
, "klmd-sha-512", KLMD
, 3, "KLMD SHA-512")
243 DEF_FEAT(KLMD_SHA3_224
, "klmd-sha3-224", KLMD
, 32, "KLMD SHA3-224")
244 DEF_FEAT(KLMD_SHA3_256
, "klmd-sha3-256", KLMD
, 33, "KLMD SHA3-256")
245 DEF_FEAT(KLMD_SHA3_384
, "klmd-sha3-384", KLMD
, 34, "KLMD SHA3-384")
246 DEF_FEAT(KLMD_SHA3_512
, "klmd-sha3-512", KLMD
, 35, "KLMD SHA3-512")
247 DEF_FEAT(KLMD_SHAKE_128
, "klmd-shake-128", KLMD
, 36, "KLMD SHAKE-128")
248 DEF_FEAT(KLMD_SHAKE_256
, "klmd-shake-256", KLMD
, 37, "KLMD SHAKE-256")
250 /* Features exposed via the PCKMO instruction. */
251 DEF_FEAT(PCKMO_EDEA
, "pckmo-edea", PCKMO
, 1, "PCKMO Encrypted-DEA-Key")
252 DEF_FEAT(PCKMO_ETDEA_128
, "pckmo-etdea-128", PCKMO
, 2, "PCKMO Encrypted-TDEA-128-Key")
253 DEF_FEAT(PCKMO_ETDEA_256
, "pckmo-etdea-192", PCKMO
, 3, "PCKMO Encrypted-TDEA-192-Key")
254 DEF_FEAT(PCKMO_AES_128
, "pckmo-aes-128", PCKMO
, 18, "PCKMO Encrypted-AES-128-Key")
255 DEF_FEAT(PCKMO_AES_192
, "pckmo-aes-192", PCKMO
, 19, "PCKMO Encrypted-AES-192-Key")
256 DEF_FEAT(PCKMO_AES_256
, "pckmo-aes-256", PCKMO
, 20, "PCKMO Encrypted-AES-256-Key")
257 DEF_FEAT(PCKMO_ECC_P256
, "pckmo-ecc-p256", PCKMO
, 32, "PCKMO Encrypt-ECC-P256-Key")
258 DEF_FEAT(PCKMO_ECC_P384
, "pckmo-ecc-p384", PCKMO
, 33, "PCKMO Encrypt-ECC-P384-Key")
259 DEF_FEAT(PCKMO_ECC_P521
, "pckmo-ecc-p521", PCKMO
, 34, "PCKMO Encrypt-ECC-P521-Key")
260 DEF_FEAT(PCKMO_ECC_ED25519
, "pckmo-ecc-ed25519", PCKMO
, 40 , "PCKMO Encrypt-ECC-Ed25519-Key")
261 DEF_FEAT(PCKMO_ECC_ED448
, "pckmo-ecc-ed448", PCKMO
, 41 , "PCKMO Encrypt-ECC-Ed448-Key")
263 /* Features exposed via the KMCTR instruction. */
264 DEF_FEAT(KMCTR_DEA
, "kmctr-dea", KMCTR
, 1, "KMCTR DEA")
265 DEF_FEAT(KMCTR_TDEA_128
, "kmctr-tdea-128", KMCTR
, 2, "KMCTR TDEA-128")
266 DEF_FEAT(KMCTR_TDEA_192
, "kmctr-tdea-192", KMCTR
, 3, "KMCTR TDEA-192")
267 DEF_FEAT(KMCTR_EDEA
, "kmctr-edea", KMCTR
, 9, "KMCTR Encrypted-DEA")
268 DEF_FEAT(KMCTR_ETDEA_128
, "kmctr-etdea-128", KMCTR
, 10, "KMCTR Encrypted-TDEA-128")
269 DEF_FEAT(KMCTR_ETDEA_192
, "kmctr-etdea-192", KMCTR
, 11, "KMCTR Encrypted-TDEA-192")
270 DEF_FEAT(KMCTR_AES_128
, "kmctr-aes-128", KMCTR
, 18, "KMCTR AES-128")
271 DEF_FEAT(KMCTR_AES_192
, "kmctr-aes-192", KMCTR
, 19, "KMCTR AES-192")
272 DEF_FEAT(KMCTR_AES_256
, "kmctr-aes-256", KMCTR
, 20, "KMCTR AES-256")
273 DEF_FEAT(KMCTR_EAES_128
, "kmctr-eaes-128", KMCTR
, 26, "KMCTR Encrypted-AES-128")
274 DEF_FEAT(KMCTR_EAES_192
, "kmctr-eaes-192", KMCTR
, 27, "KMCTR Encrypted-AES-192")
275 DEF_FEAT(KMCTR_EAES_256
, "kmctr-eaes-256", KMCTR
, 28, "KMCTR Encrypted-AES-256")
277 /* Features exposed via the KMF instruction. */
278 DEF_FEAT(KMF_DEA
, "kmf-dea", KMF
, 1, "KMF DEA")
279 DEF_FEAT(KMF_TDEA_128
, "kmf-tdea-128", KMF
, 2, "KMF TDEA-128")
280 DEF_FEAT(KMF_TDEA_192
, "kmf-tdea-192", KMF
, 3, "KMF TDEA-192")
281 DEF_FEAT(KMF_EDEA
, "kmf-edea", KMF
, 9, "KMF Encrypted-DEA")
282 DEF_FEAT(KMF_ETDEA_128
, "kmf-etdea-128", KMF
, 10, "KMF Encrypted-TDEA-128")
283 DEF_FEAT(KMF_ETDEA_192
, "kmf-etdea-192", KMF
, 11, "KMF Encrypted-TDEA-192")
284 DEF_FEAT(KMF_AES_128
, "kmf-aes-128", KMF
, 18, "KMF AES-128")
285 DEF_FEAT(KMF_AES_192
, "kmf-aes-192", KMF
, 19, "KMF AES-192")
286 DEF_FEAT(KMF_AES_256
, "kmf-aes-256", KMF
, 20, "KMF AES-256")
287 DEF_FEAT(KMF_EAES_128
, "kmf-eaes-128", KMF
, 26, "KMF Encrypted-AES-128")
288 DEF_FEAT(KMF_EAES_192
, "kmf-eaes-192", KMF
, 27, "KMF Encrypted-AES-192")
289 DEF_FEAT(KMF_EAES_256
, "kmf-eaes-256", KMF
, 28, "KMF Encrypted-AES-256")
291 /* Features exposed via the KMO instruction. */
292 DEF_FEAT(KMO_DEA
, "kmo-dea", KMO
, 1, "KMO DEA")
293 DEF_FEAT(KMO_TDEA_128
, "kmo-tdea-128", KMO
, 2, "KMO TDEA-128")
294 DEF_FEAT(KMO_TDEA_192
, "kmo-tdea-192", KMO
, 3, "KMO TDEA-192")
295 DEF_FEAT(KMO_EDEA
, "kmo-edea", KMO
, 9, "KMO Encrypted-DEA")
296 DEF_FEAT(KMO_ETDEA_128
, "kmo-etdea-128", KMO
, 10, "KMO Encrypted-TDEA-128")
297 DEF_FEAT(KMO_ETDEA_192
, "kmo-etdea-192", KMO
, 11, "KMO Encrypted-TDEA-192")
298 DEF_FEAT(KMO_AES_128
, "kmo-aes-128", KMO
, 18, "KMO AES-128")
299 DEF_FEAT(KMO_AES_192
, "kmo-aes-192", KMO
, 19, "KMO AES-192")
300 DEF_FEAT(KMO_AES_256
, "kmo-aes-256", KMO
, 20, "KMO AES-256")
301 DEF_FEAT(KMO_EAES_128
, "kmo-eaes-128", KMO
, 26, "KMO Encrypted-AES-128")
302 DEF_FEAT(KMO_EAES_192
, "kmo-eaes-192", KMO
, 27, "KMO Encrypted-AES-192")
303 DEF_FEAT(KMO_EAES_256
, "kmo-eaes-256", KMO
, 28, "KMO Encrypted-AES-256")
305 /* Features exposed via the PCC instruction. */
306 DEF_FEAT(PCC_CMAC_DEA
, "pcc-cmac-dea", PCC
, 1, "PCC Compute-Last-Block-CMAC-Using-DEA")
307 DEF_FEAT(PCC_CMAC_TDEA_128
, "pcc-cmac-tdea-128", PCC
, 2, "PCC Compute-Last-Block-CMAC-Using-TDEA-128")
308 DEF_FEAT(PCC_CMAC_TDEA_192
, "pcc-cmac-tdea-192", PCC
, 3, "PCC Compute-Last-Block-CMAC-Using-TDEA-192")
309 DEF_FEAT(PCC_CMAC_ETDEA_128
, "pcc-cmac-edea", PCC
, 9, "PCC Compute-Last-Block-CMAC-Using-Encrypted-DEA")
310 DEF_FEAT(PCC_CMAC_ETDEA_192
, "pcc-cmac-etdea-128", PCC
, 10, "PCC Compute-Last-Block-CMAC-Using-Encrypted-TDEA-128")
311 DEF_FEAT(PCC_CMAC_TDEA
, "pcc-cmac-etdea-192", PCC
, 11, "PCC Compute-Last-Block-CMAC-Using-EncryptedTDEA-192")
312 DEF_FEAT(PCC_CMAC_AES_128
, "pcc-cmac-aes-128", PCC
, 18, "PCC Compute-Last-Block-CMAC-Using-AES-128")
313 DEF_FEAT(PCC_CMAC_AES_192
, "pcc-cmac-aes-192", PCC
, 19, "PCC Compute-Last-Block-CMAC-Using-AES-192")
314 DEF_FEAT(PCC_CMAC_AES_256
, "pcc-cmac-aes-256", PCC
, 20, "PCC Compute-Last-Block-CMAC-Using-AES-256")
315 DEF_FEAT(PCC_CMAC_EAES_128
, "pcc-cmac-eaes-128", PCC
, 26, "PCC Compute-Last-Block-CMAC-Using-Encrypted-AES-128")
316 DEF_FEAT(PCC_CMAC_EAES_192
, "pcc-cmac-eaes-192", PCC
, 27, "PCC Compute-Last-Block-CMAC-Using-Encrypted-AES-192")
317 DEF_FEAT(PCC_CMAC_EAES_256
, "pcc-cmac-eaes-256", PCC
, 28, "PCC Compute-Last-Block-CMAC-Using-Encrypted-AES-256")
318 DEF_FEAT(PCC_XTS_AES_128
, "pcc-xts-aes-128", PCC
, 50, "PCC Compute-XTS-Parameter-Using-AES-128")
319 DEF_FEAT(PCC_XTS_AES_256
, "pcc-xts-aes-256", PCC
, 52, "PCC Compute-XTS-Parameter-Using-AES-256")
320 DEF_FEAT(PCC_XTS_EAES_128
, "pcc-xts-eaes-128", PCC
, 58, "PCC Compute-XTS-Parameter-Using-Encrypted-AES-128")
321 DEF_FEAT(PCC_XTS_EAES_256
, "pcc-xts-eaes-256", PCC
, 60, "PCC Compute-XTS-Parameter-Using-Encrypted-AES-256")
322 DEF_FEAT(PCC_SCALAR_MULT_P256
, "pcc-scalar-mult-p256", PCC
, 64, "PCC Scalar-Multiply-P256")
323 DEF_FEAT(PCC_SCALAR_MULT_P384
, "pcc-scalar-mult-p384", PCC
, 65, "PCC Scalar-Multiply-P384")
324 DEF_FEAT(PCC_SCALAR_MULT_P512
, "pcc-scalar-mult-p521", PCC
, 66, "PCC Scalar-Multiply-P521")
325 DEF_FEAT(PCC_SCALAR_MULT_ED25519
, "pcc-scalar-mult-ed25519", PCC
, 72, "PCC Scalar-Multiply-Ed25519")
326 DEF_FEAT(PCC_SCALAR_MULT_ED448
, "pcc-scalar-mult-ed448", PCC
, 73, "PCC Scalar-Multiply-Ed448")
327 DEF_FEAT(PCC_SCALAR_MULT_X25519
, "pcc-scalar-mult-x25519", PCC
, 80, "PCC Scalar-Multiply-X25519")
328 DEF_FEAT(PCC_SCALAR_MULT_X448
, "pcc-scalar-mult-x448", PCC
, 81, "PCC Scalar-Multiply-X448")
330 /* Features exposed via the PPNO/PRNO instruction. */
331 DEF_FEAT(PPNO_SHA_512_DRNG
, "ppno-sha-512-drng", PPNO
, 3, "PPNO SHA-512-DRNG")
332 DEF_FEAT(PRNO_TRNG_QRTCR
, "prno-trng-qrtcr", PPNO
, 112, "PRNO TRNG-Query-Raw-to-Conditioned-Ratio")
333 DEF_FEAT(PRNO_TRNG
, "prno-trng", PPNO
, 114, "PRNO TRNG")
335 /* Features exposed via the KMA instruction. */
336 DEF_FEAT(KMA_GCM_AES_128
, "kma-gcm-aes-128", KMA
, 18, "KMA GCM-AES-128")
337 DEF_FEAT(KMA_GCM_AES_192
, "kma-gcm-aes-192", KMA
, 19, "KMA GCM-AES-192")
338 DEF_FEAT(KMA_GCM_AES_256
, "kma-gcm-aes-256", KMA
, 20, "KMA GCM-AES-256")
339 DEF_FEAT(KMA_GCM_EAES_128
, "kma-gcm-eaes-128", KMA
, 26, "KMA GCM-Encrypted-AES-128")
340 DEF_FEAT(KMA_GCM_EAES_192
, "kma-gcm-eaes-192", KMA
, 27, "KMA GCM-Encrypted-AES-192")
341 DEF_FEAT(KMA_GCM_EAES_256
, "kma-gcm-eaes-256", KMA
, 28, "KMA GCM-Encrypted-AES-256")
343 /* Features exposed via the KDSA instruction. */
344 DEF_FEAT(KDSA_ECDSA_VERIFY_P256
, "kdsa-ecdsa-verify-p256", KDSA
, 1, "KDSA ECDSA-Verify-P256")
345 DEF_FEAT(KDSA_ECDSA_VERIFY_P384
, "kdsa-ecdsa-verify-p384", KDSA
, 2, "KDSA ECDSA-Verify-P384")
346 DEF_FEAT(KDSA_ECDSA_VERIFY_P512
, "kdsa-ecdsa-verify-p521", KDSA
, 3, "KDSA ECDSA-Verify-P521")
347 DEF_FEAT(KDSA_ECDSA_SIGN_P256
, "kdsa-ecdsa-sign-p256", KDSA
, 9, "KDSA ECDSA-Sign-P256")
348 DEF_FEAT(KDSA_ECDSA_SIGN_P384
, "kdsa-ecdsa-sign-p384", KDSA
, 10, "KDSA ECDSA-Sign-P384")
349 DEF_FEAT(KDSA_ECDSA_SIGN_P512
, "kdsa-ecdsa-sign-p521", KDSA
, 11, "KDSA ECDSA-Sign-P521")
350 DEF_FEAT(KDSA_EECDSA_SIGN_P256
, "kdsa-eecdsa-sign-p256", KDSA
, 17, "KDSA Encrypted-ECDSA-Sign-P256")
351 DEF_FEAT(KDSA_EECDSA_SIGN_P384
, "kdsa-eecdsa-sign-p384", KDSA
, 18, "KDSA Encrypted-ECDSA-Sign-P384")
352 DEF_FEAT(KDSA_EECDSA_SIGN_P512
, "kdsa-eecdsa-sign-p521", KDSA
, 19, "KDSA Encrypted-ECDSA-Sign-P521")
353 DEF_FEAT(KDSA_EDDSA_VERIFY_ED25519
, "kdsa-eddsa-verify-ed25519", KDSA
, 32, "KDSA EdDSA-Verify-Ed25519")
354 DEF_FEAT(KDSA_EDDSA_VERIFY_ED448
, "kdsa-eddsa-verify-ed448", KDSA
, 36, "KDSA EdDSA-Verify-Ed448")
355 DEF_FEAT(KDSA_EDDSA_SIGN_ED25519
, "kdsa-eddsa-sign-ed25519", KDSA
, 40, "KDSA EdDSA-Sign-Ed25519")
356 DEF_FEAT(KDSA_EDDSA_SIGN_ED448
, "kdsa-eddsa-sign-ed448", KDSA
, 44, "KDSA EdDSA-Sign-Ed448")
357 DEF_FEAT(KDSA_EEDDSA_SIGN_ED25519
, "kdsa-eeddsa-sign-ed25519", KDSA
, 48, "KDSA Encrypted-EdDSA-Sign-Ed25519")
358 DEF_FEAT(KDSA_EEDDSA_SIGN_ED448
, "kdsa-eeddsa-sign-ed448", KDSA
, 52, "KDSA Encrypted-EdDSA-Sign-Ed448")
360 /* Features exposed via the SORTL instruction. */
361 DEF_FEAT(SORTL_SFLR
, "sortl-sflr", SORTL
, 1, "SORTL SFLR")
362 DEF_FEAT(SORTL_SVLR
, "sortl-svlr", SORTL
, 2, "SORTL SVLR")
363 DEF_FEAT(SORTL_32
, "sortl-32", SORTL
, 130, "SORTL 32 input lists")
364 DEF_FEAT(SORTL_128
, "sortl-128", SORTL
, 132, "SORTL 128 input lists")
365 DEF_FEAT(SORTL_F0
, "sortl-f0", SORTL
, 192, "SORTL format 0 parameter-block")
367 /* Features exposed via the DEFLATE instruction. */
368 DEF_FEAT(DEFLATE_GHDT
, "dfltcc-gdht", DFLTCC
, 1, "DFLTCC GDHT")
369 DEF_FEAT(DEFLATE_CMPR
, "dfltcc-cmpr", DFLTCC
, 2, "DFLTCC CMPR")
370 DEF_FEAT(DEFLATE_XPND
, "dfltcc-xpnd", DFLTCC
, 4, "DFLTCC XPND")
371 DEF_FEAT(DEFLATE_F0
, "dfltcc-f0", DFLTCC
, 192, "DFLTCC format 0 parameter-block")