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