aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCorvin Köhne <corvin.koehne@gmail.com>2024-08-28 15:43:28 +0200
committerCédric Le Goater <clg@redhat.com>2024-09-17 10:37:55 +0200
commit8719224166832ff8230d7dd8599f42bd60e2eb96 (patch)
tree992ab178174f6c780c50401ddfc5661ddba162fb
parent971ca22f041b8a1e67314a777caf3ce6f2832034 (diff)
downloadqemu-8719224166832ff8230d7dd8599f42bd60e2eb96.zip
qemu-8719224166832ff8230d7dd8599f42bd60e2eb96.tar.gz
qemu-8719224166832ff8230d7dd8599f42bd60e2eb96.tar.bz2
vfio/igd: correctly calculate stolen memory size for gen 9 and later
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>
-rw-r--r--hw/vfio/igd.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/hw/vfio/igd.c b/hw/vfio/igd.c
index 0751c43..a95d441 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)