Commit 9669d3c570c7a2129c6d6d4e32b856a2d155eb54
1 parent
7b455225
x86: Fix powerdown for non-ACPI case
Trivial fix for a corner case: system_shutdown on isapc machines causes qemu to segfaults due to accessing the uninitialized pm_state. Issue a system shutdown instead. Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com> Signed-off-by: Aurelien Jarno <aurelien@aurel32.net> git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@5130 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
1 changed file
with
4 additions
and
2 deletions
hw/acpi.c
... | ... | @@ -72,7 +72,7 @@ typedef struct PIIX4PMState { |
72 | 72 | #define SMBHSTDAT1 0x06 |
73 | 73 | #define SMBBLKDAT 0x07 |
74 | 74 | |
75 | -PIIX4PMState *pm_state; | |
75 | +static PIIX4PMState *pm_state; | |
76 | 76 | |
77 | 77 | static uint32_t get_pmtmr(PIIX4PMState *s) |
78 | 78 | { |
... | ... | @@ -526,7 +526,9 @@ i2c_bus *piix4_pm_init(PCIBus *bus, int devfn, uint32_t smb_io_base, |
526 | 526 | #if defined(TARGET_I386) |
527 | 527 | void qemu_system_powerdown(void) |
528 | 528 | { |
529 | - if(pm_state->pmen & PWRBTN_EN) { | |
529 | + if (!pm_state) { | |
530 | + qemu_system_shutdown_request(); | |
531 | + } else if (pm_state->pmen & PWRBTN_EN) { | |
530 | 532 | pm_state->pmsts |= PWRBTN_EN; |
531 | 533 | pm_update_sci(pm_state); |
532 | 534 | } | ... | ... |