mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-24 21:45:21 +00:00
qemu: account for mdev devices in getPPC64MemLockLimitBytes()
This function is a specialized version of qemuDomainGetMemLockLimitBytes() for PPC64. Simplifying it in the same manner as the previous patch has the nice side effect of accounting for the possibility of an mdev device (I don't know if mdev devices are supported on PPC, but even if not then a) the additional check for mdev devices gained by using qemuDomainNeedsVFIO() in place of open coding will be an effective NOP, and b) if mdev devices are supported on PPC64 in the future, this function will be prepared for it). Signed-off-by: Laine Stump <laine@redhat.com> Reviewed-by: Daniel Henrique Barboza <danielhb413@gmail.com>
This commit is contained in:
parent
0789edc86a
commit
e7068a0bc2
@ -9122,7 +9122,6 @@ getPPC64MemLockLimitBytes(virDomainDefPtr def,
|
|||||||
unsigned long long passthroughLimit = 0;
|
unsigned long long passthroughLimit = 0;
|
||||||
size_t i, nPCIHostBridges = 0;
|
size_t i, nPCIHostBridges = 0;
|
||||||
virPCIDeviceAddressPtr pciAddr;
|
virPCIDeviceAddressPtr pciAddr;
|
||||||
bool usesVFIO = false;
|
|
||||||
bool nvlink2Capable = false;
|
bool nvlink2Capable = false;
|
||||||
|
|
||||||
for (i = 0; i < def->ncontrollers; i++) {
|
for (i = 0; i < def->ncontrollers; i++) {
|
||||||
@ -9138,7 +9137,6 @@ getPPC64MemLockLimitBytes(virDomainDefPtr def,
|
|||||||
virDomainHostdevDefPtr dev = def->hostdevs[i];
|
virDomainHostdevDefPtr dev = def->hostdevs[i];
|
||||||
|
|
||||||
if (virHostdevIsVFIODevice(dev)) {
|
if (virHostdevIsVFIODevice(dev)) {
|
||||||
usesVFIO = true;
|
|
||||||
|
|
||||||
pciAddr = &dev->source.subsys.u.pci.addr;
|
pciAddr = &dev->source.subsys.u.pci.addr;
|
||||||
if (virPCIDeviceAddressIsValid(pciAddr, false)) {
|
if (virPCIDeviceAddressIsValid(pciAddr, false)) {
|
||||||
@ -9153,9 +9151,6 @@ getPPC64MemLockLimitBytes(virDomainDefPtr def,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virDomainDefHasNVMeDisk(def))
|
|
||||||
usesVFIO = true;
|
|
||||||
|
|
||||||
memory = virDomainDefGetMemoryTotal(def);
|
memory = virDomainDefGetMemoryTotal(def);
|
||||||
|
|
||||||
if (def->mem.max_memory)
|
if (def->mem.max_memory)
|
||||||
@ -9180,7 +9175,7 @@ getPPC64MemLockLimitBytes(virDomainDefPtr def,
|
|||||||
8192;
|
8192;
|
||||||
|
|
||||||
/* NVLink2 support in QEMU is a special case of the passthrough
|
/* NVLink2 support in QEMU is a special case of the passthrough
|
||||||
* mechanics explained in the usesVFIO case below. The GPU RAM
|
* mechanics explained in the forceVFIO case below. The GPU RAM
|
||||||
* is placed with a gap after maxMemory. The current QEMU
|
* is placed with a gap after maxMemory. The current QEMU
|
||||||
* implementation puts the NVIDIA RAM above the PCI MMIO, which
|
* implementation puts the NVIDIA RAM above the PCI MMIO, which
|
||||||
* starts at 32TiB and is the MMIO reserved for the guest main RAM.
|
* starts at 32TiB and is the MMIO reserved for the guest main RAM.
|
||||||
@ -9204,7 +9199,7 @@ getPPC64MemLockLimitBytes(virDomainDefPtr def,
|
|||||||
passthroughLimit = maxMemory +
|
passthroughLimit = maxMemory +
|
||||||
128 * (1ULL<<30) / 512 * nPCIHostBridges +
|
128 * (1ULL<<30) / 512 * nPCIHostBridges +
|
||||||
8192;
|
8192;
|
||||||
} else if (usesVFIO || forceVFIO) {
|
} else if (forceVFIO || qemuDomainNeedsVFIO(def)) {
|
||||||
/* For regular (non-NVLink2 present) VFIO passthrough, the value
|
/* For regular (non-NVLink2 present) VFIO passthrough, the value
|
||||||
* of passthroughLimit is:
|
* of passthroughLimit is:
|
||||||
*
|
*
|
||||||
|
Loading…
x
Reference in New Issue
Block a user