qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [PATCH 05/25] qom: push type up to Object


From: Anthony Liguori
Subject: Re: [Qemu-devel] [PATCH 05/25] qom: push type up to Object
Date: Tue, 03 Apr 2012 15:55:25 -0500
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:11.0) Gecko/20120310 Thunderbird/11.0

On 04/03/2012 06:15 AM, Paolo Bonzini wrote:
Now that Object is a type, add an instance_init function and push
the "type" property from qdev to there.

Signed-off-by: Paolo Bonzini<address@hidden>

Reviewed-by: Anthony Liguori <address@hidden>

Regards,

Anthony Liguori

---
  hw/qdev.c    |    6 ------
  qom/object.c |   11 +++++++++++
  2 files changed, 11 insertions(+), 6 deletions(-)

diff --git a/hw/qdev.c b/hw/qdev.c
index 0d3c0fc..bb6c1aa 100644
--- a/hw/qdev.c
+++ b/hw/qdev.c
@@ -510,11 +510,6 @@ char* qdev_get_fw_dev_path(DeviceState *dev)
      return strdup(path);
  }

-static char *qdev_get_type(Object *obj, Error **errp)
-{
-    return g_strdup(object_get_typename(obj));
-}
-
  /**
   * Legacy property handling
   */
@@ -630,7 +625,6 @@ static void device_initfn(Object *obj)
          qdev_property_add_static(dev, prop, NULL);
      }

-    object_property_add_str(OBJECT(dev), "type", qdev_get_type, NULL, NULL);
      qdev_prop_set_defaults(dev, qdev_get_props(dev));
  }

diff --git a/qom/object.c b/qom/object.c
index 585619d..f3ffaa6 100644
--- a/qom/object.c
+++ b/qom/object.c
@@ -1215,6 +1215,16 @@ void object_property_add_str(Object *obj, const char 
*name,
                          prop, errp);
  }

+static char *qdev_get_type(Object *obj, Error **errp)
+{
+    return g_strdup(object_get_typename(obj));
+}
+
+static void object_instance_init(Object *obj)
+{
+    object_property_add_str(obj, "type", qdev_get_type, NULL, NULL);
+}
+
  static void register_types(void)
  {
      static TypeInfo interface_info = {
@@ -1226,6 +1236,7 @@ static void register_types(void)
      static TypeInfo object_info = {
          .name = TYPE_OBJECT,
          .instance_size = sizeof(Object),
+        .instance_init = object_instance_init,
          .abstract = true,
      };





reply via email to

[Prev in Thread] Current Thread [Next in Thread]