[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 8/8] vfio/igd: correctly calculate stolen memory size for gen 9 an
From: |
Cédric Le Goater |
Subject: |
[PULL 8/8] vfio/igd: correctly calculate stolen memory size for gen 9 and later |
Date: |
Tue, 17 Sep 2024 12:32:29 +0200 |
From: Corvin Köhne <corvin.koehne@gmail.com>
We have to update the calculation of the stolen memory size because
we've seen devices using values of 0xf0 and above for the graphics mode
select field. The new calculation was taken from the linux kernel [1].
[1]
https://github.com/torvalds/linux/blob/7c626ce4bae1ac14f60076d00eafe71af30450ba/arch/x86/kernel/early-quirks.c#L455-L460
Signed-off-by: Corvin Köhne <c.koehne@beckhoff.com>
Reviewed-by: Alex Williamson <alex.williamson@redhat.com>
---
hw/vfio/igd.c | 15 +++++++++++----
1 file changed, 11 insertions(+), 4 deletions(-)
diff --git a/hw/vfio/igd.c b/hw/vfio/igd.c
index
0751c43eae04aac5152c627af648319151ee1e39..a95d441f68661c23eee976be5d74b2da354f9498
100644
--- a/hw/vfio/igd.c
+++ b/hw/vfio/igd.c
@@ -488,11 +488,18 @@ static int igd_get_stolen_mb(int gen, uint32_t gmch)
gms = (gmch >> 8) & 0xff;
}
- if (gms > 0x10) {
- error_report("Unsupported IGD GMS value 0x%x", gms);
- return 0;
+ if (gen < 9) {
+ if (gms > 0x10) {
+ error_report("Unsupported IGD GMS value 0x%x", gms);
+ return 0;
+ }
+ return gms * 32;
+ } else {
+ if (gms < 0xf0)
+ return gms * 32;
+ else
+ return gms * 4 + 4;
}
- return gms * 32;
}
void vfio_probe_igd_bar4_quirk(VFIOPCIDevice *vdev, int nr)
--
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, 2024/09/17
- [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 <=
- [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