virtio-mmio: switch to linux headers
Switch to virtio_mmio.h from Linux - will make it easier to implement virtio 1. Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
This commit is contained in:
		
							parent
							
								
									5878b13642
								
							
						
					
					
						commit
						7e71da7f12
					
				@ -20,6 +20,7 @@
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include "qemu/osdep.h"
 | 
			
		||||
#include "standard-headers/linux/virtio_mmio.h"
 | 
			
		||||
#include "hw/sysbus.h"
 | 
			
		||||
#include "hw/virtio/virtio.h"
 | 
			
		||||
#include "qemu/host-utils.h"
 | 
			
		||||
@ -52,28 +53,6 @@ do { printf("virtio_mmio: " fmt , ## __VA_ARGS__); } while (0)
 | 
			
		||||
#define VIRTIO_MMIO(obj) \
 | 
			
		||||
        OBJECT_CHECK(VirtIOMMIOProxy, (obj), TYPE_VIRTIO_MMIO)
 | 
			
		||||
 | 
			
		||||
/* Memory mapped register offsets */
 | 
			
		||||
#define VIRTIO_MMIO_MAGIC 0x0
 | 
			
		||||
#define VIRTIO_MMIO_VERSION 0x4
 | 
			
		||||
#define VIRTIO_MMIO_DEVICEID 0x8
 | 
			
		||||
#define VIRTIO_MMIO_VENDORID 0xc
 | 
			
		||||
#define VIRTIO_MMIO_HOSTFEATURES 0x10
 | 
			
		||||
#define VIRTIO_MMIO_HOSTFEATURESSEL 0x14
 | 
			
		||||
#define VIRTIO_MMIO_GUESTFEATURES 0x20
 | 
			
		||||
#define VIRTIO_MMIO_GUESTFEATURESSEL 0x24
 | 
			
		||||
#define VIRTIO_MMIO_GUESTPAGESIZE 0x28
 | 
			
		||||
#define VIRTIO_MMIO_QUEUESEL 0x30
 | 
			
		||||
#define VIRTIO_MMIO_QUEUENUMMAX 0x34
 | 
			
		||||
#define VIRTIO_MMIO_QUEUENUM 0x38
 | 
			
		||||
#define VIRTIO_MMIO_QUEUEALIGN 0x3c
 | 
			
		||||
#define VIRTIO_MMIO_QUEUEPFN 0x40
 | 
			
		||||
#define VIRTIO_MMIO_QUEUENOTIFY 0x50
 | 
			
		||||
#define VIRTIO_MMIO_INTERRUPTSTATUS 0x60
 | 
			
		||||
#define VIRTIO_MMIO_INTERRUPTACK 0x64
 | 
			
		||||
#define VIRTIO_MMIO_STATUS 0x70
 | 
			
		||||
/* Device specific config space starts here */
 | 
			
		||||
#define VIRTIO_MMIO_CONFIG 0x100
 | 
			
		||||
 | 
			
		||||
#define VIRT_MAGIC 0x74726976 /* 'virt' */
 | 
			
		||||
#define VIRT_VERSION 1
 | 
			
		||||
#define VIRT_VENDOR 0x554D4551 /* 'QEMU' */
 | 
			
		||||
@ -104,10 +83,10 @@ static int virtio_mmio_ioeventfd_assign(DeviceState *d,
 | 
			
		||||
    VirtIOMMIOProxy *proxy = VIRTIO_MMIO(d);
 | 
			
		||||
 | 
			
		||||
    if (assign) {
 | 
			
		||||
        memory_region_add_eventfd(&proxy->iomem, VIRTIO_MMIO_QUEUENOTIFY, 4,
 | 
			
		||||
        memory_region_add_eventfd(&proxy->iomem, VIRTIO_MMIO_QUEUE_NOTIFY, 4,
 | 
			
		||||
                                  true, n, notifier);
 | 
			
		||||
    } else {
 | 
			
		||||
        memory_region_del_eventfd(&proxy->iomem, VIRTIO_MMIO_QUEUENOTIFY, 4,
 | 
			
		||||
        memory_region_del_eventfd(&proxy->iomem, VIRTIO_MMIO_QUEUE_NOTIFY, 4,
 | 
			
		||||
                                  true, n, notifier);
 | 
			
		||||
    }
 | 
			
		||||
    return 0;
 | 
			
		||||
@ -140,11 +119,11 @@ static uint64_t virtio_mmio_read(void *opaque, hwaddr offset, unsigned size)
 | 
			
		||||
         * device ID of zero means no backend will claim it.
 | 
			
		||||
         */
 | 
			
		||||
        switch (offset) {
 | 
			
		||||
        case VIRTIO_MMIO_MAGIC:
 | 
			
		||||
        case VIRTIO_MMIO_MAGIC_VALUE:
 | 
			
		||||
            return VIRT_MAGIC;
 | 
			
		||||
        case VIRTIO_MMIO_VERSION:
 | 
			
		||||
            return VIRT_VERSION;
 | 
			
		||||
        case VIRTIO_MMIO_VENDORID:
 | 
			
		||||
        case VIRTIO_MMIO_VENDOR_ID:
 | 
			
		||||
            return VIRT_VENDOR;
 | 
			
		||||
        default:
 | 
			
		||||
            return 0;
 | 
			
		||||
@ -169,40 +148,40 @@ static uint64_t virtio_mmio_read(void *opaque, hwaddr offset, unsigned size)
 | 
			
		||||
        return 0;
 | 
			
		||||
    }
 | 
			
		||||
    switch (offset) {
 | 
			
		||||
    case VIRTIO_MMIO_MAGIC:
 | 
			
		||||
    case VIRTIO_MMIO_MAGIC_VALUE:
 | 
			
		||||
        return VIRT_MAGIC;
 | 
			
		||||
    case VIRTIO_MMIO_VERSION:
 | 
			
		||||
        return VIRT_VERSION;
 | 
			
		||||
    case VIRTIO_MMIO_DEVICEID:
 | 
			
		||||
    case VIRTIO_MMIO_DEVICE_ID:
 | 
			
		||||
        return vdev->device_id;
 | 
			
		||||
    case VIRTIO_MMIO_VENDORID:
 | 
			
		||||
    case VIRTIO_MMIO_VENDOR_ID:
 | 
			
		||||
        return VIRT_VENDOR;
 | 
			
		||||
    case VIRTIO_MMIO_HOSTFEATURES:
 | 
			
		||||
    case VIRTIO_MMIO_DEVICE_FEATURES:
 | 
			
		||||
        if (proxy->host_features_sel) {
 | 
			
		||||
            return 0;
 | 
			
		||||
        }
 | 
			
		||||
        return vdev->host_features;
 | 
			
		||||
    case VIRTIO_MMIO_QUEUENUMMAX:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUE_NUM_MAX:
 | 
			
		||||
        if (!virtio_queue_get_num(vdev, vdev->queue_sel)) {
 | 
			
		||||
            return 0;
 | 
			
		||||
        }
 | 
			
		||||
        return VIRTQUEUE_MAX_SIZE;
 | 
			
		||||
    case VIRTIO_MMIO_QUEUEPFN:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUE_PFN:
 | 
			
		||||
        return virtio_queue_get_addr(vdev, vdev->queue_sel)
 | 
			
		||||
            >> proxy->guest_page_shift;
 | 
			
		||||
    case VIRTIO_MMIO_INTERRUPTSTATUS:
 | 
			
		||||
    case VIRTIO_MMIO_INTERRUPT_STATUS:
 | 
			
		||||
        return atomic_read(&vdev->isr);
 | 
			
		||||
    case VIRTIO_MMIO_STATUS:
 | 
			
		||||
        return vdev->status;
 | 
			
		||||
    case VIRTIO_MMIO_HOSTFEATURESSEL:
 | 
			
		||||
    case VIRTIO_MMIO_GUESTFEATURES:
 | 
			
		||||
    case VIRTIO_MMIO_GUESTFEATURESSEL:
 | 
			
		||||
    case VIRTIO_MMIO_GUESTPAGESIZE:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUESEL:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUENUM:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUEALIGN:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUENOTIFY:
 | 
			
		||||
    case VIRTIO_MMIO_INTERRUPTACK:
 | 
			
		||||
    case VIRTIO_MMIO_DEVICE_FEATURES_SEL:
 | 
			
		||||
    case VIRTIO_MMIO_DRIVER_FEATURES:
 | 
			
		||||
    case VIRTIO_MMIO_DRIVER_FEATURES_SEL:
 | 
			
		||||
    case VIRTIO_MMIO_GUEST_PAGE_SIZE:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUE_SEL:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUE_NUM:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUE_ALIGN:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUE_NOTIFY:
 | 
			
		||||
    case VIRTIO_MMIO_INTERRUPT_ACK:
 | 
			
		||||
        DPRINTF("read of write-only register\n");
 | 
			
		||||
        return 0;
 | 
			
		||||
    default:
 | 
			
		||||
@ -251,18 +230,18 @@ static void virtio_mmio_write(void *opaque, hwaddr offset, uint64_t value,
 | 
			
		||||
        return;
 | 
			
		||||
    }
 | 
			
		||||
    switch (offset) {
 | 
			
		||||
    case VIRTIO_MMIO_HOSTFEATURESSEL:
 | 
			
		||||
    case VIRTIO_MMIO_DEVICE_FEATURES_SEL:
 | 
			
		||||
        proxy->host_features_sel = value;
 | 
			
		||||
        break;
 | 
			
		||||
    case VIRTIO_MMIO_GUESTFEATURES:
 | 
			
		||||
    case VIRTIO_MMIO_DRIVER_FEATURES:
 | 
			
		||||
        if (!proxy->guest_features_sel) {
 | 
			
		||||
            virtio_set_features(vdev, value);
 | 
			
		||||
        }
 | 
			
		||||
        break;
 | 
			
		||||
    case VIRTIO_MMIO_GUESTFEATURESSEL:
 | 
			
		||||
    case VIRTIO_MMIO_DRIVER_FEATURES_SEL:
 | 
			
		||||
        proxy->guest_features_sel = value;
 | 
			
		||||
        break;
 | 
			
		||||
    case VIRTIO_MMIO_GUESTPAGESIZE:
 | 
			
		||||
    case VIRTIO_MMIO_GUEST_PAGE_SIZE:
 | 
			
		||||
        proxy->guest_page_shift = ctz32(value);
 | 
			
		||||
        if (proxy->guest_page_shift > 31) {
 | 
			
		||||
            proxy->guest_page_shift = 0;
 | 
			
		||||
@ -270,22 +249,22 @@ static void virtio_mmio_write(void *opaque, hwaddr offset, uint64_t value,
 | 
			
		||||
        DPRINTF("guest page size %" PRIx64 " shift %d\n", value,
 | 
			
		||||
                proxy->guest_page_shift);
 | 
			
		||||
        break;
 | 
			
		||||
    case VIRTIO_MMIO_QUEUESEL:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUE_SEL:
 | 
			
		||||
        if (value < VIRTIO_QUEUE_MAX) {
 | 
			
		||||
            vdev->queue_sel = value;
 | 
			
		||||
        }
 | 
			
		||||
        break;
 | 
			
		||||
    case VIRTIO_MMIO_QUEUENUM:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUE_NUM:
 | 
			
		||||
        DPRINTF("mmio_queue write %d max %d\n", (int)value, VIRTQUEUE_MAX_SIZE);
 | 
			
		||||
        virtio_queue_set_num(vdev, vdev->queue_sel, value);
 | 
			
		||||
        /* Note: only call this function for legacy devices */
 | 
			
		||||
        virtio_queue_update_rings(vdev, vdev->queue_sel);
 | 
			
		||||
        break;
 | 
			
		||||
    case VIRTIO_MMIO_QUEUEALIGN:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUE_ALIGN:
 | 
			
		||||
        /* Note: this is only valid for legacy devices */
 | 
			
		||||
        virtio_queue_set_align(vdev, vdev->queue_sel, value);
 | 
			
		||||
        break;
 | 
			
		||||
    case VIRTIO_MMIO_QUEUEPFN:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUE_PFN:
 | 
			
		||||
        if (value == 0) {
 | 
			
		||||
            virtio_reset(vdev);
 | 
			
		||||
        } else {
 | 
			
		||||
@ -293,12 +272,12 @@ static void virtio_mmio_write(void *opaque, hwaddr offset, uint64_t value,
 | 
			
		||||
                                  value << proxy->guest_page_shift);
 | 
			
		||||
        }
 | 
			
		||||
        break;
 | 
			
		||||
    case VIRTIO_MMIO_QUEUENOTIFY:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUE_NOTIFY:
 | 
			
		||||
        if (value < VIRTIO_QUEUE_MAX) {
 | 
			
		||||
            virtio_queue_notify(vdev, value);
 | 
			
		||||
        }
 | 
			
		||||
        break;
 | 
			
		||||
    case VIRTIO_MMIO_INTERRUPTACK:
 | 
			
		||||
    case VIRTIO_MMIO_INTERRUPT_ACK:
 | 
			
		||||
        atomic_and(&vdev->isr, ~value);
 | 
			
		||||
        virtio_update_irq(vdev);
 | 
			
		||||
        break;
 | 
			
		||||
@ -317,13 +296,13 @@ static void virtio_mmio_write(void *opaque, hwaddr offset, uint64_t value,
 | 
			
		||||
            virtio_reset(vdev);
 | 
			
		||||
        }
 | 
			
		||||
        break;
 | 
			
		||||
    case VIRTIO_MMIO_MAGIC:
 | 
			
		||||
    case VIRTIO_MMIO_MAGIC_VALUE:
 | 
			
		||||
    case VIRTIO_MMIO_VERSION:
 | 
			
		||||
    case VIRTIO_MMIO_DEVICEID:
 | 
			
		||||
    case VIRTIO_MMIO_VENDORID:
 | 
			
		||||
    case VIRTIO_MMIO_HOSTFEATURES:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUENUMMAX:
 | 
			
		||||
    case VIRTIO_MMIO_INTERRUPTSTATUS:
 | 
			
		||||
    case VIRTIO_MMIO_DEVICE_ID:
 | 
			
		||||
    case VIRTIO_MMIO_VENDOR_ID:
 | 
			
		||||
    case VIRTIO_MMIO_DEVICE_FEATURES:
 | 
			
		||||
    case VIRTIO_MMIO_QUEUE_NUM_MAX:
 | 
			
		||||
    case VIRTIO_MMIO_INTERRUPT_STATUS:
 | 
			
		||||
        DPRINTF("write to readonly register\n");
 | 
			
		||||
        break;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user