xref: /openbmc/qemu/hw/display/virtio-gpu-pci-gl.c (revision 57c9363c452af64fe058aa946cc923eae7f7ad33)
117cdac0bSGerd Hoffmann /*
217cdac0bSGerd Hoffmann  * Virtio video device
317cdac0bSGerd Hoffmann  *
417cdac0bSGerd Hoffmann  * Copyright Red Hat
517cdac0bSGerd Hoffmann  *
617cdac0bSGerd Hoffmann  * Authors:
717cdac0bSGerd Hoffmann  *  Dave Airlie
817cdac0bSGerd Hoffmann  *
917cdac0bSGerd Hoffmann  * This work is licensed under the terms of the GNU GPL, version 2 or later.
1017cdac0bSGerd Hoffmann  * See the COPYING file in the top-level directory.
1117cdac0bSGerd Hoffmann  *
1217cdac0bSGerd Hoffmann  */
1317cdac0bSGerd Hoffmann 
1417cdac0bSGerd Hoffmann #include "qemu/osdep.h"
1517cdac0bSGerd Hoffmann #include "qapi/error.h"
1617cdac0bSGerd Hoffmann #include "qemu/module.h"
1717cdac0bSGerd Hoffmann #include "hw/pci/pci.h"
1817cdac0bSGerd Hoffmann #include "hw/qdev-properties.h"
1917cdac0bSGerd Hoffmann #include "hw/virtio/virtio.h"
2017cdac0bSGerd Hoffmann #include "hw/virtio/virtio-bus.h"
2117cdac0bSGerd Hoffmann #include "hw/virtio/virtio-gpu-pci.h"
2217cdac0bSGerd Hoffmann #include "qom/object.h"
2317cdac0bSGerd Hoffmann 
2417cdac0bSGerd Hoffmann #define TYPE_VIRTIO_GPU_GL_PCI "virtio-gpu-gl-pci"
2517cdac0bSGerd Hoffmann typedef struct VirtIOGPUGLPCI VirtIOGPUGLPCI;
2617cdac0bSGerd Hoffmann DECLARE_INSTANCE_CHECKER(VirtIOGPUGLPCI, VIRTIO_GPU_GL_PCI,
2717cdac0bSGerd Hoffmann                          TYPE_VIRTIO_GPU_GL_PCI)
2817cdac0bSGerd Hoffmann 
2917cdac0bSGerd Hoffmann struct VirtIOGPUGLPCI {
3017cdac0bSGerd Hoffmann     VirtIOGPUPCIBase parent_obj;
3117cdac0bSGerd Hoffmann     VirtIOGPUGL vdev;
3217cdac0bSGerd Hoffmann };
3317cdac0bSGerd Hoffmann 
virtio_gpu_gl_initfn(Object * obj)3417cdac0bSGerd Hoffmann static void virtio_gpu_gl_initfn(Object *obj)
3517cdac0bSGerd Hoffmann {
3617cdac0bSGerd Hoffmann     VirtIOGPUGLPCI *dev = VIRTIO_GPU_GL_PCI(obj);
3717cdac0bSGerd Hoffmann 
3817cdac0bSGerd Hoffmann     virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
3917cdac0bSGerd Hoffmann                                 TYPE_VIRTIO_GPU_GL);
4017cdac0bSGerd Hoffmann     VIRTIO_GPU_PCI_BASE(obj)->vgpu = VIRTIO_GPU_BASE(&dev->vdev);
4117cdac0bSGerd Hoffmann }
4217cdac0bSGerd Hoffmann 
4317cdac0bSGerd Hoffmann static const VirtioPCIDeviceTypeInfo virtio_gpu_gl_pci_info = {
4417cdac0bSGerd Hoffmann     .generic_name = TYPE_VIRTIO_GPU_GL_PCI,
4517cdac0bSGerd Hoffmann     .parent = TYPE_VIRTIO_GPU_PCI_BASE,
4617cdac0bSGerd Hoffmann     .instance_size = sizeof(VirtIOGPUGLPCI),
4717cdac0bSGerd Hoffmann     .instance_init = virtio_gpu_gl_initfn,
4817cdac0bSGerd Hoffmann };
49561d0f45SGerd Hoffmann module_obj(TYPE_VIRTIO_GPU_GL_PCI);
50*24ce7aa7SJose R. Ziviani module_kconfig(VIRTIO_PCI);
5117cdac0bSGerd Hoffmann 
virtio_gpu_gl_pci_register_types(void)5217cdac0bSGerd Hoffmann static void virtio_gpu_gl_pci_register_types(void)
5317cdac0bSGerd Hoffmann {
5417cdac0bSGerd Hoffmann     virtio_pci_types_register(&virtio_gpu_gl_pci_info);
5517cdac0bSGerd Hoffmann }
5617cdac0bSGerd Hoffmann 
5717cdac0bSGerd Hoffmann type_init(virtio_gpu_gl_pci_register_types)
58561d0f45SGerd Hoffmann 
59561d0f45SGerd Hoffmann module_dep("hw-display-virtio-gpu-pci");
60