/* * This file is part of the coreboot project. * * Copyright (C) 2011 Advanced Micro Devices, Inc. * * 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 Statement */ DefinitionBlock ( "DSDT.AML", /* Output filename */ "DSDT", /* Signature */ 0x02, /* DSDT Revision, needs to be 2 for 64bit */ "AMD ", /* OEMID */ "TORPEDO ", /* TABLE ID */ 0x00010001 /* OEM Revision */ ) { /* Start of ASL file */ /* #include "../../../arch/x86/acpi/debug.asl" */ /* Include global debug methods if needed */ /* Data to be patched by the BIOS during POST */ /* FIXME the patching is not done yet! */ /* Memory related values */ Name(LOMH, 0x0) /* Start of unused memory in C0000-E0000 range */ Name(PBAD, 0x0) /* Address of BIOS area (If TOM2 != 0, Addr >> 16) */ Name(PBLN, 0x0) /* Length of BIOS area */ Name(PCBA, 0xE0000000) /* Base address of PCIe config space */ Name(HPBA, 0xFED00000) /* Base address of HPET table */ Name(SSFG, 0x0D) /* S1 support: bit 0, S2 Support: bit 1, etc. S0 & S5 assumed */ /* Some global data */ Name(OSV, Ones) /* Assume nothing */ Name(GPIC, 0x1) /* Assume PIC */ /* * Processor Object * */ Scope (\_PR) { /* define processor scope */ Processor( CPU0, /* name space name */ 0, /* Unique number for this processor */ 0x810, /* PBLK system I/O address !hardcoded! */ 0x06 /* PBLKLEN for boot processor */ ) { #include "acpi/cpstate.asl" } Processor( CPU1, /* name space name */ 1, /* Unique number for this processor */ 0x0000, /* PBLK system I/O address !hardcoded! */ 0x00 /* PBLKLEN for boot processor */ ) { #include "acpi/cpstate.asl" } Processor( CPU2, /* name space name */ 2, /* Unique number for this processor */ 0x0000, /* PBLK system I/O address !hardcoded! */ 0x00 /* PBLKLEN for boot processor */ ) { #include "acpi/cpstate.asl" } Processor( CPU3, /* name space name */ 3, /* Unique number for this processor */ 0x0000, /* PBLK system I/O address !hardcoded! */ 0x00 /* PBLKLEN for boot processor */ ) { #include "acpi/cpstate.asl" } } /* End _PR scope */ /* PIC IRQ mapping registers, C00h-C01h. */ OperationRegion(PIRQ, SystemIO, 0x00000C00, 0x00000002) Field(PIRQ, ByteAcc, NoLock, Preserve) { PIDX, 0x00000008, PDAT, 0x00000008, /* Offset: 1h */ } IndexField(PIDX, PDAT, ByteAcc, NoLock, Preserve) { PIRA, 0x00000008, /* Index 0 */ PIRB, 0x00000008, /* Index 1 */ PIRC, 0x00000008, /* Index 2 */ PIRD, 0x00000008, /* Index 3 */ PIRE, 0x00000008, /* Index 4 */ PIRF, 0x00000008, /* Index 5 */ PIRG, 0x00000008, /* Index 6 */ PIRH, 0x00000008, /* Index 7 */ Offset(0x10), PIRS, 0x00000008, Offset(0x13), HDAD, 0x00000008, , 0x00000008, GEC, 0x00000008, Offset(0x30), USB1, 0x00000008, USB2, 0x00000008, USB3, 0x00000008, USB4, 0x00000008, USB5, 0x00000008, USB6, 0x00000008, USB7, 0x00000008, Offset(0x40), IDE, 0x00000008, SATA, 0x00000008, Offset(0x50), GPP0, 0x00000008, GPP1, 0x00000008, GPP2, 0x00000008, GPP3, 0x00000008 } /* PCI Error control register */ OperationRegion(PERC, SystemIO, 0x00000C14, 0x00000001) Field(PERC, ByteAcc, NoLock, Preserve) { SENS, 0x00000001, PENS, 0x00000001, SENE, 0x00000001, PENE, 0x00000001, } /* Client Management index/data registers */ OperationRegion(CMT, SystemIO, 0x00000C50, 0x00000002) Field(CMT, ByteAcc, NoLock, Preserve) { CMTI, 8, /* Client Management Data register */ G64E, 1, G64O, 1, G32O, 2, , 2, GPSL, 2, } /* GPM Port register */ OperationRegion(GPT, SystemIO, 0x00000C52, 0x00000001) Field(GPT, ByteAcc, NoLock, Preserve) { GPB0,1, GPB1,1, GPB2,1, GPB3,1, GPB4,1, GPB5,1, GPB6,1, GPB7,1, } /* Flash ROM program enable register */ OperationRegion(FRE, SystemIO, 0x00000C6F, 0x00000001) Field(FRE, ByteAcc, NoLock, Preserve) { , 0x00000006, FLRE, 0x00000001, } /* PM2 index/data registers */ OperationRegion(PM2R, SystemIO, 0x00000CD0, 0x00000002) Field(PM2R, ByteAcc, NoLock, Preserve) { PM2I, 0x00000008, PM2D, 0x00000008, } /* Power Management I/O registers, TODO:PMIO is quite different in SB900. */ OperationRegion(PMRG, SystemIO, 0x00000CD6, 0x00000002) Field(PMRG, ByteAcc, NoLock, Preserve) { PMRI, 0x00000008, PMRD, 0x00000008, } IndexField (PMRI, PMRD, ByteAcc, NoLock, Preserve) { Offset(0x24), MMSO,32, Offset(0x37), /* GPMLevelConfig0 */ , 3, PLC0, 1, PLC1, 1, PLC2, 1, PLC3, 1, PLC8, 1, Offset(0x38), /* GPMLevelConfig1 */ , 1, PLC4, 1, PLC5, 1, , 1, PLC6, 1, PLC7, 1, Offset(0x50), HPAD,32, Offset(0x60), P1EB,16, Offset(0x65), /* UsbPMControl */ , 4, URRE, 1, Offset(0x96), /* GPM98IN */ G8IS, 1, G9IS, 1, Offset(0x9A), /* EnhanceControl */ ,7, HPDE, 1, Offset(0xC8), ,2, SPRE,1, TPDE,1, Offset(0xF0), ,3, RSTU,1 } /* PM1 Event Block * First word is PM1_Status, Second word is PM1_Enable */ OperationRegion(P1E0, SystemIO, P1EB, 0x04) Field(P1E0, ByteAcc, NoLock, Preserve) { ,14, PEWS,1, WSTA,1, ,14, PEWD,1 } OperationRegion (GRAM, SystemMemory, 0x0400, 0x0100) Field (GRAM, ByteAcc, Lock, Preserve) { Offset (0x10), FLG0, 8 } Scope(\_SB) { /* PCIe Configuration Space for 16 busses */ OperationRegion(PCFG, SystemMemory, PCBA, 0x01000000) /* Each bus consumes 1MB */ Field(PCFG, ByteAcc, NoLock, Preserve) { /* Byte offsets are computed using the following technique: * ((bus number + 1) * ((device number * 8) * 4096)) + register offset * The 8 comes from 8 functions per device, and 4096 bytes per function config space */ Offset(0x00088024), /* Byte offset to SATA register 24h - Bus 0, Device 17, Function 0 */ STB5, 32, Offset(0x00098042), /* Byte offset to OHCI0 register 42h - Bus 0, Device 19, Function 0 */ PT0D, 1, PT1D, 1, PT2D, 1, PT3D, 1, PT4D, 1, PT5D, 1, PT6D, 1, PT7D, 1, PT8D, 1, PT9D, 1, Offset(0x000A0004), /* Byte offset to SMBUS register 4h - Bus 0, Device 20, Function 0 */ SBIE, 1, SBME, 1, Offset(0x000A0008), /* Byte offset to SMBUS register 8h - Bus 0, Device 20, Function 0 */ SBRI, 8, Offset(0x000A0014), /* Byte offset to SMBUS register 14h - Bus 0, Device 20, Function 0 */ SBB1, 32, Offset(0x000A0078), /* Byte offset to SMBUS register 78h - Bus 0, Device 20, Function 0 */ ,14, P92E, 1, /* Port92 decode enable */ } OperationRegion(SB5, SystemMemory, STB5, 0x1000) Field(SB5, AnyAcc, NoLock, Preserve){ /* Port 0 */ Offset(0x120), /* Port 0 Task file status */ P0ER, 1, , 2, P0DQ, 1, , 3, P0BY, 1, Offset(0x128), /* Port 0 Serial ATA status */ P0DD, 4, , 4, P0IS, 4, Offset(0x12C), /* Port 0 Serial ATA control */ P0DI, 4, Offset(0x130), /* Port 0 Serial ATA error */ , 16, P0PR, 1, /* Port 1 */ offset(0x1A0), /* Port 1 Task file status */ P1ER, 1, , 2, P1DQ, 1, , 3, P1BY, 1, Offset(0x1A8), /* Port 1 Serial ATA status */ P1DD, 4, , 4, P1IS, 4, Offset(0x1AC), /* Port 1 Serial ATA control */ P1DI, 4, Offset(0x1B0), /* Port 1 Serial ATA error */ , 16, P1PR, 1, /* Port 2 */ Offset(0x220), /* Port 2 Task file status */ P2ER, 1, , 2, P2DQ, 1, , 3, P2BY, 1, Offset(0x228), /* Port 2 Serial ATA status */ P2DD, 4, , 4, P2IS, 4, Offset(0x22C), /* Port 2 Serial ATA control */ P2DI, 4, Offset(0x230), /* Port 2 Serial ATA error */ , 16, P2PR, 1, /* Port 3 */ Offset(0x2A0), /* Port 3 Task file status */ P3ER, 1, , 2, P3DQ, 1, , 3, P3BY, 1, Offset(0x2A8), /* Port 3 Serial ATA status */ P3DD, 4, , 4, P3IS, 4, Offset(0x2AC), /* Port 3 Serial ATA control */ P3DI, 4, Offset(0x2B0), /* Port 3 Serial ATA error */ , 16, P3PR, 1, } } #include "acpi/routing.asl" Scope(\_SB) { /* Debug Port registers, 80h. */ OperationRegion(DBBG, SystemIO, 0x00000080, 0x00000001) Field(DBBG, ByteAcc, NoLock, Preserve) { DBG8, 0x00000008, } Method(_PIC, 1) { Store(Arg0, GPIC) If (GPIC) { Store(0xAA, \_SB.DBG8) \_SB.DSPI() } else { Store(0xAC, \_SB.DBG8) } } Method(DSPI, 0) { \_SB.GRUA(0x1F) \_SB.GRUB(0x1F) \_SB.GRUC(0x1F) \_SB.GRUD(0x1F) Store(0x1F, PIRE) Store(0x1F, PIRF) Store(0x1F, PIRG) Store(0x1F, PIRH) } Method(GRUA, 1) { Store(Arg0, PIRA) Store(Arg0, HDAD) Store(Arg0, GEC) Store(Arg0, GPP0) Store(Arg0, GPP0) } Method(GRUB, 1) { Store(Arg0, PIRB) Store(Arg0, USB2) Store(Arg0, USB4) Store(Arg0, USB6) Store(Arg0, GPP1) Store(Arg0, IDE) } Method(GRUC, 1) { Store(Arg0, PIRC) Store(Arg0, USB1) Store(Arg0, USB3) Store(Arg0, USB5) Store(Arg0, USB7) Store(Arg0, GPP2) } Method(GRUD, 1) { Store(Arg0, PIRD) Store(Arg0, SATA) Store(Arg0, GPP3) } Name(IRQB, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) { 15 }}) Name(IRQP, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) { 3, 4, 5, 7, 10, 11, 12, 14, 15 }}) Device(INTA) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 1) Method(_STA, 0) { if (PIRA) { Return(0x0B) } else { Return(0x09) } } Method(_DIS ,0) { \_SB.GRUA(0x1F) } Method(_PRS ,0) { Return(IRQP) } Method(_CRS ,0) { CreateWordField(IRQB, 1, IRQN) ShiftLeft(1, PIRA, IRQN) Return(IRQB) } Method(_SRS, 1) { CreateWordField(Arg0, 1, IRQM) FindSetRightBit(IRQM, Local0) Decrement(Local0) \_SB.GRUA(Local0) } } Device(INTB) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 2) Method(_STA, 0) { if (PIRB) { Return(0x0B) } else { Return(0x09) } } Method(_DIS ,0) { \_SB.GRUB(0x1F) } Method(_PRS ,0) { Return(IRQP) } Method(_CRS ,0) { CreateWordField(IRQB, 1, IRQN) ShiftLeft(1, PIRB, IRQN) Return(IRQB) } Method(_SRS, 1) { CreateWordField(Arg0, 1, IRQM) FindSetRightBit(IRQM, Local0) Decrement(Local0) \_SB.GRUB(Local0) } } Device(INTC) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 3) Method(_STA, 0) { if (PIRC) { Return(0x0B) } else { Return(0x09) } } Method(_DIS ,0) { \_SB.GRUC(0x1F) } Method(_PRS ,0) { Return(IRQP) } Method(_CRS ,0) { CreateWordField(IRQB, 1, IRQN) ShiftLeft(1, PIRC, IRQN) Return(IRQB) } Method(_SRS, 1) { CreateWordField(Arg0, 1, IRQM) FindSetRightBit(IRQM, Local0) Decrement(Local0) \_SB.GRUC(Local0) } } Device(INTD) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 4) Method(_STA, 0) { if (PIRD) { Return(0x0B) } else { Return(0x09) } } Method(_DIS ,0) { \_SB.GRUD(0x1F) } Method(_PRS ,0) { Return(IRQP) } Method(_CRS ,0) { CreateWordField(IRQB, 1, IRQN) ShiftLeft(1, PIRD, IRQN) Return(IRQB) } Method(_SRS, 1) { CreateWordField(Arg0, 1, IRQM) FindSetRightBit(IRQM, Local0) Decrement(Local0) \_SB.GRUD(Local0) } } Device(INTE) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 5) Method(_STA, 0) { if (PIRE) { Return(0x0B) } else { Return(0x09) } } Method(_DIS ,0) { Store(0x1F, PIRE) } Method(_PRS ,0) { Return(IRQP) } Method(_CRS ,0) { CreateWordField(IRQB, 1, IRQN) ShiftLeft(1, PIRE, IRQN) Return(IRQB) } Method(_SRS, 1) { CreateWordField(Arg0, 1, IRQM) FindSetRightBit(IRQM, Local0) Decrement(Local0) Store(Local0, PIRE) } } Device(INTF) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 6) Method(_STA, 0) { if (PIRF) { Return(0x0B) } else { Return(0x09) } } Method(_DIS ,0) { Store(0x1F, PIRF) } Method(_PRS ,0) { Return(IRQP) } Method(_CRS ,0) { CreateWordField(IRQB, 1, IRQN) ShiftLeft(1, PIRF, IRQN) Return(IRQB) } Method(_SRS, 1) { CreateWordField(Arg0, 1, IRQM) FindSetRightBit(IRQM, Local0) Decrement(Local0) Store(Local0, PIRF) } } Device(INTG) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 7) Method(_STA, 0) { if (PIRG) { Return(0x0B) } else { Return(0x09) } } Method(_DIS ,0) { Store(0x1F, PIRG) } Method(_PRS ,0) { Return(IRQP) } Method(_CRS ,0) { CreateWordField(IRQB, 1, IRQN) ShiftLeft(1, PIRG, IRQN) Return(IRQB) } Method(_SRS, 1) { CreateWordField(Arg0, 1, IRQM) FindSetRightBit(IRQM, Local0) Decrement(Local0) Store(Local0, PIRG) } } Device(INTH) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 8) Method(_STA, 0) { if (PIRH) { Return(0x0B) } else { Return(0x09) } } Method(_DIS ,0) { Store(0x1F, PIRH) } Method(_PRS ,0) { Return(IRQP) } Method(_CRS ,0) { CreateWordField(IRQB, 1, IRQN) ShiftLeft(1, PIRH, IRQN) Return(IRQB) } Method(_SRS, 1) { CreateWordField(Arg0, 1, IRQM) FindSetRightBit(IRQM, Local0) Decrement(Local0) Store(Local0, PIRH) } } } /* End Scope(_SB) */ /* Supported sleep states: */ Name(\_S0, Package () {0x00, 0x00, 0x00, 0x00} ) /* (S0) - working state */ If (LAnd(SSFG, 0x01)) { Name(\_S1, Package () {0x01, 0x01, 0x00, 0x00} ) /* (S1) - sleeping w/CPU context */ } If (LAnd(SSFG, 0x02)) { Name(\_S2, Package () {0x02, 0x02, 0x00, 0x00} ) /* (S2) - "light" Suspend to RAM */ } If (LAnd(SSFG, 0x04)) { Name(\_S3, Package () {0x03, 0x03, 0x00, 0x00} ) /* (S3) - Suspend to RAM */ } If (LAnd(SSFG, 0x08)) { Name(\_S4, Package () {0x04, 0x04, 0x00, 0x00} ) /* (S4) - Suspend to Disk */ } Name(\_S5, Package () {0x05, 0x05, 0x00, 0x00} ) /* (S5) - Soft Off */ Name(\_SB.CSPS ,0) /* Current Sleep State (S0, S1, S2, S3, S4, S5) */ Name(CSMS, 0) /* Current System State */ /* Wake status package */ Name(WKST,Package(){Zero, Zero}) /* * \_PTS - Prepare to Sleep method * * Entry: * Arg0=The value of the sleeping state S1=1, S2=2, etc * * Exit: * -none- * * The _PTS control method is executed at the beginning of the sleep process * for S1-S5. The sleeping value is passed to the _PTS control method. This * control method may be executed a relatively long time before entering the * sleep state and the OS may abort the operation without notification to * the ACPI driver. This method cannot modify the configuration or power * state of any device in the system. */ Method(\_PTS, 1) { /* DBGO("\\_PTS\n") */ /* DBGO("From S0 to S") */ /* DBGO(Arg0) */ /* DBGO("\n") */ /* Don't allow PCIRST# to reset USB */ if (LEqual(Arg0,3)){ Store(0,URRE) } /* Clear sleep SMI status flag and enable sleep SMI trap. */ /*Store(One, CSSM) Store(One, SSEN)*/ /* On older chips, clear PciExpWakeDisEn */ /*if (LLessEqual(\_SB.SBRI, 0x13)) { * Store(0,\_SB.PWDE) *} */ /* Clear wake status structure. */ Store(0, Index(WKST,0)) Store(0, Index(WKST,1)) } /* End Method(\_PTS) */ /* * The following method results in a "not a valid reserved NameSeg" * warning so I have commented it out for the duration. It isn't * used, so it could be removed. * * * \_GTS OEM Going To Sleep method * * Entry: * Arg0=The value of the sleeping state S1=1, S2=2 * * Exit: * -none- * * Method(\_GTS, 1) { * DBGO("\\_GTS\n") * DBGO("From S0 to S") * DBGO(Arg0) * DBGO("\n") * } */ /* * \_BFS OEM Back From Sleep method * * Entry: * Arg0=The value of the sleeping state S1=1, S2=2 * * Exit: * -none- */ Method(\_BFS, 1) { /* DBGO("\\_BFS\n") */ /* DBGO("From S") */ /* DBGO(Arg0) */ /* DBGO(" to S0\n") */ } /* * \_WAK System Wake method * * Entry: * Arg0=The value of the sleeping state S1=1, S2=2 * * Exit: * Return package of 2 DWords * Dword 1 - Status * 0x00000000 wake succeeded * 0x00000001 Wake was signaled but failed due to lack of power * 0x00000002 Wake was signaled but failed due to thermal condition * Dword 2 - Power Supply state * if non-zero the effective S-state the power supply entered */ Method(\_WAK, 1) { /* DBGO("\\_WAK\n") */ /* DBGO("From S") */ /* DBGO(Arg0) */ /* DBGO(" to S0\n") */ /* Re-enable HPET */ Store(1,HPDE) /* Restore PCIRST# so it resets USB */ if (LEqual(Arg0,3)){ Store(1,URRE) } /* Arbitrarily clear PciExpWakeStatus */ Store(PEWS, PEWS) /* if(DeRefOf(Index(WKST,0))) { * Store(0, Index(WKST,1)) * } else { * Store(Arg0, Index(WKST,1)) * } */ Return(WKST) } /* End Method(\_WAK) */ Scope(\_GPE) { /* Start Scope GPE */ } /* End Scope GPE */ /* South Bridge */ Scope(\_SB) { /* Start \_SB scope */ #include "../../../arch/x86/acpi/globutil.asl" /* global utility methods expected within the \_SB scope */ /* _SB.PCI0 */ /* Note: Only need HID on Primary Bus */ Device(PCI0) { External (TOM1) External (TOM2) Name(_HID, EISAID("PNP0A03")) Name(_ADR, 0x00180000) /* Dev# = BSP Dev#, Func# = 0 */ Method(_BBN, 0) { /* Bus number = 0 */ Return(0) } Method(_STA, 0) { /* DBGO("\\_SB\\PCI0\\_STA\n") */ Return(0x0B) /* Status is visible */ } Method(_PRT,0) { If(GPIC){ Return(APR0) } /* APIC mode */ Return (PR0) /* PIC Mode */ } /* end _PRT */ /* Describe the Northbridge devices */ Device(AMRT) { Name(_ADR, 0x00000000) } /* end AMRT */ /* The internal GFX bridge */ Device(AGPB) { Name(_ADR, 0x00010000) Method(_STA,0) { Return(0x0F) } } /* end AGPB */ /* The external GFX bridge */ Device(PBR2) { Name(_ADR, 0x00020000) Method(_PRT,0) { If(GPIC){ Return(APS2) } /* APIC mode */ Return (PS2) /* PIC Mode */ } /* end _PRT */ } /* end PBR2 */ /* The external GFX bridge */ Device(PBR3) { Name(_ADR, 0x00030000) Method(_PRT,0) { If(GPIC){ Return(APS3) } /* APIC mode */ Return (PS3) /* PIC Mode */ } /* end _PRT */ } /* end PBR3 */ Device(PBR4) { Name(_ADR, 0x00040000) Method(_PRT,0) { If(GPIC){ Return(APS4) } /* APIC mode */ Return (PS4) /* PIC Mode */ } /* end _PRT */ } /* end PBR4 */ Device(PBR5) { Name(_ADR, 0x00050000) Method(_PRT,0) { If(GPIC){ Return(APS5) } /* APIC mode */ Return (PS5) /* PIC Mode */ } /* end _PRT */ } /* end PBR5 */ Device(PBR6) { Name(_ADR, 0x00060000) Method(_PRT,0) { If(GPIC){ Return(APS6) } /* APIC mode */ Return (PS6) /* PIC Mode */ } /* end _PRT */ } /* end PBR6 */ /* The onboard EtherNet chip */ Device(PBR7) { Name(_ADR, 0x00070000) Method(_PRT,0) { If(GPIC){ Return(APS7) } /* APIC mode */ Return (PS7) /* PIC Mode */ } /* end _PRT */ } /* end PBR7 */ Device(PE20) { Name(_ADR, 0x00150000) Method(_PRT,0) { If(GPIC){ Return(APE0) } /* APIC mode */ Return (PE0) /* PIC Mode */ } /* end _PRT */ } /* end PE20 */ Device(PE21) { Name(_ADR, 0x00150001) Method(_PRT,0) { If(GPIC){ Return(APE1) } /* APIC mode */ Return (PE1) /* PIC Mode */ } /* end _PRT */ } /* end PE21 */ Device(PE22) { Name(_ADR, 0x00150002) Method(_PRT,0) { If(GPIC){ Return(APE2) } /* APIC mode */ Return (APE2) /* PIC Mode */ } /* end _PRT */ } /* end PE22 */ Device(PE23) { Name(_ADR, 0x00150003) Method(_PRT,0) { If(GPIC){ Return(APE3) } /* APIC mode */ Return (PE3) /* PIC Mode */ } /* end _PRT */ } /* end PE23 */ /* Describe the Southbridge devices */ Device(AZHD) { Name(_ADR, 0x00140002) OperationRegion(AZPD, PCI_Config, 0x00, 0x100) Field(AZPD, AnyAcc, NoLock, Preserve) { offset (0x42), NSDI, 1, NSDO, 1, NSEN, 1, } } /* end AZHD */ Device(GEC) { Name(_ADR, 0x00140006) } /* end GEC */ Device(UOH1) { Name(_ADR, 0x00120000) #include "acpi/usb.asl" } /* end UOH1 */ Device(UOH3) { Name(_ADR, 0x00130000) #include "acpi/usb.asl" } /* end UOH3 */ Device(UOH5) { Name(_ADR, 0x00160000) #include "acpi/usb.asl" } /* end UOH5 */ Device(UEH1) { Name(_ADR, 0x00140005) #include "acpi/usb.asl" } /* end UEH1 */ Device(UOH2) { Name(_ADR, 0x00120002) #include "acpi/usb.asl" } /* end UOH2 */ Device(UOH4) { Name(_ADR, 0x00130002) #include "acpi/usb.asl" } /* end UOH4 */ Device(UOH6) { Name(_ADR, 0x00160002) #include "acpi/usb.asl" } /* end UOH5 */ Device(XHC0) { Name(_ADR, 0x00100000) #include "acpi/usb.asl" } /* end XHC0 */ Device(XHC1) { Name(_ADR, 0x00100001) #include "acpi/usb.asl" } /* end XHC1 */ Device(SBUS) { Name(_ADR, 0x00140000) } /* end SBUS */ Device(LIBR) { Name(_ADR, 0x00140003) /* Real Time Clock Device */ Device(RTC0) { Name(_HID, EISAID("PNP0B00")) /* AT Real Time Clock (not PIIX4 compatible) */ Name(_CRS, ResourceTemplate() { IRQNoFlags(){8} IO(Decode16,0x0070, 0x0070, 0, 2) /* IO(Decode16,0x0070, 0x0070, 0, 4) */ }) } /* End Device(_SB.PCI0.LpcIsaBr.RTC0) */ Device(TMR) { /* Timer */ Name(_HID,EISAID("PNP0100")) /* System Timer */ Name(_CRS, ResourceTemplate() { IRQNoFlags(){0} IO(Decode16, 0x0040, 0x0040, 0, 4) /* IO(Decode16, 0x0048, 0x0048, 0, 4) */ }) } /* End Device(_SB.PCI0.LpcIsaBr.TMR) */ Device(SPKR) { /* Speaker */ Name(_HID,EISAID("PNP0800")) /* AT style speaker */ Name(_CRS, ResourceTemplate() { IO(Decode16, 0x0061, 0x0061, 0, 1) }) } /* End Device(_SB.PCI0.LpcIsaBr.SPKR) */ Device(PIC) { Name(_HID,EISAID("PNP0000")) /* AT Interrupt Controller */ Name(_CRS, ResourceTemplate() { IRQNoFlags(){2} IO(Decode16,0x0020, 0x0020, 0, 2) IO(Decode16,0x00A0, 0x00A0, 0, 2) /* IO(Decode16, 0x00D0, 0x00D0, 0x10, 0x02) */ /* IO(Decode16, 0x04D0, 0x04D0, 0x10, 0x02) */ }) } /* End Device(_SB.PCI0.LpcIsaBr.PIC) */ Device(MAD) { /* 8257 DMA */ Name(_HID,EISAID("PNP0200")) /* Hardware Device ID */ Name(_CRS, ResourceTemplate() { DMA(Compatibility,BusMaster,Transfer8){4} IO(Decode16, 0x0000, 0x0000, 0x10, 0x10) IO(Decode16, 0x0081, 0x0081, 0x01, 0x03) IO(Decode16, 0x0087, 0x0087, 0x01, 0x01) IO(Decode16, 0x0089, 0x0089, 0x01, 0x03) IO(Decode16, 0x008F, 0x008F, 0x01, 0x01) IO(Decode16, 0x00C0, 0x00C0, 0x10, 0x20) }) /* End Name(_SB.PCI0.LpcIsaBr.MAD._CRS) */ } /* End Device(_SB.PCI0.LpcIsaBr.MAD) */ Device(COPR) { Name(_HID,EISAID("PNP0C04")) /* Math Coprocessor */ Name(_CRS, ResourceTemplate() { IO(Decode16, 0x00F0, 0x00F0, 0, 0x10) IRQNoFlags(){13} }) } /* End Device(_SB.PCI0.LpcIsaBr.COPR) */ #if 0 Device(HPTM) { Name(_HID,EISAID("PNP0103")) Name(CRS,ResourceTemplate() { Memory32Fixed(ReadOnly,0xFED00000, 0x00000400, HPT) /* 1kb reserved space */ }) Method(_STA, 0) { Return(0x0F) /* sata is visible */ } Method(_CRS, 0) { CreateDwordField(CRS, ^HPT._BAS, HPBA) Store(HPBA, HPBA) Return(CRS) } } /* End Device(_SB.PCI0.LpcIsaBr.COPR) */ #endif Device (PS2M) { Name (_HID, EisaId ("PNP0F13")) Name (_CRS, ResourceTemplate () { IRQNoFlags () {12} }) Method (_STA, 0, NotSerialized) { And (FLG0, 0x04, Local0) If (LEqual (Local0, 0x04)) { Return (0x0F) } Else { Return (0x00) } } } Device (PS2K) { Name (_HID, EisaId ("PNP0303")) Name (_CRS, ResourceTemplate () { IO (Decode16, 0x0060, 0x0060, 0x01, 0x01) IO (Decode16, 0x0064, 0x0064, 0x01, 0x01) IRQNoFlags () {1} }) } } /* end LIBR */ Device(STCR) { Name(_ADR, 0x00110000) #include "acpi/sata.asl" } /* end STCR */ /* Primary (and only) IDE channel */ Device(IDEC) { Name(_ADR, 0x00140001) #include "acpi/ide.asl" } /* end IDEC */ Name(CRES, ResourceTemplate() { IO(Decode16, 0x0CF8, 0x0CF8, 1, 8) WORDIO(ResourceProducer, MinFixed, MaxFixed, PosDecode, EntireRange, 0x0000, /* address granularity */ 0x0000, /* range minimum */ 0x0CF7, /* range maximum */ 0x0000, /* translation */ 0x0CF8 /* length */ ) WORDIO(ResourceProducer, MinFixed, MaxFixed, PosDecode, EntireRange, 0x0000, /* address granularity */ 0x0D00, /* range minimum */ 0xFFFF, /* range maximum */ 0x0000, /* translation */ 0xF300 /* length */ ) /* memory space for PCI BARs below 4GB */ Memory32Fixed(ReadOnly, 0x00000000, 0x00000000, MMIO) }) /* End Name(_SB.PCI0.CRES) */ Method(_CRS, 0) { /* DBGO("\\_SB\\PCI0\\_CRS\n") */ CreateDWordField(CRES, ^MMIO._BAS, MM1B) CreateDWordField(CRES, ^MMIO._LEN, MM1L) /* * Declare memory between TOM1 and 4GB as available * for PCI MMIO. * Use ShiftLeft to avoid 64bit constant (for XP). * This will work even if the OS does 32bit arithmetic, as * 32bit (0x00000000 - TOM1) will wrap and give the same * result as 64bit (0x100000000 - TOM1). */ Store(TOM1, MM1B) ShiftLeft(0x10000000, 4, Local0) Subtract(Local0, TOM1, Local0) Store(Local0, MM1L) Return(CRES) /* note to change the Name buffer */ } /* end of Method(_SB.PCI0._CRS) */ } /* End Device(PCI0) */ Device(PWRB) { /* Start Power button device */ Name(_HID, EISAID("PNP0C0C")) Name(_UID, 0xAA) Name(_STA, 0x0B) /* sata is invisible */ } } /* End \_SB scope */ } /* End of ASL file */