[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 7/8] vfio/igd: don't set stolen memory size to zero
From: |
Cédric Le Goater |
Subject: |
[PULL 7/8] vfio/igd: don't set stolen memory size to zero |
Date: |
Tue, 17 Sep 2024 12:32:28 +0200 |
From: Corvin Köhne <corvin.koehne@gmail.com>
The stolen memory is required for the GOP (EFI) driver and the Windows
driver. While the GOP driver seems to work with any stolen memory size,
the Windows driver will crash if the size doesn't match the size
allocated by the host BIOS. For that reason, it doesn't make sense to
overwrite the stolen memory size. It's true that this wastes some VM
memory. In the worst case, the stolen memory can take up more than a GB.
However, that's uncommon. Additionally, it's likely that a bunch of RAM
is assigned to VMs making use of GPU passthrough.
Signed-off-by: Corvin Köhne <c.koehne@beckhoff.com>
Reviewed-by: Alex Williamson <alex.williamson@redhat.com>
---
hw/vfio/igd.c | 35 ++++++++++++++++++-----------------
1 file changed, 18 insertions(+), 17 deletions(-)
diff --git a/hw/vfio/igd.c b/hw/vfio/igd.c
index
8a41b16421b425688dd2cacd3a113efbad82e91b..0751c43eae04aac5152c627af648319151ee1e39
100644
--- a/hw/vfio/igd.c
+++ b/hw/vfio/igd.c
@@ -478,6 +478,23 @@ void vfio_probe_igd_bar0_quirk(VFIOPCIDevice *vdev, int nr)
QLIST_INSERT_HEAD(&vdev->bars[nr].quirks, quirk, next);
}
+static int igd_get_stolen_mb(int gen, uint32_t gmch)
+{
+ int gms;
+
+ if (gen < 8) {
+ gms = (gmch >> 3) & 0x1f;
+ } else {
+ gms = (gmch >> 8) & 0xff;
+ }
+
+ if (gms > 0x10) {
+ error_report("Unsupported IGD GMS value 0x%x", gms);
+ return 0;
+ }
+ return gms * 32;
+}
+
void vfio_probe_igd_bar4_quirk(VFIOPCIDevice *vdev, int nr)
{
g_autofree struct vfio_region_info *rom = NULL;
@@ -655,23 +672,7 @@ void vfio_probe_igd_bar4_quirk(VFIOPCIDevice *vdev, int nr)
ggms_mb = 1 << ggms_mb;
}
- /*
- * Assume we have no GMS memory, but allow it to be overridden by device
- * option (experimental). The spec doesn't actually allow zero GMS when
- * when IVD (IGD VGA Disable) is clear, but the claim is that it's unused,
- * so let's not waste VM memory for it.
- */
- gmch &= ~((gen < 8 ? 0x1f : 0xff) << (gen < 8 ? 3 : 8));
-
- if (vdev->igd_gms) {
- if (vdev->igd_gms <= 0x10) {
- gms_mb = vdev->igd_gms * 32;
- gmch |= vdev->igd_gms << (gen < 8 ? 3 : 8);
- } else {
- error_report("Unsupported IGD GMS value 0x%x", vdev->igd_gms);
- vdev->igd_gms = 0;
- }
- }
+ gms_mb = igd_get_stolen_mb(gen, gmch);
/*
* Request reserved memory for stolen memory via fw_cfg. VM firmware
--
2.46.0
- [PULL 0/8] vfio queue, Cédric Le Goater, 2024/09/17
- [PULL 3/8] vfio/igd: support legacy mode for all known generations, Cédric Le Goater, 2024/09/17
- [PULL 1/8] hw/vfio/pci.c: Use correct type in trace_vfio_msix_early_setup(), Cédric Le Goater, 2024/09/17
- [PULL 7/8] vfio/igd: don't set stolen memory size to zero,
Cédric Le Goater <=
- [PULL 2/8] vfio/igd: return an invalid generation for unknown devices, Cédric Le Goater, 2024/09/17
- [PULL 8/8] vfio/igd: correctly calculate stolen memory size for gen 9 and later, Cédric Le Goater, 2024/09/17
- [PULL 5/8] vfio/igd: add new bar0 quirk to emulate BDSM mirror, Cédric Le Goater, 2024/09/17
- [PULL 4/8] vfio/igd: use new BDSM register location and size for gen 11 and later, Cédric Le Goater, 2024/09/17
- [PULL 6/8] vfio/igd: add ID's for ElkhartLake and TigerLake, Cédric Le Goater, 2024/09/17
- Re: [PULL 0/8] vfio queue, Peter Maydell, 2024/09/17