[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 1/5] qdev: add user_creatable_requires_machine_allowance class
From: |
Damien Hedde |
Subject: |
[PATCH v2 1/5] qdev: add user_creatable_requires_machine_allowance class flag |
Date: |
Thu, 31 Mar 2022 13:53:08 +0200 |
This flag will be used in device_add to check if
the device needs special allowance from the machine
model.
It will replace the current check based only on the
device being a TYPE_SYB_BUS_DEVICE.
Signed-off-by: Damien Hedde <damien.hedde@greensocs.com>
---
v2:
+ change the flag name and put it just below user_creatable
---
include/hw/qdev-core.h | 9 +++++++++
hw/core/qdev.c | 1 +
hw/core/sysbus.c | 1 +
3 files changed, 11 insertions(+)
diff --git a/include/hw/qdev-core.h b/include/hw/qdev-core.h
index 92c3d65208..6a040fcd3b 100644
--- a/include/hw/qdev-core.h
+++ b/include/hw/qdev-core.h
@@ -122,6 +122,15 @@ struct DeviceClass {
* TODO remove once we're there
*/
bool user_creatable;
+ /*
+ * Some devices can be user created under certain conditions (eg:
+ * specific machine support for sysbus devices), but it is
+ * preferable to prevent global allowance for the reasons
+ * described above.
+ * This flag is an additional constraint over user_creatable:
+ * user_creatable still needs to be set to true.
+ */
+ bool user_creatable_requires_machine_allowance;
bool hotpluggable;
/* callbacks */
diff --git a/hw/core/qdev.c b/hw/core/qdev.c
index 84f3019440..0844c85a21 100644
--- a/hw/core/qdev.c
+++ b/hw/core/qdev.c
@@ -833,6 +833,7 @@ static void device_class_init(ObjectClass *class, void
*data)
*/
dc->hotpluggable = true;
dc->user_creatable = true;
+ dc->user_creatable_requires_machine_allowance = false;
vc->get_id = device_vmstate_if_get_id;
rc->get_state = device_get_reset_state;
rc->child_foreach = device_reset_child_foreach;
diff --git a/hw/core/sysbus.c b/hw/core/sysbus.c
index 05c1da3d31..5f771ed1e9 100644
--- a/hw/core/sysbus.c
+++ b/hw/core/sysbus.c
@@ -325,6 +325,7 @@ static void sysbus_device_class_init(ObjectClass *klass,
void *data)
* subclass needs to override it and set user_creatable=true.
*/
k->user_creatable = false;
+ k->user_creatable_requires_machine_allowance = true;
}
static const TypeInfo sysbus_device_type_info = {
--
2.35.1