Thanks for working on this! On Thu, Oct 24, 2024 at 01:34:29PM +0100, Conor Dooley wrote: > @@ -308,12 +354,10 @@ const struct riscv_isa_ext_data riscv_isa_ext[] = { > __RISCV_ISA_EXT_DATA(d, RISCV_ISA_EXT_d), > __RISCV_ISA_EXT_DATA(q, RISCV_ISA_EXT_q), > __RISCV_ISA_EXT_SUPERSET(c, RISCV_ISA_EXT_c, riscv_c_exts), > - __RISCV_ISA_EXT_SUPERSET(v, RISCV_ISA_EXT_v, riscv_v_exts), > + __RISCV_ISA_EXT_SUPERSET_VALIDATE(v, RISCV_ISA_EXT_v, riscv_v_exts, riscv_ext_vector_float_validate), This patch adds validation for not just the vector crypto extensions but also v, zve32f, zve32x, zve64d, zve64f, and zve64x. I think that should be split into a separate patch or at least called out explicitly in the commit message. > + __RISCV_ISA_EXT_BUNDLE_VALIDATE(zk, riscv_zk_bundled_exts, riscv_ext_vector_crypto_validate), > + __RISCV_ISA_EXT_BUNDLE_VALIDATE(zkn, riscv_zkn_bundled_exts, riscv_ext_vector_crypto_validate), > __RISCV_ISA_EXT_DATA(zknd, RISCV_ISA_EXT_ZKND), > __RISCV_ISA_EXT_DATA(zkne, RISCV_ISA_EXT_ZKNE), > __RISCV_ISA_EXT_DATA(zknh, RISCV_ISA_EXT_ZKNH), > __RISCV_ISA_EXT_DATA(zkr, RISCV_ISA_EXT_ZKR), > - __RISCV_ISA_EXT_BUNDLE(zks, riscv_zks_bundled_exts), > + __RISCV_ISA_EXT_BUNDLE_VALIDATE(zks, riscv_zks_bundled_exts, riscv_ext_vector_crypto_validate), zk* are the scalar crypto extensions, which don't require vector. - Eric