xref: /qemu/hw/virtio/vhost-user-device-pci.c (revision eee77809733d3a94c0d78a29a93d032c1faefd2c)
1*eee77809SAlex Bennée /*
2*eee77809SAlex Bennée  * Vhost-user generic virtio device PCI glue
3*eee77809SAlex Bennée  *
4*eee77809SAlex Bennée  * Copyright (c) 2023 Linaro Ltd
5*eee77809SAlex Bennée  * Author: Alex Bennée <alex.bennee@linaro.org>
6*eee77809SAlex Bennée  *
7*eee77809SAlex Bennée  * SPDX-License-Identifier: GPL-2.0-or-later
8*eee77809SAlex Bennée  */
9*eee77809SAlex Bennée 
10*eee77809SAlex Bennée #include "qemu/osdep.h"
11*eee77809SAlex Bennée #include "hw/qdev-properties.h"
12*eee77809SAlex Bennée #include "hw/virtio/vhost-user-device.h"
13*eee77809SAlex Bennée #include "hw/virtio/virtio-pci.h"
14*eee77809SAlex Bennée 
15*eee77809SAlex Bennée struct VHostUserDevicePCI {
16*eee77809SAlex Bennée     VirtIOPCIProxy parent_obj;
17*eee77809SAlex Bennée     VHostUserBase vub;
18*eee77809SAlex Bennée };
19*eee77809SAlex Bennée 
20*eee77809SAlex Bennée typedef struct VHostUserDevicePCI VHostUserDevicePCI;
21*eee77809SAlex Bennée 
22*eee77809SAlex Bennée #define TYPE_VHOST_USER_DEVICE_PCI "vhost-user-device-pci-base"
23*eee77809SAlex Bennée 
24*eee77809SAlex Bennée DECLARE_INSTANCE_CHECKER(VHostUserDevicePCI,
25*eee77809SAlex Bennée                          VHOST_USER_DEVICE_PCI,
26*eee77809SAlex Bennée                          TYPE_VHOST_USER_DEVICE_PCI)
27*eee77809SAlex Bennée 
28*eee77809SAlex Bennée static void vhost_user_device_pci_realize(VirtIOPCIProxy *vpci_dev, Error **errp)
29*eee77809SAlex Bennée {
30*eee77809SAlex Bennée     VHostUserDevicePCI *dev = VHOST_USER_DEVICE_PCI(vpci_dev);
31*eee77809SAlex Bennée     DeviceState *vdev = DEVICE(&dev->vub);
32*eee77809SAlex Bennée 
33*eee77809SAlex Bennée     vpci_dev->nvectors = 1;
34*eee77809SAlex Bennée     qdev_realize(vdev, BUS(&vpci_dev->bus), errp);
35*eee77809SAlex Bennée }
36*eee77809SAlex Bennée 
37*eee77809SAlex Bennée static void vhost_user_device_pci_class_init(ObjectClass *klass, void *data)
38*eee77809SAlex Bennée {
39*eee77809SAlex Bennée     DeviceClass *dc = DEVICE_CLASS(klass);
40*eee77809SAlex Bennée     VirtioPCIClass *k = VIRTIO_PCI_CLASS(klass);
41*eee77809SAlex Bennée     PCIDeviceClass *pcidev_k = PCI_DEVICE_CLASS(klass);
42*eee77809SAlex Bennée     k->realize = vhost_user_device_pci_realize;
43*eee77809SAlex Bennée     set_bit(DEVICE_CATEGORY_INPUT, dc->categories);
44*eee77809SAlex Bennée     pcidev_k->vendor_id = PCI_VENDOR_ID_REDHAT_QUMRANET;
45*eee77809SAlex Bennée     pcidev_k->device_id = 0; /* Set by virtio-pci based on virtio id */
46*eee77809SAlex Bennée     pcidev_k->revision = 0x00;
47*eee77809SAlex Bennée     pcidev_k->class_id = PCI_CLASS_COMMUNICATION_OTHER;
48*eee77809SAlex Bennée }
49*eee77809SAlex Bennée 
50*eee77809SAlex Bennée static void vhost_user_device_pci_instance_init(Object *obj)
51*eee77809SAlex Bennée {
52*eee77809SAlex Bennée     VHostUserDevicePCI *dev = VHOST_USER_DEVICE_PCI(obj);
53*eee77809SAlex Bennée 
54*eee77809SAlex Bennée     virtio_instance_init_common(obj, &dev->vub, sizeof(dev->vub),
55*eee77809SAlex Bennée                                 TYPE_VHOST_USER_DEVICE);
56*eee77809SAlex Bennée }
57*eee77809SAlex Bennée 
58*eee77809SAlex Bennée static const VirtioPCIDeviceTypeInfo vhost_user_device_pci_info = {
59*eee77809SAlex Bennée     .base_name = TYPE_VHOST_USER_DEVICE_PCI,
60*eee77809SAlex Bennée     .non_transitional_name = "vhost-user-device-pci",
61*eee77809SAlex Bennée     .instance_size = sizeof(VHostUserDevicePCI),
62*eee77809SAlex Bennée     .instance_init = vhost_user_device_pci_instance_init,
63*eee77809SAlex Bennée     .class_init = vhost_user_device_pci_class_init,
64*eee77809SAlex Bennée };
65*eee77809SAlex Bennée 
66*eee77809SAlex Bennée static void vhost_user_device_pci_register(void)
67*eee77809SAlex Bennée {
68*eee77809SAlex Bennée     virtio_pci_types_register(&vhost_user_device_pci_info);
69*eee77809SAlex Bennée }
70*eee77809SAlex Bennée 
71*eee77809SAlex Bennée type_init(vhost_user_device_pci_register);
72