1 // SPDX-License-Identifier: GPL-2.0
3 * Mediated virtual PCI display host device driver
5 * Emulate enough of qemu stdvga to make bochs-drm.ko happy. That is
6 * basically the vram memory bar and the bochs dispi interface vbe
7 * registers in the mmio register bar. Specifically it does *not*
8 * include any legacy vga stuff. Device looks a lot like "qemu -device
11 * (c) Gerd Hoffmann <kraxel@redhat.com>
13 * based on mtty driver which is:
14 * Copyright (c) 2016, NVIDIA CORPORATION. All rights reserved.
15 * Author: Neo Jia <cjia@nvidia.com>
16 * Kirti Wankhede <kwankhede@nvidia.com>
18 * This program is free software; you can redistribute it and/or modify
19 * it under the terms of the GNU General Public License version 2 as
20 * published by the Free Software Foundation.
22 #include <linux/init.h>
23 #include <linux/module.h>
24 #include <linux/device.h>
25 #include <linux/kernel.h>
26 #include <linux/slab.h>
27 #include <linux/vmalloc.h>
28 #include <linux/cdev.h>
29 #include <linux/vfio.h>
30 #include <linux/iommu.h>
31 #include <linux/sysfs.h>
32 #include <linux/mdev.h>
33 #include <linux/pci.h>
34 #include <linux/dma-buf.h>
35 #include <linux/highmem.h>
36 #include <drm/drm_fourcc.h>
37 #include <drm/drm_rect.h>
38 #include <drm/drm_modeset_lock.h>
39 #include <drm/drm_property.h>
40 #include <drm/drm_plane.h>
43 #define VBE_DISPI_INDEX_ID 0x0
44 #define VBE_DISPI_INDEX_XRES 0x1
45 #define VBE_DISPI_INDEX_YRES 0x2
46 #define VBE_DISPI_INDEX_BPP 0x3
47 #define VBE_DISPI_INDEX_ENABLE 0x4
48 #define VBE_DISPI_INDEX_BANK 0x5
49 #define VBE_DISPI_INDEX_VIRT_WIDTH 0x6
50 #define VBE_DISPI_INDEX_VIRT_HEIGHT 0x7
51 #define VBE_DISPI_INDEX_X_OFFSET 0x8
52 #define VBE_DISPI_INDEX_Y_OFFSET 0x9
53 #define VBE_DISPI_INDEX_VIDEO_MEMORY_64K 0xa
54 #define VBE_DISPI_INDEX_COUNT 0xb
56 #define VBE_DISPI_ID0 0xB0C0
57 #define VBE_DISPI_ID1 0xB0C1
58 #define VBE_DISPI_ID2 0xB0C2
59 #define VBE_DISPI_ID3 0xB0C3
60 #define VBE_DISPI_ID4 0xB0C4
61 #define VBE_DISPI_ID5 0xB0C5
63 #define VBE_DISPI_DISABLED 0x00
64 #define VBE_DISPI_ENABLED 0x01
65 #define VBE_DISPI_GETCAPS 0x02
66 #define VBE_DISPI_8BIT_DAC 0x20
67 #define VBE_DISPI_LFB_ENABLED 0x40
68 #define VBE_DISPI_NOCLEARMEM 0x80
71 #define MBOCHS_NAME "mbochs"
72 #define MBOCHS_CLASS_NAME "mbochs"
74 #define MBOCHS_EDID_REGION_INDEX VFIO_PCI_NUM_REGIONS
75 #define MBOCHS_NUM_REGIONS (MBOCHS_EDID_REGION_INDEX+1)
77 #define MBOCHS_CONFIG_SPACE_SIZE 0xff
78 #define MBOCHS_MMIO_BAR_OFFSET PAGE_SIZE
79 #define MBOCHS_MMIO_BAR_SIZE PAGE_SIZE
80 #define MBOCHS_EDID_OFFSET (MBOCHS_MMIO_BAR_OFFSET + \
82 #define MBOCHS_EDID_SIZE PAGE_SIZE
83 #define MBOCHS_MEMORY_BAR_OFFSET (MBOCHS_EDID_OFFSET + \
86 #define MBOCHS_EDID_BLOB_OFFSET (MBOCHS_EDID_SIZE/2)
88 #define STORE_LE16(addr, val) (*(u16 *)addr = val)
89 #define STORE_LE32(addr, val) (*(u32 *)addr = val)
92 MODULE_LICENSE("GPL v2");
94 static int max_mbytes
= 256;
95 module_param_named(count
, max_mbytes
, int, 0444);
96 MODULE_PARM_DESC(mem
, "megabytes available to " MBOCHS_NAME
" devices");
99 #define MBOCHS_TYPE_1 "small"
100 #define MBOCHS_TYPE_2 "medium"
101 #define MBOCHS_TYPE_3 "large"
103 static const struct mbochs_type
{
110 .name
= MBOCHS_CLASS_NAME
"-" MBOCHS_TYPE_1
,
115 .name
= MBOCHS_CLASS_NAME
"-" MBOCHS_TYPE_2
,
120 .name
= MBOCHS_CLASS_NAME
"-" MBOCHS_TYPE_3
,
128 static dev_t mbochs_devt
;
129 static struct class *mbochs_class
;
130 static struct cdev mbochs_cdev
;
131 static struct device mbochs_dev
;
132 static int mbochs_used_mbytes
;
134 struct vfio_region_info_ext
{
135 struct vfio_region_info base
;
136 struct vfio_region_info_cap_type type
;
150 struct mbochs_dmabuf
{
151 struct mbochs_mode mode
;
156 struct mdev_state
*mdev_state
;
157 struct list_head next
;
161 /* State of each mdev device */
166 struct mutex ops_lock
;
167 struct mdev_device
*mdev
;
169 const struct mbochs_type
*type
;
170 u16 vbe
[VBE_DISPI_INDEX_COUNT
];
174 struct vfio_region_gfx_edid edid_regs
;
177 struct list_head dmabufs
;
182 static const char *vbe_name_list
[VBE_DISPI_INDEX_COUNT
] = {
183 [VBE_DISPI_INDEX_ID
] = "id",
184 [VBE_DISPI_INDEX_XRES
] = "xres",
185 [VBE_DISPI_INDEX_YRES
] = "yres",
186 [VBE_DISPI_INDEX_BPP
] = "bpp",
187 [VBE_DISPI_INDEX_ENABLE
] = "enable",
188 [VBE_DISPI_INDEX_BANK
] = "bank",
189 [VBE_DISPI_INDEX_VIRT_WIDTH
] = "virt-width",
190 [VBE_DISPI_INDEX_VIRT_HEIGHT
] = "virt-height",
191 [VBE_DISPI_INDEX_X_OFFSET
] = "x-offset",
192 [VBE_DISPI_INDEX_Y_OFFSET
] = "y-offset",
193 [VBE_DISPI_INDEX_VIDEO_MEMORY_64K
] = "video-mem",
196 static const char *vbe_name(u32 index
)
198 if (index
< ARRAY_SIZE(vbe_name_list
))
199 return vbe_name_list
[index
];
203 static struct page
*__mbochs_get_page(struct mdev_state
*mdev_state
,
205 static struct page
*mbochs_get_page(struct mdev_state
*mdev_state
,
208 static const struct mbochs_type
*mbochs_find_type(struct kobject
*kobj
)
212 for (i
= 0; i
< ARRAY_SIZE(mbochs_types
); i
++)
213 if (strcmp(mbochs_types
[i
].name
, kobj
->name
) == 0)
214 return mbochs_types
+ i
;
218 static void mbochs_create_config_space(struct mdev_state
*mdev_state
)
220 STORE_LE16((u16
*) &mdev_state
->vconfig
[PCI_VENDOR_ID
],
222 STORE_LE16((u16
*) &mdev_state
->vconfig
[PCI_DEVICE_ID
],
224 STORE_LE16((u16
*) &mdev_state
->vconfig
[PCI_SUBSYSTEM_VENDOR_ID
],
225 PCI_SUBVENDOR_ID_REDHAT_QUMRANET
);
226 STORE_LE16((u16
*) &mdev_state
->vconfig
[PCI_SUBSYSTEM_ID
],
227 PCI_SUBDEVICE_ID_QEMU
);
229 STORE_LE16((u16
*) &mdev_state
->vconfig
[PCI_COMMAND
],
230 PCI_COMMAND_IO
| PCI_COMMAND_MEMORY
);
231 STORE_LE16((u16
*) &mdev_state
->vconfig
[PCI_CLASS_DEVICE
],
232 PCI_CLASS_DISPLAY_OTHER
);
233 mdev_state
->vconfig
[PCI_CLASS_REVISION
] = 0x01;
235 STORE_LE32((u32
*) &mdev_state
->vconfig
[PCI_BASE_ADDRESS_0
],
236 PCI_BASE_ADDRESS_SPACE_MEMORY
|
237 PCI_BASE_ADDRESS_MEM_TYPE_32
|
238 PCI_BASE_ADDRESS_MEM_PREFETCH
);
239 mdev_state
->bar_mask
[0] = ~(mdev_state
->memsize
) + 1;
241 STORE_LE32((u32
*) &mdev_state
->vconfig
[PCI_BASE_ADDRESS_2
],
242 PCI_BASE_ADDRESS_SPACE_MEMORY
|
243 PCI_BASE_ADDRESS_MEM_TYPE_32
);
244 mdev_state
->bar_mask
[2] = ~(MBOCHS_MMIO_BAR_SIZE
) + 1;
247 static int mbochs_check_framebuffer(struct mdev_state
*mdev_state
,
248 struct mbochs_mode
*mode
)
250 struct device
*dev
= mdev_dev(mdev_state
->mdev
);
251 u16
*vbe
= mdev_state
->vbe
;
254 WARN_ON(!mutex_is_locked(&mdev_state
->ops_lock
));
256 if (!(vbe
[VBE_DISPI_INDEX_ENABLE
] & VBE_DISPI_ENABLED
))
259 memset(mode
, 0, sizeof(*mode
));
260 switch (vbe
[VBE_DISPI_INDEX_BPP
]) {
262 mode
->drm_format
= DRM_FORMAT_XRGB8888
;
266 dev_info_ratelimited(dev
, "%s: bpp %d not supported\n",
267 __func__
, vbe
[VBE_DISPI_INDEX_BPP
]);
271 mode
->width
= vbe
[VBE_DISPI_INDEX_XRES
];
272 mode
->height
= vbe
[VBE_DISPI_INDEX_YRES
];
273 virt_width
= vbe
[VBE_DISPI_INDEX_VIRT_WIDTH
];
274 if (virt_width
< mode
->width
)
275 virt_width
= mode
->width
;
276 mode
->stride
= virt_width
* mode
->bytepp
;
277 mode
->size
= (u64
)mode
->stride
* mode
->height
;
278 mode
->offset
= ((u64
)vbe
[VBE_DISPI_INDEX_X_OFFSET
] * mode
->bytepp
+
279 (u64
)vbe
[VBE_DISPI_INDEX_Y_OFFSET
] * mode
->stride
);
281 if (mode
->width
< 64 || mode
->height
< 64) {
282 dev_info_ratelimited(dev
, "%s: invalid resolution %dx%d\n",
283 __func__
, mode
->width
, mode
->height
);
286 if (mode
->offset
+ mode
->size
> mdev_state
->memsize
) {
287 dev_info_ratelimited(dev
, "%s: framebuffer memory overflow\n",
295 memset(mode
, 0, sizeof(*mode
));
299 static bool mbochs_modes_equal(struct mbochs_mode
*mode1
,
300 struct mbochs_mode
*mode2
)
302 return memcmp(mode1
, mode2
, sizeof(struct mbochs_mode
)) == 0;
305 static void handle_pci_cfg_write(struct mdev_state
*mdev_state
, u16 offset
,
306 char *buf
, u32 count
)
308 struct device
*dev
= mdev_dev(mdev_state
->mdev
);
309 int index
= (offset
- PCI_BASE_ADDRESS_0
) / 0x04;
313 case PCI_BASE_ADDRESS_0
:
314 case PCI_BASE_ADDRESS_2
:
315 cfg_addr
= *(u32
*)buf
;
317 if (cfg_addr
== 0xffffffff) {
318 cfg_addr
= (cfg_addr
& mdev_state
->bar_mask
[index
]);
320 cfg_addr
&= PCI_BASE_ADDRESS_MEM_MASK
;
322 dev_info(dev
, "BAR #%d @ 0x%x\n",
326 cfg_addr
|= (mdev_state
->vconfig
[offset
] &
327 ~PCI_BASE_ADDRESS_MEM_MASK
);
328 STORE_LE32(&mdev_state
->vconfig
[offset
], cfg_addr
);
333 static void handle_mmio_write(struct mdev_state
*mdev_state
, u16 offset
,
334 char *buf
, u32 count
)
336 struct device
*dev
= mdev_dev(mdev_state
->mdev
);
341 case 0x400 ... 0x41f: /* vga ioports remapped */
343 case 0x500 ... 0x515: /* bochs dispi interface */
346 index
= (offset
- 0x500) / 2;
348 if (index
< ARRAY_SIZE(mdev_state
->vbe
))
349 mdev_state
->vbe
[index
] = reg16
;
350 dev_dbg(dev
, "%s: vbe write %d = %d (%s)\n",
351 __func__
, index
, reg16
, vbe_name(index
));
353 case 0x600 ... 0x607: /* qemu extended regs */
357 dev_dbg(dev
, "%s: @0x%03x, count %d (unhandled)\n",
358 __func__
, offset
, count
);
363 static void handle_mmio_read(struct mdev_state
*mdev_state
, u16 offset
,
364 char *buf
, u32 count
)
366 struct device
*dev
= mdev_dev(mdev_state
->mdev
);
367 struct vfio_region_gfx_edid
*edid
;
372 case 0x000 ... 0x3ff: /* edid block */
373 edid
= &mdev_state
->edid_regs
;
374 if (edid
->link_state
!= VFIO_DEVICE_GFX_LINK_STATE_UP
||
375 offset
>= edid
->edid_size
) {
376 memset(buf
, 0, count
);
379 memcpy(buf
, mdev_state
->edid_blob
+ offset
, count
);
381 case 0x500 ... 0x515: /* bochs dispi interface */
384 index
= (offset
- 0x500) / 2;
385 if (index
< ARRAY_SIZE(mdev_state
->vbe
))
386 reg16
= mdev_state
->vbe
[index
];
387 dev_dbg(dev
, "%s: vbe read %d = %d (%s)\n",
388 __func__
, index
, reg16
, vbe_name(index
));
393 dev_dbg(dev
, "%s: @0x%03x, count %d (unhandled)\n",
394 __func__
, offset
, count
);
395 memset(buf
, 0, count
);
400 static void handle_edid_regs(struct mdev_state
*mdev_state
, u16 offset
,
401 char *buf
, u32 count
, bool is_write
)
403 char *regs
= (void *)&mdev_state
->edid_regs
;
405 if (offset
+ count
> sizeof(mdev_state
->edid_regs
))
414 case offsetof(struct vfio_region_gfx_edid
, link_state
):
415 case offsetof(struct vfio_region_gfx_edid
, edid_size
):
416 memcpy(regs
+ offset
, buf
, count
);
423 memcpy(buf
, regs
+ offset
, count
);
427 static void handle_edid_blob(struct mdev_state
*mdev_state
, u16 offset
,
428 char *buf
, u32 count
, bool is_write
)
430 if (offset
+ count
> mdev_state
->edid_regs
.edid_max_size
)
433 memcpy(mdev_state
->edid_blob
+ offset
, buf
, count
);
435 memcpy(buf
, mdev_state
->edid_blob
+ offset
, count
);
438 static ssize_t
mdev_access(struct mdev_device
*mdev
, char *buf
, size_t count
,
439 loff_t pos
, bool is_write
)
441 struct mdev_state
*mdev_state
= mdev_get_drvdata(mdev
);
442 struct device
*dev
= mdev_dev(mdev
);
448 mutex_lock(&mdev_state
->ops_lock
);
450 if (pos
< MBOCHS_CONFIG_SPACE_SIZE
) {
452 handle_pci_cfg_write(mdev_state
, pos
, buf
, count
);
454 memcpy(buf
, (mdev_state
->vconfig
+ pos
), count
);
456 } else if (pos
>= MBOCHS_MMIO_BAR_OFFSET
&&
457 pos
+ count
<= (MBOCHS_MMIO_BAR_OFFSET
+
458 MBOCHS_MMIO_BAR_SIZE
)) {
459 pos
-= MBOCHS_MMIO_BAR_OFFSET
;
461 handle_mmio_write(mdev_state
, pos
, buf
, count
);
463 handle_mmio_read(mdev_state
, pos
, buf
, count
);
465 } else if (pos
>= MBOCHS_EDID_OFFSET
&&
466 pos
+ count
<= (MBOCHS_EDID_OFFSET
+
468 pos
-= MBOCHS_EDID_OFFSET
;
469 if (pos
< MBOCHS_EDID_BLOB_OFFSET
) {
470 handle_edid_regs(mdev_state
, pos
, buf
, count
, is_write
);
472 pos
-= MBOCHS_EDID_BLOB_OFFSET
;
473 handle_edid_blob(mdev_state
, pos
, buf
, count
, is_write
);
476 } else if (pos
>= MBOCHS_MEMORY_BAR_OFFSET
&&
478 MBOCHS_MEMORY_BAR_OFFSET
+ mdev_state
->memsize
) {
479 pos
-= MBOCHS_MMIO_BAR_OFFSET
;
480 poff
= pos
& ~PAGE_MASK
;
481 pg
= __mbochs_get_page(mdev_state
, pos
>> PAGE_SHIFT
);
484 memcpy(map
+ poff
, buf
, count
);
486 memcpy(buf
, map
+ poff
, count
);
491 dev_dbg(dev
, "%s: %s @0x%llx (unhandled)\n",
492 __func__
, is_write
? "WR" : "RD", pos
);
501 mutex_unlock(&mdev_state
->ops_lock
);
506 static int mbochs_reset(struct mdev_device
*mdev
)
508 struct mdev_state
*mdev_state
= mdev_get_drvdata(mdev
);
509 u32 size64k
= mdev_state
->memsize
/ (64 * 1024);
512 for (i
= 0; i
< ARRAY_SIZE(mdev_state
->vbe
); i
++)
513 mdev_state
->vbe
[i
] = 0;
514 mdev_state
->vbe
[VBE_DISPI_INDEX_ID
] = VBE_DISPI_ID5
;
515 mdev_state
->vbe
[VBE_DISPI_INDEX_VIDEO_MEMORY_64K
] = size64k
;
519 static int mbochs_create(struct kobject
*kobj
, struct mdev_device
*mdev
)
521 const struct mbochs_type
*type
= mbochs_find_type(kobj
);
522 struct device
*dev
= mdev_dev(mdev
);
523 struct mdev_state
*mdev_state
;
526 type
= &mbochs_types
[0];
527 if (type
->mbytes
+ mbochs_used_mbytes
> max_mbytes
)
530 mdev_state
= kzalloc(sizeof(struct mdev_state
), GFP_KERNEL
);
531 if (mdev_state
== NULL
)
534 mdev_state
->vconfig
= kzalloc(MBOCHS_CONFIG_SPACE_SIZE
, GFP_KERNEL
);
535 if (mdev_state
->vconfig
== NULL
)
538 mdev_state
->memsize
= type
->mbytes
* 1024 * 1024;
539 mdev_state
->pagecount
= mdev_state
->memsize
>> PAGE_SHIFT
;
540 mdev_state
->pages
= kcalloc(mdev_state
->pagecount
,
541 sizeof(struct page
*),
543 if (!mdev_state
->pages
)
546 dev_info(dev
, "%s: %s, %d MB, %ld pages\n", __func__
,
547 kobj
->name
, type
->mbytes
, mdev_state
->pagecount
);
549 mutex_init(&mdev_state
->ops_lock
);
550 mdev_state
->mdev
= mdev
;
551 mdev_set_drvdata(mdev
, mdev_state
);
552 INIT_LIST_HEAD(&mdev_state
->dmabufs
);
553 mdev_state
->next_id
= 1;
555 mdev_state
->type
= type
;
556 mdev_state
->edid_regs
.max_xres
= type
->max_x
;
557 mdev_state
->edid_regs
.max_yres
= type
->max_y
;
558 mdev_state
->edid_regs
.edid_offset
= MBOCHS_EDID_BLOB_OFFSET
;
559 mdev_state
->edid_regs
.edid_max_size
= sizeof(mdev_state
->edid_blob
);
560 mbochs_create_config_space(mdev_state
);
563 mbochs_used_mbytes
+= type
->mbytes
;
567 kfree(mdev_state
->vconfig
);
572 static int mbochs_remove(struct mdev_device
*mdev
)
574 struct mdev_state
*mdev_state
= mdev_get_drvdata(mdev
);
576 mbochs_used_mbytes
-= mdev_state
->type
->mbytes
;
577 mdev_set_drvdata(mdev
, NULL
);
578 kfree(mdev_state
->pages
);
579 kfree(mdev_state
->vconfig
);
584 static ssize_t
mbochs_read(struct mdev_device
*mdev
, char __user
*buf
,
585 size_t count
, loff_t
*ppos
)
587 unsigned int done
= 0;
593 if (count
>= 4 && !(*ppos
% 4)) {
596 ret
= mdev_access(mdev
, (char *)&val
, sizeof(val
),
601 if (copy_to_user(buf
, &val
, sizeof(val
)))
605 } else if (count
>= 2 && !(*ppos
% 2)) {
608 ret
= mdev_access(mdev
, (char *)&val
, sizeof(val
),
613 if (copy_to_user(buf
, &val
, sizeof(val
)))
620 ret
= mdev_access(mdev
, (char *)&val
, sizeof(val
),
625 if (copy_to_user(buf
, &val
, sizeof(val
)))
643 static ssize_t
mbochs_write(struct mdev_device
*mdev
, const char __user
*buf
,
644 size_t count
, loff_t
*ppos
)
646 unsigned int done
= 0;
652 if (count
>= 4 && !(*ppos
% 4)) {
655 if (copy_from_user(&val
, buf
, sizeof(val
)))
658 ret
= mdev_access(mdev
, (char *)&val
, sizeof(val
),
664 } else if (count
>= 2 && !(*ppos
% 2)) {
667 if (copy_from_user(&val
, buf
, sizeof(val
)))
670 ret
= mdev_access(mdev
, (char *)&val
, sizeof(val
),
679 if (copy_from_user(&val
, buf
, sizeof(val
)))
682 ret
= mdev_access(mdev
, (char *)&val
, sizeof(val
),
700 static struct page
*__mbochs_get_page(struct mdev_state
*mdev_state
,
703 WARN_ON(!mutex_is_locked(&mdev_state
->ops_lock
));
705 if (!mdev_state
->pages
[pgoff
]) {
706 mdev_state
->pages
[pgoff
] =
707 alloc_pages(GFP_HIGHUSER
| __GFP_ZERO
, 0);
708 if (!mdev_state
->pages
[pgoff
])
712 get_page(mdev_state
->pages
[pgoff
]);
713 return mdev_state
->pages
[pgoff
];
716 static struct page
*mbochs_get_page(struct mdev_state
*mdev_state
,
721 if (WARN_ON(pgoff
>= mdev_state
->pagecount
))
724 mutex_lock(&mdev_state
->ops_lock
);
725 page
= __mbochs_get_page(mdev_state
, pgoff
);
726 mutex_unlock(&mdev_state
->ops_lock
);
731 static void mbochs_put_pages(struct mdev_state
*mdev_state
)
733 struct device
*dev
= mdev_dev(mdev_state
->mdev
);
736 WARN_ON(!mutex_is_locked(&mdev_state
->ops_lock
));
738 for (i
= 0; i
< mdev_state
->pagecount
; i
++) {
739 if (!mdev_state
->pages
[i
])
741 put_page(mdev_state
->pages
[i
]);
742 mdev_state
->pages
[i
] = NULL
;
745 dev_dbg(dev
, "%s: %d pages released\n", __func__
, count
);
748 static vm_fault_t
mbochs_region_vm_fault(struct vm_fault
*vmf
)
750 struct vm_area_struct
*vma
= vmf
->vma
;
751 struct mdev_state
*mdev_state
= vma
->vm_private_data
;
752 pgoff_t page_offset
= (vmf
->address
- vma
->vm_start
) >> PAGE_SHIFT
;
754 if (page_offset
>= mdev_state
->pagecount
)
755 return VM_FAULT_SIGBUS
;
757 vmf
->page
= mbochs_get_page(mdev_state
, page_offset
);
759 return VM_FAULT_SIGBUS
;
764 static const struct vm_operations_struct mbochs_region_vm_ops
= {
765 .fault
= mbochs_region_vm_fault
,
768 static int mbochs_mmap(struct mdev_device
*mdev
, struct vm_area_struct
*vma
)
770 struct mdev_state
*mdev_state
= mdev_get_drvdata(mdev
);
772 if (vma
->vm_pgoff
!= MBOCHS_MEMORY_BAR_OFFSET
>> PAGE_SHIFT
)
774 if (vma
->vm_end
< vma
->vm_start
)
776 if (vma
->vm_end
- vma
->vm_start
> mdev_state
->memsize
)
778 if ((vma
->vm_flags
& VM_SHARED
) == 0)
781 vma
->vm_ops
= &mbochs_region_vm_ops
;
782 vma
->vm_private_data
= mdev_state
;
786 static vm_fault_t
mbochs_dmabuf_vm_fault(struct vm_fault
*vmf
)
788 struct vm_area_struct
*vma
= vmf
->vma
;
789 struct mbochs_dmabuf
*dmabuf
= vma
->vm_private_data
;
791 if (WARN_ON(vmf
->pgoff
>= dmabuf
->pagecount
))
792 return VM_FAULT_SIGBUS
;
794 vmf
->page
= dmabuf
->pages
[vmf
->pgoff
];
799 static const struct vm_operations_struct mbochs_dmabuf_vm_ops
= {
800 .fault
= mbochs_dmabuf_vm_fault
,
803 static int mbochs_mmap_dmabuf(struct dma_buf
*buf
, struct vm_area_struct
*vma
)
805 struct mbochs_dmabuf
*dmabuf
= buf
->priv
;
806 struct device
*dev
= mdev_dev(dmabuf
->mdev_state
->mdev
);
808 dev_dbg(dev
, "%s: %d\n", __func__
, dmabuf
->id
);
810 if ((vma
->vm_flags
& VM_SHARED
) == 0)
813 vma
->vm_ops
= &mbochs_dmabuf_vm_ops
;
814 vma
->vm_private_data
= dmabuf
;
818 static void mbochs_print_dmabuf(struct mbochs_dmabuf
*dmabuf
,
821 struct device
*dev
= mdev_dev(dmabuf
->mdev_state
->mdev
);
822 u32 fourcc
= dmabuf
->mode
.drm_format
;
824 dev_dbg(dev
, "%s/%d: %c%c%c%c, %dx%d, stride %d, off 0x%llx, size 0x%llx, pages %ld\n",
826 fourcc
? ((fourcc
>> 0) & 0xff) : '-',
827 fourcc
? ((fourcc
>> 8) & 0xff) : '-',
828 fourcc
? ((fourcc
>> 16) & 0xff) : '-',
829 fourcc
? ((fourcc
>> 24) & 0xff) : '-',
830 dmabuf
->mode
.width
, dmabuf
->mode
.height
, dmabuf
->mode
.stride
,
831 dmabuf
->mode
.offset
, dmabuf
->mode
.size
, dmabuf
->pagecount
);
834 static struct sg_table
*mbochs_map_dmabuf(struct dma_buf_attachment
*at
,
835 enum dma_data_direction direction
)
837 struct mbochs_dmabuf
*dmabuf
= at
->dmabuf
->priv
;
838 struct device
*dev
= mdev_dev(dmabuf
->mdev_state
->mdev
);
841 dev_dbg(dev
, "%s: %d\n", __func__
, dmabuf
->id
);
843 sg
= kzalloc(sizeof(*sg
), GFP_KERNEL
);
846 if (sg_alloc_table_from_pages(sg
, dmabuf
->pages
, dmabuf
->pagecount
,
847 0, dmabuf
->mode
.size
, GFP_KERNEL
) < 0)
849 if (!dma_map_sg(at
->dev
, sg
->sgl
, sg
->nents
, direction
))
859 return ERR_PTR(-ENOMEM
);
862 static void mbochs_unmap_dmabuf(struct dma_buf_attachment
*at
,
864 enum dma_data_direction direction
)
866 struct mbochs_dmabuf
*dmabuf
= at
->dmabuf
->priv
;
867 struct device
*dev
= mdev_dev(dmabuf
->mdev_state
->mdev
);
869 dev_dbg(dev
, "%s: %d\n", __func__
, dmabuf
->id
);
875 static void mbochs_release_dmabuf(struct dma_buf
*buf
)
877 struct mbochs_dmabuf
*dmabuf
= buf
->priv
;
878 struct mdev_state
*mdev_state
= dmabuf
->mdev_state
;
879 struct device
*dev
= mdev_dev(mdev_state
->mdev
);
882 dev_dbg(dev
, "%s: %d\n", __func__
, dmabuf
->id
);
884 for (pg
= 0; pg
< dmabuf
->pagecount
; pg
++)
885 put_page(dmabuf
->pages
[pg
]);
887 mutex_lock(&mdev_state
->ops_lock
);
889 if (dmabuf
->unlinked
)
891 mutex_unlock(&mdev_state
->ops_lock
);
894 static struct dma_buf_ops mbochs_dmabuf_ops
= {
895 .map_dma_buf
= mbochs_map_dmabuf
,
896 .unmap_dma_buf
= mbochs_unmap_dmabuf
,
897 .release
= mbochs_release_dmabuf
,
898 .mmap
= mbochs_mmap_dmabuf
,
901 static struct mbochs_dmabuf
*mbochs_dmabuf_alloc(struct mdev_state
*mdev_state
,
902 struct mbochs_mode
*mode
)
904 struct mbochs_dmabuf
*dmabuf
;
905 pgoff_t page_offset
, pg
;
907 WARN_ON(!mutex_is_locked(&mdev_state
->ops_lock
));
909 dmabuf
= kzalloc(sizeof(struct mbochs_dmabuf
), GFP_KERNEL
);
913 dmabuf
->mode
= *mode
;
914 dmabuf
->id
= mdev_state
->next_id
++;
915 dmabuf
->pagecount
= DIV_ROUND_UP(mode
->size
, PAGE_SIZE
);
916 dmabuf
->pages
= kcalloc(dmabuf
->pagecount
, sizeof(struct page
*),
919 goto err_free_dmabuf
;
921 page_offset
= dmabuf
->mode
.offset
>> PAGE_SHIFT
;
922 for (pg
= 0; pg
< dmabuf
->pagecount
; pg
++) {
923 dmabuf
->pages
[pg
] = __mbochs_get_page(mdev_state
,
925 if (!dmabuf
->pages
[pg
])
929 dmabuf
->mdev_state
= mdev_state
;
930 list_add(&dmabuf
->next
, &mdev_state
->dmabufs
);
932 mbochs_print_dmabuf(dmabuf
, __func__
);
937 put_page(dmabuf
->pages
[--pg
]);
938 kfree(dmabuf
->pages
);
944 static struct mbochs_dmabuf
*
945 mbochs_dmabuf_find_by_mode(struct mdev_state
*mdev_state
,
946 struct mbochs_mode
*mode
)
948 struct mbochs_dmabuf
*dmabuf
;
950 WARN_ON(!mutex_is_locked(&mdev_state
->ops_lock
));
952 list_for_each_entry(dmabuf
, &mdev_state
->dmabufs
, next
)
953 if (mbochs_modes_equal(&dmabuf
->mode
, mode
))
959 static struct mbochs_dmabuf
*
960 mbochs_dmabuf_find_by_id(struct mdev_state
*mdev_state
, u32 id
)
962 struct mbochs_dmabuf
*dmabuf
;
964 WARN_ON(!mutex_is_locked(&mdev_state
->ops_lock
));
966 list_for_each_entry(dmabuf
, &mdev_state
->dmabufs
, next
)
967 if (dmabuf
->id
== id
)
973 static int mbochs_dmabuf_export(struct mbochs_dmabuf
*dmabuf
)
975 struct mdev_state
*mdev_state
= dmabuf
->mdev_state
;
976 struct device
*dev
= mdev_dev(mdev_state
->mdev
);
977 DEFINE_DMA_BUF_EXPORT_INFO(exp_info
);
980 WARN_ON(!mutex_is_locked(&mdev_state
->ops_lock
));
982 if (!IS_ALIGNED(dmabuf
->mode
.offset
, PAGE_SIZE
)) {
983 dev_info_ratelimited(dev
, "%s: framebuffer not page-aligned\n",
988 exp_info
.ops
= &mbochs_dmabuf_ops
;
989 exp_info
.size
= dmabuf
->mode
.size
;
990 exp_info
.priv
= dmabuf
;
992 buf
= dma_buf_export(&exp_info
);
994 dev_info_ratelimited(dev
, "%s: dma_buf_export failed: %ld\n",
995 __func__
, PTR_ERR(buf
));
1000 dev_dbg(dev
, "%s: %d\n", __func__
, dmabuf
->id
);
1004 static int mbochs_get_region_info(struct mdev_device
*mdev
,
1005 struct vfio_region_info_ext
*ext
)
1007 struct vfio_region_info
*region_info
= &ext
->base
;
1008 struct mdev_state
*mdev_state
;
1010 mdev_state
= mdev_get_drvdata(mdev
);
1014 if (region_info
->index
>= MBOCHS_NUM_REGIONS
)
1017 switch (region_info
->index
) {
1018 case VFIO_PCI_CONFIG_REGION_INDEX
:
1019 region_info
->offset
= 0;
1020 region_info
->size
= MBOCHS_CONFIG_SPACE_SIZE
;
1021 region_info
->flags
= (VFIO_REGION_INFO_FLAG_READ
|
1022 VFIO_REGION_INFO_FLAG_WRITE
);
1024 case VFIO_PCI_BAR0_REGION_INDEX
:
1025 region_info
->offset
= MBOCHS_MEMORY_BAR_OFFSET
;
1026 region_info
->size
= mdev_state
->memsize
;
1027 region_info
->flags
= (VFIO_REGION_INFO_FLAG_READ
|
1028 VFIO_REGION_INFO_FLAG_WRITE
|
1029 VFIO_REGION_INFO_FLAG_MMAP
);
1031 case VFIO_PCI_BAR2_REGION_INDEX
:
1032 region_info
->offset
= MBOCHS_MMIO_BAR_OFFSET
;
1033 region_info
->size
= MBOCHS_MMIO_BAR_SIZE
;
1034 region_info
->flags
= (VFIO_REGION_INFO_FLAG_READ
|
1035 VFIO_REGION_INFO_FLAG_WRITE
);
1037 case MBOCHS_EDID_REGION_INDEX
:
1038 ext
->base
.argsz
= sizeof(*ext
);
1039 ext
->base
.offset
= MBOCHS_EDID_OFFSET
;
1040 ext
->base
.size
= MBOCHS_EDID_SIZE
;
1041 ext
->base
.flags
= (VFIO_REGION_INFO_FLAG_READ
|
1042 VFIO_REGION_INFO_FLAG_WRITE
|
1043 VFIO_REGION_INFO_FLAG_CAPS
);
1044 ext
->base
.cap_offset
= offsetof(typeof(*ext
), type
);
1045 ext
->type
.header
.id
= VFIO_REGION_INFO_CAP_TYPE
;
1046 ext
->type
.header
.version
= 1;
1047 ext
->type
.header
.next
= 0;
1048 ext
->type
.type
= VFIO_REGION_TYPE_GFX
;
1049 ext
->type
.subtype
= VFIO_REGION_SUBTYPE_GFX_EDID
;
1052 region_info
->size
= 0;
1053 region_info
->offset
= 0;
1054 region_info
->flags
= 0;
1060 static int mbochs_get_irq_info(struct mdev_device
*mdev
,
1061 struct vfio_irq_info
*irq_info
)
1063 irq_info
->count
= 0;
1067 static int mbochs_get_device_info(struct mdev_device
*mdev
,
1068 struct vfio_device_info
*dev_info
)
1070 dev_info
->flags
= VFIO_DEVICE_FLAGS_PCI
;
1071 dev_info
->num_regions
= MBOCHS_NUM_REGIONS
;
1072 dev_info
->num_irqs
= VFIO_PCI_NUM_IRQS
;
1076 static int mbochs_query_gfx_plane(struct mdev_device
*mdev
,
1077 struct vfio_device_gfx_plane_info
*plane
)
1079 struct mdev_state
*mdev_state
= mdev_get_drvdata(mdev
);
1080 struct device
*dev
= mdev_dev(mdev
);
1081 struct mbochs_dmabuf
*dmabuf
;
1082 struct mbochs_mode mode
;
1085 if (plane
->flags
& VFIO_GFX_PLANE_TYPE_PROBE
) {
1086 if (plane
->flags
== (VFIO_GFX_PLANE_TYPE_PROBE
|
1087 VFIO_GFX_PLANE_TYPE_DMABUF
))
1092 if (plane
->flags
!= VFIO_GFX_PLANE_TYPE_DMABUF
)
1095 plane
->drm_format_mod
= 0;
1101 mutex_lock(&mdev_state
->ops_lock
);
1104 if (plane
->drm_plane_type
== DRM_PLANE_TYPE_PRIMARY
)
1105 ret
= mbochs_check_framebuffer(mdev_state
, &mode
);
1107 plane
->drm_format
= 0;
1112 plane
->dmabuf_id
= 0;
1116 dmabuf
= mbochs_dmabuf_find_by_mode(mdev_state
, &mode
);
1118 mbochs_dmabuf_alloc(mdev_state
, &mode
);
1120 mutex_unlock(&mdev_state
->ops_lock
);
1124 plane
->drm_format
= dmabuf
->mode
.drm_format
;
1125 plane
->width
= dmabuf
->mode
.width
;
1126 plane
->height
= dmabuf
->mode
.height
;
1127 plane
->stride
= dmabuf
->mode
.stride
;
1128 plane
->size
= dmabuf
->mode
.size
;
1129 plane
->dmabuf_id
= dmabuf
->id
;
1132 if (plane
->drm_plane_type
== DRM_PLANE_TYPE_PRIMARY
&&
1133 mdev_state
->active_id
!= plane
->dmabuf_id
) {
1134 dev_dbg(dev
, "%s: primary: %d => %d\n", __func__
,
1135 mdev_state
->active_id
, plane
->dmabuf_id
);
1136 mdev_state
->active_id
= plane
->dmabuf_id
;
1138 mutex_unlock(&mdev_state
->ops_lock
);
1142 static int mbochs_get_gfx_dmabuf(struct mdev_device
*mdev
,
1145 struct mdev_state
*mdev_state
= mdev_get_drvdata(mdev
);
1146 struct mbochs_dmabuf
*dmabuf
;
1148 mutex_lock(&mdev_state
->ops_lock
);
1150 dmabuf
= mbochs_dmabuf_find_by_id(mdev_state
, id
);
1152 mutex_unlock(&mdev_state
->ops_lock
);
1157 mbochs_dmabuf_export(dmabuf
);
1159 mutex_unlock(&mdev_state
->ops_lock
);
1164 return dma_buf_fd(dmabuf
->buf
, 0);
1167 static long mbochs_ioctl(struct mdev_device
*mdev
, unsigned int cmd
,
1171 unsigned long minsz
, outsz
;
1174 case VFIO_DEVICE_GET_INFO
:
1176 struct vfio_device_info info
;
1178 minsz
= offsetofend(struct vfio_device_info
, num_irqs
);
1180 if (copy_from_user(&info
, (void __user
*)arg
, minsz
))
1183 if (info
.argsz
< minsz
)
1186 ret
= mbochs_get_device_info(mdev
, &info
);
1190 if (copy_to_user((void __user
*)arg
, &info
, minsz
))
1195 case VFIO_DEVICE_GET_REGION_INFO
:
1197 struct vfio_region_info_ext info
;
1199 minsz
= offsetofend(typeof(info
), base
.offset
);
1201 if (copy_from_user(&info
, (void __user
*)arg
, minsz
))
1204 outsz
= info
.base
.argsz
;
1207 if (outsz
> sizeof(info
))
1210 ret
= mbochs_get_region_info(mdev
, &info
);
1214 if (copy_to_user((void __user
*)arg
, &info
, outsz
))
1220 case VFIO_DEVICE_GET_IRQ_INFO
:
1222 struct vfio_irq_info info
;
1224 minsz
= offsetofend(struct vfio_irq_info
, count
);
1226 if (copy_from_user(&info
, (void __user
*)arg
, minsz
))
1229 if ((info
.argsz
< minsz
) ||
1230 (info
.index
>= VFIO_PCI_NUM_IRQS
))
1233 ret
= mbochs_get_irq_info(mdev
, &info
);
1237 if (copy_to_user((void __user
*)arg
, &info
, minsz
))
1243 case VFIO_DEVICE_QUERY_GFX_PLANE
:
1245 struct vfio_device_gfx_plane_info plane
;
1247 minsz
= offsetofend(struct vfio_device_gfx_plane_info
,
1250 if (copy_from_user(&plane
, (void __user
*)arg
, minsz
))
1253 if (plane
.argsz
< minsz
)
1256 ret
= mbochs_query_gfx_plane(mdev
, &plane
);
1260 if (copy_to_user((void __user
*)arg
, &plane
, minsz
))
1266 case VFIO_DEVICE_GET_GFX_DMABUF
:
1270 if (get_user(dmabuf_id
, (__u32 __user
*)arg
))
1273 return mbochs_get_gfx_dmabuf(mdev
, dmabuf_id
);
1276 case VFIO_DEVICE_SET_IRQS
:
1279 case VFIO_DEVICE_RESET
:
1280 return mbochs_reset(mdev
);
1285 static int mbochs_open(struct mdev_device
*mdev
)
1287 if (!try_module_get(THIS_MODULE
))
1293 static void mbochs_close(struct mdev_device
*mdev
)
1295 struct mdev_state
*mdev_state
= mdev_get_drvdata(mdev
);
1296 struct mbochs_dmabuf
*dmabuf
, *tmp
;
1298 mutex_lock(&mdev_state
->ops_lock
);
1300 list_for_each_entry_safe(dmabuf
, tmp
, &mdev_state
->dmabufs
, next
) {
1301 list_del(&dmabuf
->next
);
1303 /* free in mbochs_release_dmabuf() */
1304 dmabuf
->unlinked
= true;
1309 mbochs_put_pages(mdev_state
);
1311 mutex_unlock(&mdev_state
->ops_lock
);
1312 module_put(THIS_MODULE
);
1316 memory_show(struct device
*dev
, struct device_attribute
*attr
,
1319 struct mdev_device
*mdev
= mdev_from_dev(dev
);
1320 struct mdev_state
*mdev_state
= mdev_get_drvdata(mdev
);
1322 return sprintf(buf
, "%d MB\n", mdev_state
->type
->mbytes
);
1324 static DEVICE_ATTR_RO(memory
);
1326 static struct attribute
*mdev_dev_attrs
[] = {
1327 &dev_attr_memory
.attr
,
1331 static const struct attribute_group mdev_dev_group
= {
1333 .attrs
= mdev_dev_attrs
,
1336 const struct attribute_group
*mdev_dev_groups
[] = {
1342 name_show(struct kobject
*kobj
, struct device
*dev
, char *buf
)
1344 return sprintf(buf
, "%s\n", kobj
->name
);
1346 MDEV_TYPE_ATTR_RO(name
);
1349 description_show(struct kobject
*kobj
, struct device
*dev
, char *buf
)
1351 const struct mbochs_type
*type
= mbochs_find_type(kobj
);
1353 return sprintf(buf
, "virtual display, %d MB video memory\n",
1354 type
? type
->mbytes
: 0);
1356 MDEV_TYPE_ATTR_RO(description
);
1359 available_instances_show(struct kobject
*kobj
, struct device
*dev
, char *buf
)
1361 const struct mbochs_type
*type
= mbochs_find_type(kobj
);
1362 int count
= (max_mbytes
- mbochs_used_mbytes
) / type
->mbytes
;
1364 return sprintf(buf
, "%d\n", count
);
1366 MDEV_TYPE_ATTR_RO(available_instances
);
1368 static ssize_t
device_api_show(struct kobject
*kobj
, struct device
*dev
,
1371 return sprintf(buf
, "%s\n", VFIO_DEVICE_API_PCI_STRING
);
1373 MDEV_TYPE_ATTR_RO(device_api
);
1375 static struct attribute
*mdev_types_attrs
[] = {
1376 &mdev_type_attr_name
.attr
,
1377 &mdev_type_attr_description
.attr
,
1378 &mdev_type_attr_device_api
.attr
,
1379 &mdev_type_attr_available_instances
.attr
,
1383 static struct attribute_group mdev_type_group1
= {
1384 .name
= MBOCHS_TYPE_1
,
1385 .attrs
= mdev_types_attrs
,
1388 static struct attribute_group mdev_type_group2
= {
1389 .name
= MBOCHS_TYPE_2
,
1390 .attrs
= mdev_types_attrs
,
1393 static struct attribute_group mdev_type_group3
= {
1394 .name
= MBOCHS_TYPE_3
,
1395 .attrs
= mdev_types_attrs
,
1398 static struct attribute_group
*mdev_type_groups
[] = {
1405 static const struct mdev_parent_ops mdev_fops
= {
1406 .owner
= THIS_MODULE
,
1407 .mdev_attr_groups
= mdev_dev_groups
,
1408 .supported_type_groups
= mdev_type_groups
,
1409 .create
= mbochs_create
,
1410 .remove
= mbochs_remove
,
1411 .open
= mbochs_open
,
1412 .release
= mbochs_close
,
1413 .read
= mbochs_read
,
1414 .write
= mbochs_write
,
1415 .ioctl
= mbochs_ioctl
,
1416 .mmap
= mbochs_mmap
,
1419 static const struct file_operations vd_fops
= {
1420 .owner
= THIS_MODULE
,
1423 static void mbochs_device_release(struct device
*dev
)
1428 static int __init
mbochs_dev_init(void)
1432 ret
= alloc_chrdev_region(&mbochs_devt
, 0, MINORMASK
+ 1, MBOCHS_NAME
);
1434 pr_err("Error: failed to register mbochs_dev, err: %d\n", ret
);
1437 cdev_init(&mbochs_cdev
, &vd_fops
);
1438 cdev_add(&mbochs_cdev
, mbochs_devt
, MINORMASK
+ 1);
1439 pr_info("%s: major %d\n", __func__
, MAJOR(mbochs_devt
));
1441 mbochs_class
= class_create(THIS_MODULE
, MBOCHS_CLASS_NAME
);
1442 if (IS_ERR(mbochs_class
)) {
1443 pr_err("Error: failed to register mbochs_dev class\n");
1444 ret
= PTR_ERR(mbochs_class
);
1447 mbochs_dev
.class = mbochs_class
;
1448 mbochs_dev
.release
= mbochs_device_release
;
1449 dev_set_name(&mbochs_dev
, "%s", MBOCHS_NAME
);
1451 ret
= device_register(&mbochs_dev
);
1455 ret
= mdev_register_device(&mbochs_dev
, &mdev_fops
);
1462 device_unregister(&mbochs_dev
);
1464 class_destroy(mbochs_class
);
1466 cdev_del(&mbochs_cdev
);
1467 unregister_chrdev_region(mbochs_devt
, MINORMASK
+ 1);
1471 static void __exit
mbochs_dev_exit(void)
1473 mbochs_dev
.bus
= NULL
;
1474 mdev_unregister_device(&mbochs_dev
);
1476 device_unregister(&mbochs_dev
);
1477 cdev_del(&mbochs_cdev
);
1478 unregister_chrdev_region(mbochs_devt
, MINORMASK
+ 1);
1479 class_destroy(mbochs_class
);
1480 mbochs_class
= NULL
;
1483 module_init(mbochs_dev_init
)
1484 module_exit(mbochs_dev_exit
)