[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v3 21/23] hw/uefi-vars-isa: add acpi device
From: |
Gerd Hoffmann |
Subject: |
[PATCH v3 21/23] hw/uefi-vars-isa: add acpi device |
Date: |
Tue, 11 Feb 2025 10:23:19 +0100 |
Tell the guest OS the io address range is used.
Shows up in /proc/ioports in linux.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
---
hw/uefi/var-service-isa.c | 25 +++++++++++++++++++++++++
1 file changed, 25 insertions(+)
diff --git a/hw/uefi/var-service-isa.c b/hw/uefi/var-service-isa.c
index 8247b9ae054a..24d1cae1bb19 100644
--- a/hw/uefi/var-service-isa.c
+++ b/hw/uefi/var-service-isa.c
@@ -6,6 +6,7 @@
#include "qemu/osdep.h"
#include "migration/vmstate.h"
+#include "hw/acpi/acpi_aml_interface.h"
#include "hw/isa/isa.h"
#include "hw/qdev-properties.h"
@@ -61,12 +62,32 @@ static void uefi_vars_isa_realize(DeviceState *dev, Error
**errp)
uefi_vars_realize(&uv->state, errp);
}
+static void uefi_vars_isa_build_aml(AcpiDevAmlIf *adev, Aml *scope)
+{
+ Aml *dev;
+ Aml *crs;
+
+ crs = aml_resource_template();
+ aml_append(crs, aml_io(AML_DECODE16,
+ UEFI_VARS_IO_BASE, UEFI_VARS_IO_BASE,
+ 0x00, UEFI_VARS_REGS_SIZE));
+
+ dev = aml_device("QEFI");
+ aml_append(dev, aml_name_decl("_HID", aml_string("UEFIVARS")));
+ aml_append(dev, aml_name_decl("_STA", aml_int(0xb)));
+ aml_append(dev, aml_name_decl("_CRS", crs));
+
+ aml_append(scope, dev);
+}
+
static void uefi_vars_isa_class_init(ObjectClass *klass, void *data)
{
DeviceClass *dc = DEVICE_CLASS(klass);
+ AcpiDevAmlIfClass *adevc = ACPI_DEV_AML_IF_CLASS(klass);
dc->realize = uefi_vars_isa_realize;
dc->vmsd = &vmstate_uefi_vars_isa;
+ adevc->build_dev_aml = uefi_vars_isa_build_aml;
device_class_set_legacy_reset(dc, uefi_vars_isa_reset);
device_class_set_props(dc, uefi_vars_isa_properties);
set_bit(DEVICE_CATEGORY_MISC, dc->categories);
@@ -78,6 +99,10 @@ static const TypeInfo uefi_vars_isa_info = {
.instance_size = sizeof(uefi_vars_isa_state),
.instance_init = uefi_vars_isa_init,
.class_init = uefi_vars_isa_class_init,
+ .interfaces = (InterfaceInfo[]) {
+ { TYPE_ACPI_DEV_AML_IF },
+ { },
+ },
};
module_obj(TYPE_UEFI_VARS_ISA);
module_dep("hw-uefi-vars");
--
2.48.1
- [PATCH v3 13/23] hw/uefi: add var-service-json.c + qapi for NV vars., (continued)
- [PATCH v3 13/23] hw/uefi: add var-service-json.c + qapi for NV vars., Gerd Hoffmann, 2025/02/11
- [PATCH v3 16/23] hw/uefi: add to meson, Gerd Hoffmann, 2025/02/11
- [PATCH v3 18/23] hw/uefi-vars-sysbus: qemu platform bus support, Gerd Hoffmann, 2025/02/11
- [PATCH v3 12/23] hw/uefi: add var-service-siglist.c, Gerd Hoffmann, 2025/02/11
- [PATCH v3 15/23] hw/uefi: add UEFI_VARS to Kconfig, Gerd Hoffmann, 2025/02/11
- [PATCH v3 22/23] docs: add uefi variable service documentation, Gerd Hoffmann, 2025/02/11
- [PATCH v3 20/23] hw/uefi: add uefi-vars-isa device, Gerd Hoffmann, 2025/02/11
- [PATCH v3 19/23] hw/uefi-vars-sysbus: allow for arm virt, Gerd Hoffmann, 2025/02/11
- [PATCH v3 17/23] hw/uefi: add uefi-vars-sysbus device, Gerd Hoffmann, 2025/02/11
- [PATCH v3 14/23] hw/uefi: add trace-events, Gerd Hoffmann, 2025/02/11
- [PATCH v3 21/23] hw/uefi-vars-isa: add acpi device,
Gerd Hoffmann <=
- [PATCH v3 23/23] hw/uefi: add MAINTAINERS entry, Gerd Hoffmann, 2025/02/11
- Re: [PATCH v3 00/23] hw/uefi: add uefi variable service, Ard Biesheuvel, 2025/02/13