x86: apci: Change PM1_CNT register access to RMW
authorBin Meng <bmeng.cn@gmail.com>
Fri, 21 Apr 2017 14:24:42 +0000 (07:24 -0700)
committerBin Meng <bmeng.cn@gmail.com>
Wed, 17 May 2017 09:11:46 +0000 (17:11 +0800)
In enter_acpi_mode() PM1_CNT register is changed to PM1_CNT_SCI_EN
directly without preserving its previous value. Update to change
the register access to read-modify-write (RMW).

Signed-off-by: Bin Meng <bmeng.cn@gmail.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
Tested-by: Stefan Roese <sr@denx.de>
arch/x86/lib/acpi_table.c

index f118345..8be8120 100644 (file)
@@ -306,6 +306,8 @@ static void acpi_create_mcfg(struct acpi_mcfg *mcfg)
 
 static void enter_acpi_mode(int pm1_cnt)
 {
+       u16 val = inw(pm1_cnt);
+
        /*
         * PM1_CNT register bit0 selects the power management event to be
         * either an SCI or SMI interrupt. When this bit is set, then power
@@ -320,7 +322,7 @@ static void enter_acpi_mode(int pm1_cnt)
         * system, and expose ourselves to OSPM as working under ACPI mode
         * already, turn this bit on.
         */
-       outw(PM1_CNT_SCI_EN, pm1_cnt);
+       outw(val | PM1_CNT_SCI_EN, pm1_cnt);
 }
 
 /*