i945: Consolidate acpi/platform.asl
Change-Id: Iccb2dda8a427e483c04693e46b00e0bc2452a26b Signed-off-by: Vladimir Serbinenko <phcoder@gmail.com> Reviewed-on: http://review.coreboot.org/7086 Tested-by: build bot (Jenkins) Reviewed-by: Patrick Georgi <pgeorgi@google.com>
This commit is contained in:
parent
4aad743434
commit
24813c1490
|
@ -0,0 +1,37 @@
|
||||||
|
/* These come from the dynamically created CPU SSDT */
|
||||||
|
External(PDC0)
|
||||||
|
External(PDC1)
|
||||||
|
|
||||||
|
// Power notification
|
||||||
|
|
||||||
|
External (\_PR_.CPU0, DeviceObj)
|
||||||
|
External (\_PR_.CPU1, DeviceObj)
|
||||||
|
External (\_PR_.CPU0._PPC)
|
||||||
|
External (\_PR_.CPU1._PPC)
|
||||||
|
|
||||||
|
Method (PNOT)
|
||||||
|
{
|
||||||
|
If (MPEN) {
|
||||||
|
If(And(PDC0, 0x08)) {
|
||||||
|
Notify (\_PR_.CPU0, 0x80) // _PPC
|
||||||
|
|
||||||
|
If (And(PDC0, 0x10)) {
|
||||||
|
Sleep(100)
|
||||||
|
Notify(\_PR_.CPU0, 0x81) // _CST
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
If(And(PDC1, 0x08)) {
|
||||||
|
Notify (\_PR_.CPU1, 0x80) // _PPC
|
||||||
|
If (And(PDC1, 0x10)) {
|
||||||
|
Sleep(100)
|
||||||
|
Notify(\_PR_.CPU1, 0x81) // _CST
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} Else { // UP
|
||||||
|
Notify (\_PR_.CPU0, 0x80)
|
||||||
|
Sleep(0x64)
|
||||||
|
Notify(\_PR_.CPU0, 0x81)
|
||||||
|
}
|
||||||
|
}
|
|
@ -19,48 +19,6 @@
|
||||||
* MA 02110-1301 USA
|
* MA 02110-1301 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* These come from the dynamically created CPU SSDT */
|
|
||||||
External(PDC0)
|
|
||||||
External(PDC1)
|
|
||||||
|
|
||||||
/* The APM port can be used for generating software SMIs */
|
|
||||||
|
|
||||||
OperationRegion (APMP, SystemIO, 0xb2, 2)
|
|
||||||
Field (APMP, ByteAcc, NoLock, Preserve)
|
|
||||||
{
|
|
||||||
APMC, 8, // APM command
|
|
||||||
APMS, 8 // APM status
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Port 80 POST */
|
|
||||||
|
|
||||||
OperationRegion (POST, SystemIO, 0x80, 1)
|
|
||||||
Field (POST, ByteAcc, Lock, Preserve)
|
|
||||||
{
|
|
||||||
DBG0, 8
|
|
||||||
}
|
|
||||||
|
|
||||||
/* SMI I/O Trap */
|
|
||||||
Method(TRAP, 1, Serialized)
|
|
||||||
{
|
|
||||||
Store (Arg0, SMIF) // SMI Function
|
|
||||||
Store (0, TRP0) // Generate trap
|
|
||||||
Return (SMIF) // Return value of SMI handler
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PIC method is called by the OS to choose between interrupt
|
|
||||||
* routing via the i8259 interrupt controller or the APIC.
|
|
||||||
*
|
|
||||||
* _PIC is called with a parameter of 0 for i8259 configuration and
|
|
||||||
* with a parameter of 1 for Local Apic/IOAPIC configuration.
|
|
||||||
*/
|
|
||||||
|
|
||||||
Method(_PIC, 1)
|
|
||||||
{
|
|
||||||
// Remember the OS' IRQ routing choice.
|
|
||||||
Store(Arg0, PICM)
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _WAK method is called on system wakeup */
|
/* The _WAK method is called on system wakeup */
|
||||||
|
|
||||||
Method(_WAK,1)
|
Method(_WAK,1)
|
||||||
|
@ -85,38 +43,6 @@ Method(_WAK,1)
|
||||||
Return(Package(){0,0})
|
Return(Package(){0,0})
|
||||||
}
|
}
|
||||||
|
|
||||||
// Power notification
|
|
||||||
|
|
||||||
External (\_PR_.CPU0, DeviceObj)
|
|
||||||
External (\_PR_.CPU1, DeviceObj)
|
|
||||||
|
|
||||||
Method (PNOT)
|
|
||||||
{
|
|
||||||
If (MPEN) {
|
|
||||||
If(And(PDC0, 0x08)) {
|
|
||||||
Notify (\_PR_.CPU0, 0x80) // _PPC
|
|
||||||
|
|
||||||
If (And(PDC0, 0x10)) {
|
|
||||||
Sleep(100)
|
|
||||||
Notify(\_PR_.CPU0, 0x81) // _CST
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
If(And(PDC1, 0x08)) {
|
|
||||||
Notify (\_PR_.CPU1, 0x80) // _PPC
|
|
||||||
If (And(PDC1, 0x10)) {
|
|
||||||
Sleep(100)
|
|
||||||
Notify(\_PR_.CPU1, 0x81) // _CST
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
} Else { // UP
|
|
||||||
Notify (\_PR_.CPU0, 0x80)
|
|
||||||
Sleep(0x64)
|
|
||||||
Notify(\_PR_.CPU0, 0x81)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* System Bus */
|
/* System Bus */
|
||||||
|
|
||||||
Scope(\_SB)
|
Scope(\_SB)
|
||||||
|
@ -133,49 +59,7 @@ Scope(\_SB)
|
||||||
|
|
||||||
// TRAP(71) // TODO
|
// TRAP(71) // TODO
|
||||||
|
|
||||||
/* Determine the Operating System and save the value in OSYS.
|
\GOS()
|
||||||
* We have to do this in order to be able to work around
|
|
||||||
* certain windows bugs.
|
|
||||||
*
|
|
||||||
* OSYS value | Operating System
|
|
||||||
* -----------+------------------
|
|
||||||
* 2000 | Windows 2000
|
|
||||||
* 2001 | Windows XP(+SP1)
|
|
||||||
* 2002 | Windows XP SP2
|
|
||||||
* 2006 | Windows Vista
|
|
||||||
* ???? | Windows 7
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Let's assume we're running at least Windows 2000 */
|
|
||||||
Store (2000, OSYS)
|
|
||||||
|
|
||||||
If (CondRefOf(_OSI, Local0)) {
|
|
||||||
/* Linux answers _OSI with "True" for a couple of
|
|
||||||
* Windows version queries. But unlike Windows it
|
|
||||||
* needs a Video repost, so let's determine whether
|
|
||||||
* we're running Linux.
|
|
||||||
*/
|
|
||||||
|
|
||||||
If (_OSI("Linux")) {
|
|
||||||
Store (1, LINX)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001")) {
|
|
||||||
Store (2001, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001 SP1")) {
|
|
||||||
Store (2001, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001 SP2")) {
|
|
||||||
Store (2002, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2006")) {
|
|
||||||
Store (2006, OSYS)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* And the OS workarounds start right after we know what we're
|
/* And the OS workarounds start right after we know what we're
|
||||||
* running: Windows XP SP1 needs to have C-State coordination
|
* running: Windows XP SP1 needs to have C-State coordination
|
||||||
|
@ -189,4 +73,3 @@ Scope(\_SB)
|
||||||
// TRAP(43) // TODO
|
// TRAP(43) // TODO
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -37,6 +37,9 @@ DefinitionBlock(
|
||||||
|
|
||||||
// global NVS and variables
|
// global NVS and variables
|
||||||
#include <southbridge/intel/i82801gx/acpi/globalnvs.asl>
|
#include <southbridge/intel/i82801gx/acpi/globalnvs.asl>
|
||||||
|
#include <southbridge/intel/i82801gx/acpi/platform.asl>
|
||||||
|
|
||||||
|
#include <cpu/intel/model_6dx/acpi/cpu.asl>
|
||||||
|
|
||||||
Scope (\_SB) {
|
Scope (\_SB) {
|
||||||
Device (PCI0)
|
Device (PCI0)
|
||||||
|
|
|
@ -120,6 +120,8 @@ Device(EC0)
|
||||||
}
|
}
|
||||||
|
|
||||||
PNOT()
|
PNOT()
|
||||||
|
Notify(\_SB.BAT0, 0x80) // Execute BAT0 _BST
|
||||||
|
Notify(\_SB.BAT1, 0x80) // Execute BAT1 _BST
|
||||||
}
|
}
|
||||||
|
|
||||||
Method (_Q02, 0)
|
Method (_Q02, 0)
|
||||||
|
@ -133,12 +135,16 @@ Device(EC0)
|
||||||
}
|
}
|
||||||
|
|
||||||
PNOT()
|
PNOT()
|
||||||
|
Notify(\_SB.BAT0, 0x80) // Execute BAT0 _BST
|
||||||
|
Notify(\_SB.BAT1, 0x80) // Execute BAT1 _BST
|
||||||
}
|
}
|
||||||
|
|
||||||
Method (_Q05, 0)
|
Method (_Q05, 0)
|
||||||
{
|
{
|
||||||
Notify(SLPB, 0x80)
|
Notify(SLPB, 0x80)
|
||||||
PNOT()
|
PNOT()
|
||||||
|
Notify(\_SB.BAT0, 0x80) // Execute BAT0 _BST
|
||||||
|
Notify(\_SB.BAT1, 0x80) // Execute BAT1 _BST
|
||||||
}
|
}
|
||||||
|
|
||||||
Method (_Q07, 0)
|
Method (_Q07, 0)
|
||||||
|
|
|
@ -19,44 +19,6 @@
|
||||||
* MA 02110-1301 USA
|
* MA 02110-1301 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* The APM port can be used for generating software SMIs */
|
|
||||||
|
|
||||||
OperationRegion (APMP, SystemIO, 0xb2, 2)
|
|
||||||
Field (APMP, ByteAcc, NoLock, Preserve)
|
|
||||||
{
|
|
||||||
APMC, 8, // APM command
|
|
||||||
APMS, 8 // APM status
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Port 80 POST */
|
|
||||||
|
|
||||||
OperationRegion (POST, SystemIO, 0x80, 1)
|
|
||||||
Field (POST, ByteAcc, Lock, Preserve)
|
|
||||||
{
|
|
||||||
DBG0, 8
|
|
||||||
}
|
|
||||||
|
|
||||||
/* SMI I/O Trap */
|
|
||||||
Method(TRAP, 1, Serialized)
|
|
||||||
{
|
|
||||||
Store (Arg0, SMIF) // SMI Function
|
|
||||||
Store (0, TRP0) // Generate trap
|
|
||||||
Return (SMIF) // Return value of SMI handler
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PIC method is called by the OS to choose between interrupt
|
|
||||||
* routing via the i8259 interrupt controller or the APIC.
|
|
||||||
*
|
|
||||||
* _PIC is called with a parameter of 0 for i8259 configuration and
|
|
||||||
* with a parameter of 1 for Local Apic/IOAPIC configuration.
|
|
||||||
*/
|
|
||||||
|
|
||||||
Method(_PIC, 1)
|
|
||||||
{
|
|
||||||
// Remember the OS' IRQ routing choice.
|
|
||||||
Store(Arg0, PICM)
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PTS method (Prepare To Sleep) is called before the OS is
|
/* The _PTS method (Prepare To Sleep) is called before the OS is
|
||||||
* entering a sleep state. The sleep state number is passed in Arg0
|
* entering a sleep state. The sleep state number is passed in Arg0
|
||||||
*/
|
*/
|
||||||
|
@ -149,47 +111,6 @@ Method(_WAK,1)
|
||||||
Return(Package(){0,0})
|
Return(Package(){0,0})
|
||||||
}
|
}
|
||||||
|
|
||||||
// Power notification
|
|
||||||
|
|
||||||
External (\_PR_.CPU0, DeviceObj)
|
|
||||||
External (\_PR_.CPU1, DeviceObj)
|
|
||||||
External (\_PR_.CPU0._PPC)
|
|
||||||
External (\_PR_.CPU1._PPC)
|
|
||||||
/* These come from the dynamically created CPU SSDT */
|
|
||||||
External(PDC0)
|
|
||||||
External(PDC1)
|
|
||||||
|
|
||||||
Method (PNOT)
|
|
||||||
{
|
|
||||||
If (MPEN) {
|
|
||||||
If(And(PDC0, 0x08)) {
|
|
||||||
Notify (\_PR_.CPU0, 0x80) // _PPC
|
|
||||||
|
|
||||||
If (And(PDC0, 0x10)) {
|
|
||||||
Sleep(100)
|
|
||||||
Notify(\_PR_.CPU0, 0x81) // _CST
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
If(And(PDC1, 0x08)) {
|
|
||||||
Notify (\_PR_.CPU1, 0x80) // _PPC
|
|
||||||
If (And(PDC1, 0x10)) {
|
|
||||||
Sleep(100)
|
|
||||||
Notify(\_PR_.CPU1, 0x81) // _CST
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
} Else { // UP
|
|
||||||
Notify (\_PR_.CPU0, 0x80)
|
|
||||||
Sleep(0x64)
|
|
||||||
Notify(\_PR_.CPU0, 0x81)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Notify the Batteries
|
|
||||||
Notify(\_SB.BAT0, 0x80) // Execute BAT0 _BST
|
|
||||||
Notify(\_SB.BAT1, 0x80) // Execute BAT1 _BST
|
|
||||||
}
|
|
||||||
|
|
||||||
// Hardcoded for now..
|
// Hardcoded for now..
|
||||||
Name (CFGD, 0x113B69F1)
|
Name (CFGD, 0x113B69F1)
|
||||||
|
|
||||||
|
@ -210,49 +131,7 @@ Scope(\_SB)
|
||||||
TRAP(0x47)
|
TRAP(0x47)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Determine the Operating System and save the value in OSYS.
|
\GOS()
|
||||||
* We have to do this in order to be able to work around
|
|
||||||
* certain windows bugs.
|
|
||||||
*
|
|
||||||
* OSYS value | Operating System
|
|
||||||
* -----------+------------------
|
|
||||||
* 2000 | Windows 2000
|
|
||||||
* 2001 | Windows XP(+SP1)
|
|
||||||
* 2002 | Windows XP SP2
|
|
||||||
* 2006 | Windows Vista
|
|
||||||
* ???? | Windows 7
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Let's assume we're running at least Windows 2000 */
|
|
||||||
Store (2000, OSYS)
|
|
||||||
|
|
||||||
If (CondRefOf(_OSI, Local0)) {
|
|
||||||
/* Linux answers _OSI with "True" for a couple of
|
|
||||||
* Windows version queries. But unlike Windows it
|
|
||||||
* needs a Video repost, so let's determine whether
|
|
||||||
* we're running Linux.
|
|
||||||
*/
|
|
||||||
|
|
||||||
If (_OSI("Linux")) {
|
|
||||||
Store (1, LINX)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001")) {
|
|
||||||
Store (2001, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001 SP1")) {
|
|
||||||
Store (2001, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001 SP2")) {
|
|
||||||
Store (2002, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2006")) {
|
|
||||||
Store (2006, OSYS)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* And the OS workarounds start right after we know what we're
|
/* And the OS workarounds start right after we know what we're
|
||||||
* running: Windows XP SP1 needs to have C-State coordination
|
* running: Windows XP SP1 needs to have C-State coordination
|
||||||
|
|
|
@ -31,6 +31,8 @@ DefinitionBlock(
|
||||||
0x20090419 // OEM revision
|
0x20090419 // OEM revision
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
#include <southbridge/intel/i82801gx/acpi/platform.asl>
|
||||||
|
|
||||||
// Some generic macros
|
// Some generic macros
|
||||||
#include "acpi/platform.asl"
|
#include "acpi/platform.asl"
|
||||||
|
|
||||||
|
@ -46,6 +48,8 @@ DefinitionBlock(
|
||||||
// Thermal Zone
|
// Thermal Zone
|
||||||
#include "acpi/thermal.asl"
|
#include "acpi/thermal.asl"
|
||||||
|
|
||||||
|
#include <cpu/intel/model_6dx/acpi/cpu.asl>
|
||||||
|
|
||||||
Scope (\_SB) {
|
Scope (\_SB) {
|
||||||
Device (PCI0)
|
Device (PCI0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -17,44 +17,6 @@
|
||||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* The APM port can be used for generating software SMIs */
|
|
||||||
|
|
||||||
OperationRegion (APMP, SystemIO, 0xb2, 2)
|
|
||||||
Field (APMP, ByteAcc, NoLock, Preserve)
|
|
||||||
{
|
|
||||||
APMC, 8, // APM command
|
|
||||||
APMS, 8 // APM status
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Port 80 POST */
|
|
||||||
|
|
||||||
OperationRegion (POST, SystemIO, 0x80, 1)
|
|
||||||
Field (POST, ByteAcc, Lock, Preserve)
|
|
||||||
{
|
|
||||||
DBG0, 8
|
|
||||||
}
|
|
||||||
|
|
||||||
/* SMI I/O Trap */
|
|
||||||
Method(TRAP, 1, Serialized)
|
|
||||||
{
|
|
||||||
Store (Arg0, SMIF) // SMI Function
|
|
||||||
Store (0, TRP0) // Generate trap
|
|
||||||
Return (SMIF) // Return value of SMI handler
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PIC method is called by the OS to choose between interrupt
|
|
||||||
* routing via the i8259 interrupt controller or the APIC.
|
|
||||||
*
|
|
||||||
* _PIC is called with a parameter of 0 for i8259 configuration and
|
|
||||||
* with a parameter of 1 for Local Apic/IOAPIC configuration.
|
|
||||||
*/
|
|
||||||
|
|
||||||
Method(_PIC, 1)
|
|
||||||
{
|
|
||||||
// Remember the OS' IRQ routing choice.
|
|
||||||
Store(Arg0, PICM)
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PTS method (Prepare To Sleep) is called before the OS is
|
/* The _PTS method (Prepare To Sleep) is called before the OS is
|
||||||
* entering a sleep state. The sleep state number is passed in Arg0
|
* entering a sleep state. The sleep state number is passed in Arg0
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -32,11 +32,15 @@ DefinitionBlock(
|
||||||
// global NVS and variables
|
// global NVS and variables
|
||||||
#include <southbridge/intel/i82801gx/acpi/globalnvs.asl>
|
#include <southbridge/intel/i82801gx/acpi/globalnvs.asl>
|
||||||
|
|
||||||
|
#include <southbridge/intel/i82801gx/acpi/platform.asl>
|
||||||
|
|
||||||
// General Purpose Events
|
// General Purpose Events
|
||||||
//#include "acpi/gpe.asl"
|
//#include "acpi/gpe.asl"
|
||||||
|
|
||||||
//#include "acpi/thermal.asl"
|
//#include "acpi/thermal.asl"
|
||||||
|
|
||||||
|
#include <cpu/intel/model_6dx/acpi/cpu.asl>
|
||||||
|
|
||||||
Scope (\_SB) {
|
Scope (\_SB) {
|
||||||
Device (PCI0)
|
Device (PCI0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -17,44 +17,6 @@
|
||||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* The APM port can be used for generating software SMIs */
|
|
||||||
|
|
||||||
OperationRegion (APMP, SystemIO, 0xb2, 2)
|
|
||||||
Field (APMP, ByteAcc, NoLock, Preserve)
|
|
||||||
{
|
|
||||||
APMC, 8, // APM command
|
|
||||||
APMS, 8 // APM status
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Port 80 POST */
|
|
||||||
|
|
||||||
OperationRegion (POST, SystemIO, 0x80, 1)
|
|
||||||
Field (POST, ByteAcc, Lock, Preserve)
|
|
||||||
{
|
|
||||||
DBG0, 8
|
|
||||||
}
|
|
||||||
|
|
||||||
/* SMI I/O Trap */
|
|
||||||
Method(TRAP, 1, Serialized)
|
|
||||||
{
|
|
||||||
Store (Arg0, SMIF) // SMI Function
|
|
||||||
Store (0, TRP0) // Generate trap
|
|
||||||
Return (SMIF) // Return value of SMI handler
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PIC method is called by the OS to choose between interrupt
|
|
||||||
* routing via the i8259 interrupt controller or the APIC.
|
|
||||||
*
|
|
||||||
* _PIC is called with a parameter of 0 for i8259 configuration and
|
|
||||||
* with a parameter of 1 for Local Apic/IOAPIC configuration.
|
|
||||||
*/
|
|
||||||
|
|
||||||
Method(_PIC, 1)
|
|
||||||
{
|
|
||||||
// Remember the OS' IRQ routing choice.
|
|
||||||
Store(Arg0, PICM)
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PTS method (Prepare To Sleep) is called before the OS is
|
/* The _PTS method (Prepare To Sleep) is called before the OS is
|
||||||
* entering a sleep state. The sleep state number is passed in Arg0
|
* entering a sleep state. The sleep state number is passed in Arg0
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -31,6 +31,7 @@ DefinitionBlock(
|
||||||
|
|
||||||
// global NVS and variables
|
// global NVS and variables
|
||||||
#include <southbridge/intel/i82801gx/acpi/globalnvs.asl>
|
#include <southbridge/intel/i82801gx/acpi/globalnvs.asl>
|
||||||
|
#include <southbridge/intel/i82801gx/acpi/platform.asl>
|
||||||
|
|
||||||
// General Purpose Events
|
// General Purpose Events
|
||||||
//#include "acpi/gpe.asl"
|
//#include "acpi/gpe.asl"
|
||||||
|
@ -41,6 +42,8 @@ DefinitionBlock(
|
||||||
// Thermal Zone
|
// Thermal Zone
|
||||||
//#include "acpi/thermal.asl"
|
//#include "acpi/thermal.asl"
|
||||||
|
|
||||||
|
#include <cpu/intel/model_6dx/acpi/cpu.asl>
|
||||||
|
|
||||||
Scope (\_SB) {
|
Scope (\_SB) {
|
||||||
Device (PCI0)
|
Device (PCI0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -17,44 +17,6 @@
|
||||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* The APM port can be used for generating software SMIs */
|
|
||||||
|
|
||||||
OperationRegion (APMP, SystemIO, 0xb2, 2)
|
|
||||||
Field (APMP, ByteAcc, NoLock, Preserve)
|
|
||||||
{
|
|
||||||
APMC, 8, // APM command
|
|
||||||
APMS, 8 // APM status
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Port 80 POST */
|
|
||||||
|
|
||||||
OperationRegion (POST, SystemIO, 0x80, 1)
|
|
||||||
Field (POST, ByteAcc, Lock, Preserve)
|
|
||||||
{
|
|
||||||
DBG0, 8
|
|
||||||
}
|
|
||||||
|
|
||||||
/* SMI I/O Trap */
|
|
||||||
Method(TRAP, 1, Serialized)
|
|
||||||
{
|
|
||||||
Store (Arg0, SMIF) // SMI Function
|
|
||||||
Store (0, TRP0) // Generate trap
|
|
||||||
Return (SMIF) // Return value of SMI handler
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PIC method is called by the OS to choose between interrupt
|
|
||||||
* routing via the i8259 interrupt controller or the APIC.
|
|
||||||
*
|
|
||||||
* _PIC is called with a parameter of 0 for i8259 configuration and
|
|
||||||
* with a parameter of 1 for Local Apic/IOAPIC configuration.
|
|
||||||
*/
|
|
||||||
|
|
||||||
Method(_PIC, 1)
|
|
||||||
{
|
|
||||||
// Remember the OS' IRQ routing choice.
|
|
||||||
Store(Arg0, PICM)
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PTS method (Prepare To Sleep) is called before the OS is
|
/* The _PTS method (Prepare To Sleep) is called before the OS is
|
||||||
* entering a sleep state. The sleep state number is passed in Arg0
|
* entering a sleep state. The sleep state number is passed in Arg0
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -31,12 +31,15 @@ DefinitionBlock(
|
||||||
|
|
||||||
// global NVS and variables
|
// global NVS and variables
|
||||||
#include <southbridge/intel/i82801gx/acpi/globalnvs.asl>
|
#include <southbridge/intel/i82801gx/acpi/globalnvs.asl>
|
||||||
|
#include <southbridge/intel/i82801gx/acpi/platform.asl>
|
||||||
|
|
||||||
// General Purpose Events
|
// General Purpose Events
|
||||||
//#include "acpi/gpe.asl"
|
//#include "acpi/gpe.asl"
|
||||||
|
|
||||||
//#include "acpi/thermal.asl"
|
//#include "acpi/thermal.asl"
|
||||||
|
|
||||||
|
#include <cpu/intel/model_6dx/acpi/cpu.asl>
|
||||||
|
|
||||||
Scope (\_SB) {
|
Scope (\_SB) {
|
||||||
Device (PCI0)
|
Device (PCI0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -19,48 +19,6 @@
|
||||||
* MA 02110-1301 USA
|
* MA 02110-1301 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* These come from the dynamically created CPU SSDT */
|
|
||||||
External(PDC0)
|
|
||||||
External(PDC1)
|
|
||||||
|
|
||||||
/* The APM port can be used for generating software SMIs */
|
|
||||||
|
|
||||||
OperationRegion (APMP, SystemIO, 0xb2, 2)
|
|
||||||
Field (APMP, ByteAcc, NoLock, Preserve)
|
|
||||||
{
|
|
||||||
APMC, 8, // APM command
|
|
||||||
APMS, 8 // APM status
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Port 80 POST */
|
|
||||||
|
|
||||||
OperationRegion (POST, SystemIO, 0x80, 1)
|
|
||||||
Field (POST, ByteAcc, Lock, Preserve)
|
|
||||||
{
|
|
||||||
DBG0, 8
|
|
||||||
}
|
|
||||||
|
|
||||||
/* SMI I/O Trap */
|
|
||||||
Method(TRAP, 1, Serialized)
|
|
||||||
{
|
|
||||||
Store (Arg0, SMIF) // SMI Function
|
|
||||||
Store (0, TRP0) // Generate trap
|
|
||||||
Return (SMIF) // Return value of SMI handler
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PIC method is called by the OS to choose between interrupt
|
|
||||||
* routing via the i8259 interrupt controller or the APIC.
|
|
||||||
*
|
|
||||||
* _PIC is called with a parameter of 0 for i8259 configuration and
|
|
||||||
* with a parameter of 1 for Local Apic/IOAPIC configuration.
|
|
||||||
*/
|
|
||||||
|
|
||||||
Method(_PIC, 1)
|
|
||||||
{
|
|
||||||
// Remember the OS' IRQ routing choice.
|
|
||||||
Store(Arg0, PICM)
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PTS method (Prepare To Sleep) is called before the OS is
|
/* The _PTS method (Prepare To Sleep) is called before the OS is
|
||||||
* entering a sleep state. The sleep state number is passed in Arg0
|
* entering a sleep state. The sleep state number is passed in Arg0
|
||||||
*/
|
*/
|
||||||
|
@ -95,42 +53,6 @@ Method(_WAK,1)
|
||||||
Return(Package(){0,0})
|
Return(Package(){0,0})
|
||||||
}
|
}
|
||||||
|
|
||||||
// Power notification
|
|
||||||
|
|
||||||
External (\_PR_.CPU0, DeviceObj)
|
|
||||||
External (\_PR_.CPU1, DeviceObj)
|
|
||||||
|
|
||||||
Method (PNOT)
|
|
||||||
{
|
|
||||||
If (MPEN) {
|
|
||||||
If(And(PDC0, 0x08)) {
|
|
||||||
Notify (\_PR_.CPU0, 0x80) // _PPC
|
|
||||||
|
|
||||||
If (And(PDC0, 0x10)) {
|
|
||||||
Sleep(100)
|
|
||||||
Notify(\_PR_.CPU0, 0x81) // _CST
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
If(And(PDC1, 0x08)) {
|
|
||||||
Notify (\_PR_.CPU1, 0x80) // _PPC
|
|
||||||
If (And(PDC1, 0x10)) {
|
|
||||||
Sleep(100)
|
|
||||||
Notify(\_PR_.CPU1, 0x81) // _CST
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
} Else { // UP
|
|
||||||
Notify (\_PR_.CPU0, 0x80)
|
|
||||||
Sleep(0x64)
|
|
||||||
Notify(\_PR_.CPU0, 0x81)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Notify the Batteries
|
|
||||||
Notify(\_SB.PCI0.LPCB.EC.BAT0, 0x80) // Execute BAT1 _BST
|
|
||||||
Notify(\_SB.PCI0.LPCB.EC.BAT1, 0x80) // Execute BAT2 _BST
|
|
||||||
}
|
|
||||||
|
|
||||||
/* System Bus */
|
/* System Bus */
|
||||||
|
|
||||||
Scope(\_SB)
|
Scope(\_SB)
|
||||||
|
@ -147,49 +69,7 @@ Scope(\_SB)
|
||||||
|
|
||||||
// TRAP(71) // TODO
|
// TRAP(71) // TODO
|
||||||
|
|
||||||
/* Determine the Operating System and save the value in OSYS.
|
\GOS()
|
||||||
* We have to do this in order to be able to work around
|
|
||||||
* certain windows bugs.
|
|
||||||
*
|
|
||||||
* OSYS value | Operating System
|
|
||||||
* -----------+------------------
|
|
||||||
* 2000 | Windows 2000
|
|
||||||
* 2001 | Windows XP(+SP1)
|
|
||||||
* 2002 | Windows XP SP2
|
|
||||||
* 2006 | Windows Vista
|
|
||||||
* ???? | Windows 7
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Let's assume we're running at least Windows 2000 */
|
|
||||||
Store (2000, OSYS)
|
|
||||||
|
|
||||||
If (CondRefOf(_OSI, Local0)) {
|
|
||||||
/* Linux answers _OSI with "True" for a couple of
|
|
||||||
* Windows version queries. But unlike Windows it
|
|
||||||
* needs a Video repost, so let's determine whether
|
|
||||||
* we're running Linux.
|
|
||||||
*/
|
|
||||||
|
|
||||||
If (_OSI("Linux")) {
|
|
||||||
Store (1, LINX)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001")) {
|
|
||||||
Store (2001, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001 SP1")) {
|
|
||||||
Store (2001, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001 SP2")) {
|
|
||||||
Store (2002, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2006")) {
|
|
||||||
Store (2006, OSYS)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* And the OS workarounds start right after we know what we're
|
/* And the OS workarounds start right after we know what we're
|
||||||
* running: Windows XP SP1 needs to have C-State coordination
|
* running: Windows XP SP1 needs to have C-State coordination
|
||||||
|
|
|
@ -38,6 +38,7 @@ DefinitionBlock(
|
||||||
|
|
||||||
// global NVS and variables
|
// global NVS and variables
|
||||||
#include <southbridge/intel/i82801gx/acpi/globalnvs.asl>
|
#include <southbridge/intel/i82801gx/acpi/globalnvs.asl>
|
||||||
|
#include <southbridge/intel/i82801gx/acpi/platform.asl>
|
||||||
|
|
||||||
// General Purpose Events
|
// General Purpose Events
|
||||||
#include "acpi/gpe.asl"
|
#include "acpi/gpe.asl"
|
||||||
|
@ -45,6 +46,8 @@ DefinitionBlock(
|
||||||
// mainboard specific devices
|
// mainboard specific devices
|
||||||
#include "acpi/mainboard.asl"
|
#include "acpi/mainboard.asl"
|
||||||
|
|
||||||
|
#include <cpu/intel/model_6dx/acpi/cpu.asl>
|
||||||
|
|
||||||
Scope (\_SB) {
|
Scope (\_SB) {
|
||||||
Device (PCI0)
|
Device (PCI0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -19,48 +19,6 @@
|
||||||
* MA 02110-1301 USA
|
* MA 02110-1301 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* These come from the dynamically created CPU SSDT */
|
|
||||||
External(PDC0)
|
|
||||||
External(PDC1)
|
|
||||||
|
|
||||||
/* The APM port can be used for generating software SMIs */
|
|
||||||
|
|
||||||
OperationRegion (APMP, SystemIO, 0xb2, 2)
|
|
||||||
Field (APMP, ByteAcc, NoLock, Preserve)
|
|
||||||
{
|
|
||||||
APMC, 8, // APM command
|
|
||||||
APMS, 8 // APM status
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Port 80 POST */
|
|
||||||
|
|
||||||
OperationRegion (POST, SystemIO, 0x80, 1)
|
|
||||||
Field (POST, ByteAcc, Lock, Preserve)
|
|
||||||
{
|
|
||||||
DBG0, 8
|
|
||||||
}
|
|
||||||
|
|
||||||
/* SMI I/O Trap */
|
|
||||||
Method(TRAP, 1, Serialized)
|
|
||||||
{
|
|
||||||
Store (Arg0, SMIF) // SMI Function
|
|
||||||
Store (0, TRP0) // Generate trap
|
|
||||||
Return (SMIF) // Return value of SMI handler
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PIC method is called by the OS to choose between interrupt
|
|
||||||
* routing via the i8259 interrupt controller or the APIC.
|
|
||||||
*
|
|
||||||
* _PIC is called with a parameter of 0 for i8259 configuration and
|
|
||||||
* with a parameter of 1 for Local Apic/IOAPIC configuration.
|
|
||||||
*/
|
|
||||||
|
|
||||||
Method(_PIC, 1)
|
|
||||||
{
|
|
||||||
// Remember the OS' IRQ routing choice.
|
|
||||||
Store(Arg0, PICM)
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PTS method (Prepare To Sleep) is called before the OS is
|
/* The _PTS method (Prepare To Sleep) is called before the OS is
|
||||||
* entering a sleep state. The sleep state number is passed in Arg0
|
* entering a sleep state. The sleep state number is passed in Arg0
|
||||||
*/
|
*/
|
||||||
|
@ -95,42 +53,6 @@ Method(_WAK,1)
|
||||||
Return(Package(){0,0})
|
Return(Package(){0,0})
|
||||||
}
|
}
|
||||||
|
|
||||||
// Power notification
|
|
||||||
|
|
||||||
External (\_PR_.CPU0, DeviceObj)
|
|
||||||
External (\_PR_.CPU1, DeviceObj)
|
|
||||||
|
|
||||||
Method (PNOT)
|
|
||||||
{
|
|
||||||
If (MPEN) {
|
|
||||||
If(And(PDC0, 0x08)) {
|
|
||||||
Notify (\_PR_.CPU0, 0x80) // _PPC
|
|
||||||
|
|
||||||
If (And(PDC0, 0x10)) {
|
|
||||||
Sleep(100)
|
|
||||||
Notify(\_PR_.CPU0, 0x81) // _CST
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
If(And(PDC1, 0x08)) {
|
|
||||||
Notify (\_PR_.CPU1, 0x80) // _PPC
|
|
||||||
If (And(PDC1, 0x10)) {
|
|
||||||
Sleep(100)
|
|
||||||
Notify(\_PR_.CPU1, 0x81) // _CST
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
} Else { // UP
|
|
||||||
Notify (\_PR_.CPU0, 0x80)
|
|
||||||
Sleep(0x64)
|
|
||||||
Notify(\_PR_.CPU0, 0x81)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Notify the Batteries
|
|
||||||
Notify(\_SB.PCI0.LPCB.EC.BAT0, 0x80) // Execute BAT1 _BST
|
|
||||||
Notify(\_SB.PCI0.LPCB.EC.BAT1, 0x80) // Execute BAT2 _BST
|
|
||||||
}
|
|
||||||
|
|
||||||
/* System Bus */
|
/* System Bus */
|
||||||
|
|
||||||
Scope(\_SB)
|
Scope(\_SB)
|
||||||
|
@ -147,49 +69,7 @@ Scope(\_SB)
|
||||||
|
|
||||||
// TRAP(71) // TODO
|
// TRAP(71) // TODO
|
||||||
|
|
||||||
/* Determine the Operating System and save the value in OSYS.
|
\GOS()
|
||||||
* We have to do this in order to be able to work around
|
|
||||||
* certain windows bugs.
|
|
||||||
*
|
|
||||||
* OSYS value | Operating System
|
|
||||||
* -----------+------------------
|
|
||||||
* 2000 | Windows 2000
|
|
||||||
* 2001 | Windows XP(+SP1)
|
|
||||||
* 2002 | Windows XP SP2
|
|
||||||
* 2006 | Windows Vista
|
|
||||||
* ???? | Windows 7
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Let's assume we're running at least Windows 2000 */
|
|
||||||
Store (2000, OSYS)
|
|
||||||
|
|
||||||
If (CondRefOf(_OSI, Local0)) {
|
|
||||||
/* Linux answers _OSI with "True" for a couple of
|
|
||||||
* Windows version queries. But unlike Windows it
|
|
||||||
* needs a Video repost, so let's determine whether
|
|
||||||
* we're running Linux.
|
|
||||||
*/
|
|
||||||
|
|
||||||
If (_OSI("Linux")) {
|
|
||||||
Store (1, LINX)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001")) {
|
|
||||||
Store (2001, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001 SP1")) {
|
|
||||||
Store (2001, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001 SP2")) {
|
|
||||||
Store (2002, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2006")) {
|
|
||||||
Store (2006, OSYS)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* And the OS workarounds start right after we know what we're
|
/* And the OS workarounds start right after we know what we're
|
||||||
* running: Windows XP SP1 needs to have C-State coordination
|
* running: Windows XP SP1 needs to have C-State coordination
|
||||||
|
|
|
@ -38,6 +38,7 @@ DefinitionBlock(
|
||||||
|
|
||||||
// global NVS and variables
|
// global NVS and variables
|
||||||
#include <southbridge/intel/i82801gx/acpi/globalnvs.asl>
|
#include <southbridge/intel/i82801gx/acpi/globalnvs.asl>
|
||||||
|
#include <southbridge/intel/i82801gx/acpi/platform.asl>
|
||||||
|
|
||||||
// General Purpose Events
|
// General Purpose Events
|
||||||
#include "acpi/gpe.asl"
|
#include "acpi/gpe.asl"
|
||||||
|
@ -45,6 +46,8 @@ DefinitionBlock(
|
||||||
// mainboard specific devices
|
// mainboard specific devices
|
||||||
#include "acpi/mainboard.asl"
|
#include "acpi/mainboard.asl"
|
||||||
|
|
||||||
|
#include <cpu/intel/model_6dx/acpi/cpu.asl>
|
||||||
|
|
||||||
Scope (\_SB) {
|
Scope (\_SB) {
|
||||||
Device (PCI0)
|
Device (PCI0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -107,6 +107,9 @@ Device(EC0)
|
||||||
Store("_Q30: AC In/Out", Debug)
|
Store("_Q30: AC In/Out", Debug)
|
||||||
Notify(ADP1, 0x80) // Tell the Power Adapter
|
Notify(ADP1, 0x80) // Tell the Power Adapter
|
||||||
PNOT() // and the CPU and Battery
|
PNOT() // and the CPU and Battery
|
||||||
|
// Notify the Batteries
|
||||||
|
Notify(BAT1, 0x80) // Execute BAT1 _BST
|
||||||
|
Notify(BAT2, 0x80) // Execute BAT2 _BST
|
||||||
}
|
}
|
||||||
|
|
||||||
Method (_Q31, 0)
|
Method (_Q31, 0)
|
||||||
|
|
|
@ -19,48 +19,6 @@
|
||||||
* MA 02110-1301 USA
|
* MA 02110-1301 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* These come from the dynamically created CPU SSDT */
|
|
||||||
External(PDC0)
|
|
||||||
External(PDC1)
|
|
||||||
|
|
||||||
/* The APM port can be used for generating software SMIs */
|
|
||||||
|
|
||||||
OperationRegion (APMP, SystemIO, 0xb2, 2)
|
|
||||||
Field (APMP, ByteAcc, NoLock, Preserve)
|
|
||||||
{
|
|
||||||
APMC, 8, // APM command
|
|
||||||
APMS, 8 // APM status
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Port 80 POST */
|
|
||||||
|
|
||||||
OperationRegion (POST, SystemIO, 0x80, 1)
|
|
||||||
Field (POST, ByteAcc, Lock, Preserve)
|
|
||||||
{
|
|
||||||
DBG0, 8
|
|
||||||
}
|
|
||||||
|
|
||||||
/* SMI I/O Trap */
|
|
||||||
Method(TRAP, 1, Serialized)
|
|
||||||
{
|
|
||||||
Store (Arg0, SMIF) // SMI Function
|
|
||||||
Store (0, TRP0) // Generate trap
|
|
||||||
Return (SMIF) // Return value of SMI handler
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PIC method is called by the OS to choose between interrupt
|
|
||||||
* routing via the i8259 interrupt controller or the APIC.
|
|
||||||
*
|
|
||||||
* _PIC is called with a parameter of 0 for i8259 configuration and
|
|
||||||
* with a parameter of 1 for Local Apic/IOAPIC configuration.
|
|
||||||
*/
|
|
||||||
|
|
||||||
Method(_PIC, 1)
|
|
||||||
{
|
|
||||||
// Remember the OS' IRQ routing choice.
|
|
||||||
Store(Arg0, PICM)
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The _PTS method (Prepare To Sleep) is called before the OS is
|
/* The _PTS method (Prepare To Sleep) is called before the OS is
|
||||||
* entering a sleep state. The sleep state number is passed in Arg0
|
* entering a sleep state. The sleep state number is passed in Arg0
|
||||||
*/
|
*/
|
||||||
|
@ -95,42 +53,6 @@ Method(_WAK,1)
|
||||||
Return(Package(){0,0})
|
Return(Package(){0,0})
|
||||||
}
|
}
|
||||||
|
|
||||||
// Power notification
|
|
||||||
|
|
||||||
External (\_PR_.CPU0, DeviceObj)
|
|
||||||
External (\_PR_.CPU1, DeviceObj)
|
|
||||||
|
|
||||||
Method (PNOT)
|
|
||||||
{
|
|
||||||
If (MPEN) {
|
|
||||||
If(And(PDC0, 0x08)) {
|
|
||||||
Notify (\_PR_.CPU0, 0x80) // _PPC
|
|
||||||
|
|
||||||
If (And(PDC0, 0x10)) {
|
|
||||||
Sleep(100)
|
|
||||||
Notify(\_PR_.CPU0, 0x81) // _CST
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
If(And(PDC1, 0x08)) {
|
|
||||||
Notify (\_PR_.CPU1, 0x80) // _PPC
|
|
||||||
If (And(PDC1, 0x10)) {
|
|
||||||
Sleep(100)
|
|
||||||
Notify(\_PR_.CPU1, 0x81) // _CST
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
} Else { // UP
|
|
||||||
Notify (\_PR_.CPU0, 0x80)
|
|
||||||
Sleep(0x64)
|
|
||||||
Notify(\_PR_.CPU0, 0x81)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Notify the Batteries
|
|
||||||
Notify(BAT1, 0x80) // Execute BAT1 _BST
|
|
||||||
Notify(BAT2, 0x80) // Execute BAT2 _BST
|
|
||||||
}
|
|
||||||
|
|
||||||
/* System Bus */
|
/* System Bus */
|
||||||
|
|
||||||
Scope(\_SB)
|
Scope(\_SB)
|
||||||
|
@ -147,49 +69,7 @@ Scope(\_SB)
|
||||||
|
|
||||||
// TRAP(71) // TODO
|
// TRAP(71) // TODO
|
||||||
|
|
||||||
/* Determine the Operating System and save the value in OSYS.
|
\GOS()
|
||||||
* We have to do this in order to be able to work around
|
|
||||||
* certain windows bugs.
|
|
||||||
*
|
|
||||||
* OSYS value | Operating System
|
|
||||||
* -----------+------------------
|
|
||||||
* 2000 | Windows 2000
|
|
||||||
* 2001 | Windows XP(+SP1)
|
|
||||||
* 2002 | Windows XP SP2
|
|
||||||
* 2006 | Windows Vista
|
|
||||||
* ???? | Windows 7
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Let's assume we're running at least Windows 2000 */
|
|
||||||
Store (2000, OSYS)
|
|
||||||
|
|
||||||
If (CondRefOf(_OSI, Local0)) {
|
|
||||||
/* Linux answers _OSI with "True" for a couple of
|
|
||||||
* Windows version queries. But unlike Windows it
|
|
||||||
* needs a Video repost, so let's determine whether
|
|
||||||
* we're running Linux.
|
|
||||||
*/
|
|
||||||
|
|
||||||
If (_OSI("Linux")) {
|
|
||||||
Store (1, LINX)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001")) {
|
|
||||||
Store (2001, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001 SP1")) {
|
|
||||||
Store (2001, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2001 SP2")) {
|
|
||||||
Store (2002, OSYS)
|
|
||||||
}
|
|
||||||
|
|
||||||
If (_OSI("Windows 2006")) {
|
|
||||||
Store (2006, OSYS)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* And the OS workarounds start right after we know what we're
|
/* And the OS workarounds start right after we know what we're
|
||||||
* running: Windows XP SP1 needs to have C-State coordination
|
* running: Windows XP SP1 needs to have C-State coordination
|
||||||
|
|
|
@ -33,6 +33,7 @@ DefinitionBlock(
|
||||||
|
|
||||||
// global NVS and variables
|
// global NVS and variables
|
||||||
#include <southbridge/intel/i82801gx/acpi/globalnvs.asl>
|
#include <southbridge/intel/i82801gx/acpi/globalnvs.asl>
|
||||||
|
#include <southbridge/intel/i82801gx/acpi/platform.asl>
|
||||||
|
|
||||||
// General Purpose Events
|
// General Purpose Events
|
||||||
#include "acpi/gpe.asl"
|
#include "acpi/gpe.asl"
|
||||||
|
@ -43,6 +44,8 @@ DefinitionBlock(
|
||||||
// Thermal Zone
|
// Thermal Zone
|
||||||
#include "acpi/thermal.asl"
|
#include "acpi/thermal.asl"
|
||||||
|
|
||||||
|
#include <cpu/intel/model_6dx/acpi/cpu.asl>
|
||||||
|
|
||||||
Scope (\_SB) {
|
Scope (\_SB) {
|
||||||
Device (PCI0)
|
Device (PCI0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -0,0 +1,105 @@
|
||||||
|
/*
|
||||||
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* The APM port can be used for generating software SMIs */
|
||||||
|
|
||||||
|
OperationRegion (APMP, SystemIO, 0xb2, 2)
|
||||||
|
Field (APMP, ByteAcc, NoLock, Preserve)
|
||||||
|
{
|
||||||
|
APMC, 8, // APM command
|
||||||
|
APMS, 8 // APM status
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Port 80 POST */
|
||||||
|
|
||||||
|
OperationRegion (POST, SystemIO, 0x80, 1)
|
||||||
|
Field (POST, ByteAcc, Lock, Preserve)
|
||||||
|
{
|
||||||
|
DBG0, 8
|
||||||
|
}
|
||||||
|
|
||||||
|
/* SMI I/O Trap */
|
||||||
|
Method(TRAP, 1, Serialized)
|
||||||
|
{
|
||||||
|
Store (Arg0, SMIF) // SMI Function
|
||||||
|
Store (0, TRP0) // Generate trap
|
||||||
|
Return (SMIF) // Return value of SMI handler
|
||||||
|
}
|
||||||
|
|
||||||
|
/* The _PIC method is called by the OS to choose between interrupt
|
||||||
|
* routing via the i8259 interrupt controller or the APIC.
|
||||||
|
*
|
||||||
|
* _PIC is called with a parameter of 0 for i8259 configuration and
|
||||||
|
* with a parameter of 1 for Local Apic/IOAPIC configuration.
|
||||||
|
*/
|
||||||
|
|
||||||
|
Method(_PIC, 1)
|
||||||
|
{
|
||||||
|
// Remember the OS' IRQ routing choice.
|
||||||
|
Store(Arg0, PICM)
|
||||||
|
}
|
||||||
|
|
||||||
|
Method(GOS, 0)
|
||||||
|
{
|
||||||
|
/* Determine the Operating System and save the value in OSYS.
|
||||||
|
* We have to do this in order to be able to work around
|
||||||
|
* certain windows bugs.
|
||||||
|
*
|
||||||
|
* OSYS value | Operating System
|
||||||
|
* -----------+------------------
|
||||||
|
* 2000 | Windows 2000
|
||||||
|
* 2001 | Windows XP(+SP1)
|
||||||
|
* 2002 | Windows XP SP2
|
||||||
|
* 2006 | Windows Vista
|
||||||
|
* ???? | Windows 7
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Let's assume we're running at least Windows 2000 */
|
||||||
|
Store (2000, OSYS)
|
||||||
|
|
||||||
|
If (CondRefOf(_OSI, Local0)) {
|
||||||
|
/* Linux answers _OSI with "True" for a couple of
|
||||||
|
* Windows version queries. But unlike Windows it
|
||||||
|
* needs a Video repost, so let's determine whether
|
||||||
|
* we're running Linux.
|
||||||
|
*/
|
||||||
|
|
||||||
|
If (_OSI("Linux")) {
|
||||||
|
Store (1, LINX)
|
||||||
|
}
|
||||||
|
|
||||||
|
If (_OSI("Windows 2001")) {
|
||||||
|
Store (2001, OSYS)
|
||||||
|
}
|
||||||
|
|
||||||
|
If (_OSI("Windows 2001 SP1")) {
|
||||||
|
Store (2001, OSYS)
|
||||||
|
}
|
||||||
|
|
||||||
|
If (_OSI("Windows 2001 SP2")) {
|
||||||
|
Store (2002, OSYS)
|
||||||
|
}
|
||||||
|
|
||||||
|
If (_OSI("Windows 2006")) {
|
||||||
|
Store (2006, OSYS)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue