On Mon, 2025-12-01 at 12:50 +0000, Chalios, Babis wrote:
> acpi_send_gpe_events() sends events encoded in the AcpiEventStatusBits
> enum. The maximum bit used so far in the latter was 128, hence a single
> byte (ACPIGPE.sts[0]) is currently enough to hold the set bits.
> 
> When we add an extra one, we will need a second byte to encode the state
> and casting from AcpiEventStatusBits to uint8_t will silently ignore the
> higher bits.
> 
> Fix this, by taking into account the length value inside ACPIGPE.
> 
> Signed-off-by: Babis Chalios <[email protected]>
> ---
>  hw/acpi/core.c | 8 +++++++-
>  1 file changed, 7 insertions(+), 1 deletion(-)
> 
> diff --git a/hw/acpi/core.c b/hw/acpi/core.c
> index ff16582803..48694eca54 100644
> --- a/hw/acpi/core.c
> +++ b/hw/acpi/core.c
> @@ -730,7 +730,13 @@ uint32_t acpi_gpe_ioport_readb(ACPIREGS *ar, uint32_t 
> addr)
>  void acpi_send_gpe_event(ACPIREGS *ar, qemu_irq irq,
>                           AcpiEventStatusBits status)
>  {
> -    ar->gpe.sts[0] |= status;
> +    int i;
> +
> +    for (i = 0; i < ar->gpe.len; i++) {
> +        ar->gpe.sts[i] |= (status & 0xff);
> +        status >>= 8;
> +    }
> +
>      acpi_update_sci(ar, irq);
>  }
>  

Testing with the guest code that's now merged into net-next, I see that
still doesn't actually raise the SCI. It needs this in
acpi_update_sci():

--- a/hw/acpi/core.c
+++ b/hw/acpi/core.c
@@ -741,13 +741,16 @@ void acpi_send_gpe_event(ACPIREGS *ar, qemu_irq irq,
 
 void acpi_update_sci(ACPIREGS *regs, qemu_irq irq)
 {
-    int sci_level, pm1a_sts;
+    int i, sci_level, pm1a_sts;
 
     pm1a_sts = acpi_pm1_evt_get_sts(regs);
 
     sci_level = ((pm1a_sts &
-                  regs->pm1.evt.en & ACPI_BITMASK_PM1_COMMON_ENABLED) != 0) ||
-                ((regs->gpe.sts[0] & regs->gpe.en[0]) != 0);
+                  regs->pm1.evt.en & ACPI_BITMASK_PM1_COMMON_ENABLED) != 0);
+
+    for (i = 0; !sci_level && i < regs->gpe.len; i++) {
+        sci_level = ((regs->gpe.sts[i] & regs->gpe.en[i]) != 0);
+    }
 
     qemu_set_irq(irq, sci_level);
 

I'll send a new series with that fixed, and with an independent local
vmclock-abi.h header instead of using the one from Linux. And maybe
some QMP/HMP commands for the toolstack to bump the disruption and
generation counters.

Attachment: smime.p7s
Description: S/MIME cryptographic signature

Reply via email to