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.
smime.p7s
Description: S/MIME cryptographic signature
