qom: Drop object_property_set_description() parameter @errp
object_property_set_description() and object_class_property_set_description() fail only when property @name is not found. There are 85 calls of object_property_set_description() and object_class_property_set_description(). None of them can fail: * 84 immediately follow the creation of the property. * The one in spapr_rng_instance_init() refers to a property created in spapr_rng_class_init(), from spapr_rng_properties[]. Every one of them still gets to decide what to pass for @errp. 51 calls pass &error_abort, 32 calls pass NULL, one receives the error and propagates it to &error_abort, and one propagates it to &error_fatal. I'm actually surprised none of them violates the Error API. What are we gaining by letting callers handle the "property not found" error? Use when the property is not known to exist is simpler: you don't have to guard the call with a check. We haven't found such a use in 5+ years. Until we do, let's make life a bit simpler and drop the @errp parameter. Signed-off-by: Markus Armbruster <armbru@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Reviewed-by: Paolo Bonzini <pbonzini@redhat.com> Message-Id: <20200505152926.18877-8-armbru@redhat.com> [One semantic rebase conflict resolved]
This commit is contained in:
parent
7025188772
commit
7eecec7d12
@ -3113,13 +3113,13 @@ static void kvm_accel_class_init(ObjectClass *oc, void *data)
|
|||||||
NULL, kvm_set_kernel_irqchip,
|
NULL, kvm_set_kernel_irqchip,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, "kernel-irqchip",
|
object_class_property_set_description(oc, "kernel-irqchip",
|
||||||
"Configure KVM in-kernel irqchip", &error_abort);
|
"Configure KVM in-kernel irqchip");
|
||||||
|
|
||||||
object_class_property_add(oc, "kvm-shadow-mem", "int",
|
object_class_property_add(oc, "kvm-shadow-mem", "int",
|
||||||
kvm_get_kvm_shadow_mem, kvm_set_kvm_shadow_mem,
|
kvm_get_kvm_shadow_mem, kvm_set_kvm_shadow_mem,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, "kvm-shadow-mem",
|
object_class_property_set_description(oc, "kvm-shadow-mem",
|
||||||
"KVM shadow MMU size", &error_abort);
|
"KVM shadow MMU size");
|
||||||
}
|
}
|
||||||
|
|
||||||
static const TypeInfo kvm_accel_type = {
|
static const TypeInfo kvm_accel_type = {
|
||||||
|
@ -210,7 +210,7 @@ static void tcg_accel_class_init(ObjectClass *oc, void *data)
|
|||||||
tcg_get_tb_size, tcg_set_tb_size,
|
tcg_get_tb_size, tcg_set_tb_size,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, "tb-size",
|
object_class_property_set_description(oc, "tb-size",
|
||||||
"TCG translation block cache size", &error_abort);
|
"TCG translation block cache size");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -144,23 +144,20 @@ memfd_backend_class_init(ObjectClass *oc, void *data)
|
|||||||
memfd_backend_set_hugetlb,
|
memfd_backend_set_hugetlb,
|
||||||
&error_abort);
|
&error_abort);
|
||||||
object_class_property_set_description(oc, "hugetlb",
|
object_class_property_set_description(oc, "hugetlb",
|
||||||
"Use huge pages",
|
"Use huge pages");
|
||||||
&error_abort);
|
|
||||||
object_class_property_add(oc, "hugetlbsize", "int",
|
object_class_property_add(oc, "hugetlbsize", "int",
|
||||||
memfd_backend_get_hugetlbsize,
|
memfd_backend_get_hugetlbsize,
|
||||||
memfd_backend_set_hugetlbsize,
|
memfd_backend_set_hugetlbsize,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, "hugetlbsize",
|
object_class_property_set_description(oc, "hugetlbsize",
|
||||||
"Huge pages size (ex: 2M, 1G)",
|
"Huge pages size (ex: 2M, 1G)");
|
||||||
&error_abort);
|
|
||||||
}
|
}
|
||||||
object_class_property_add_bool(oc, "seal",
|
object_class_property_add_bool(oc, "seal",
|
||||||
memfd_backend_get_seal,
|
memfd_backend_get_seal,
|
||||||
memfd_backend_set_seal,
|
memfd_backend_set_seal,
|
||||||
&error_abort);
|
&error_abort);
|
||||||
object_class_property_set_description(oc, "seal",
|
object_class_property_set_description(oc, "seal",
|
||||||
"Seal growing & shrinking",
|
"Seal growing & shrinking");
|
||||||
&error_abort);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const TypeInfo memfd_backend_info = {
|
static const TypeInfo memfd_backend_info = {
|
||||||
|
@ -465,46 +465,46 @@ host_memory_backend_class_init(ObjectClass *oc, void *data)
|
|||||||
host_memory_backend_get_merge,
|
host_memory_backend_get_merge,
|
||||||
host_memory_backend_set_merge, &error_abort);
|
host_memory_backend_set_merge, &error_abort);
|
||||||
object_class_property_set_description(oc, "merge",
|
object_class_property_set_description(oc, "merge",
|
||||||
"Mark memory as mergeable", &error_abort);
|
"Mark memory as mergeable");
|
||||||
object_class_property_add_bool(oc, "dump",
|
object_class_property_add_bool(oc, "dump",
|
||||||
host_memory_backend_get_dump,
|
host_memory_backend_get_dump,
|
||||||
host_memory_backend_set_dump, &error_abort);
|
host_memory_backend_set_dump, &error_abort);
|
||||||
object_class_property_set_description(oc, "dump",
|
object_class_property_set_description(oc, "dump",
|
||||||
"Set to 'off' to exclude from core dump", &error_abort);
|
"Set to 'off' to exclude from core dump");
|
||||||
object_class_property_add_bool(oc, "prealloc",
|
object_class_property_add_bool(oc, "prealloc",
|
||||||
host_memory_backend_get_prealloc,
|
host_memory_backend_get_prealloc,
|
||||||
host_memory_backend_set_prealloc, &error_abort);
|
host_memory_backend_set_prealloc, &error_abort);
|
||||||
object_class_property_set_description(oc, "prealloc",
|
object_class_property_set_description(oc, "prealloc",
|
||||||
"Preallocate memory", &error_abort);
|
"Preallocate memory");
|
||||||
object_class_property_add(oc, "prealloc-threads", "int",
|
object_class_property_add(oc, "prealloc-threads", "int",
|
||||||
host_memory_backend_get_prealloc_threads,
|
host_memory_backend_get_prealloc_threads,
|
||||||
host_memory_backend_set_prealloc_threads,
|
host_memory_backend_set_prealloc_threads,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, "prealloc-threads",
|
object_class_property_set_description(oc, "prealloc-threads",
|
||||||
"Number of CPU threads to use for prealloc", &error_abort);
|
"Number of CPU threads to use for prealloc");
|
||||||
object_class_property_add(oc, "size", "int",
|
object_class_property_add(oc, "size", "int",
|
||||||
host_memory_backend_get_size,
|
host_memory_backend_get_size,
|
||||||
host_memory_backend_set_size,
|
host_memory_backend_set_size,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, "size",
|
object_class_property_set_description(oc, "size",
|
||||||
"Size of the memory region (ex: 500M)", &error_abort);
|
"Size of the memory region (ex: 500M)");
|
||||||
object_class_property_add(oc, "host-nodes", "int",
|
object_class_property_add(oc, "host-nodes", "int",
|
||||||
host_memory_backend_get_host_nodes,
|
host_memory_backend_get_host_nodes,
|
||||||
host_memory_backend_set_host_nodes,
|
host_memory_backend_set_host_nodes,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, "host-nodes",
|
object_class_property_set_description(oc, "host-nodes",
|
||||||
"Binds memory to the list of NUMA host nodes", &error_abort);
|
"Binds memory to the list of NUMA host nodes");
|
||||||
object_class_property_add_enum(oc, "policy", "HostMemPolicy",
|
object_class_property_add_enum(oc, "policy", "HostMemPolicy",
|
||||||
&HostMemPolicy_lookup,
|
&HostMemPolicy_lookup,
|
||||||
host_memory_backend_get_policy,
|
host_memory_backend_get_policy,
|
||||||
host_memory_backend_set_policy, &error_abort);
|
host_memory_backend_set_policy, &error_abort);
|
||||||
object_class_property_set_description(oc, "policy",
|
object_class_property_set_description(oc, "policy",
|
||||||
"Set the NUMA policy", &error_abort);
|
"Set the NUMA policy");
|
||||||
object_class_property_add_bool(oc, "share",
|
object_class_property_add_bool(oc, "share",
|
||||||
host_memory_backend_get_share, host_memory_backend_set_share,
|
host_memory_backend_get_share, host_memory_backend_set_share,
|
||||||
&error_abort);
|
&error_abort);
|
||||||
object_class_property_set_description(oc, "share",
|
object_class_property_set_description(oc, "share",
|
||||||
"Mark the memory as private to QEMU or shared", &error_abort);
|
"Mark the memory as private to QEMU or shared");
|
||||||
object_class_property_add_bool(oc, "x-use-canonical-path-for-ramblock-id",
|
object_class_property_add_bool(oc, "x-use-canonical-path-for-ramblock-id",
|
||||||
host_memory_backend_get_use_canonical_path,
|
host_memory_backend_get_use_canonical_path,
|
||||||
host_memory_backend_set_use_canonical_path, &error_abort);
|
host_memory_backend_set_use_canonical_path, &error_abort);
|
||||||
|
@ -546,7 +546,7 @@ static void aspeed_machine_class_props_init(ObjectClass *oc)
|
|||||||
aspeed_get_mmio_exec,
|
aspeed_get_mmio_exec,
|
||||||
aspeed_set_mmio_exec, &error_abort);
|
aspeed_set_mmio_exec, &error_abort);
|
||||||
object_class_property_set_description(oc, "execute-in-place",
|
object_class_property_set_description(oc, "execute-in-place",
|
||||||
"boot directly from CE0 flash device", &error_abort);
|
"boot directly from CE0 flash device");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void aspeed_machine_class_init(ObjectClass *oc, void *data)
|
static void aspeed_machine_class_init(ObjectClass *oc, void *data)
|
||||||
|
@ -752,8 +752,7 @@ static void vexpress_instance_init(Object *obj)
|
|||||||
vexpress_set_secure, NULL);
|
vexpress_set_secure, NULL);
|
||||||
object_property_set_description(obj, "secure",
|
object_property_set_description(obj, "secure",
|
||||||
"Set on/off to enable/disable the ARM "
|
"Set on/off to enable/disable the ARM "
|
||||||
"Security Extensions (TrustZone)",
|
"Security Extensions (TrustZone)");
|
||||||
NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void vexpress_a15_instance_init(Object *obj)
|
static void vexpress_a15_instance_init(Object *obj)
|
||||||
@ -770,8 +769,7 @@ static void vexpress_a15_instance_init(Object *obj)
|
|||||||
object_property_set_description(obj, "virtualization",
|
object_property_set_description(obj, "virtualization",
|
||||||
"Set on/off to enable/disable the ARM "
|
"Set on/off to enable/disable the ARM "
|
||||||
"Virtualization Extensions "
|
"Virtualization Extensions "
|
||||||
"(defaults to same as 'secure')",
|
"(defaults to same as 'secure')");
|
||||||
NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void vexpress_a9_instance_init(Object *obj)
|
static void vexpress_a9_instance_init(Object *obj)
|
||||||
|
@ -2272,7 +2272,7 @@ static void virt_machine_class_init(ObjectClass *oc, void *data)
|
|||||||
virt_get_acpi, virt_set_acpi,
|
virt_get_acpi, virt_set_acpi,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, "acpi",
|
object_class_property_set_description(oc, "acpi",
|
||||||
"Enable ACPI", &error_abort);
|
"Enable ACPI");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void virt_instance_init(Object *obj)
|
static void virt_instance_init(Object *obj)
|
||||||
@ -2289,8 +2289,7 @@ static void virt_instance_init(Object *obj)
|
|||||||
virt_set_secure, NULL);
|
virt_set_secure, NULL);
|
||||||
object_property_set_description(obj, "secure",
|
object_property_set_description(obj, "secure",
|
||||||
"Set on/off to enable/disable the ARM "
|
"Set on/off to enable/disable the ARM "
|
||||||
"Security Extensions (TrustZone)",
|
"Security Extensions (TrustZone)");
|
||||||
NULL);
|
|
||||||
|
|
||||||
/* EL2 is also disabled by default, for similar reasons */
|
/* EL2 is also disabled by default, for similar reasons */
|
||||||
vms->virt = false;
|
vms->virt = false;
|
||||||
@ -2299,8 +2298,7 @@ static void virt_instance_init(Object *obj)
|
|||||||
object_property_set_description(obj, "virtualization",
|
object_property_set_description(obj, "virtualization",
|
||||||
"Set on/off to enable/disable emulating a "
|
"Set on/off to enable/disable emulating a "
|
||||||
"guest CPU which implements the ARM "
|
"guest CPU which implements the ARM "
|
||||||
"Virtualization Extensions",
|
"Virtualization Extensions");
|
||||||
NULL);
|
|
||||||
|
|
||||||
/* High memory is enabled by default */
|
/* High memory is enabled by default */
|
||||||
vms->highmem = true;
|
vms->highmem = true;
|
||||||
@ -2308,15 +2306,13 @@ static void virt_instance_init(Object *obj)
|
|||||||
virt_set_highmem, NULL);
|
virt_set_highmem, NULL);
|
||||||
object_property_set_description(obj, "highmem",
|
object_property_set_description(obj, "highmem",
|
||||||
"Set on/off to enable/disable using "
|
"Set on/off to enable/disable using "
|
||||||
"physical address space above 32 bits",
|
"physical address space above 32 bits");
|
||||||
NULL);
|
|
||||||
vms->gic_version = VIRT_GIC_VERSION_NOSEL;
|
vms->gic_version = VIRT_GIC_VERSION_NOSEL;
|
||||||
object_property_add_str(obj, "gic-version", virt_get_gic_version,
|
object_property_add_str(obj, "gic-version", virt_get_gic_version,
|
||||||
virt_set_gic_version, NULL);
|
virt_set_gic_version, NULL);
|
||||||
object_property_set_description(obj, "gic-version",
|
object_property_set_description(obj, "gic-version",
|
||||||
"Set GIC version. "
|
"Set GIC version. "
|
||||||
"Valid values are 2, 3, host and max",
|
"Valid values are 2, 3, host and max");
|
||||||
NULL);
|
|
||||||
|
|
||||||
vms->highmem_ecam = !vmc->no_highmem_ecam;
|
vms->highmem_ecam = !vmc->no_highmem_ecam;
|
||||||
|
|
||||||
@ -2329,8 +2325,7 @@ static void virt_instance_init(Object *obj)
|
|||||||
virt_set_its, NULL);
|
virt_set_its, NULL);
|
||||||
object_property_set_description(obj, "its",
|
object_property_set_description(obj, "its",
|
||||||
"Set on/off to enable/disable "
|
"Set on/off to enable/disable "
|
||||||
"ITS instantiation",
|
"ITS instantiation");
|
||||||
NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Default disallows iommu instantiation */
|
/* Default disallows iommu instantiation */
|
||||||
@ -2338,8 +2333,7 @@ static void virt_instance_init(Object *obj)
|
|||||||
object_property_add_str(obj, "iommu", virt_get_iommu, virt_set_iommu, NULL);
|
object_property_add_str(obj, "iommu", virt_get_iommu, virt_set_iommu, NULL);
|
||||||
object_property_set_description(obj, "iommu",
|
object_property_set_description(obj, "iommu",
|
||||||
"Set the IOMMU type. "
|
"Set the IOMMU type. "
|
||||||
"Valid values are none and smmuv3",
|
"Valid values are none and smmuv3");
|
||||||
NULL);
|
|
||||||
|
|
||||||
/* Default disallows RAS instantiation */
|
/* Default disallows RAS instantiation */
|
||||||
vms->ras = false;
|
vms->ras = false;
|
||||||
@ -2347,8 +2341,7 @@ static void virt_instance_init(Object *obj)
|
|||||||
virt_set_ras, NULL);
|
virt_set_ras, NULL);
|
||||||
object_property_set_description(obj, "ras",
|
object_property_set_description(obj, "ras",
|
||||||
"Set on/off to enable/disable reporting host memory errors "
|
"Set on/off to enable/disable reporting host memory errors "
|
||||||
"to a KVM guest using ACPI and guest external abort exceptions",
|
"to a KVM guest using ACPI and guest external abort exceptions");
|
||||||
NULL);
|
|
||||||
|
|
||||||
vms->irqmap = a15irqmap;
|
vms->irqmap = a15irqmap;
|
||||||
|
|
||||||
|
@ -212,8 +212,7 @@ static void xlnx_zcu102_machine_instance_init(Object *obj)
|
|||||||
zcu102_set_secure, NULL);
|
zcu102_set_secure, NULL);
|
||||||
object_property_set_description(obj, "secure",
|
object_property_set_description(obj, "secure",
|
||||||
"Set on/off to enable/disable the ARM "
|
"Set on/off to enable/disable the ARM "
|
||||||
"Security Extensions (TrustZone)",
|
"Security Extensions (TrustZone)");
|
||||||
NULL);
|
|
||||||
|
|
||||||
/* Default to virt (EL2) being disabled */
|
/* Default to virt (EL2) being disabled */
|
||||||
s->virt = false;
|
s->virt = false;
|
||||||
@ -222,8 +221,7 @@ static void xlnx_zcu102_machine_instance_init(Object *obj)
|
|||||||
object_property_set_description(obj, "virtualization",
|
object_property_set_description(obj, "virtualization",
|
||||||
"Set on/off to enable/disable emulating a "
|
"Set on/off to enable/disable emulating a "
|
||||||
"guest CPU which implements the ARM "
|
"guest CPU which implements the ARM "
|
||||||
"Virtualization Extensions",
|
"Virtualization Extensions");
|
||||||
NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void xlnx_zcu102_machine_class_init(ObjectClass *oc, void *data)
|
static void xlnx_zcu102_machine_class_init(ObjectClass *oc, void *data)
|
||||||
|
@ -789,83 +789,82 @@ static void machine_class_init(ObjectClass *oc, void *data)
|
|||||||
object_class_property_add_str(oc, "kernel",
|
object_class_property_add_str(oc, "kernel",
|
||||||
machine_get_kernel, machine_set_kernel, &error_abort);
|
machine_get_kernel, machine_set_kernel, &error_abort);
|
||||||
object_class_property_set_description(oc, "kernel",
|
object_class_property_set_description(oc, "kernel",
|
||||||
"Linux kernel image file", &error_abort);
|
"Linux kernel image file");
|
||||||
|
|
||||||
object_class_property_add_str(oc, "initrd",
|
object_class_property_add_str(oc, "initrd",
|
||||||
machine_get_initrd, machine_set_initrd, &error_abort);
|
machine_get_initrd, machine_set_initrd, &error_abort);
|
||||||
object_class_property_set_description(oc, "initrd",
|
object_class_property_set_description(oc, "initrd",
|
||||||
"Linux initial ramdisk file", &error_abort);
|
"Linux initial ramdisk file");
|
||||||
|
|
||||||
object_class_property_add_str(oc, "append",
|
object_class_property_add_str(oc, "append",
|
||||||
machine_get_append, machine_set_append, &error_abort);
|
machine_get_append, machine_set_append, &error_abort);
|
||||||
object_class_property_set_description(oc, "append",
|
object_class_property_set_description(oc, "append",
|
||||||
"Linux kernel command line", &error_abort);
|
"Linux kernel command line");
|
||||||
|
|
||||||
object_class_property_add_str(oc, "dtb",
|
object_class_property_add_str(oc, "dtb",
|
||||||
machine_get_dtb, machine_set_dtb, &error_abort);
|
machine_get_dtb, machine_set_dtb, &error_abort);
|
||||||
object_class_property_set_description(oc, "dtb",
|
object_class_property_set_description(oc, "dtb",
|
||||||
"Linux kernel device tree file", &error_abort);
|
"Linux kernel device tree file");
|
||||||
|
|
||||||
object_class_property_add_str(oc, "dumpdtb",
|
object_class_property_add_str(oc, "dumpdtb",
|
||||||
machine_get_dumpdtb, machine_set_dumpdtb, &error_abort);
|
machine_get_dumpdtb, machine_set_dumpdtb, &error_abort);
|
||||||
object_class_property_set_description(oc, "dumpdtb",
|
object_class_property_set_description(oc, "dumpdtb",
|
||||||
"Dump current dtb to a file and quit", &error_abort);
|
"Dump current dtb to a file and quit");
|
||||||
|
|
||||||
object_class_property_add(oc, "phandle-start", "int",
|
object_class_property_add(oc, "phandle-start", "int",
|
||||||
machine_get_phandle_start, machine_set_phandle_start,
|
machine_get_phandle_start, machine_set_phandle_start,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, "phandle-start",
|
object_class_property_set_description(oc, "phandle-start",
|
||||||
"The first phandle ID we may generate dynamically", &error_abort);
|
"The first phandle ID we may generate dynamically");
|
||||||
|
|
||||||
object_class_property_add_str(oc, "dt-compatible",
|
object_class_property_add_str(oc, "dt-compatible",
|
||||||
machine_get_dt_compatible, machine_set_dt_compatible, &error_abort);
|
machine_get_dt_compatible, machine_set_dt_compatible, &error_abort);
|
||||||
object_class_property_set_description(oc, "dt-compatible",
|
object_class_property_set_description(oc, "dt-compatible",
|
||||||
"Overrides the \"compatible\" property of the dt root node",
|
"Overrides the \"compatible\" property of the dt root node");
|
||||||
&error_abort);
|
|
||||||
|
|
||||||
object_class_property_add_bool(oc, "dump-guest-core",
|
object_class_property_add_bool(oc, "dump-guest-core",
|
||||||
machine_get_dump_guest_core, machine_set_dump_guest_core, &error_abort);
|
machine_get_dump_guest_core, machine_set_dump_guest_core, &error_abort);
|
||||||
object_class_property_set_description(oc, "dump-guest-core",
|
object_class_property_set_description(oc, "dump-guest-core",
|
||||||
"Include guest memory in a core dump", &error_abort);
|
"Include guest memory in a core dump");
|
||||||
|
|
||||||
object_class_property_add_bool(oc, "mem-merge",
|
object_class_property_add_bool(oc, "mem-merge",
|
||||||
machine_get_mem_merge, machine_set_mem_merge, &error_abort);
|
machine_get_mem_merge, machine_set_mem_merge, &error_abort);
|
||||||
object_class_property_set_description(oc, "mem-merge",
|
object_class_property_set_description(oc, "mem-merge",
|
||||||
"Enable/disable memory merge support", &error_abort);
|
"Enable/disable memory merge support");
|
||||||
|
|
||||||
object_class_property_add_bool(oc, "usb",
|
object_class_property_add_bool(oc, "usb",
|
||||||
machine_get_usb, machine_set_usb, &error_abort);
|
machine_get_usb, machine_set_usb, &error_abort);
|
||||||
object_class_property_set_description(oc, "usb",
|
object_class_property_set_description(oc, "usb",
|
||||||
"Set on/off to enable/disable usb", &error_abort);
|
"Set on/off to enable/disable usb");
|
||||||
|
|
||||||
object_class_property_add_bool(oc, "graphics",
|
object_class_property_add_bool(oc, "graphics",
|
||||||
machine_get_graphics, machine_set_graphics, &error_abort);
|
machine_get_graphics, machine_set_graphics, &error_abort);
|
||||||
object_class_property_set_description(oc, "graphics",
|
object_class_property_set_description(oc, "graphics",
|
||||||
"Set on/off to enable/disable graphics emulation", &error_abort);
|
"Set on/off to enable/disable graphics emulation");
|
||||||
|
|
||||||
object_class_property_add_str(oc, "firmware",
|
object_class_property_add_str(oc, "firmware",
|
||||||
machine_get_firmware, machine_set_firmware,
|
machine_get_firmware, machine_set_firmware,
|
||||||
&error_abort);
|
&error_abort);
|
||||||
object_class_property_set_description(oc, "firmware",
|
object_class_property_set_description(oc, "firmware",
|
||||||
"Firmware image", &error_abort);
|
"Firmware image");
|
||||||
|
|
||||||
object_class_property_add_bool(oc, "suppress-vmdesc",
|
object_class_property_add_bool(oc, "suppress-vmdesc",
|
||||||
machine_get_suppress_vmdesc, machine_set_suppress_vmdesc,
|
machine_get_suppress_vmdesc, machine_set_suppress_vmdesc,
|
||||||
&error_abort);
|
&error_abort);
|
||||||
object_class_property_set_description(oc, "suppress-vmdesc",
|
object_class_property_set_description(oc, "suppress-vmdesc",
|
||||||
"Set on to disable self-describing migration", &error_abort);
|
"Set on to disable self-describing migration");
|
||||||
|
|
||||||
object_class_property_add_bool(oc, "enforce-config-section",
|
object_class_property_add_bool(oc, "enforce-config-section",
|
||||||
machine_get_enforce_config_section, machine_set_enforce_config_section,
|
machine_get_enforce_config_section, machine_set_enforce_config_section,
|
||||||
&error_abort);
|
&error_abort);
|
||||||
object_class_property_set_description(oc, "enforce-config-section",
|
object_class_property_set_description(oc, "enforce-config-section",
|
||||||
"Set on to enforce configuration section migration", &error_abort);
|
"Set on to enforce configuration section migration");
|
||||||
|
|
||||||
object_class_property_add_str(oc, "memory-encryption",
|
object_class_property_add_str(oc, "memory-encryption",
|
||||||
machine_get_memory_encryption, machine_set_memory_encryption,
|
machine_get_memory_encryption, machine_set_memory_encryption,
|
||||||
&error_abort);
|
&error_abort);
|
||||||
object_class_property_set_description(oc, "memory-encryption",
|
object_class_property_set_description(oc, "memory-encryption",
|
||||||
"Set memory encryption object to use", &error_abort);
|
"Set memory encryption object to use");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void machine_class_base_init(ObjectClass *oc, void *data)
|
static void machine_class_base_init(ObjectClass *oc, void *data)
|
||||||
@ -898,7 +897,7 @@ static void machine_initfn(Object *obj)
|
|||||||
&error_abort);
|
&error_abort);
|
||||||
object_property_set_description(obj, "nvdimm",
|
object_property_set_description(obj, "nvdimm",
|
||||||
"Set on/off to enable/disable "
|
"Set on/off to enable/disable "
|
||||||
"NVDIMM instantiation", NULL);
|
"NVDIMM instantiation");
|
||||||
|
|
||||||
object_property_add_str(obj, "nvdimm-persistence",
|
object_property_add_str(obj, "nvdimm-persistence",
|
||||||
machine_get_nvdimm_persistence,
|
machine_get_nvdimm_persistence,
|
||||||
@ -906,8 +905,7 @@ static void machine_initfn(Object *obj)
|
|||||||
&error_abort);
|
&error_abort);
|
||||||
object_property_set_description(obj, "nvdimm-persistence",
|
object_property_set_description(obj, "nvdimm-persistence",
|
||||||
"Set NVDIMM persistence"
|
"Set NVDIMM persistence"
|
||||||
"Valid values are cpu, mem-ctrl",
|
"Valid values are cpu, mem-ctrl");
|
||||||
NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mc->cpu_index_to_instance_props && mc->get_default_cpu_node_id) {
|
if (mc->cpu_index_to_instance_props && mc->get_default_cpu_node_id) {
|
||||||
@ -918,7 +916,7 @@ static void machine_initfn(Object *obj)
|
|||||||
object_property_set_description(obj, "hmat",
|
object_property_set_description(obj, "hmat",
|
||||||
"Set on/off to enable/disable "
|
"Set on/off to enable/disable "
|
||||||
"ACPI Heterogeneous Memory Attribute "
|
"ACPI Heterogeneous Memory Attribute "
|
||||||
"Table (HMAT)", NULL);
|
"Table (HMAT)");
|
||||||
}
|
}
|
||||||
|
|
||||||
object_property_add_str(obj, "memory-backend",
|
object_property_add_str(obj, "memory-backend",
|
||||||
@ -926,8 +924,7 @@ static void machine_initfn(Object *obj)
|
|||||||
&error_abort);
|
&error_abort);
|
||||||
object_property_set_description(obj, "memory-backend",
|
object_property_set_description(obj, "memory-backend",
|
||||||
"Set RAM backend"
|
"Set RAM backend"
|
||||||
"Valid value is ID of hostmem based backend",
|
"Valid value is ID of hostmem based backend");
|
||||||
&error_abort);
|
|
||||||
|
|
||||||
/* Register notifier when init is done for sysbus sanity checks */
|
/* Register notifier when init is done for sysbus sanity checks */
|
||||||
ms->sysbus_notifier.notify = machine_init_notify;
|
ms->sysbus_notifier.notify = machine_init_notify;
|
||||||
|
@ -775,8 +775,7 @@ void qdev_property_add_static(DeviceState *dev, Property *prop)
|
|||||||
prop, &error_abort);
|
prop, &error_abort);
|
||||||
|
|
||||||
object_property_set_description(obj, prop->name,
|
object_property_set_description(obj, prop->name,
|
||||||
prop->info->description,
|
prop->info->description);
|
||||||
&error_abort);
|
|
||||||
|
|
||||||
if (prop->set_default) {
|
if (prop->set_default) {
|
||||||
prop->info->set_default_value(op, prop);
|
prop->info->set_default_value(op, prop);
|
||||||
@ -805,8 +804,7 @@ static void qdev_class_add_property(DeviceClass *klass, Property *prop)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
object_class_property_set_description(oc, prop->name,
|
object_class_property_set_description(oc, prop->name,
|
||||||
prop->info->description,
|
prop->info->description);
|
||||||
&error_abort);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* @qdev_alias_all_properties - Add alias properties to the source object for
|
/* @qdev_alias_all_properties - Add alias properties to the source object for
|
||||||
|
@ -512,36 +512,35 @@ static void microvm_class_init(ObjectClass *oc, void *data)
|
|||||||
microvm_machine_set_pic,
|
microvm_machine_set_pic,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, MICROVM_MACHINE_PIC,
|
object_class_property_set_description(oc, MICROVM_MACHINE_PIC,
|
||||||
"Enable i8259 PIC", &error_abort);
|
"Enable i8259 PIC");
|
||||||
|
|
||||||
object_class_property_add(oc, MICROVM_MACHINE_PIT, "OnOffAuto",
|
object_class_property_add(oc, MICROVM_MACHINE_PIT, "OnOffAuto",
|
||||||
microvm_machine_get_pit,
|
microvm_machine_get_pit,
|
||||||
microvm_machine_set_pit,
|
microvm_machine_set_pit,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, MICROVM_MACHINE_PIT,
|
object_class_property_set_description(oc, MICROVM_MACHINE_PIT,
|
||||||
"Enable i8254 PIT", &error_abort);
|
"Enable i8254 PIT");
|
||||||
|
|
||||||
object_class_property_add(oc, MICROVM_MACHINE_RTC, "OnOffAuto",
|
object_class_property_add(oc, MICROVM_MACHINE_RTC, "OnOffAuto",
|
||||||
microvm_machine_get_rtc,
|
microvm_machine_get_rtc,
|
||||||
microvm_machine_set_rtc,
|
microvm_machine_set_rtc,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, MICROVM_MACHINE_RTC,
|
object_class_property_set_description(oc, MICROVM_MACHINE_RTC,
|
||||||
"Enable MC146818 RTC", &error_abort);
|
"Enable MC146818 RTC");
|
||||||
|
|
||||||
object_class_property_add_bool(oc, MICROVM_MACHINE_ISA_SERIAL,
|
object_class_property_add_bool(oc, MICROVM_MACHINE_ISA_SERIAL,
|
||||||
microvm_machine_get_isa_serial,
|
microvm_machine_get_isa_serial,
|
||||||
microvm_machine_set_isa_serial,
|
microvm_machine_set_isa_serial,
|
||||||
&error_abort);
|
&error_abort);
|
||||||
object_class_property_set_description(oc, MICROVM_MACHINE_ISA_SERIAL,
|
object_class_property_set_description(oc, MICROVM_MACHINE_ISA_SERIAL,
|
||||||
"Set off to disable the instantiation an ISA serial port",
|
"Set off to disable the instantiation an ISA serial port");
|
||||||
&error_abort);
|
|
||||||
|
|
||||||
object_class_property_add_bool(oc, MICROVM_MACHINE_OPTION_ROMS,
|
object_class_property_add_bool(oc, MICROVM_MACHINE_OPTION_ROMS,
|
||||||
microvm_machine_get_option_roms,
|
microvm_machine_get_option_roms,
|
||||||
microvm_machine_set_option_roms,
|
microvm_machine_set_option_roms,
|
||||||
&error_abort);
|
&error_abort);
|
||||||
object_class_property_set_description(oc, MICROVM_MACHINE_OPTION_ROMS,
|
object_class_property_set_description(oc, MICROVM_MACHINE_OPTION_ROMS,
|
||||||
"Set off to disable loading option ROMs", &error_abort);
|
"Set off to disable loading option ROMs");
|
||||||
|
|
||||||
object_class_property_add_bool(oc, MICROVM_MACHINE_AUTO_KERNEL_CMDLINE,
|
object_class_property_add_bool(oc, MICROVM_MACHINE_AUTO_KERNEL_CMDLINE,
|
||||||
microvm_machine_get_auto_kernel_cmdline,
|
microvm_machine_get_auto_kernel_cmdline,
|
||||||
@ -549,8 +548,7 @@ static void microvm_class_init(ObjectClass *oc, void *data)
|
|||||||
&error_abort);
|
&error_abort);
|
||||||
object_class_property_set_description(oc,
|
object_class_property_set_description(oc,
|
||||||
MICROVM_MACHINE_AUTO_KERNEL_CMDLINE,
|
MICROVM_MACHINE_AUTO_KERNEL_CMDLINE,
|
||||||
"Set off to disable adding virtio-mmio devices to the kernel cmdline",
|
"Set off to disable adding virtio-mmio devices to the kernel cmdline");
|
||||||
&error_abort);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const TypeInfo microvm_machine_info = {
|
static const TypeInfo microvm_machine_info = {
|
||||||
|
@ -1971,7 +1971,7 @@ static void pc_machine_class_init(ObjectClass *oc, void *data)
|
|||||||
pc_machine_get_vmport, pc_machine_set_vmport,
|
pc_machine_get_vmport, pc_machine_set_vmport,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, PC_MACHINE_VMPORT,
|
object_class_property_set_description(oc, PC_MACHINE_VMPORT,
|
||||||
"Enable vmport (pc & q35)", &error_abort);
|
"Enable vmport (pc & q35)");
|
||||||
|
|
||||||
object_class_property_add_bool(oc, PC_MACHINE_SMBUS,
|
object_class_property_add_bool(oc, PC_MACHINE_SMBUS,
|
||||||
pc_machine_get_smbus, pc_machine_set_smbus, &error_abort);
|
pc_machine_get_smbus, pc_machine_set_smbus, &error_abort);
|
||||||
|
@ -984,19 +984,19 @@ static void x86_machine_class_init(ObjectClass *oc, void *data)
|
|||||||
x86_machine_get_max_ram_below_4g, x86_machine_set_max_ram_below_4g,
|
x86_machine_get_max_ram_below_4g, x86_machine_set_max_ram_below_4g,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, X86_MACHINE_MAX_RAM_BELOW_4G,
|
object_class_property_set_description(oc, X86_MACHINE_MAX_RAM_BELOW_4G,
|
||||||
"Maximum ram below the 4G boundary (32bit boundary)", &error_abort);
|
"Maximum ram below the 4G boundary (32bit boundary)");
|
||||||
|
|
||||||
object_class_property_add(oc, X86_MACHINE_SMM, "OnOffAuto",
|
object_class_property_add(oc, X86_MACHINE_SMM, "OnOffAuto",
|
||||||
x86_machine_get_smm, x86_machine_set_smm,
|
x86_machine_get_smm, x86_machine_set_smm,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, X86_MACHINE_SMM,
|
object_class_property_set_description(oc, X86_MACHINE_SMM,
|
||||||
"Enable SMM", &error_abort);
|
"Enable SMM");
|
||||||
|
|
||||||
object_class_property_add(oc, X86_MACHINE_ACPI, "OnOffAuto",
|
object_class_property_add(oc, X86_MACHINE_ACPI, "OnOffAuto",
|
||||||
x86_machine_get_acpi, x86_machine_set_acpi,
|
x86_machine_get_acpi, x86_machine_set_acpi,
|
||||||
NULL, NULL, &error_abort);
|
NULL, NULL, &error_abort);
|
||||||
object_class_property_set_description(oc, X86_MACHINE_ACPI,
|
object_class_property_set_description(oc, X86_MACHINE_ACPI,
|
||||||
"Enable ACPI", &error_abort);
|
"Enable ACPI");
|
||||||
}
|
}
|
||||||
|
|
||||||
static const TypeInfo x86_machine_info = {
|
static const TypeInfo x86_machine_info = {
|
||||||
|
@ -631,8 +631,7 @@ static void core99_instance_init(Object *obj)
|
|||||||
core99_set_via_config, NULL);
|
core99_set_via_config, NULL);
|
||||||
object_property_set_description(obj, "via",
|
object_property_set_description(obj, "via",
|
||||||
"Set VIA configuration. "
|
"Set VIA configuration. "
|
||||||
"Valid values are cuda, pmu and pmu-adb",
|
"Valid values are cuda, pmu and pmu-adb");
|
||||||
NULL);
|
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -2030,8 +2030,7 @@ static void pnv_machine_class_init(ObjectClass *oc, void *data)
|
|||||||
pnv_machine_get_hb, pnv_machine_set_hb,
|
pnv_machine_get_hb, pnv_machine_set_hb,
|
||||||
&error_abort);
|
&error_abort);
|
||||||
object_class_property_set_description(oc, "hb-mode",
|
object_class_property_set_description(oc, "hb-mode",
|
||||||
"Use a hostboot like boot loader",
|
"Use a hostboot like boot loader");
|
||||||
NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#define DEFINE_PNV8_CHIP_TYPE(type, class_initfn) \
|
#define DEFINE_PNV8_CHIP_TYPE(type, class_initfn) \
|
||||||
|
@ -3307,8 +3307,7 @@ static void spapr_instance_init(Object *obj)
|
|||||||
object_property_add_str(obj, "kvm-type",
|
object_property_add_str(obj, "kvm-type",
|
||||||
spapr_get_kvm_type, spapr_set_kvm_type, NULL);
|
spapr_get_kvm_type, spapr_set_kvm_type, NULL);
|
||||||
object_property_set_description(obj, "kvm-type",
|
object_property_set_description(obj, "kvm-type",
|
||||||
"Specifies the KVM virtualization mode (HV, PR)",
|
"Specifies the KVM virtualization mode (HV, PR)");
|
||||||
NULL);
|
|
||||||
object_property_add_bool(obj, "modern-hotplug-events",
|
object_property_add_bool(obj, "modern-hotplug-events",
|
||||||
spapr_get_modern_hotplug_events,
|
spapr_get_modern_hotplug_events,
|
||||||
spapr_set_modern_hotplug_events,
|
spapr_set_modern_hotplug_events,
|
||||||
@ -3316,8 +3315,7 @@ static void spapr_instance_init(Object *obj)
|
|||||||
object_property_set_description(obj, "modern-hotplug-events",
|
object_property_set_description(obj, "modern-hotplug-events",
|
||||||
"Use dedicated hotplug event mechanism in"
|
"Use dedicated hotplug event mechanism in"
|
||||||
" place of standard EPOW events when possible"
|
" place of standard EPOW events when possible"
|
||||||
" (required for memory hot-unplug support)",
|
" (required for memory hot-unplug support)");
|
||||||
NULL);
|
|
||||||
ppc_compat_add_property(obj, "max-cpu-compat", &spapr->max_compat_pvr,
|
ppc_compat_add_property(obj, "max-cpu-compat", &spapr->max_compat_pvr,
|
||||||
"Maximum permitted CPU compatibility mode",
|
"Maximum permitted CPU compatibility mode",
|
||||||
&error_fatal);
|
&error_fatal);
|
||||||
@ -3325,14 +3323,13 @@ static void spapr_instance_init(Object *obj)
|
|||||||
object_property_add_str(obj, "resize-hpt",
|
object_property_add_str(obj, "resize-hpt",
|
||||||
spapr_get_resize_hpt, spapr_set_resize_hpt, NULL);
|
spapr_get_resize_hpt, spapr_set_resize_hpt, NULL);
|
||||||
object_property_set_description(obj, "resize-hpt",
|
object_property_set_description(obj, "resize-hpt",
|
||||||
"Resizing of the Hash Page Table (enabled, disabled, required)",
|
"Resizing of the Hash Page Table (enabled, disabled, required)");
|
||||||
NULL);
|
|
||||||
object_property_add_uint32_ptr(obj, "vsmt",
|
object_property_add_uint32_ptr(obj, "vsmt",
|
||||||
&spapr->vsmt, OBJ_PROP_FLAG_READWRITE,
|
&spapr->vsmt, OBJ_PROP_FLAG_READWRITE,
|
||||||
&error_abort);
|
&error_abort);
|
||||||
object_property_set_description(obj, "vsmt",
|
object_property_set_description(obj, "vsmt",
|
||||||
"Virtual SMT: KVM behaves as if this were"
|
"Virtual SMT: KVM behaves as if this were"
|
||||||
" the host's SMT mode", &error_abort);
|
" the host's SMT mode");
|
||||||
|
|
||||||
object_property_add_bool(obj, "vfio-no-msix-emulation",
|
object_property_add_bool(obj, "vfio-no-msix-emulation",
|
||||||
spapr_get_msix_emulation, NULL, NULL);
|
spapr_get_msix_emulation, NULL, NULL);
|
||||||
@ -3342,27 +3339,25 @@ static void spapr_instance_init(Object *obj)
|
|||||||
&error_abort);
|
&error_abort);
|
||||||
object_property_set_description(obj, "kernel-addr",
|
object_property_set_description(obj, "kernel-addr",
|
||||||
stringify(KERNEL_LOAD_ADDR)
|
stringify(KERNEL_LOAD_ADDR)
|
||||||
" for -kernel is the default",
|
" for -kernel is the default");
|
||||||
NULL);
|
|
||||||
spapr->kernel_addr = KERNEL_LOAD_ADDR;
|
spapr->kernel_addr = KERNEL_LOAD_ADDR;
|
||||||
/* The machine class defines the default interrupt controller mode */
|
/* The machine class defines the default interrupt controller mode */
|
||||||
spapr->irq = smc->irq;
|
spapr->irq = smc->irq;
|
||||||
object_property_add_str(obj, "ic-mode", spapr_get_ic_mode,
|
object_property_add_str(obj, "ic-mode", spapr_get_ic_mode,
|
||||||
spapr_set_ic_mode, NULL);
|
spapr_set_ic_mode, NULL);
|
||||||
object_property_set_description(obj, "ic-mode",
|
object_property_set_description(obj, "ic-mode",
|
||||||
"Specifies the interrupt controller mode (xics, xive, dual)",
|
"Specifies the interrupt controller mode (xics, xive, dual)");
|
||||||
NULL);
|
|
||||||
|
|
||||||
object_property_add_str(obj, "host-model",
|
object_property_add_str(obj, "host-model",
|
||||||
spapr_get_host_model, spapr_set_host_model,
|
spapr_get_host_model, spapr_set_host_model,
|
||||||
&error_abort);
|
&error_abort);
|
||||||
object_property_set_description(obj, "host-model",
|
object_property_set_description(obj, "host-model",
|
||||||
"Host model to advertise in guest device tree", &error_abort);
|
"Host model to advertise in guest device tree");
|
||||||
object_property_add_str(obj, "host-serial",
|
object_property_add_str(obj, "host-serial",
|
||||||
spapr_get_host_serial, spapr_set_host_serial,
|
spapr_get_host_serial, spapr_set_host_serial,
|
||||||
&error_abort);
|
&error_abort);
|
||||||
object_property_set_description(obj, "host-serial",
|
object_property_set_description(obj, "host-serial",
|
||||||
"Host serial number to advertise in guest device tree", &error_abort);
|
"Host serial number to advertise in guest device tree");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void spapr_machine_finalizefn(Object *obj)
|
static void spapr_machine_finalizefn(Object *obj)
|
||||||
|
@ -845,12 +845,8 @@ void spapr_caps_add_properties(SpaprMachineClass *smc, Error **errp)
|
|||||||
}
|
}
|
||||||
|
|
||||||
desc = g_strdup_printf("%s", cap->description);
|
desc = g_strdup_printf("%s", cap->description);
|
||||||
object_class_property_set_description(klass, name, desc, &local_err);
|
object_class_property_set_description(klass, name, desc);
|
||||||
g_free(name);
|
g_free(name);
|
||||||
g_free(desc);
|
g_free(desc);
|
||||||
if (local_err) {
|
|
||||||
error_propagate(errp, local_err);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -103,8 +103,7 @@ static void spapr_rng_instance_init(Object *obj)
|
|||||||
}
|
}
|
||||||
|
|
||||||
object_property_set_description(obj, "rng",
|
object_property_set_description(obj, "rng",
|
||||||
"ID of the random number generator backend",
|
"ID of the random number generator backend");
|
||||||
NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void spapr_rng_realize(DeviceState *dev, Error **errp)
|
static void spapr_rng_realize(DeviceState *dev, Error **errp)
|
||||||
|
@ -445,13 +445,12 @@ static void sifive_u_machine_instance_init(Object *obj)
|
|||||||
sifive_u_machine_set_start_in_flash, NULL);
|
sifive_u_machine_set_start_in_flash, NULL);
|
||||||
object_property_set_description(obj, "start-in-flash",
|
object_property_set_description(obj, "start-in-flash",
|
||||||
"Set on to tell QEMU's ROM to jump to "
|
"Set on to tell QEMU's ROM to jump to "
|
||||||
"flash. Otherwise QEMU will jump to DRAM",
|
"flash. Otherwise QEMU will jump to DRAM");
|
||||||
NULL);
|
|
||||||
|
|
||||||
s->serial = OTP_SERIAL;
|
s->serial = OTP_SERIAL;
|
||||||
object_property_add(obj, "serial", "uint32", sifive_u_machine_get_serial,
|
object_property_add(obj, "serial", "uint32", sifive_u_machine_get_serial,
|
||||||
sifive_u_machine_set_serial, NULL, &s->serial, NULL);
|
sifive_u_machine_set_serial, NULL, &s->serial, NULL);
|
||||||
object_property_set_description(obj, "serial", "Board serial number", NULL);
|
object_property_set_description(obj, "serial", "Board serial number");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void sifive_u_machine_class_init(ObjectClass *oc, void *data)
|
static void sifive_u_machine_class_init(ObjectClass *oc, void *data)
|
||||||
|
@ -144,8 +144,7 @@ static void virtual_css_bridge_class_init(ObjectClass *klass, void *data)
|
|||||||
prop_get_true, NULL, NULL);
|
prop_get_true, NULL, NULL);
|
||||||
object_class_property_set_description(klass, "cssid-unrestricted",
|
object_class_property_set_description(klass, "cssid-unrestricted",
|
||||||
"A css device can use any cssid, regardless whether virtual"
|
"A css device can use any cssid, regardless whether virtual"
|
||||||
" or not (read only, always true)",
|
" or not (read only, always true)");
|
||||||
NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const TypeInfo virtual_css_bridge_info = {
|
static const TypeInfo virtual_css_bridge_info = {
|
||||||
|
@ -731,24 +731,21 @@ static inline void s390_machine_initfn(Object *obj)
|
|||||||
machine_get_aes_key_wrap,
|
machine_get_aes_key_wrap,
|
||||||
machine_set_aes_key_wrap, NULL);
|
machine_set_aes_key_wrap, NULL);
|
||||||
object_property_set_description(obj, "aes-key-wrap",
|
object_property_set_description(obj, "aes-key-wrap",
|
||||||
"enable/disable AES key wrapping using the CPACF wrapping key",
|
"enable/disable AES key wrapping using the CPACF wrapping key");
|
||||||
NULL);
|
|
||||||
object_property_set_bool(obj, true, "aes-key-wrap", NULL);
|
object_property_set_bool(obj, true, "aes-key-wrap", NULL);
|
||||||
|
|
||||||
object_property_add_bool(obj, "dea-key-wrap",
|
object_property_add_bool(obj, "dea-key-wrap",
|
||||||
machine_get_dea_key_wrap,
|
machine_get_dea_key_wrap,
|
||||||
machine_set_dea_key_wrap, NULL);
|
machine_set_dea_key_wrap, NULL);
|
||||||
object_property_set_description(obj, "dea-key-wrap",
|
object_property_set_description(obj, "dea-key-wrap",
|
||||||
"enable/disable DEA key wrapping using the CPACF wrapping key",
|
"enable/disable DEA key wrapping using the CPACF wrapping key");
|
||||||
NULL);
|
|
||||||
object_property_set_bool(obj, true, "dea-key-wrap", NULL);
|
object_property_set_bool(obj, true, "dea-key-wrap", NULL);
|
||||||
object_property_add_str(obj, "loadparm",
|
object_property_add_str(obj, "loadparm",
|
||||||
machine_get_loadparm, machine_set_loadparm, NULL);
|
machine_get_loadparm, machine_set_loadparm, NULL);
|
||||||
object_property_set_description(obj, "loadparm",
|
object_property_set_description(obj, "loadparm",
|
||||||
"Up to 8 chars in set of [A-Za-z0-9. ] (lower case chars converted"
|
"Up to 8 chars in set of [A-Za-z0-9. ] (lower case chars converted"
|
||||||
" to upper case) to pass to machine loader, boot manager,"
|
" to upper case) to pass to machine loader, boot manager,"
|
||||||
" and guest kernel",
|
" and guest kernel");
|
||||||
NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const TypeInfo ccw_machine_info = {
|
static const TypeInfo ccw_machine_info = {
|
||||||
|
@ -797,8 +797,7 @@ static void ram_initfn(Object *obj)
|
|||||||
object_property_allow_set_link,
|
object_property_allow_set_link,
|
||||||
OBJ_PROP_LINK_STRONG, &error_abort);
|
OBJ_PROP_LINK_STRONG, &error_abort);
|
||||||
object_property_set_description(obj, "memdev", "Set RAM backend"
|
object_property_set_description(obj, "memdev", "Set RAM backend"
|
||||||
"Valid value is ID of a hostmem backend",
|
"Valid value is ID of a hostmem backend");
|
||||||
&error_abort);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ram_class_init(ObjectClass *klass, void *data)
|
static void ram_class_init(ObjectClass *klass, void *data)
|
||||||
|
@ -201,7 +201,7 @@ static void xen_accel_class_init(ObjectClass *oc, void *data)
|
|||||||
xen_get_igd_gfx_passthru, xen_set_igd_gfx_passthru,
|
xen_get_igd_gfx_passthru, xen_set_igd_gfx_passthru,
|
||||||
&error_abort);
|
&error_abort);
|
||||||
object_class_property_set_description(oc, "igd-passthru",
|
object_class_property_set_description(oc, "igd-passthru",
|
||||||
"Set on/off to enable/disable igd passthrou", &error_abort);
|
"Set on/off to enable/disable igd passthrou");
|
||||||
}
|
}
|
||||||
|
|
||||||
#define TYPE_XEN_ACCEL ACCEL_CLASS_NAME("xen")
|
#define TYPE_XEN_ACCEL ACCEL_CLASS_NAME("xen")
|
||||||
|
@ -1813,16 +1813,14 @@ ObjectProperty *object_property_add_const_link(Object *obj, const char *name,
|
|||||||
* @obj: the object owning the property
|
* @obj: the object owning the property
|
||||||
* @name: the name of the property
|
* @name: the name of the property
|
||||||
* @description: the description of the property on the object
|
* @description: the description of the property on the object
|
||||||
* @errp: if an error occurs, a pointer to an area to store the error
|
|
||||||
*
|
*
|
||||||
* Set an object property's description.
|
* Set an object property's description.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
void object_property_set_description(Object *obj, const char *name,
|
void object_property_set_description(Object *obj, const char *name,
|
||||||
const char *description, Error **errp);
|
const char *description);
|
||||||
void object_class_property_set_description(ObjectClass *klass, const char *name,
|
void object_class_property_set_description(ObjectClass *klass, const char *name,
|
||||||
const char *description,
|
const char *description);
|
||||||
Error **errp);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* object_child_foreach:
|
* object_child_foreach:
|
||||||
|
19
qom/object.c
19
qom/object.c
@ -2802,38 +2802,27 @@ object_property_add_alias(Object *obj, const char *name,
|
|||||||
}
|
}
|
||||||
|
|
||||||
object_property_set_description(obj, op->name,
|
object_property_set_description(obj, op->name,
|
||||||
target_prop->description,
|
target_prop->description);
|
||||||
&error_abort);
|
|
||||||
return op;
|
return op;
|
||||||
}
|
}
|
||||||
|
|
||||||
void object_property_set_description(Object *obj, const char *name,
|
void object_property_set_description(Object *obj, const char *name,
|
||||||
const char *description, Error **errp)
|
const char *description)
|
||||||
{
|
{
|
||||||
ObjectProperty *op;
|
ObjectProperty *op;
|
||||||
|
|
||||||
op = object_property_find(obj, name, errp);
|
op = object_property_find(obj, name, &error_abort);
|
||||||
if (!op) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
g_free(op->description);
|
g_free(op->description);
|
||||||
op->description = g_strdup(description);
|
op->description = g_strdup(description);
|
||||||
}
|
}
|
||||||
|
|
||||||
void object_class_property_set_description(ObjectClass *klass,
|
void object_class_property_set_description(ObjectClass *klass,
|
||||||
const char *name,
|
const char *name,
|
||||||
const char *description,
|
const char *description)
|
||||||
Error **errp)
|
|
||||||
{
|
{
|
||||||
ObjectProperty *op;
|
ObjectProperty *op;
|
||||||
|
|
||||||
op = g_hash_table_lookup(klass->properties, name);
|
op = g_hash_table_lookup(klass->properties, name);
|
||||||
if (!op) {
|
|
||||||
error_setg(errp, "Property '.%s' not found", name);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
g_free(op->description);
|
g_free(op->description);
|
||||||
op->description = g_strdup(description);
|
op->description = g_strdup(description);
|
||||||
}
|
}
|
||||||
|
@ -770,8 +770,7 @@ static void aarch64_cpu_initfn(Object *obj)
|
|||||||
aarch64_cpu_set_aarch64, NULL);
|
aarch64_cpu_set_aarch64, NULL);
|
||||||
object_property_set_description(obj, "aarch64",
|
object_property_set_description(obj, "aarch64",
|
||||||
"Set on/off to enable/disable aarch64 "
|
"Set on/off to enable/disable aarch64 "
|
||||||
"execution state ",
|
"execution state ");
|
||||||
NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void aarch64_cpu_finalizefn(Object *obj)
|
static void aarch64_cpu_finalizefn(Object *obj)
|
||||||
|
@ -204,7 +204,7 @@ void kvm_arm_add_vcpu_properties(Object *obj)
|
|||||||
object_property_set_description(obj, "kvm-no-adjvtime",
|
object_property_set_description(obj, "kvm-no-adjvtime",
|
||||||
"Set on to disable the adjustment of "
|
"Set on to disable the adjustment of "
|
||||||
"the virtual counter. VM stopped time "
|
"the virtual counter. VM stopped time "
|
||||||
"will be counted.", &error_abort);
|
"will be counted.");
|
||||||
}
|
}
|
||||||
|
|
||||||
bool kvm_arm_pmu_supported(CPUState *cpu)
|
bool kvm_arm_pmu_supported(CPUState *cpu)
|
||||||
|
@ -251,19 +251,19 @@ qsev_guest_class_init(ObjectClass *oc, void *data)
|
|||||||
qsev_guest_set_sev_device,
|
qsev_guest_set_sev_device,
|
||||||
NULL);
|
NULL);
|
||||||
object_class_property_set_description(oc, "sev-device",
|
object_class_property_set_description(oc, "sev-device",
|
||||||
"SEV device to use", NULL);
|
"SEV device to use");
|
||||||
object_class_property_add_str(oc, "dh-cert-file",
|
object_class_property_add_str(oc, "dh-cert-file",
|
||||||
qsev_guest_get_dh_cert_file,
|
qsev_guest_get_dh_cert_file,
|
||||||
qsev_guest_set_dh_cert_file,
|
qsev_guest_set_dh_cert_file,
|
||||||
NULL);
|
NULL);
|
||||||
object_class_property_set_description(oc, "dh-cert-file",
|
object_class_property_set_description(oc, "dh-cert-file",
|
||||||
"guest owners DH certificate (encoded with base64)", NULL);
|
"guest owners DH certificate (encoded with base64)");
|
||||||
object_class_property_add_str(oc, "session-file",
|
object_class_property_add_str(oc, "session-file",
|
||||||
qsev_guest_get_session_file,
|
qsev_guest_get_session_file,
|
||||||
qsev_guest_set_session_file,
|
qsev_guest_set_session_file,
|
||||||
NULL);
|
NULL);
|
||||||
object_class_property_set_description(oc, "session-file",
|
object_class_property_set_description(oc, "session-file",
|
||||||
"guest owners session parameters (encoded with base64)", NULL);
|
"guest owners session parameters (encoded with base64)");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -324,7 +324,7 @@ void ppc_compat_add_property(Object *obj, const char *name,
|
|||||||
|
|
||||||
names = g_strjoinv(", ", namesv);
|
names = g_strjoinv(", ", namesv);
|
||||||
desc = g_strdup_printf("%s. Valid values are %s.", basedesc, names);
|
desc = g_strdup_printf("%s. Valid values are %s.", basedesc, names);
|
||||||
object_property_set_description(obj, name, desc, &local_err);
|
object_property_set_description(obj, name, desc);
|
||||||
|
|
||||||
g_free(names);
|
g_free(names);
|
||||||
g_free(desc);
|
g_free(desc);
|
||||||
|
@ -1107,13 +1107,13 @@ void s390_cpu_model_register_props(Object *obj)
|
|||||||
const S390FeatDef *def = s390_feat_def(feat);
|
const S390FeatDef *def = s390_feat_def(feat);
|
||||||
object_property_add(obj, def->name, "bool", get_feature,
|
object_property_add(obj, def->name, "bool", get_feature,
|
||||||
set_feature, NULL, (void *) feat, NULL);
|
set_feature, NULL, (void *) feat, NULL);
|
||||||
object_property_set_description(obj, def->name, def->desc , NULL);
|
object_property_set_description(obj, def->name, def->desc);
|
||||||
}
|
}
|
||||||
for (group = 0; group < S390_FEAT_GROUP_MAX; group++) {
|
for (group = 0; group < S390_FEAT_GROUP_MAX; group++) {
|
||||||
const S390FeatGroupDef *def = s390_feat_group_def(group);
|
const S390FeatGroupDef *def = s390_feat_group_def(group);
|
||||||
object_property_add(obj, def->name, "bool", get_feature_group,
|
object_property_add(obj, def->name, "bool", get_feature_group,
|
||||||
set_feature_group, NULL, (void *) group, NULL);
|
set_feature_group, NULL, (void *) group, NULL);
|
||||||
object_property_set_description(obj, def->name, def->desc , NULL);
|
object_property_set_description(obj, def->name, def->desc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user