diff options
author | Dr. David Alan Gilbert <dgilbert@redhat.com> | 2019-07-12 13:19:59 +0100 |
---|---|---|
committer | Michael S. Tsirkin <mst@redhat.com> | 2019-07-25 07:21:11 -0400 |
commit | 39dfc8afc0b93963398afc465a3d24799e13b356 (patch) | |
tree | b26855809b885742cffc10bc46746abfea027cd2 | |
parent | efd4028b7aec5030b6ac39c0ddc50353d0658704 (diff) | |
download | virtio-spec-39dfc8afc0b93963398afc465a3d24799e13b356.tar.gz |
pci: Define id field
For the virtio-fs device we require multiple large shared memory
regions. Differentiate these by an 'id' field in the base capability.
Fixes: https://github.com/oasis-tcs/virtio-spec/issues/40
Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
Reviewed-by: Cornelia Huck <cohuck@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
-rw-r--r-- | content.tex | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/content.tex b/content.tex index 6433226..fafa532 100644 --- a/content.tex +++ b/content.tex @@ -651,7 +651,8 @@ struct virtio_pci_cap { u8 cap_len; /* Generic PCI field: capability length */ u8 cfg_type; /* Identifies the structure. */ u8 bar; /* Where to find it. */ - u8 padding[3]; /* Pad to full dword. */ + u8 id; /* Multiple capabilities of the same type */ + u8 padding[2]; /* Pad to full dword. */ le32 offset; /* Offset within bar. */ le32 length; /* Length of the structure, in bytes. */ }; @@ -697,7 +698,8 @@ The fields are interpreted as follows: The device MAY offer more than one structure of any type - this makes it possible for the device to expose multiple interfaces to drivers. The order of the capabilities in the capability list specifies the order of preference - suggested by the device. + suggested by the device. A device may specify that this ordering mechanism be + overridden by the use of the \field{id} field. \begin{note} For example, on some hypervisors, notifications using IO accesses are faster than memory accesses. In this case, the device would expose two @@ -716,6 +718,12 @@ The fields are interpreted as follows: Any other value is reserved for future use. +\item[\field{id}] + Used by some device types to uniquely identify multiple capabilities + of a certain type. If the device type does not specify the meaning of + this field, its contents are undefined. + + \item[\field{offset}] indicates where the structure begins relative to the base address associated with the BAR. The alignment requirements of \field{offset} are indicated |