1*267f6646SMarc-André Lureau /* 2*267f6646SMarc-André Lureau * vhost-user VGA device 3*267f6646SMarc-André Lureau * 4*267f6646SMarc-André Lureau * Copyright Red Hat, Inc. 2018 5*267f6646SMarc-André Lureau * 6*267f6646SMarc-André Lureau * This work is licensed under the terms of the GNU GPL, version 2 or later. 7*267f6646SMarc-André Lureau * See the COPYING file in the top-level directory. 8*267f6646SMarc-André Lureau * 9*267f6646SMarc-André Lureau */ 10*267f6646SMarc-André Lureau 11*267f6646SMarc-André Lureau #include "qemu/osdep.h" 12*267f6646SMarc-André Lureau #include "qapi/error.h" 13*267f6646SMarc-André Lureau #include "virtio-vga.h" 14*267f6646SMarc-André Lureau 15*267f6646SMarc-André Lureau #define TYPE_VHOST_USER_VGA "vhost-user-vga" 16*267f6646SMarc-André Lureau 17*267f6646SMarc-André Lureau #define VHOST_USER_VGA(obj) \ 18*267f6646SMarc-André Lureau OBJECT_CHECK(VhostUserVGA, (obj), TYPE_VHOST_USER_VGA) 19*267f6646SMarc-André Lureau 20*267f6646SMarc-André Lureau typedef struct VhostUserVGA { 21*267f6646SMarc-André Lureau VirtIOVGABase parent_obj; 22*267f6646SMarc-André Lureau 23*267f6646SMarc-André Lureau VhostUserGPU vdev; 24*267f6646SMarc-André Lureau } VhostUserVGA; 25*267f6646SMarc-André Lureau 26*267f6646SMarc-André Lureau static void vhost_user_vga_inst_initfn(Object *obj) 27*267f6646SMarc-André Lureau { 28*267f6646SMarc-André Lureau VhostUserVGA *dev = VHOST_USER_VGA(obj); 29*267f6646SMarc-André Lureau 30*267f6646SMarc-André Lureau virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev), 31*267f6646SMarc-André Lureau TYPE_VHOST_USER_GPU); 32*267f6646SMarc-André Lureau 33*267f6646SMarc-André Lureau VIRTIO_VGA_BASE(dev)->vgpu = VIRTIO_GPU_BASE(&dev->vdev); 34*267f6646SMarc-André Lureau 35*267f6646SMarc-André Lureau object_property_add_alias(obj, "chardev", 36*267f6646SMarc-André Lureau OBJECT(&dev->vdev), "chardev", 37*267f6646SMarc-André Lureau &error_abort); 38*267f6646SMarc-André Lureau } 39*267f6646SMarc-André Lureau 40*267f6646SMarc-André Lureau static const VirtioPCIDeviceTypeInfo vhost_user_vga_info = { 41*267f6646SMarc-André Lureau .generic_name = TYPE_VHOST_USER_VGA, 42*267f6646SMarc-André Lureau .parent = TYPE_VIRTIO_VGA_BASE, 43*267f6646SMarc-André Lureau .instance_size = sizeof(struct VhostUserVGA), 44*267f6646SMarc-André Lureau .instance_init = vhost_user_vga_inst_initfn, 45*267f6646SMarc-André Lureau }; 46*267f6646SMarc-André Lureau 47*267f6646SMarc-André Lureau static void vhost_user_vga_register_types(void) 48*267f6646SMarc-André Lureau { 49*267f6646SMarc-André Lureau virtio_pci_types_register(&vhost_user_vga_info); 50*267f6646SMarc-André Lureau } 51*267f6646SMarc-André Lureau 52*267f6646SMarc-André Lureau type_init(vhost_user_vga_register_types) 53