|
@@ -579,6 +579,10 @@ void acpi_pm1_cnt_update(ACPIREGS *ar,
|
|
|
bool sci_enable, bool sci_disable)
|
|
|
{
|
|
|
/* ACPI specs 3.0, 4.7.2.5 */
|
|
|
+ if (ar->pm1.cnt.acpi_only) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
if (sci_enable) {
|
|
|
ar->pm1.cnt.cnt |= ACPI_BITMASK_SCI_ENABLE;
|
|
|
} else if (sci_disable) {
|
|
@@ -608,11 +612,13 @@ static const MemoryRegionOps acpi_pm_cnt_ops = {
|
|
|
};
|
|
|
|
|
|
void acpi_pm1_cnt_init(ACPIREGS *ar, MemoryRegion *parent,
|
|
|
- bool disable_s3, bool disable_s4, uint8_t s4_val)
|
|
|
+ bool disable_s3, bool disable_s4, uint8_t s4_val,
|
|
|
+ bool acpi_only)
|
|
|
{
|
|
|
FWCfgState *fw_cfg;
|
|
|
|
|
|
ar->pm1.cnt.s4_val = s4_val;
|
|
|
+ ar->pm1.cnt.acpi_only = acpi_only;
|
|
|
ar->wakeup.notify = acpi_notify_wakeup;
|
|
|
qemu_register_wakeup_notifier(&ar->wakeup);
|
|
|
|
|
@@ -638,6 +644,9 @@ void acpi_pm1_cnt_init(ACPIREGS *ar, MemoryRegion *parent,
|
|
|
void acpi_pm1_cnt_reset(ACPIREGS *ar)
|
|
|
{
|
|
|
ar->pm1.cnt.cnt = 0;
|
|
|
+ if (ar->pm1.cnt.acpi_only) {
|
|
|
+ ar->pm1.cnt.cnt |= ACPI_BITMASK_SCI_ENABLE;
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
/* ACPI GPE */
|