qemu-devel
[Top][All Lists]
Advanced

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

[Qemu-devel] [PATCH v6 08/27] virtio-net: add bootindex to qom property


From: arei.gonglei
Subject: [Qemu-devel] [PATCH v6 08/27] virtio-net: add bootindex to qom property
Date: Sat, 30 Aug 2014 18:00:08 +0800

From: Gonglei <address@hidden>

Add a qom property with the same name 'bootindex',
when we remove it form qdev property, things will
continue to work just fine, and we can use qom features
which are not supported by qdev property.

Signed-off-by: Gonglei <address@hidden>
---
 hw/net/virtio-net.c    | 20 ++++++++++++++++++++
 hw/virtio/virtio-pci.c | 22 ++++++++++++++++++++++
 2 files changed, 42 insertions(+)

diff --git a/hw/net/virtio-net.c b/hw/net/virtio-net.c
index 09ecb24..8b409ad 100644
--- a/hw/net/virtio-net.c
+++ b/hw/net/virtio-net.c
@@ -1685,6 +1685,22 @@ static void virtio_net_device_unrealize(DeviceState 
*dev, Error **errp)
     virtio_cleanup(vdev);
 }
 
+static void virtio_net_get_bootindex(Object *obj, Visitor *v, void *opaque,
+                                     const char *name, Error **errp)
+{
+    VirtIONet *n = VIRTIO_NET(obj);
+
+    get_bootindex(&n->nic_conf.bootindex, v, name, errp);
+}
+
+static void virtio_net_set_bootindex(Object *obj, Visitor *v, void *opaque,
+                                     const char *name, Error **errp)
+{
+    VirtIONet *n = VIRTIO_NET(obj);
+
+    set_bootindex(&n->nic_conf.bootindex, v, name, errp);
+}
+
 static void virtio_net_instance_init(Object *obj)
 {
     VirtIONet *n = VIRTIO_NET(obj);
@@ -1694,6 +1710,10 @@ static void virtio_net_instance_init(Object *obj)
      * Can be overriden with virtio_net_set_config_size.
      */
     n->config_size = sizeof(struct virtio_net_config);
+
+    object_property_add(obj, "bootindex", "int",
+                        virtio_net_get_bootindex,
+                        virtio_net_set_bootindex, NULL, NULL, NULL);
 }
 
 static Property virtio_net_properties[] = {
diff --git a/hw/virtio/virtio-pci.c b/hw/virtio/virtio-pci.c
index ddb5da1..ca8bdfd 100644
--- a/hw/virtio/virtio-pci.c
+++ b/hw/virtio/virtio-pci.c
@@ -1451,11 +1451,33 @@ static void virtio_net_pci_class_init(ObjectClass 
*klass, void *data)
     vpciklass->init = virtio_net_pci_init;
 }
 
+static void virtio_net_pci_get_bootindex(Object *obj, Visitor *v, void *opaque,
+                                         const char *name, Error **errp)
+{
+    VirtIONetPCI *dev = VIRTIO_NET_PCI(obj);
+    VirtIONet *n = &dev->vdev;
+
+     get_bootindex(&n->nic_conf.bootindex, v, name, errp);
+}
+
+static void virtio_net_pci_set_bootindex(Object *obj, Visitor *v, void *opaque,
+                                         const char *name, Error **errp)
+{
+    VirtIONetPCI *dev = VIRTIO_NET_PCI(obj);
+    VirtIONet *n = &dev->vdev;
+
+     set_bootindex(&n->nic_conf.bootindex, v, name, errp);
+}
+
 static void virtio_net_pci_instance_init(Object *obj)
 {
     VirtIONetPCI *dev = VIRTIO_NET_PCI(obj);
     object_initialize(&dev->vdev, sizeof(dev->vdev), TYPE_VIRTIO_NET);
     object_property_add_child(obj, "virtio-backend", OBJECT(&dev->vdev), NULL);
+
+    object_property_add(obj, "bootindex", "int",
+                        virtio_net_pci_get_bootindex,
+                        virtio_net_pci_set_bootindex, NULL, NULL, NULL);
 }
 
 static const TypeInfo virtio_net_pci_info = {
-- 
1.7.12.4





reply via email to

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