thebeanogamer / rpms / qemu-kvm

Forked from rpms/qemu-kvm 6 months ago
Clone

Blame SOURCES/kvm-hw-acpi-Add-ospm_status-hook-implementation-for-acpi.patch

97168e
From edead46187b1e55ad5e238332780aef19f1bc214 Mon Sep 17 00:00:00 2001
97168e
From: Jon Maloy <jmaloy@redhat.com>
97168e
Date: Wed, 9 Nov 2022 18:41:18 -0500
97168e
Subject: [PATCH 1/2] hw/acpi: Add ospm_status hook implementation for acpi-ged
97168e
97168e
RH-Author: Jon Maloy <jmaloy@redhat.com>
97168e
RH-MergeRequest: 228: qemu-kvm: backport some aarch64 fixes
97168e
RH-Bugzilla: 2132609
97168e
RH-Acked-by: Cornelia Huck <cohuck@redhat.com>
97168e
RH-Acked-by: Igor Mammedov <imammedo@redhat.com>
97168e
RH-Acked-by: Eric Auger <eric.auger@redhat.com>
97168e
RH-Acked-by: Gavin Shan <gshan@redhat.com>
97168e
RH-Commit: [1/2] 99730b1a27666ca745dc28d90751c938d43f1682 (jmaloy/qemu-kvm)
97168e
97168e
BZ: https://bugzilla.redhat.com/show_bug.cgi?id=2132609
97168e
Upstream: Merged
97168e
97168e
commit d4424bebceaa8ffbc23060ce45e52a9bb817e3c9
97168e
Author: Keqian Zhu <zhukeqian1@huawei.com>
97168e
Date:   Tue Aug 16 17:49:57 2022 +0800
97168e
97168e
    hw/acpi: Add ospm_status hook implementation for acpi-ged
97168e
97168e
    Setup an ARM virtual machine of machine virt and execute qmp "query-acpi-ospm-status"
97168e
    causes segmentation fault with following dumpstack:
97168e
     #1  0x0000aaaaab64235c in qmp_query_acpi_ospm_status (errp=errp@entry=0xfffffffff030) at ../monitor/qmp-cmds.c:312
97168e
     #2  0x0000aaaaabfc4e20 in qmp_marshal_query_acpi_ospm_status (args=<optimized out>, ret=0xffffea4ffe90, errp=0xffffea4ffe88) at qapi/qapi-commands-acpi.c:63
97168e
     #3  0x0000aaaaabff8ba0 in do_qmp_dispatch_bh (opaque=0xffffea4ffe98) at ../qapi/qmp-dispatch.c:128
97168e
     #4  0x0000aaaaac02e594 in aio_bh_call (bh=0xffffe0004d80) at ../util/async.c:150
97168e
     #5  aio_bh_poll (ctx=ctx@entry=0xaaaaad0f6040) at ../util/async.c:178
97168e
     #6  0x0000aaaaac00bd40 in aio_dispatch (ctx=ctx@entry=0xaaaaad0f6040) at ../util/aio-posix.c:421
97168e
     #7  0x0000aaaaac02e010 in aio_ctx_dispatch (source=0xaaaaad0f6040, callback=<optimized out>, user_data=<optimized out>) at ../util/async.c:320
97168e
     #8  0x0000fffff76f6884 in g_main_context_dispatch () at /usr/lib64/libglib-2.0.so.0
97168e
     #9  0x0000aaaaac0452d4 in glib_pollfds_poll () at ../util/main-loop.c:297
97168e
     #10 os_host_main_loop_wait (timeout=0) at ../util/main-loop.c:320
97168e
     #11 main_loop_wait (nonblocking=nonblocking@entry=0) at ../util/main-loop.c:596
97168e
     #12 0x0000aaaaab5c9e50 in qemu_main_loop () at ../softmmu/runstate.c:734
97168e
     #13 0x0000aaaaab185370 in qemu_main (argc=argc@entry=47, argv=argv@entry=0xfffffffff518, envp=envp@entry=0x0) at ../softmmu/main.c:38
97168e
     #14 0x0000aaaaab16f99c in main (argc=47, argv=0xfffffffff518) at ../softmmu/main.c:47
97168e
97168e
    Fixes: ebb62075021a ("hw/acpi: Add ACPI Generic Event Device Support")
97168e
    Signed-off-by: Keqian Zhu <zhukeqian1@huawei.com>
97168e
    Reviewed-by: Igor Mammedov <imammedo@redhat.com>
97168e
    Message-id: 20220816094957.31700-1-zhukeqian1@huawei.com
97168e
    Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
97168e
97168e
(cherry picked from commit d4424bebceaa8ffbc23060ce45e52a9bb817e3c9)
97168e
Signed-off-by: Jon Maloy <jmaloy@redhat.com>
97168e
---
97168e
 hw/acpi/generic_event_device.c | 8 ++++++++
97168e
 1 file changed, 8 insertions(+)
97168e
97168e
diff --git a/hw/acpi/generic_event_device.c b/hw/acpi/generic_event_device.c
97168e
index e28457a7d1..a3d31631fe 100644
97168e
--- a/hw/acpi/generic_event_device.c
97168e
+++ b/hw/acpi/generic_event_device.c
97168e
@@ -267,6 +267,13 @@ static void acpi_ged_unplug_cb(HotplugHandler *hotplug_dev,
97168e
     }
97168e
 }
97168e
 
97168e
+static void acpi_ged_ospm_status(AcpiDeviceIf *adev, ACPIOSTInfoList ***list)
97168e
+{
97168e
+    AcpiGedState *s = ACPI_GED(adev);
97168e
+
97168e
+    acpi_memory_ospm_status(&s->memhp_state, list);
97168e
+}
97168e
+
97168e
 static void acpi_ged_send_event(AcpiDeviceIf *adev, AcpiEventStatusBits ev)
97168e
 {
97168e
     AcpiGedState *s = ACPI_GED(adev);
97168e
@@ -409,6 +416,7 @@ static void acpi_ged_class_init(ObjectClass *class, void *data)
97168e
     hc->unplug_request = acpi_ged_unplug_request_cb;
97168e
     hc->unplug = acpi_ged_unplug_cb;
97168e
 
97168e
+    adevc->ospm_status = acpi_ged_ospm_status;
97168e
     adevc->send_event = acpi_ged_send_event;
97168e
 }
97168e
 
97168e
-- 
97168e
2.37.3
97168e