]> git.proxmox.com Git - mirror_edk2.git/commitdiff
OvmfPkg/Virtio.h: Added PCI/MMIO Virtio Headers Offsets
authorOlivier Martin <olivier.martin@arm.com>
Tue, 29 Oct 2013 06:08:39 +0000 (06:08 +0000)
committeroliviermartin <oliviermartin@6f19259b-4bc3-4df7-8a09-765794883524>
Tue, 29 Oct 2013 06:08:39 +0000 (06:08 +0000)
Offsets are different between the PCI and MMIO transport layer.

Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Olivier Martin <olivier.martin@arm.com>
Reviewed-by: Laszlo Ersek <lersek@redhat.com>
Tested-by: Laszlo Ersek <lersek@redhat.com>
git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@14808 6f19259b-4bc3-4df7-8a09-765794883524

OvmfPkg/Include/IndustryStandard/Virtio.h

index e5abe1bd6e26b000132da62bd7977d9952d41c57..f1eb2ea120d09e88513f73c232ad47093ab81a62 100644 (file)
@@ -4,6 +4,7 @@
   specification.\r
 \r
   Copyright (C) 2012, Red Hat, Inc.\r
+  Portion of Copyright (C) 2013, ARM Ltd.\r
 \r
   This program and the accompanying materials are licensed and made available\r
   under the terms and conditions of the BSD License which accompanies this\r
 #define VIRTIO_DEVICE_SPECIFIC_CONFIGURATION_OFFSET_PCI_WITH_MSI_X  24\r
 #define VIRTIO_DEVICE_SPECIFIC_CONFIGURATION_OFFSET_MMIO            0x100\r
 \r
+//\r
+// PCI VirtIo Header Offsets\r
+//\r
+#define VIRTIO_PCI_OFFSET_DEVICE_FEATURES           0x00\r
+#define VIRTIO_PCI_OFFSET_GUEST_FEATURES            0x04\r
+#define VIRTIO_PCI_OFFSET_QUEUE_ADDRESS             0x08\r
+#define VIRTIO_PCI_OFFSET_QUEUE_SIZE                0x0C\r
+#define VIRTIO_PCI_OFFSET_QUEUE_SELECT              0x0E\r
+#define VIRTIO_PCI_OFFSET_QUEUE_NOTIFY              0x10\r
+#define VIRTIO_PCI_OFFSET_QUEUE_DEVICE_STATUS       0x12\r
+#define VIRTIO_PCI_OFFSET_QUEUE_DEVICE_ISR          0x13\r
+\r
+//\r
+// MMIO VirtIo Header Offsets\r
+//\r
+#define VIRTIO_MMIO_OFFSET_MAGIC                    0x00\r
+#define VIRTIO_MMIO_OFFSET_VERSION                  0x04\r
+#define VIRTIO_MMIO_OFFSET_DEVICE_ID                0x08\r
+#define VIRTIO_MMIO_OFFSET_VENDOR_ID                0x0C\r
+#define VIRTIO_MMIO_OFFSET_HOST_FEATURES            0x10\r
+#define VIRTIO_MMIO_OFFSET_HOST_FEATURES_SEL        0x14\r
+#define VIRTIO_MMIO_OFFSET_GUEST_FEATURES           0x20\r
+#define VIRTIO_MMIO_OFFSET_GUEST_FEATURES_SEL       0x24\r
+#define VIRTIO_MMIO_OFFSET_GUEST_PAGE_SIZE          0x28\r
+#define VIRTIO_MMIO_OFFSET_QUEUE_SEL                0x30\r
+#define VIRTIO_MMIO_OFFSET_QUEUE_NUM_MAX            0x34\r
+#define VIRTIO_MMIO_OFFSET_QUEUE_NUM                0x38\r
+#define VIRTIO_MMIO_OFFSET_QUEUE_ALIGN              0x3C\r
+#define VIRTIO_MMIO_OFFSET_QUEUE_PFN                0x40\r
+#define VIRTIO_MMIO_OFFSET_QUEUE_NOTIFY             0x50\r
+#define VIRTIO_MMIO_OFFSET_INTERRUPT_STATUS         0x60\r
+#define VIRTIO_MMIO_OFFSET_INTERRUPT_ACK            0x64\r
+#define VIRTIO_MMIO_OFFSET_STATUS                   0x70\r
+\r
 //\r
 // Data in the communication area is defined as packed and accessed as\r
 // volatile.\r