[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 7/7] vfio/igd: correctly calculate stolen memory size for gen
|
From: |
Corvin Köhne |
|
Subject: |
[PATCH v2 7/7] vfio/igd: correctly calculate stolen memory size for gen 9 and later |
|
Date: |
Wed, 28 Aug 2024 14:39:59 +0200 |
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>
---
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 0751c43eae..a95d441f68 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
This email contains confidential information. If you have received it in error,
you must not read, use, copy or pass on this e-mail or its attachments. If you
have received the e-mail in error, please inform me immediately by reply e-mail
and then delete this e-mail from your system. Thank you
Diese E-Mail enthält vertrauliche Informationen. Sollten Sie sie irrtümlich
erhalten haben, dürfen Sie diese E-Mail oder ihre Anhänge nicht lesen,
verwenden, kopieren oder weitergeben. Sollten Sie die Mail versehentlich
erhalten haben, teilen Sie mir dies bitte umgehend per Antwort-E-Mail mit und
löschen Sie diese E-Mail dann aus Ihrem System. Vielen Dank
Beckhoff Automation GmbH & Co. KG | Managing Director: Dipl. Phys. Hans Beckhoff
Registered office: Verl, Germany | Register court: Guetersloh HRA 7075
- [PATCH v2 0/7] vfio/igd: add passthrough support for IGDs of gen 11 and later, Corvin Köhne, 2024/08/28
- [PATCH v2 2/7] vfio/igd: support legacy mode for all known generations, Corvin Köhne, 2024/08/28
- [PATCH v2 1/7] vfio/igd: return an invalid generation for unknown devices, Corvin Köhne, 2024/08/28
- [PATCH v2 3/7] vfio/igd: use new BDSM register location and size for gen 11 and later, Corvin Köhne, 2024/08/28
- [PATCH v2 4/7] vfio/igd: add new bar0 quirk to emulate BDSM mirror, Corvin Köhne, 2024/08/28
- [PATCH v2 5/7] vfio/igd: add ID's for ElkhartLake and TigerLake, Corvin Köhne, 2024/08/28