Author: svens
Date: Wed Feb 16 16:04:59 2011
New Revision: 6368
URL: https://tracker.coreboot.org/trac/coreboot/changeset/6368

Log:
Add ACPI code for Lenvo X60

It currently supports:

- Sleepbutton
- AC state
- Battery state
- Interrupt routing
- Display Brightness control
- Hotkeys

Signed-off-by: Sven Schnelle <[email protected]>

Acked-by: Peter Stuge <[email protected]>

Added:
   trunk/src/mainboard/lenovo/x60/acpi/
   trunk/src/mainboard/lenovo/x60/acpi/ac.asl
   trunk/src/mainboard/lenovo/x60/acpi/battery.asl
   trunk/src/mainboard/lenovo/x60/acpi/beep.asl
   trunk/src/mainboard/lenovo/x60/acpi/ec.asl
   trunk/src/mainboard/lenovo/x60/acpi/gpe.asl
   trunk/src/mainboard/lenovo/x60/acpi/i945_pci_irqs.asl
   trunk/src/mainboard/lenovo/x60/acpi/ich7_pci_irqs.asl
   trunk/src/mainboard/lenovo/x60/acpi/lid.asl
   trunk/src/mainboard/lenovo/x60/acpi/mainboard.asl
   trunk/src/mainboard/lenovo/x60/acpi/platform.asl
      - copied, changed from r6367, 
trunk/src/mainboard/roda/rk886ex/acpi/platform.asl
   trunk/src/mainboard/lenovo/x60/acpi/sleepbutton.asl
   trunk/src/mainboard/lenovo/x60/acpi/superio.asl
   trunk/src/mainboard/lenovo/x60/acpi/thermal.asl
   trunk/src/mainboard/lenovo/x60/acpi/video.asl
   trunk/src/mainboard/lenovo/x60/dsdt.asl
      - copied unchanged from r6367, trunk/src/mainboard/roda/rk886ex/dsdt.asl
Modified:
   trunk/src/mainboard/lenovo/x60/Kconfig

Modified: trunk/src/mainboard/lenovo/x60/Kconfig
==============================================================================
--- trunk/src/mainboard/lenovo/x60/Kconfig      Wed Feb 16 14:43:00 2011        
(r6367)
+++ trunk/src/mainboard/lenovo/x60/Kconfig      Wed Feb 16 16:04:59 2011        
(r6368)
@@ -21,6 +21,7 @@
        select BOARD_ROMSIZE_KB_2048
        select CHANNEL_XOR_RANDOMIZATION
        select HAVE_SMI_HANDLER
+       select HAVE_ACPI_TABLES
 
 config MAINBOARD_DIR
        string

Added: trunk/src/mainboard/lenovo/x60/acpi/ac.asl
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ trunk/src/mainboard/lenovo/x60/acpi/ac.asl  Wed Feb 16 16:04:59 2011        
(r6368)
@@ -0,0 +1,44 @@
+/*
+ * This file is part of the coreboot project.
+ *
+ * Copyright (c) 2011 Sven Schnelle <[email protected]>
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; version 2 of
+ * the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
+ * MA 02110-1301 USA
+ */
+
+Field(ERAM, ByteAcc, NoLock, Preserve)
+{
+               Offset (0x46),
+                               , 4,
+                           HPAC, 1
+}
+
+Device(AC)
+{
+       Name(_HID, "ACPI0003")
+       Name(_UID, 0x00)
+       Name(_PCL, Package() { \_SB } )
+
+       Method(_PSR, 0, NotSerialized)
+       {
+               return (HPAC)
+       }
+
+       Method(_STA, 0, NotSerialized)
+       {
+               Return (0x0f)
+       }
+}

Added: trunk/src/mainboard/lenovo/x60/acpi/battery.asl
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ trunk/src/mainboard/lenovo/x60/acpi/battery.asl     Wed Feb 16 16:04:59 
2011        (r6368)
@@ -0,0 +1,296 @@
+/*
+ * This file is part of the coreboot project.
+ *
+ * Copyright (c) 2011 Sven Schnelle <[email protected]>
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; version 2 of
+ * the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
+ * MA 02110-1301 USA
+ */
+
+Field(ERAM, ByteAcc, NoLock, Preserve)
+{
+       Offset (0x38),
+                       B0ST, 4,        /* Battery 0 state */
+                           , 1,
+                       B0CH, 1,        /* Battery 0 charging */
+                       B0DI, 1,        /* Battery 0 discharging */
+                       B0PR, 1,        /* Battery 0 present */
+       Offset (0x39),
+                       B1ST, 4,        /* Battery 1 state */
+                           , 1,
+                       B1CH, 1,        /* Battery 1 charging, */
+                       B1DI, 1,        /* Battery 1 discharging,*/
+                       B1PR, 1         /* Battery 1 present */
+}
+
+/* EC Registers */
+/* PAGE == 0x00 */
+Field (ERAM, ByteAcc, NoLock, Preserve)
+{
+       Offset(0xa0),
+                       BARC, 16,               /* Battery remaining capacity */
+                       BAFC, 16,               /* Battery full charge capacity 
*/
+       Offset(0xa8),
+                       BAPR, 16,               /* Battery present rate */
+                       BAVO, 16,               /* Battery Voltage */
+}
+
+/* PAGE == 0x01 */
+Field (ERAM, ByteAcc, NoLock, Preserve)
+{
+       Offset(0xa0),
+                           , 15,
+                       BAMA,  1,
+}
+
+/* PAGE == 0x02 */
+Field (ERAM, ByteAcc, NoLock, Preserve)
+{
+       Offset(0xa0),
+                       BADC, 16,               /* Design Capacity */
+                       BADV, 16,               /* Design voltage */
+                           , 16,
+                           , 16,
+                           , 16,
+                       BASN, 16,
+}
+
+/* PAGE == 0x04: Battery type */
+Field (ERAM, ByteAcc, NoLock, Preserve)
+{
+       Offset(0xa0),
+                       BATY, 32
+}
+
+
+/* PAGE == 0x05: Battery OEM information */
+Field (ERAM, ByteAcc, NoLock, Preserve)
+{
+       Offset(0xa0),
+                       BAOE, 128
+}
+
+/* PAGE == 0x06: Battery name */
+Field (ERAM, ByteAcc, NoLock, Preserve)
+{
+       Offset(0xa0),
+                       BANA, 128
+}
+
+/* Arg0: Battery
+ * Arg1: Battery Status Package
+ * Arg2: charging
+ * Arg3: discharging
+ */
+Method(BSTA, 4, NotSerialized)
+{
+       Acquire(ECLK, 0xffff)
+       Store(0, Local0)
+       Or(1, Arg0, PAGE)
+       Store(BAMA, Local1)
+       Store(Arg0, PAGE) /* Battery dynamic information */
+
+       Store(BAPR, Local2)
+
+       if (Arg2) // charging
+       {
+               Or(2, Local0, Local0)
+
+               If (LGreaterEqual (Local2, 0x8000)) {
+                       Store(0, Local2)
+               }
+       }
+
+       if (Arg3) // discharging
+       {
+               Or(1, Local0, Local0)
+               Subtract(0x10000, Local2, Local2)
+       }
+
+       Store(Local0, Index(Arg1, 0x00))
+
+       if (Local1) {
+               Multiply (BARC, 10, Index(Arg1, 2))
+               Multiply (Local2, BAVO, Local2)
+               Divide (Local2, 1000, Local3, Index(Arg1, 1))
+       } else {
+               Store(BARC, Index(Arg1, 2))
+               Store(Local2, Index(Arg1, 1))
+       }
+       Store(BAVO, Index(Arg1, 3))
+       Release(ECLK)
+       Return (Arg1)
+}
+
+Method(BINF, 2, NotSerialized)
+{
+       Acquire(ECLK, 0xffff)
+       Or(1, Arg1, PAGE) /* Battery 0 static information */
+       Xor(BAMA, 1, Index(Arg0, 0))
+       Store(BAMA, Local0)
+       Store(Arg1, PAGE)
+       Store(BAFC, Local2)
+       Or(2, Arg1, PAGE)
+       Store(BADC, Local1)
+
+       if (Local0)
+       {
+               Multiply (Local1, 10, Local1)
+               Multiply (Local2, 10, Local2)
+       }
+
+       Store(Local1, Index(Arg0, 1))   // Design Capacity
+       Store(Local2, Index(Arg0, 2))   // Last full charge capacity
+       Store(BADV, Index(Arg0, 4))     // Design Voltage
+       Divide (Local2, 20, Local0, Index(Arg0, 5)) // Warning capacity
+
+       Store (BASN, Local0)
+       Name (SERN, Buffer (0x06) { "     " })
+       Store (4, Local1)
+       While (Local0)
+       {
+               Divide (Local0, 0x0A, Local2, Local0)
+               Add (Local2, 48, Index (SERN, Local1))
+               Decrement (Local1)
+       }
+       Store (SERN, Index (Arg0, 10)) // Serial Number
+
+       Or(4, Arg1, PAGE)
+       Name (TYPE, Buffer() { 0, 0, 0, 0, 0 })
+       Store(BATY, TYPE)
+       Store(TYPE, Index (Arg0, 11)) // Battery type
+       Or(5, Arg1, PAGE)
+       Store(BAOE, Index (Arg0, 12)) // OEM information
+       Or(6, Arg1, PAGE)
+       Store(BANA, Index (Arg0, 9))  // Model number
+       Release(ECLK)
+       Return (Arg0)
+}
+
+Device (BAT0)
+{
+       Name (_HID, EisaId ("PNP0C0A"))
+       Name (_UID, 0x00)
+       Name (_PCL, Package () { \_SB })
+
+       Name (BATS, Package ()
+       {
+               0x00,                   // 0: PowerUnit: Report in mWh
+               0xFFFFFFFF,             // 1: Design cap
+               0xFFFFFFFF,             // 2: Last full charge cap
+               0x01,                   // 3: Battery Technology
+               10800,                  // 4: Design Voltage (mV)
+               0x00,                   // 5: Warning design capacity
+               200,                    // 6: Low design capacity
+               1,                      // 7: granularity1
+               1,                      // 8: granularity2
+               "",                     // 9: Model number
+               "",                     // A: Serial number
+               "",                     // B: Battery Type
+               ""                      // C: OEM information
+       })
+
+       Method (_BIF, 0, NotSerialized)
+       {
+               Return (BINF(BATS, 0))
+       }
+
+       Name (BATI, Package ()
+       {
+               0,                      // Battery State
+                                       // Bit 0 - discharge
+                                       // Bit 1 - charge
+                                       // Bit 2 - critical state
+               0,                      // Battery present Rate
+               0,                      // Battery remaining capacity
+               0                       // Battery present voltage
+       })
+
+       Method (_BST, 0, NotSerialized)
+       {
+               if (B0PR) {
+                       Return (BSTA(0, BATI, B0CH, B0DI))
+               } else {
+                       Return (BATS)
+               }
+       }
+
+       Method (_STA, 0, NotSerialized)
+       {
+               if (B0PR) {
+                       Return (0x1f)
+               } else {
+                       Return (0x0f)
+               }
+       }
+}
+
+Device (BAT1)
+{
+       Name (_HID, EisaId ("PNP0C0A"))
+       Name (_UID, 0x00)
+       Name (_PCL, Package () { \_SB })
+
+       Name (BATS, Package ()
+       {
+               0x00,                   // 0: PowerUnit: Report in mWh
+               0xFFFFFFFF,             // 1: Design cap
+               0xFFFFFFFF,             // 2: Last full charge cap
+               0x01,                   // 3: Battery Technology
+               10800,                  // 4: Design Voltage (mV)
+               0x00,                   // 5: Warning design capacity
+               200,                    // 6: Low design capacity
+               1,                      // 7: granularity1
+               1,                      // 8: granularity2
+               "",                     // 9: Model number
+               "",                     // A: Serial number
+               "",                     // B: Battery Type
+               ""                      // C: OEM information
+       })
+
+       Method (_BIF, 0, NotSerialized)
+       {
+               Return (BINF(BATS, 0x10))
+       }
+
+       Name (BATI, Package ()
+       {
+               0,                      // Battery State
+                                       // Bit 0 - discharge
+                                       // Bit 1 - charge
+                                       // Bit 2 - critical state
+               0,                      // Battery present Rate
+               0,                      // Battery remaining capacity
+               0                       // Battery present voltage
+       })
+
+       Method (_BST, 0, NotSerialized)
+       {
+               if (B1PR) {
+                       Return (BSTA(0x10, BATI, B1CH, B1DI))
+               } else {
+                       Return (BATS)
+               }
+       }
+
+       Method (_STA, 0, NotSerialized)
+       {
+               if (B1PR) {
+                       Return (0x1f)
+               } else {
+                       Return (0x0f)
+               }
+       }
+}

Added: trunk/src/mainboard/lenovo/x60/acpi/beep.asl
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ trunk/src/mainboard/lenovo/x60/acpi/beep.asl        Wed Feb 16 16:04:59 
2011        (r6368)
@@ -0,0 +1,32 @@
+/*
+ * This file is part of the coreboot project.
+ *
+ * Copyright (c) 2011 Sven Schnelle <[email protected]>
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; version 2 of
+ * the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
+ * MA 02110-1301 USA
+ */
+
+Field(ERAM, ByteAcc, NoLock, Preserve)
+{
+               Offset (0x06),
+                       SNDS, 8         /* Write to this register to generate 
sound */
+
+}
+
+Method(BEEP, 1, NotSerialized)
+{
+       Store (Arg0, SNDS)
+}

Added: trunk/src/mainboard/lenovo/x60/acpi/ec.asl
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ trunk/src/mainboard/lenovo/x60/acpi/ec.asl  Wed Feb 16 16:04:59 2011        
(r6368)
@@ -0,0 +1,101 @@
+/*
+ * This file is part of the coreboot project.
+ *
+ * Copyright (c) 2011 Sven Schnelle <[email protected]>
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; version 2 of
+ * the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
+ * MA 02110-1301 USA
+ */
+
+Device(EC)
+{
+       Name (_HID, EISAID("PNP0C09"))
+       Name (_UID, 0)
+
+       Name (_GPE, 28)
+       Mutex (ECLK, 0)
+
+       OperationRegion(ERAM, EmbeddedControl, 0x00, 0x100)
+       Field (ERAM, ByteAcc, NoLock, Preserve)
+       {
+               Offset (0x05),
+                               HSPA, 1,
+               Offset (0x0C),
+                               LEDS, 8,        /* LED state */
+               Offset (0x3B),
+                                   , 1,
+                               KBLT, 1,         /* Keyboard Light */
+               Offset (0x81),
+                               PAGE, 8         /* Information Page Selector */
+        }
+
+       Method (_CRS, 0)
+       {
+               Name (ECMD, ResourceTemplate()
+               {
+                       IO (Decode16, 0x62, 0x62, 1, 1)
+                       IO (Decode16, 0x66, 0x66, 1, 1)
+               })
+               Return (ECMD)
+       }
+
+       Method (LED, 1, NotSerialized)
+       {
+               Store(Arg0, LEDS)
+       }
+
+       Method (_INI, 0, NotSerialized)
+       {
+       }
+
+       /* Sleep Button pressed */
+       Method(_Q13, 0, NotSerialized)
+       {
+               Notify(\_SB.PCI0.LPCB.EC.SLPB, 0x80)
+       }
+
+       /* Brightness up GPE */
+       Method(_Q14, 0, NotSerialized)
+       {
+               \DSPC.BRTU ()
+       }
+
+       /* Brightness down GPE */
+       Method(_Q15, 0, NotSerialized)
+       {
+               \DSPC.BRTD()
+       }
+
+       /* AC status change: present */
+       Method(_Q26, 0, NotSerialized)
+       {
+               Notify (AC, 0x80)
+               Beep(6)
+       }
+
+       /* AC status change: not present */
+       Method(_Q27, 0, NotSerialized)
+       {
+               Notify (AC, 0x80)
+               Beep(6)
+       }
+
+
+#include "ac.asl"
+#include "battery.asl"
+#include "sleepbutton.asl"
+#include "lid.asl"
+#include "beep.asl"
+}

Added: trunk/src/mainboard/lenovo/x60/acpi/gpe.asl
==============================================================================

Added: trunk/src/mainboard/lenovo/x60/acpi/i945_pci_irqs.asl
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ trunk/src/mainboard/lenovo/x60/acpi/i945_pci_irqs.asl       Wed Feb 16 
16:04:59 2011        (r6368)
@@ -0,0 +1,63 @@
+/*
+ * This file is part of the coreboot project.
+ *
+ * Copyright (C) 2011 Sven Schnelle <[email protected]>
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; version 2 of
+ * the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
+ * MA 02110-1301 USA
+ */
+
+/* This is board specific information: IRQ routing for the
+ * i945
+ */
+
+
+// PCI Interrupt Routing
+Method(_PRT)
+{
+       If (PICM) {
+               Return (Package() {
+                       Package() { 0x0002ffff, 0, 0, 0x10 }, // VGA
+                       Package() { 0x001bffff, 1, 0, 0x11 }, // Audio
+                       Package() { 0x001cffff, 0, 0, 0x14 }, // PCI bridge
+                       Package() { 0x001cffff, 1, 0, 0x15 }, // PCI bridge
+                       Package() { 0x001cffff, 2, 0, 0x16 }, // PCI bridge
+                       Package() { 0x001cffff, 3, 0, 0x17 }, // PCI bridge
+                       Package() { 0x001dffff, 0, 0, 0x10 }, // USB
+                       Package() { 0x001dffff, 1, 0, 0x11 }, // USB
+                       Package() { 0x001dffff, 2, 0, 0x12 }, // USB
+                       Package() { 0x001dffff, 3, 0, 0x13 }, // USB
+                       Package() { 0x001fffff, 0, 0, 0x17 }, // LPC
+                       Package() { 0x001fffff, 1, 0, 0x10 }, // IDE
+                       Package() { 0x001fffff, 2, 0, 0x10 }  // SATA
+               })
+       } Else {
+               Return (Package() {
+                       Package() { 0x0002ffff, 0, \_SB.PCI0.LPCB.LNKA, 0 }, // 
VGA
+                       Package() { 0x001bffff, 1, \_SB.PCI0.LPCB.LNKB, 0 }, // 
Audio
+                       Package() { 0x001cffff, 0, \_SB.PCI0.LPCB.LNKE, 0 }, // 
PCI
+                       Package() { 0x001cffff, 1, \_SB.PCI0.LPCB.LNKF, 0 }, // 
PCI
+                       Package() { 0x001cffff, 2, \_SB.PCI0.LPCB.LNKG, 0 }, // 
PCI
+                       Package() { 0x001cffff, 3, \_SB.PCI0.LPCB.LNKH, 0 }, // 
PCI
+                       Package() { 0x001dffff, 0, \_SB.PCI0.LPCB.LNKA, 0 }, // 
USB
+                       Package() { 0x001dffff, 1, \_SB.PCI0.LPCB.LNKB, 0 }, // 
USB
+                       Package() { 0x001dffff, 2, \_SB.PCI0.LPCB.LNKC, 0 }, // 
USB
+                       Package() { 0x001dffff, 3, \_SB.PCI0.LPCB.LNKD, 0 }, // 
USB
+                       Package() { 0x001fffff, 0, \_SB.PCI0.LPCB.LNKH, 0 }, // 
LPC
+                       Package() { 0x001fffff, 1, \_SB.PCI0.LPCB.LNKA, 0 }, // 
IDE
+                       Package() { 0x001fffff, 2, \_SB.PCI0.LPCB.LNKA, 0 }  // 
SATA
+               })
+       }
+}

Added: trunk/src/mainboard/lenovo/x60/acpi/ich7_pci_irqs.asl
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ trunk/src/mainboard/lenovo/x60/acpi/ich7_pci_irqs.asl       Wed Feb 16 
16:04:59 2011        (r6368)
@@ -0,0 +1,46 @@
+/*
+ * This file is part of the coreboot project.
+ *
+ * Copyright (C) 2007-2009 coresystems GmbH
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; version 2 of
+ * the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
+ * MA 02110-1301 USA
+ */
+
+/* This is board specific information: IRQ routing for the
+ * 0:1e.0 PCI bridge of the ICH7
+ */
+
+If (PICM) {
+       Return (Package() {
+               Package (0x04) { 0x0000FFFF, 0x00, 0x00, 0x10 },
+               Package (0x04) { 0x0000FFFF, 0x01, 0x00, 0x11 },
+               Package (0x04) { 0x0000FFFF, 0x02, 0x00, 0x12 },
+               Package (0x04) { 0x0001FFFF, 0x00, 0x00, 0x10 },
+               Package (0x04) { 0x0002FFFF, 0x00, 0x00, 0x15 },
+               Package (0x04) { 0x0002FFFF, 0x01, 0x00, 0x16 },
+               Package (0x04) { 0x0008FFFF, 0x00, 0x00, 0x14 }
+       })
+ } Else {
+       Return (Package() {
+               Package (0x04) { 0x0000FFFF, 0x00, \_SB.PCI0.LPCB.LNKA, 0x00 },
+               Package (0x04) { 0x0000FFFF, 0x01, \_SB.PCI0.LPCB.LNKB, 0x00 },
+               Package (0x04) { 0x0000FFFF, 0x02, \_SB.PCI0.LPCB.LNKC, 0x00 },
+               Package (0x04) { 0x0001FFFF, 0x00, \_SB.PCI0.LPCB.LNKA, 0x00 },
+               Package (0x04) { 0x0002FFFF, 0x00, \_SB.PCI0.LPCB.LNKF, 0x00 },
+               Package (0x04) { 0x0002FFFF, 0x01, \_SB.PCI0.LPCB.LNKG, 0x00 },
+               Package (0x04) { 0x0008FFFF, 0x00, \_SB.PCI0.LPCB.LNKE, 0x00 }
+       })
+}

Added: trunk/src/mainboard/lenovo/x60/acpi/lid.asl
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ trunk/src/mainboard/lenovo/x60/acpi/lid.asl Wed Feb 16 16:04:59 2011        
(r6368)
@@ -0,0 +1,37 @@
+/*
+ * This file is part of the coreboot project.
+ *
+ * Copyright (c) 2011 Sven Schnelle <[email protected]>
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; version 2 of
+ * the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
+ * MA 02110-1301 USA
+ */
+
+Field(ERAM, ByteAcc, NoLock, Preserve)
+{
+               Offset (0x46),
+                               , 2,
+                       LIDS    , 1
+}
+
+Device(LID)
+{
+       Name(_HID, "PNP0C0D")
+
+       Method(_LId, 0, NotSerialized)
+       {
+               return (LIDS)
+       }
+}

Added: trunk/src/mainboard/lenovo/x60/acpi/mainboard.asl
==============================================================================

Copied and modified: trunk/src/mainboard/lenovo/x60/acpi/platform.asl (from 
r6367, trunk/src/mainboard/roda/rk886ex/acpi/platform.asl)
==============================================================================
--- trunk/src/mainboard/roda/rk886ex/acpi/platform.asl  Wed Feb 16 14:43:00 
2011        (r6367, copy source)
+++ trunk/src/mainboard/lenovo/x60/acpi/platform.asl    Wed Feb 16 16:04:59 
2011        (r6368)
@@ -127,8 +127,8 @@
        }
 
        // Notify the Batteries
-       Notify(BAT1, 0x80) // Execute BAT1 _BST
-       Notify(BAT2, 0x80) // Execute BAT2 _BST
+       Notify(\_SB.PCI0.LPCB.EC.BAT0, 0x80) // Execute BAT1 _BST
+       Notify(\_SB.PCI0.LPCB.EC.BAT1, 0x80) // Execute BAT2 _BST
 }
 
 /* System Bus */

Added: trunk/src/mainboard/lenovo/x60/acpi/sleepbutton.asl
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ trunk/src/mainboard/lenovo/x60/acpi/sleepbutton.asl Wed Feb 16 16:04:59 
2011        (r6368)
@@ -0,0 +1,25 @@
+/*
+ * This file is part of the coreboot project.
+ *
+ * Copyright (c) 2011 Sven Schnelle <[email protected]>
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; version 2 of
+ * the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
+ * MA 02110-1301 USA
+ */
+
+Device(SLPB)
+{
+        Name (_HID, EisaId ("PNP0C0E"))
+}

Added: trunk/src/mainboard/lenovo/x60/acpi/superio.asl
==============================================================================

Added: trunk/src/mainboard/lenovo/x60/acpi/thermal.asl
==============================================================================

Added: trunk/src/mainboard/lenovo/x60/acpi/video.asl
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ trunk/src/mainboard/lenovo/x60/acpi/video.asl       Wed Feb 16 16:04:59 
2011        (r6368)
@@ -0,0 +1,51 @@
+/*
+ * This file is part of the coreboot project.
+ *
+ * Copyright (c) 2011 Sven Schnelle <[email protected]>
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; version 2 of
+ * the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
+ * MA 02110-1301 USA
+ */
+
+Device (DSPC)
+{
+       Name (_ADR, 0x00020001)
+       OperationRegion (DSPC, PCI_Config, 0x00, 0x100)
+       Field (DSPC, ByteAcc, NoLock, Preserve)
+       {
+               Offset (0xf4),
+                      BRTC, 8
+       }
+
+       Method(BRTD, 0, NotSerialized)
+       {
+               Store(BRTC, Local0)
+               if (LGreater (Local0, 15))
+               {
+                       Subtract(Local0, 16, Local0)
+                       Store(Local0, BRTC)
+               }
+       }
+
+       Method(BRTU, 0, NotSerialized)
+       {
+               Store (BRTC, Local0)
+               if (LLess(Local0, 0xff))
+               {
+                       Add (Local0, 16, Local0)
+                       Store(Local0, BRTC)
+               }
+       }
+}

Copied: trunk/src/mainboard/lenovo/x60/dsdt.asl (from r6367, 
trunk/src/mainboard/roda/rk886ex/dsdt.asl)
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ trunk/src/mainboard/lenovo/x60/dsdt.asl     Wed Feb 16 16:04:59 2011        
(r6368, copy of r6367, trunk/src/mainboard/roda/rk886ex/dsdt.asl)
@@ -0,0 +1,56 @@
+/*
+ * This file is part of the coreboot project.
+ *
+ * Copyright (C) 2007-2009 coresystems GmbH
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; version 2 of
+ * the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
+ * MA 02110-1301 USA
+ */
+
+DefinitionBlock(
+       "dsdt.aml",
+       "DSDT",
+       0x03,           // DSDT revision: ACPI v3.0
+       "COREv4",       // OEM id
+       "COREBOOT",     // OEM table id
+       0x20090419      // OEM revision
+)
+{
+       // Some generic macros
+       #include "acpi/platform.asl"
+
+       // global NVS and variables
+       #include "../../../southbridge/intel/i82801gx/acpi/globalnvs.asl"
+
+       // General Purpose Events
+       #include "acpi/gpe.asl"
+
+       // mainboard specific devices
+       #include "acpi/mainboard.asl"
+
+       // Thermal Zone
+       #include "acpi/thermal.asl"
+
+       Scope (\_SB) {
+               Device (PCI0)
+               {
+                       #include "../../../northbridge/intel/i945/acpi/i945.asl"
+                       #include 
"../../../southbridge/intel/i82801gx/acpi/ich7.asl"
+               }
+       }
+
+       /* Chipset specific sleep states */
+       #include "../../../southbridge/intel/i82801gx/acpi/sleepstates.asl"
+}

-- 
coreboot mailing list: [email protected]
http://www.coreboot.org/mailman/listinfo/coreboot

Reply via email to