mirror of
https://github.com/cloud-hypervisor/cloud-hypervisor.git
synced 2025-01-08 22:05:20 +00:00
vm-virtio: Fix alignment and MSI-X table size on the BAR
As mentioned in the PCI specification: If a dedicated Base Address register is not feasible, it is recommended that a function isolate the MSI-X structures from the non-MSI-X structures with aligned 8 KB ranges rather than the mandatory aligned 4 KB ranges. That's why this patch ensures that each structure present on the BAR is 8KiB aligned. It also fixes the MSI-X table and PBA sizes so that they can support up to 2048 vectors, as specified for MSI-X. Signed-off-by: Sebastien Boeuf <sebastien.boeuf@intel.com>
This commit is contained in:
parent
edd1279609
commit
42378caa8b
@ -137,19 +137,27 @@ impl PciSubclass for PciVirtioSubclass {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Allocate one bar for the structs pointed to by the capability structures.
|
// Allocate one bar for the structs pointed to by the capability structures.
|
||||||
|
// As per the PCI specification, because the same BAR shares MSI-X and non
|
||||||
|
// MSI-X structures, it is recommended to use 8KiB alignment for all those
|
||||||
|
// structures.
|
||||||
const COMMON_CONFIG_BAR_OFFSET: u64 = 0x0000;
|
const COMMON_CONFIG_BAR_OFFSET: u64 = 0x0000;
|
||||||
const COMMON_CONFIG_SIZE: u64 = 56;
|
const COMMON_CONFIG_SIZE: u64 = 56;
|
||||||
const ISR_CONFIG_BAR_OFFSET: u64 = 0x1000;
|
const ISR_CONFIG_BAR_OFFSET: u64 = 0x2000;
|
||||||
const ISR_CONFIG_SIZE: u64 = 1;
|
const ISR_CONFIG_SIZE: u64 = 1;
|
||||||
const DEVICE_CONFIG_BAR_OFFSET: u64 = 0x2000;
|
const DEVICE_CONFIG_BAR_OFFSET: u64 = 0x4000;
|
||||||
const DEVICE_CONFIG_SIZE: u64 = 0x1000;
|
const DEVICE_CONFIG_SIZE: u64 = 0x1000;
|
||||||
const NOTIFICATION_BAR_OFFSET: u64 = 0x3000;
|
const NOTIFICATION_BAR_OFFSET: u64 = 0x6000;
|
||||||
const NOTIFICATION_SIZE: u64 = 0x1000;
|
const NOTIFICATION_SIZE: u64 = 0x1000;
|
||||||
const MSIX_TABLE_BAR_OFFSET: u64 = 0x6000;
|
const MSIX_TABLE_BAR_OFFSET: u64 = 0x8000;
|
||||||
const MSIX_TABLE_SIZE: u64 = 0x1000;
|
// The size is 256KiB because the table can hold up to 2048 entries, with each
|
||||||
const MSIX_PBA_BAR_OFFSET: u64 = 0x7000;
|
// entry being 128 bits (4 DWORDS).
|
||||||
const MSIX_PBA_SIZE: u64 = 0x1000;
|
const MSIX_TABLE_SIZE: u64 = 0x40000;
|
||||||
const CAPABILITY_BAR_SIZE: u64 = 0x8000;
|
const MSIX_PBA_BAR_OFFSET: u64 = 0x48000;
|
||||||
|
// The size is 2KiB because the Pending Bit Array has one bit per vector and it
|
||||||
|
// can support up to 2048 vectors.
|
||||||
|
const MSIX_PBA_SIZE: u64 = 0x800;
|
||||||
|
// The BAR size must be a power of 2.
|
||||||
|
const CAPABILITY_BAR_SIZE: u64 = 0x80000;
|
||||||
|
|
||||||
const NOTIFY_OFF_MULTIPLIER: u32 = 4; // A dword per notification address.
|
const NOTIFY_OFF_MULTIPLIER: u32 = 4; // A dword per notification address.
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user