/* * This file is part of the coreboot project. * * Copyright (C) 2008 Advanced Micro Devices, Inc. * Copyright (C) 2010 Siemens AG, Inc. * (Written by Josef Kellermann for Siemens AG, 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 ("DSDT.aml", "DSDT", 2, "SIEMENS", "SITEMP ", 0x20101005) { /* Data to be patched by the BIOS during POST */ /* Memory related values */ Name(LOMH, 0x0) /* Start of unused memory in C0000-E0000 range */ Name(HPBA, 0xFED00000) /* Base address of HPET table */ /* USB overcurrent mapping pins. */ Name(UOM0, 0) Name(UOM1, 2) Name(UOM2, 0) Name(UOM3, 7) Name(UOM4, 2) Name(UOM5, 2) Name(UOM6, 6) Name(UOM7, 2) Name(UOM8, 6) Name(UOM9, 6) Name(DSEN, 1) // Display Output Switching Enable // Power notification /* PIC IRQ mapping registers, C00h-C01h */ OperationRegion(PRQM, SystemIO, 0x00000C00, 0x00000002) Field(PRQM, ByteAcc, NoLock, Preserve) { PRQI, 0x00000008, PRQD, 0x00000008, /* Offset: 1h */ } IndexField(PRQI, PRQD, ByteAcc, NoLock, Preserve) { PINA, 0x00000008, /* Index 0 */ PINB, 0x00000008, /* Index 1 */ PINC, 0x00000008, /* Index 2 */ PIND, 0x00000008, /* Index 3 */ SINT, 0x00000008, /* Index 4 */ Offset(0x09), PINE, 0x00000008, /* Index 9 */ PINF, 0x00000008, /* Index A */ PING, 0x00000008, /* Index B */ PINH, 0x00000008, /* Index C */ } /* 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 */ OperationRegion(PIOR, SystemIO, 0x00000CD6, 0x00000002) Field(PIOR, ByteAcc, NoLock, Preserve) { PIOI, 0x00000008, PIOD, 0x00000008, } IndexField (PIOI, PIOD, ByteAcc, NoLock, Preserve) { Offset(0x00), /* MiscControl */ , 1, T1EE, 1, T2EE, 1, Offset(0x01), /* MiscStatus */ , 1, T1E, 1, T2E, 1, Offset(0x04), /* SmiWakeUpEventEnable3 */ , 7, SSEN, 1, Offset(0x07), /* SmiWakeUpEventStatus3 */ , 7, CSSM, 1, Offset(0x10), /* AcpiEnable */ , 6, PWDE, 1, Offset(0x1C), /* ProgramIoEnable */ , 3, MKME, 1, IO3E, 1, IO2E, 1, IO1E, 1, IO0E, 1, Offset(0x1D), /* IOMonitorStatus */ , 3, MKMS, 1, IO3S, 1, IO2S, 1, IO1S, 1, IO0S,1, Offset(0x20), /* AcpiPmEvtBlk */ APEB, 16, Offset(0x36), /* GEvtLevelConfig */ , 6, ELC6, 1, ELC7, 1, 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(0x3B), /* PMEStatus1 */ GP0S, 1, GM4S, 1, GM5S, 1, APS, 1, GM6S, 1, GM7S, 1, GP2S, 1, STSS, 1, Offset(0x55), /* SoftPciRst */ SPRE, 1, , 1, , 1, PNAT, 1, PWMK, 1, PWNS, 1, /* Offset(0x61), */ /* Options_1 */ /* ,7, */ /* R617,1, */ Offset(0x65), /* UsbPMControl */ , 4, URRE, 1, Offset(0x68), /* MiscEnable68 */ , 3, TMTE, 1, , 1, Offset(0x92), /* GEVENTIN */ , 7, E7IS, 1, Offset(0x96), /* GPM98IN */ G8IS, 1, G9IS, 1, Offset(0x9A), /* EnhanceControl */ ,7, HPDE, 1, Offset(0xA8), /* PIO7654Enable */ IO4E, 1, IO5E, 1, IO6E, 1, IO7E, 1, Offset(0xA9), /* PIO7654Status */ IO4S, 1, IO5S, 1, IO6S, 1, IO7S, 1, } /* PM1 Event Block * First word is PM1_Status, Second word is PM1_Enable */ OperationRegion(P1EB, SystemIO, APEB, 0x04) Field(P1EB, ByteAcc, NoLock, Preserve) { TMST, 1, , 3, BMST, 1, GBST, 1, Offset(0x01), PBST, 1, , 1, RTST, 1, , 3, PWST, 1, SPWS, 1, Offset(0x02), TMEN, 1, , 4, GBEN, 1, Offset(0x03), PBEN, 1, , 1, RTEN, 1, , 3, PWDA, 1, } OperationRegion (GVAR, SystemMemory, 0xBADEAFFE, 0x100) Field (GVAR, ByteAcc, NoLock, Preserve) { Offset (0x00), OSYS, 16, LINX, 16, PCBA, 32, MPEN, 8 } Name (IOLM,0xe0000000) #include "acpi/platform.asl" Scope(\_SB) { /* PCIe Configuration Space for 16 busses */ OperationRegion(PCFG, SystemMemory, PCBA, 0x2000000) /* PCIe reserved space for 31 busses */ Field(PCFG, ByteAcc, NoLock, Preserve) { Offset(0x00090024), /* Byte offset to SATA BAR5 register 24h - Bus 0, Device 18, 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(BAR5, SystemMemory, STB5, 0x1000) Field(BAR5, 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/event.asl" #include "acpi/routing.asl" #include "acpi/usb.asl" /* South Bridge */ Scope(\_SB) { /* Start \_SB scope */ #include "acpi/globutil.asl" Device(PWRB) { /* Start Power button device */ Name(_HID, EISAID("PNP0C0C")) Name(_UID, 0xAA) Name(_PRW, Package () {3, 0x04}) /* wake from S1-S4 */ Name(_STA, 0x0B) /* sata is invisible */ } /* _SB.PCI0 */ /* Note: Only need HID on Primary Bus */ Device(PCI0) { External (MMIO) 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 */ } Device (MEMR) { Name (_HID, EisaId ("PNP0C02")) Name (MEM1, ResourceTemplate () { Memory32Fixed (ReadWrite, 0x00000000, // Address Base 0x00000000, // Address Length _Y1A) Memory32Fixed (ReadWrite, 0x00000000, // Address Base 0x00000000, // Address Length _Y1B) }) Method (_CRS, 0, NotSerialized) { CreateDWordField (MEM1, \_SB.PCI0.MEMR._Y1A._BAS, MB01) CreateDWordField (MEM1, \_SB.PCI0.MEMR._Y1A._LEN, ML01) CreateDWordField (MEM1, \_SB.PCI0.MEMR._Y1B._BAS, MB02) CreateDWordField (MEM1, \_SB.PCI0.MEMR._Y1B._LEN, ML02) If (PCIF) { Store (0xFEC00000, MB01) Store (0xFEE00000, MB02) Store (0x1000, ML01) Store (0x1000, ML02) } Return (MEM1) } } Method(_PRT,0) { If(PCIF){ Return(APR0) } /* APIC mode */ Return (PR0) /* PIC Mode */ } /* end _PRT */ OperationRegion (BAR1, PCI_Config, 0x14, 0x04) Field (BAR1, ByteAcc, NoLock, Preserve) { Z009, 32 } /* Describe the Northbridge devices */ Device(AMRT) { Name(_ADR, 0x00000000) } /* end AMRT */ /* The internal GFX bridge */ Device(AGPB) { Name(_ADR, 0x00010000) Name(_PRW, Package() {0x18, 4}) Method(_PRT,0) { Return (APR1) } Device (VGA) { Name (_ADR, 0x00050000) Method (_DOS, 1) { /* Windows 2000 and Windows XP call _DOS to enable/disable * Display Output Switching during init and while a switch * is already active */ Store (And(Arg0, 7), DSEN) } Method (_STA, 0, NotSerialized) { Return (0x0F) } } } /* end AGPB */ /* The external GFX bridge */ Device(PBR2) { Name(_ADR, 0x00020000) Name(_PRW, Package() {0x18, 4}) Method(_PRT,0) { If(PCIF){ Return(APS2) } /* APIC mode */ Return (PS2) /* PIC Mode */ } /* end _PRT */ } /* end PBR2 */ /* Dev3 is also an external GFX bridge */ Device(PBR4) { Name(_ADR, 0x00040000) Name(_PRW, Package() {0x18, 4}) Method(_PRT,0) { If(PCIF){ Return(APS4) } /* APIC mode */ Return (PS4) /* PIC Mode */ } /* end _PRT */ } /* end PBR4 */ Device(PBR5) { Name(_ADR, 0x00050000) Name(_PRW, Package() {0x18, 4}) Method(_PRT,0) { If(PCIF){ Return(APS5) } /* APIC mode */ Return (PS5) /* PIC Mode */ } /* end _PRT */ } /* end PBR5 */ Device(PBR6) { Name(_ADR, 0x00060000) Name(_PRW, Package() {0x18, 4}) Method(_PRT,0) { If(PCIF){ Return(APS6) } /* APIC mode */ Return (PS6) /* PIC Mode */ } /* end _PRT */ } /* end PBR6 */ /* The onboard EtherNet chip */ Device(PBR7) { Name(_ADR, 0x00070000) Name(_PRW, Package() {0x18, 4}) Method(_PRT,0) { If(PCIF){ Return(APS7) } /* APIC mode */ Return (PS7) /* PIC Mode */ } /* end _PRT */ } /* end PBR7 */ /* PCI slot 1 */ Device(PIBR) { Name(_ADR, 0x00140004) Name(_PRW, Package() {4, 5}) // Phoenix doeas it so Method(_PRT, 0) { If(PCIF){ Return(AP2P) } /* APIC Mode */ Return (PCIB) /* PIC Mode */ } } /* Describe the Southbridge devices */ Device(SATA) { Name(_ADR, 0x00120000) #include "acpi/sata.asl" } /* end SATA */ Device(UOH1) { Name(_ADR, 0x00130000) Name(_PRW, Package() {0x0B, 3}) } /* end UOH1 */ Device(UOH2) { Name(_ADR, 0x00130001) Name(_PRW, Package() {0x0B, 3}) } /* end UOH2 */ Device(UOH3) { Name(_ADR, 0x00130002) Name(_PRW, Package() {0x0B, 3}) } /* end UOH3 */ Device(UOH4) { Name(_ADR, 0x00130003) Name(_PRW, Package() {0x0B, 3}) } /* end UOH4 */ Device(UOH5) { Name(_ADR, 0x00130004) Name(_PRW, Package() {0x0B, 3}) } /* end UOH5 */ Device(UEH1) { Name(_ADR, 0x00130005) Name(_PRW, Package() {0x0B, 3}) } /* end UEH1 */ Device(SBUS) { Name(_ADR, 0x00140000) } /* end SBUS */ /* Primary (and only) IDE channel */ Device(IDEC) { Name(_ADR, 0x00140001) #include "acpi/ide.asl" } /* end IDEC */ Device(AZHD) { Name(_ADR, 0x00140002) OperationRegion(AZPD, PCI_Config, 0x00, 0x100) Field(AZPD, AnyAcc, NoLock, Preserve) { offset (0x42), NSDI, 1, NSDO, 1, NSEN, 1, offset (0x44), IPCR, 4, offset (0x54), PWST, 2, , 6, PMEB, 1, , 6, PMST, 1, offset (0x62), MMCR, 1, offset (0x64), MMLA, 32, offset (0x68), MMHA, 32, offset (0x6C), MMDT, 16, } Method(_INI) { If(LEqual(LINX,1)){ /* If we are running Linux */ Store(zero, NSEN) Store(one, NSDO) Store(one, NSDI) } } } /* end AZHD */ Device(LPC0) { Name (_ADR, 0x00140003) Mutex (PSMX, 0x00) /* PIC IRQ mapping registers, C00h-C01h */ OperationRegion(PRQM, SystemIO, 0x00000C00, 0x00000002) Field(PRQM, ByteAcc, NoLock, Preserve) { PRQI, 0x00000008, PRQD, 0x00000008, /* Offset: 1h */ } IndexField(PRQI, PRQD, ByteAcc, NoLock, Preserve) { PINA, 0x00000008, /* Index 0 */ PINB, 0x00000008, /* Index 1 */ PINC, 0x00000008, /* Index 2 */ PIND, 0x00000008, /* Index 3 */ SINT, 0x00000008, /* Index 4 */ Offset(0x09), PINE, 0x00000008, /* Index 9 */ PINF, 0x00000008, /* Index A */ PING, 0x00000008, /* Index B */ PINH, 0x00000008, /* Index C */ } Method(CIRQ, 0x00, NotSerialized) { Store(0, PINA) Store(0, PINB) Store(0, PINC) Store(0, PIND) Store(0, SINT) Store(0, PINE) Store(0, PINF) Store(0, PING) Store(0, PINH) } Name(IRQB, ResourceTemplate(){ IRQ(Level,ActiveLow,Shared){10,11} }) Name(IRQP, ResourceTemplate(){ IRQ(Level,ActiveLow,Exclusive){3, 4, 5, 7} }) Name(PITF, ResourceTemplate(){ IRQ(Level,ActiveLow,Exclusive){9} }) Device(INTA) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 1) Method(_STA, 0) { if (PINA) { Return(0x0B) /* sata is invisible */ } else { Return(0x09) /* sata is disabled */ } } /* End Method(_SB.INTA._STA) */ Method(_DIS ,0) { Store(0, PINA) } /* End Method(_SB.INTA._DIS) */ Method(_PRS ,0) { Return(IRQB) // Return(IRQP) } /* Method(_SB.INTA._PRS) */ Method(_CRS ,0) { Store (IRQB, Local0) // CreateWordField(Local0, 0x1, IRQ0) ShiftLeft(1, PINA, IRQ0) Return(Local0) } /* Method(_SB.INTA._CRS) */ Method(_SRS, 1) { CreateWordField(ARG0, 1, IRQ0) /* Use lowest available IRQ */ FindSetRightBit(IRQ0, Local0) Decrement (Local0) Store(Local0, PINA) } /* End Method(_SB.INTA._SRS) */ } /* End Device(INTA) */ Device(INTB) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 2) Method(_STA, 0) { if (PINB) { Return(0x0B) /* sata is invisible */ } else { Return(0x09) /* sata is disabled */ } } /* End Method(_SB.INTB._STA) */ Method(_DIS ,0) { Store(0, PINB) } /* End Method(_SB.INTB._DIS) */ Method(_PRS ,0) { Return(IRQB) // Return(IRQP) } /* Method(_SB.INTB._PRS) */ Method(_CRS ,0) { Store (IRQB, Local0) // {10,11} CreateWordField(Local0, 0x1, IRQ0) ShiftLeft(1, PINB, IRQ0) Return(Local0) } /* Method(_SB.INTB._CRS) */ Method(_SRS, 1) { CreateWordField(ARG0, 1, IRQ0) /* Use lowest available IRQ */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PINB) } /* End Method(_SB.INTB._SRS) */ } /* End Device(INTB) */ Device(INTC) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 3) Method(_STA, 0) { if (PINC) { Return(0x0B) /* sata is invisible */ } else { Return(0x09) /* sata is disabled */ } } /* End Method(_SB.INTC._STA) */ Method(_DIS ,0) { Store(0, PINC) } /* End Method(_SB.INTC._DIS) */ Method(_PRS ,0) { Return(IRQB) // Return(IRQP) } /* Method(_SB.INTC._PRS) */ Method(_CRS ,0) { Store (IRQB, Local0) // {10,11} CreateWordField(Local0, 0x1, IRQ0) ShiftLeft(1, PINC, IRQ0) Return(Local0) } /* Method(_SB.INTC._CRS) */ Method(_SRS, 1) { CreateWordField(ARG0, 1, IRQ0) /* Use lowest available IRQ */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PINC) } /* End Method(_SB.INTC._SRS) */ } /* End Device(INTC) */ Device(INTD) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 4) Method(_STA, 0) { if (PIND) { Return(0x0B) /* sata is invisible */ } else { Return(0x09) /* sata is disabled */ } } /* End Method(_SB.INTD._STA) */ Method(_DIS ,0) { Store(0, PIND) } /* End Method(_SB.INTD._DIS) */ Method(_PRS ,0) { Return(IRQB) // Return(IRQP) } /* Method(_SB.INTD._PRS) */ Method(_CRS ,0) { Store (IRQB, Local0) // {10,11} CreateWordField(Local0, 0x1, IRQ0) ShiftLeft(1, PIND, IRQ0) Return(Local0) } /* Method(_SB.INTD._CRS) */ Method(_SRS, 1) { CreateWordField(ARG0, 1, IRQ0) /* Use lowest available IRQ */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PIND) } /* End Method(_SB.INTD._SRS) */ } /* End Device(INTD) */ Device(INTE) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 5) Method(_STA, 0) { if (PINE) { Return(0x0B) /* sata is invisible */ } else { Return(0x09) /* sata is disabled */ } } /* End Method(_SB.INTE._STA) */ Method(_DIS ,0) { Store(0, PINE) } /* End Method(_SB.INTE._DIS) */ Method(_PRS ,0) { Return(IRQB) // Return(IRQP) } Method(_CRS ,0) { Store (IRQB, Local0) // {10,11} CreateWordField(Local0, 0x1, IRQ0) ShiftLeft(1, PINE, IRQ0) Return(Local0) } /* Method(_SB.INTE._CRS) */ Method(_SRS, 1) { CreateWordField(ARG0, 1, IRQ0) /* Use lowest available IRQ */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PINE) } /* End Method(_SB.INTE._SRS) */ } /* End Device(INTE) */ Device(INTF) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 6) Method(_STA, 0) { if (PINF) { Return(0x0B) /* sata is invisible */ } else { Return(0x09) /* sata is disabled */ } } /* End Method(_SB.INTF._STA) */ Method(_DIS ,0) { Store(0, PINF) } /* End Method(_SB.INTF._DIS) */ Method(_PRS ,0) { Return(IRQB) // Return(PITF) } /* Method(_SB.INTF._PRS) */ Method(_CRS ,0) { Store (IRQB, Local0) // {10,11} CreateWordField(Local0, 0x1, IRQ0) ShiftLeft(1, PINF, IRQ0) Return(Local0) } /* Method(_SB.INTF._CRS) */ Method(_SRS, 1) { CreateWordField(ARG0, 1, IRQ0) /* Use lowest available IRQ */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PINF) } /* End Method(_SB.INTF._SRS) */ } /* End Device(INTF) */ Device(INTG) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 7) Method(_STA, 0) { if (PING) { Return(0x0B) /* sata is invisible */ } else { Return(0x09) /* sata is disabled */ } } /* End Method(_SB.INTG._STA) */ Method(_DIS ,0) { Store(0, PING) } /* End Method(_SB.INTG._DIS) */ Method(_PRS ,0) { Return(IRQB) // Return(IRQP) } /* Method(_SB.INTG._CRS) */ Method(_CRS ,0) { Store (IRQB, Local0) // {10,11} CreateWordField(Local0, 0x1, IRQ0) ShiftLeft(1, PING, IRQ0) Return(Local0) } /* Method(_SB.INTG._CRS) */ Method(_SRS, 1) { CreateWordField(ARG0, 1, IRQ0) /* Use lowest available IRQ */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PING) } /* End Method(_SB.INTG._SRS) */ } /* End Device(INTG) */ Device(INTH) { Name(_HID, EISAID("PNP0C0F")) Name(_UID, 8) Method(_STA, 0) { if (PINH) { Return(0x0B) /* sata is invisible */ } else { Return(0x09) /* sata is disabled */ } } /* End Method(_SB.INTH._STA) */ Method(_DIS ,0) { Store(0, PINH) } /* End Method(_SB.INTH._DIS) */ Method(_PRS ,0) { Return(IRQB) // Return(IRQP) } /* Method(_SB.INTH._CRS) */ Method(_CRS ,0) { Store (IRQB, Local0) // {10,11} CreateWordField(Local0, 0x1, IRQ0) ShiftLeft(1, PINH, IRQ0) Return(Local0) } /* Method(_SB.INTH._CRS) */ Method(_SRS, 1) { CreateWordField(ARG0, 1, IRQ0) /* Use lowest available IRQ */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PINH) } /* End Method(_SB.INTH._SRS) */ } /* End Device(INTH) */ /* Real Time Clock Device */ Device(RTC0) { Name(_HID, EISAID("PNP0B00")) /* AT Real Time Clock (not PIIX4 compatible)*/ Name(_CRS, ResourceTemplate() { IRQ (Edge, ActiveHigh, Exclusive, ) {8} IO(Decode16,0x0070, 0x0070, 1, 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() { IRQ (Edge, ActiveHigh, Exclusive, ) {0} IO(Decode16, 0x0040, 0x0040, 1, 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, 1, 1) }) } /* End Device(_SB.PCI0.LpcIsaBr.SPKR) */ Device(PIC) { Name(_HID,EISAID("PNP0000")) /* AT Interrupt Controller */ Name(_CRS, ResourceTemplate() { IRQ (Edge, ActiveHigh, Exclusive, ) {2} IO(Decode16,0x0020, 0x0020, 1, 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,NotBusMaster,Transfer8_16){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, 1, 0x10) IRQ (Edge, ActiveHigh, Exclusive, ) {13} }) } /* End Device(_SB.PCI0.LpcIsaBr.COPR) */ Device(HPET) { 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) } } Device (KBC0) { Name (_HID, EisaId ("PNP0303")) Name (_CRS, ResourceTemplate () { IO (Decode16, 0x0060, // Range Minimum 0x0060, // Range Maximum 0x01, // Alignment 0x01, // Length ) IO (Decode16, 0x0064, // Range Minimum 0x0064, // Range Maximum 0x01, // Alignment 0x01, // Length ) IRQ (Edge, ActiveHigh, Exclusive, ) {1} }) } Device (MSE0) { Name (_HID, EisaId ("PNP0F13")) Name (_CRS, ResourceTemplate () { IRQ (Edge, ActiveHigh, Exclusive, ) {12} }) } } /* end LPC0 */ Device(ACAD) { Name(_ADR, 0x00140005) Name (_PRW, Package (0x02) { 0x0C, 0x04 }) } /* end Ac97audio */ Device(ACMD) { Name(_ADR, 0x00140006) Name (_PRW, Package (0x02) { 0x0C, 0x04 }) } /* end Ac97modem */ /* ITE IT8712F Support */ OperationRegion (IOID, SystemIO, 0x2E, 0x02) /* sometimes it is 0x4E */ Field (IOID, ByteAcc, NoLock, Preserve) { SIOI, 8, SIOD, 8 /* 0x2E and 0x2F */ } IndexField (SIOI, SIOD, ByteAcc, NoLock, Preserve) { Offset (0x07), LDN, 8, /* Logical Device Number */ Offset (0x20), CID1, 8, /* Chip ID Byte 1, 0x87 */ CID2, 8, /* Chip ID Byte 2, 0x12 */ Offset (0x30), ACTR, 8, /* Function activate */ Offset (0xF0), APC0, 8, /* APC/PME Event Enable Register */ APC1, 8, /* APC/PME Status Register */ APC2, 8, /* APC/PME Control Register 1 */ APC3, 8, /* Environment Controller Special Configuration Register */ APC4, 8 /* APC/PME Control Register 2 */ } /* Enter the IT8712F MB PnP Mode */ Method (EPNP) { Store(0x87, SIOI) Store(0x01, SIOI) Store(0x55, SIOI) Store(0x55, SIOI) /* IT8712F magic number */ } /* Exit the IT8712F MB PnP Mode */ Method (XPNP) { Store (0x02, SIOI) Store (0x02, SIOD) } /* * Keyboard PME is routed to SB600 Gevent3. We can wake * up the system by pressing the key. */ Method (SIOS, 1) { /* We only enable KBD PME for S5. */ If (LLess (Arg0, 0x05)) { EPNP() /* DBGO("IT8712F\n") */ Store (0x4, LDN) Store (One, ACTR) /* Enable EC */ /* Store (0x4, LDN) Store (0x04, APC4) */ /* falling edge. which mode? Not sure. */ Store (0x4, LDN) Store (0x08, APC1) /* clear PME status, Use 0x18 for mouse & KBD */ Store (0x4, LDN) Store (0x08, APC0) /* enable PME, Use 0x18 for mouse & KBD */ XPNP() } } Method (SIOW, 1) { EPNP() Store (0x4, LDN) Store (Zero, APC0) /* disable keyboard PME */ Store (0x4, LDN) Store (0xFF, APC1) /* clear keyboard PME status */ XPNP() } /* ############################################################################################### */ 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 */ ) Memory32Fixed(READONLY, 0x000A0000, 0x00020000, VGAM) /* VGA memory space */ Memory32Fixed(READONLY, 0x000C0000, 0x00020000, EMM1) /* Assume C0000-E0000 empty */ Memory32Fixed(READONLY, 0x000E0000, 0x00020000, RDBS) /* BIOS ROM area */ /* DRAM Memory from 1MB to TopMem */ DWORDMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0, 0, 0, 0x00, 1, ,, EMM2) WORDIO (ResourceProducer, MinFixed, MaxFixed, PosDecode, EntireRange, 0x00, 0x0D00, 0xffff, 0x00, 0xf300) }) /* End Name(_SB.PCI0.CRES) */ Method(_CRS, 0) { /* DBGO("\\_SB\\PCI0\\_CRS\n") */ CreateDWordField(CRES, ^EMM1._BAS, EM1B) CreateDWordField(CRES, ^EMM1._LEN, EM1L) CreateDWordField(CRES, ^EMM2._MIN, EM2B) CreateDWordField(CRES, ^EMM2._MAX, EM2E) CreateDWordField(CRES, ^EMM2._LEN, EM2L) Store(TOM1, EM2B) Subtract(IOLM, 1, EM2E) Subtract(IOLM, TOM1, EM2L) If(LGreater(LOMH, 0xC0000)){ Store(0xC0000, EM1B) /* Hole above C0000 and below E0000 */ Subtract(LOMH, 0xC0000, EM1L) /* subtract start, assumes allocation from C0000 going up */ } Return(CRES) /* note to change the Name buffer */ } /* ########################################################################################## */ } /* End Device(PCI0) */ } /* End \_SB scope */ Scope(\_SI) { Method(_SST, 1) { /* DBGO("\\_SI\\_SST\n") */ /* DBGO(" New Indicator state: ") */ /* DBGO(Arg0) */ /* DBGO("\n") */ } } /* End Scope SI */ Mutex (SBX0, 0x00) OperationRegion (SMB0, SystemIO, 0xB00, 0x10) // 0x0C replace by 0x10 Field (SMB0, ByteAcc, NoLock, Preserve) { HSTS, 8, /* SMBUS status */ SSTS, 8, /* SMBUS slave status */ HCNT, 8, /* SMBUS control */ HCMD, 8, /* SMBUS host cmd */ HADD, 8, /* SMBUS address */ DAT0, 8, /* SMBUS data0 */ DAT1, 8, /* SMBUS data1 */ BLKD, 8, /* SMBUS block data */ SCNT, 8, /* SMBUS slave control */ SCMD, 8, /* SMBUS shaow cmd */ SEVT, 8, /* SMBUS slave event */ SDAT, 8, /* SMBUS slave data */ SMK1, 8, SLMC, 8, RADD, 8, SADD, 8 } Method (WCLR, 0, NotSerialized) { /* clear SMBUS status register */ Store (0x1E, HSTS) Store (0xFA, Local0) While (LAnd (LNotEqual (And (HSTS, 0x1E), Zero), LGreater (Local0, Zero))) { Stall (0x64) Decrement (Local0) } Return (Local0) } Method (SWTC, 1, NotSerialized) { Store (Arg0, Local0) Store (0x07, Local2) Store (One, Local1) While (LEqual (Local1, One)) { Store (And (HSTS, 0x1E), Local3) If (LNotEqual (Local3, Zero)) { /* read sucess */ If (LEqual (Local3, 0x02)) { Store (Zero, Local2) } Store (Zero, Local1) } Else { If (LLess (Local0, 0x0A)) { /* read failure */ Store (0x10, Local2) Store (Zero, Local1) } Else { Sleep (0x0A) /* 10 ms, try again */ Subtract (Local0, 0x0A, Local0) } } } Return (Local2) } Method (SMBR, 3, NotSerialized) { Store (0x07, Local0) If (LEqual (Acquire (SBX0, 0xFFFF), Zero)) { Store (WCLR (), Local0) /* clear SMBUS status register before read data */ If (LEqual (Local0, Zero)) { Release (SBX0) Return (0x0) } Store (0x1F, HSTS) Store (Or (ShiftLeft (Arg1, One), One), HADD) Store (Arg2, HCMD) If (LEqual (Arg0, 0x07)) { Store (0x48, HCNT) /* read byte */ } Store (SWTC (0x03E8), Local1) /* 1000 ms */ If (LEqual (Local1, Zero)) { If (LEqual (Arg0, 0x07)) { Store (DAT0, Local0) } } Else { Store (Local1, Local0) } Release (SBX0) } /* DBGO("the value of SMBusData0 register ") */ /* DBGO(Arg2) */ /* DBGO(" is ") */ /* DBGO(Local0) */ /* DBGO("\n") */ Return (Local0) } #include "acpi/thermal.asl" }