]> git.proxmox.com Git - qemu.git/commitdiff
Virtio-net qdev conversion
authorPaul Brook <paul@codesourcery.com>
Thu, 14 May 2009 21:35:07 +0000 (22:35 +0100)
committerPaul Brook <paul@codesourcery.com>
Thu, 14 May 2009 21:35:07 +0000 (22:35 +0100)
Signed-off-by: Paul Brook <paul@codesourcery.com>
hw/pci.c
hw/virtio-balloon.c
hw/virtio-blk.c
hw/virtio-console.c
hw/virtio-net.c
hw/virtio-net.h
hw/virtio.c
hw/virtio.h

index 1a1a83daf08f6d7c8a7ce2f2e706d2707263dc5b..644e8f7137870845f9411ceb8ec8b033263675a1 100644 (file)
--- a/hw/pci.c
+++ b/hw/pci.c
@@ -25,7 +25,6 @@
 #include "pci.h"
 #include "monitor.h"
 #include "net.h"
-#include "virtio-net.h"
 #include "sysemu.h"
 
 //#define DEBUG_PCI
index 079f49890d6bcaaf0e83581d7122df87027c06fb..b8f9184e110288e0cc3b0a13180f3fe205cf54d0 100644 (file)
@@ -172,16 +172,20 @@ static int virtio_balloon_load(QEMUFile *f, void *opaque, int version_id)
 void *virtio_balloon_init(PCIBus *bus)
 {
     VirtIOBalloon *s;
+    PCIDevice *d;
 
-    s = (VirtIOBalloon *)virtio_init_pci(bus, "virtio-balloon",
+    d = pci_register_device(bus, "virtio-balloon", sizeof(VirtIOBalloon),
+                            -1, NULL, NULL);
+    if (!d)
+        return NULL;
+
+    s = (VirtIOBalloon *)virtio_init_pci(d, "virtio-balloon",
                                          PCI_VENDOR_ID_REDHAT_QUMRANET,
                                          PCI_DEVICE_ID_VIRTIO_BALLOON,
                                          PCI_VENDOR_ID_REDHAT_QUMRANET,
                                          VIRTIO_ID_BALLOON,
                                          PCI_CLASS_MEMORY_RAM, 0x00,
-                                         8, sizeof(VirtIOBalloon));
-    if (s == NULL)
-        return NULL;
+                                         8);
 
     s->vdev.get_config = virtio_balloon_get_config;
     s->vdev.set_config = virtio_balloon_set_config;
index dad4ef08c226c2f3fbeb211a1f5a4dd3c1649b25..b80302b6896b3037409ff29938c2486b2d1ff6c7 100644 (file)
@@ -353,16 +353,20 @@ void *virtio_blk_init(PCIBus *bus, BlockDriverState *bs)
     VirtIOBlock *s;
     int cylinders, heads, secs;
     static int virtio_blk_id;
+    PCIDevice *d;
 
-    s = (VirtIOBlock *)virtio_init_pci(bus, "virtio-blk",
+    d = pci_register_device(bus, "virtio-blk", sizeof(VirtIOBlock),
+                            -1, NULL, NULL);
+    if (!d)
+        return NULL;
+
+    s = (VirtIOBlock *)virtio_init_pci(d, "virtio-blk",
                                        PCI_VENDOR_ID_REDHAT_QUMRANET,
                                        PCI_DEVICE_ID_VIRTIO_BLOCK,
                                        PCI_VENDOR_ID_REDHAT_QUMRANET,
                                        VIRTIO_ID_BLOCK,
                                        PCI_CLASS_STORAGE_OTHER, 0x00,
-                                       sizeof(struct virtio_blk_config), sizeof(VirtIOBlock));
-    if (!s)
-        return NULL;
+                                       sizeof(struct virtio_blk_config));
 
     s->vdev.get_config = virtio_blk_update_config;
     s->vdev.get_features = virtio_blk_get_features;
index b263281d8f79e707a7a8c7d73e815ea6b5776564..c006d90a957ab26bcfa5876019ec5b0df44ce1fc 100644 (file)
@@ -126,14 +126,20 @@ static int virtio_console_load(QEMUFile *f, void *opaque, int version_id)
 void *virtio_console_init(PCIBus *bus, CharDriverState *chr)
 {
     VirtIOConsole *s;
+    PCIDevice *d;
 
-    s = (VirtIOConsole *)virtio_init_pci(bus, "virtio-console",
+    d = pci_register_device(bus, "virtio-console", sizeof(VirtIOConsole),
+                            -1, NULL, NULL);
+    if (!d)
+        return NULL;
+
+    s = (VirtIOConsole *)virtio_init_pci(d, "virtio-console",
                                          PCI_VENDOR_ID_REDHAT_QUMRANET,
                                          PCI_DEVICE_ID_VIRTIO_CONSOLE,
                                          PCI_VENDOR_ID_REDHAT_QUMRANET,
                                          VIRTIO_ID_CONSOLE,
                                          PCI_CLASS_DISPLAY_OTHER, 0x00,
-                                         0, sizeof(VirtIOConsole));
+                                         0);
     if (s == NULL)
         return NULL;
 
index f9717c02e1711915e8f93ccabe448fefac89b8d7..376417043793a2d2b01ea9b942390b8a3f465ada 100644 (file)
@@ -585,21 +585,18 @@ static void virtio_net_cleanup(VLANClientState *vc)
     virtio_cleanup(&n->vdev);
 }
 
-PCIDevice *virtio_net_init(PCIBus *bus, NICInfo *nd, int devfn)
+static void virtio_net_init(PCIDevice *pci_dev)
 {
     VirtIONet *n;
     static int virtio_net_id;
 
-    n = (VirtIONet *)virtio_init_pci(bus, "virtio-net",
+    n = (VirtIONet *)virtio_init_pci(pci_dev, "virtio-net",
                                      PCI_VENDOR_ID_REDHAT_QUMRANET,
                                      PCI_DEVICE_ID_VIRTIO_NET,
                                      PCI_VENDOR_ID_REDHAT_QUMRANET,
                                      VIRTIO_ID_NET,
                                      PCI_CLASS_NETWORK_ETHERNET, 0x00,
-                                     sizeof(struct virtio_net_config),
-                                     sizeof(VirtIONet));
-    if (!n)
-        return NULL;
+                                     sizeof(struct virtio_net_config));
 
     n->vdev.get_config = virtio_net_get_config;
     n->vdev.set_config = virtio_net_set_config;
@@ -610,9 +607,9 @@ PCIDevice *virtio_net_init(PCIBus *bus, NICInfo *nd, int devfn)
     n->rx_vq = virtio_add_queue(&n->vdev, 256, virtio_net_handle_rx);
     n->tx_vq = virtio_add_queue(&n->vdev, 256, virtio_net_handle_tx);
     n->ctrl_vq = virtio_add_queue(&n->vdev, 16, virtio_net_handle_ctrl);
-    memcpy(n->mac, nd->macaddr, ETH_ALEN);
+    qdev_get_macaddr(&pci_dev->qdev, n->mac);
     n->status = VIRTIO_NET_S_LINK_UP;
-    n->vc = qemu_new_vlan_client(nd->vlan, nd->model, nd->name,
+    n->vc = qdev_get_vlan_client(&pci_dev->qdev,
                                  virtio_net_receive,
                                  virtio_net_can_receive,
                                  virtio_net_cleanup, n);
@@ -631,5 +628,11 @@ PCIDevice *virtio_net_init(PCIBus *bus, NICInfo *nd, int devfn)
 
     register_savevm("virtio-net", virtio_net_id++, VIRTIO_NET_VM_VERSION,
                     virtio_net_save, virtio_net_load, n);
-    return (PCIDevice *)n;
 }
+
+static void virtio_net_register_devices(void)
+{
+    pci_qdev_register("virtio_net", sizeof(VirtIONet), virtio_net_init);
+}
+
+device_init(virtio_net_register_devices)
index 4e203496b2abf25a733d8c149d2bbd5c52471e9b..390fe10224b249abfecb6cc00c74bd30a7c04075 100644 (file)
@@ -85,8 +85,6 @@ struct virtio_net_hdr_mrg_rxbuf
     uint16_t num_buffers;   /* Number of merged rx buffers */
 };
 
-PCIDevice *virtio_net_init(PCIBus *bus, NICInfo *nd, int devfn);
-
 /*
  * Control virtqueue data structures
  *
index 78c7637658d9415d6f76ee1f0910508aa1933ff4..21108c5c2b1c4905ab02860ff9e5f75827bc3a2c 100644 (file)
@@ -757,22 +757,16 @@ void virtio_cleanup(VirtIODevice *vdev)
     qemu_free(vdev->vq);
 }
 
-VirtIODevice *virtio_init_pci(PCIBus *bus, const char *name,
+VirtIODevice *virtio_init_pci(PCIDevice *pci_dev, const char *name,
                               uint16_t vendor, uint16_t device,
                               uint16_t subvendor, uint16_t subdevice,
                               uint16_t class_code, uint8_t pif,
-                              size_t config_size, size_t struct_size)
+                              size_t config_size)
 {
     VirtIODevice *vdev;
-    PCIDevice *pci_dev;
     uint8_t *config;
     uint32_t size;
 
-    pci_dev = pci_register_device(bus, name, struct_size,
-                                  -1, NULL, NULL);
-    if (!pci_dev)
-        return NULL;
-
     vdev = to_virtio_device(pci_dev);
 
     vdev->status = 0;
index 935b1185453d78c77d0bd92bd86f7fcbeb62e116..99d8d72a0344e4d4f938f8fc8efb6e0398f76f36 100644 (file)
@@ -92,11 +92,11 @@ struct VirtIODevice
     VirtQueue *vq;
 };
 
-VirtIODevice *virtio_init_pci(PCIBus *bus, const char *name,
+VirtIODevice *virtio_init_pci(PCIDevice *pci_dev, const char *name,
                               uint16_t vendor, uint16_t device,
                               uint16_t subvendor, uint16_t subdevice,
                               uint16_t class_code, uint8_t pif,
-                              size_t config_size, size_t struct_size);
+                              size_t config_size);
 
 VirtQueue *virtio_add_queue(VirtIODevice *vdev, int queue_size,
                             void (*handle_output)(VirtIODevice *,