NULL, (void *)prop_name);
}
-static void riscv_cpu_add_kvm_unavail_prop_array(Object *obj,
- const RISCVCPUMultiExtConfig *array)
-{
- const RISCVCPUMultiExtConfig *prop;
-
- g_assert(array);
-
- for (prop = array; prop && prop->name; prop++) {
- riscv_cpu_add_kvm_unavail_prop(obj, prop->name);
- }
-}
-
static void kvm_riscv_add_cpu_user_properties(Object *cpu_obj)
{
+ const RISCVIsaExtData *edata;
int i;
riscv_add_satp_mode_properties(cpu_obj);
NULL, multi_cfg);
}
- riscv_cpu_add_kvm_unavail_prop_array(cpu_obj, riscv_cpu_extensions);
- riscv_cpu_add_kvm_unavail_prop_array(cpu_obj, riscv_cpu_vendor_exts);
- riscv_cpu_add_kvm_unavail_prop_array(cpu_obj, riscv_cpu_experimental_exts);
+ /*
+ * Mark all isa_edata_arr properties that collides with
+ * a KVM property as unavailable.
+ */
+ for (edata = isa_edata_arr; edata && edata->name; edata++) {
+ if (edata->prop_name) {
+ riscv_cpu_add_kvm_unavail_prop(cpu_obj, edata->prop_name);
+ }
+ }
/* We don't have the needed KVM support for profiles */
for (i = 0; riscv_profiles[i] != NULL; i++) {