Fix the build. This error was introduced by change in acpi.c, the acpi_slp_type exist...
[coreboot.git] / src / southbridge / via / vt8237r / vt8237r_lpc.c
index 4d24e6161d92ef7bbf7acb43b1254222b8163540..66cb3de77b4a9da285b4ed89956c466677ce5809 100644 (file)
@@ -26,6 +26,8 @@
 #include <device/pci_ids.h>
 #include <pc80/mc146818rtc.h>
 #include <cpu/x86/lapic.h>
+#include <pc80/keyboard.h>
+#include <pc80/i8259.h>
 #include <stdlib.h>
 #include "vt8237r.h"
 #include "chip.h"
@@ -54,8 +56,8 @@ static struct ioapicreg {
 } ioapic_table[] = {
        /* IO-APIC virtual wire mode configuration. */
        /* mask, trigger, polarity, destination, delivery, vector */
-       {0,  ENABLED | TRIGGER_EDGE | POLARITY_HIGH | PHYSICAL_DEST |
-            ExtINT, NONE},
+       {0, ENABLED | TRIGGER_EDGE | POLARITY_HIGH | PHYSICAL_DEST |
+                   ExtINT, NONE},
        {1,  DISABLED, NONE},
        {2,  DISABLED, NONE},
        {3,  DISABLED, NONE},
@@ -147,8 +149,13 @@ static void pci_routing_fixup(struct device *dev)
  * Set up the power management capabilities directly into ACPI mode.
  * This avoids having to handle any System Management Interrupts (SMIs).
  */
+
+extern u8 acpi_slp_type;
+
+
 static void setup_pm(device_t dev)
 {
+       u16 tmp;
        /* Debounce LID and PWRBTN# Inputs for 16ms. */
        pci_write_config8(dev, 0x80, 0x20);
 
@@ -167,13 +174,15 @@ static void setup_pm(device_t dev)
        /* GP Timer Control 1s */
        pci_write_config8(dev, 0x93, 0x88);
 
-       /* 7 = SMBus clock from RTC 32.768KHz
-        * 5 = Internal PLL reset from susp
-        * 2 = GPO2 is GPIO
+       /*
+        * 7 = SMBus clock from RTC 32.768KHz
+        * 5 = Internal PLL reset from susp disabled
+        * 2 = GPO2 is SUSA#
         */
-       pci_write_config8(dev, 0x94, 0xa4);
+       pci_write_config8(dev, 0x94, 0xa0);
 
-       /* 7 = stp to sust delay 1msec
+       /*
+        * 7 = stp to sust delay 1msec
         * 6 = SUSST# Deasserted Before PWRGD for STD
         * 4 = PWRGOOD reset on VT8237A/S
         * 3 = GPO26/GPO27 is GPO 
@@ -215,15 +224,27 @@ static void setup_pm(device_t dev)
        outb(0x0, VT8237R_ACPI_IO_BASE + 0x42);
 
        /* SCI is generated for RTC/pwrBtn/slpBtn. */
-       outw(0x001, VT8237R_ACPI_IO_BASE + 0x04);
+       tmp = inw(VT8237R_ACPI_IO_BASE + 0x04);
+#if HAVE_ACPI_RESUME == 1
+       acpi_slp_type = ((tmp & (7 << 10)) >> 10) == 1 ? 3 : 0 ;
+       printk_debug("SLP_TYP type was %x %x\n", tmp, acpi_slp_type);
+#endif
+       /* clear sleep */
+       tmp &= ~(7 << 10);
+       tmp |= 1;
+       outw(tmp, VT8237R_ACPI_IO_BASE + 0x04);
+
 
-}
 
 
-static void vt8237r_init(struct device *dev) {
+}
+
+static void vt8237r_init(struct device *dev)
+{
        u8 enables;
 
-       /* Enable SATA LED, disable special CPU Frequency Change -
+       /*
+        * Enable SATA LED, disable special CPU Frequency Change -
         * GPIO28 GPIO22 GPIO29 GPIO23 are GPIOs.
         */
        pci_write_config8(dev, 0xe5, 0x9);
@@ -236,14 +257,18 @@ static void vt8237r_init(struct device *dev) {
        enables |= 0x08;
        pci_write_config8(dev, 0x4f, enables);
 
-       /* Set Read Pass Write Control Enable (force A2 from APIC FSB to low). */
+       /*
+        * Set Read Pass Write Control Enable
+        * (force A2 from APIC FSB to low).
+        */
        pci_write_config8(dev, 0x48, 0x8c);
 
        southbridge_init_common(dev);
 
        /* FIXME: Intel needs more bit set for C2/C3. */
 
-       /* Allow SLP# signal to assert LDTSTOP_L.
+       /*
+        * Allow SLP# signal to assert LDTSTOP_L.
         * Will work for C3 and for FID/VID change.
         */
        outb(0x1, VT8237R_ACPI_IO_BASE + 0x11);
@@ -252,40 +277,39 @@ static void vt8237r_init(struct device *dev) {
 static void vt8237s_init(struct device *dev)
 {
        u32 tmp;
-       
-       /* put SPI base VT8237S_SPI_MEM_BASE */
-       tmp = pci_read_config32(dev, 0xbc);
-       pci_write_config32(dev, 0xbc, (VT8237S_SPI_MEM_BASE >> 8) | (tmp & 0xFF000000));
-
-       /* Enable SATA LED, VR timer = 100us, VR timer should be fixed */
-       
-       pci_write_config8(dev, 0xe5, 0x69);
 
-       /* REQ5 as PCI request input - should be together with INTE-INTH. 
-        * Fast VR timer disable - need for LDTSTOP_L signal
-       */
-       pci_write_config8(dev, 0xe4, 0xa5);
+       /* Put SPI base VT8237S_SPI_MEM_BASE. */
+       tmp = pci_read_config32(dev, 0xbc);
+       pci_write_config32(dev, 0xbc,
+                          (VT8237S_SPI_MEM_BASE >> 8) | (tmp & 0xFF000000));
 
-       /* reduce further the STPCLK/LDTSTP signal to 5us */
+       /*
+        * REQ5 as PCI request input - should be together with INTE-INTH. 
+        */
+       pci_write_config8(dev, 0xe4, 0x04);
 
+       /* Reduce further the STPCLK/LDTSTP signal to 5us. */
        pci_write_config8(dev, 0xec, 0x4);
 
        /* Host Bus Power Management Control, maybe not needed */
        pci_write_config8(dev, 0x8c, 0x5);
 
-       /* Enable HPET at VT8237R_HPET_ADDR., does not work correctly on R */
+       /* Enable HPET at VT8237R_HPET_ADDR., does not work correctly on R. */
        pci_write_config32(dev, 0x68, (VT8237R_HPET_ADDR | 0x80));
 
        southbridge_init_common(dev);
-       
+
        /* FIXME: Intel needs more bit set for C2/C3. */
 
-       /* Allow SLP# signal to assert LDTSTOP_L.
-        * Will work for C3 and for FID/VID change. FIXME FIXME, pre rev A2
+       /*
+        * Allow SLP# signal to assert LDTSTOP_L.
+        * Will work for C3 and for FID/VID change. FIXME FIXME, pre rev A2.
         */
        outb(0xff, VT8237R_ACPI_IO_BASE + 0x50);
+
        dump_south(dev);
 }
+
 static void vt8237_common_init(struct device *dev)
 {
        u8 enables, byte;
@@ -315,7 +339,8 @@ static void vt8237_common_init(struct device *dev)
         */
        pci_write_config8(dev, 0x41, 0x7f);
 
-       /* Set bit 6 of 0x40 (I/O recovery time).
+       /*
+        * Set bit 6 of 0x40 (I/O recovery time).
         * IMPORTANT FIX - EISA = ECLR reg at 0x4d0! Decoding must be on so
         * that PCI interrupts can be properly marked as level triggered.
         */
@@ -338,11 +363,12 @@ static void vt8237_common_init(struct device *dev)
        pci_write_config8(dev, 0x59, 0x80);
 
        /*
-        * bit meaning
-        *   3 Bypass APIC De-Assert Message (1=Enable)
-        *   1 possibly "INTE#, INTF#, INTG#, INTH# as PCI"
-        *     bit 1=1 works for Aaron at VIA, bit 1=0 works for jakllsch
-        *   0 Dynamic Clock Gating Main Switch (1=Enable)
+        * Bit | Meaning
+        * -------------
+        *   3 | Bypass APIC De-Assert Message (1=Enable)
+        *   1 | possibly "INTE#, INTF#, INTG#, INTH# as PCI"
+        *     | bit 1=1 works for Aaron at VIA, bit 1=0 works for jakllsch
+        *   0 | Dynamic Clock Gating Main Switch (1=Enable)
         */
        pci_write_config8(dev, 0x5b, 0xb);
 
@@ -410,7 +436,6 @@ static const struct device_operations vt8237r_lpc_ops_s = {
        .scan_bus               = scan_static_bus,
 };
 
-
 static const struct device_operations vt8237r_lpc_ops_r = {
        .read_resources         = vt8237r_read_resources,
        .set_resources          = pci_dev_set_resources,