| /* |
| * This file is part of the coreboot project. |
| * |
| * Copyright (C) 2011 Kyösti Mälkki <kyosti.malkki@gmail.com> |
| * |
| * 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 (USB0) |
| { |
| Name (_ADR, 0x001D0000) |
| Name (_PRW, Package () { 0x03, 0x05 }) |
| |
| OperationRegion (USBS, PCI_Config, 0x00, 0x0100) |
| Field (USBS, ByteAcc, NoLock, Preserve) |
| { |
| Offset (0xC4), URES, 8 |
| } |
| } |
| |
| Device (USB1) |
| { |
| Name (_ADR, 0x001D0001) |
| Name (_PRW, Package () { 0x04, 0x05 }) |
| OperationRegion (USBS, PCI_Config, 0x00, 0x0100) |
| Field (USBS, ByteAcc, NoLock, Preserve) |
| { |
| Offset (0xC4), URES, 8 |
| } |
| } |
| |
| Device (USB2) |
| { |
| Name (_ADR, 0x001D0002) |
| Name (_PRW, Package () { 0x0C, 0x05 }) |
| OperationRegion (USBS, PCI_Config, 0x00, 0x0100) |
| Field (USBS, ByteAcc, NoLock, Preserve) |
| { |
| Offset (0xC4), URES, 8 |
| } |
| } |
| |
| Device (USB3) |
| { |
| Name (_ADR, 0x001D0007) |
| Name (_PRW, Package () { 0x0D, 0x05 }) /* PME_B0_STS any 0:1d or 0:1f device */ |
| OperationRegion (USBS, PCI_Config, 0x00, 0x0100) |
| Field (USBS, ByteAcc, NoLock, Preserve) |
| { |
| Offset (0xC4), URES, 8 |
| } |
| } |
| |
| Device(PCI5) |
| { |
| Name (_ADR, 0x001E0000) |
| Name (_PRW, Package () { 0x0B, 0x05 }) /* PME# _STS */ |
| Name (_PRT, Package() { |
| Package() { 0x0003ffff, 0, 0, 20 }, |
| Package() { 0x0003ffff, 1, 0, 21 }, |
| Package() { 0x0003ffff, 2, 0, 22 }, |
| Package() { 0x0003ffff, 3, 0, 23 }, |
| }) |
| } |
| |
| Device (ICH0) |
| { |
| Name (_ADR, 0x001F0000) |
| OperationRegion (D310, PCI_Config, 0x00, 0xFF) |
| Field (D310, ByteAcc, NoLock, Preserve) |
| { |
| Offset (0x40), PBAR, 16, |
| Offset (0x58), GBAR, 16, |
| } |
| |
| OperationRegion (ACPI, SystemIO, 0x0400, 0xC0) |
| Field (ACPI, ByteAcc, NoLock, Preserve) |
| { |
| Offset (0x00), PS1L,8, PS1H,8, PE1L,8, PE1H,8, |
| Offset (0x28), GS0L,8, GS0H,8, GSPL,8, GSPH,8, |
| Offset (0x2C), GE0L,8, GE0H,8, GEPL,8, GEPH,8, |
| Offset (0xB8), GPLV,8 |
| } |
| |
| Name (MSBF, ResourceTemplate () |
| { |
| /* IOAPIC 0 */ |
| Memory32Fixed (ReadWrite, IO_APIC_ADDR, 0x00001000,) |
| |
| IO (Decode16, 0x0, 0x0, 0x80, 0x0, PMIO) |
| IO (Decode16, 0x0, 0x0, 0x40, 0x0, GPIO) |
| |
| /* 8254 legacy irq */ |
| IO (Decode16, 0x04D0, 0x04D0, 0x02, 0x02,) |
| |
| /* reset generator */ |
| IO (Decode16, 0x0092, 0x0092, 0x01, 0x01, ) |
| }) |
| |
| Method (_CRS, 0, NotSerialized) |
| { |
| CreateWordField (MSBF, \_SB_.PCI0.ICH0.PMIO._MIN, IOA1) |
| CreateWordField (MSBF, \_SB_.PCI0.ICH0.PMIO._MAX, IOA2) |
| CreateByteField (MSBF, \_SB_.PCI0.ICH0.PMIO._LEN, IOAL) |
| |
| Store (PBAR, Local0) |
| If ( Land(Local0, 0x01) ) |
| { |
| And (Local0, 0xFFFE, Local0) |
| Store (Local0, IOA1) |
| Store (Local0, IOA2) |
| Store (0x80, IOAL) |
| } Else { |
| Store (0x00, IOAL) |
| } |
| |
| CreateWordField (MSBF, \_SB_.PCI0.ICH0.GPIO._MIN, IOS1) |
| CreateWordField (MSBF, \_SB_.PCI0.ICH0.GPIO._MAX, IOS2) |
| CreateByteField (MSBF, \_SB_.PCI0.ICH0.GPIO._LEN, IOSL) |
| |
| Store (GBAR, Local0) |
| If ( Land(Local0, 0x01) ) { |
| And (Local0, 0xFFFE, Local0) |
| Store (Local0, IOS1) |
| Store (Local0, IOS2) |
| Store (0x40, IOSL) |
| } Else { |
| Store (0x00, IOSL) |
| } |
| Return (MSBF) |
| } |
| |
| Device (FWH) |
| { |
| Name (_HID, EisaId ("PNP0C02")) |
| Name (_UID, 0x01) |
| |
| |
| Name (MSBG, ResourceTemplate () { |
| Memory32Fixed (ReadOnly, 0xFFF00000, 0x00080000,) |
| Memory32Fixed (ReadOnly, 0xFFF80000, 0x00080000,) |
| }) |
| |
| Method (_CRS, 0, NotSerialized) |
| { |
| Return (MSBG) |
| } |
| } |
| |
| Device (SMSC) |
| { |
| Name (_HID, EisaId ("PNP0C02")) |
| Name (_UID, 0x02) |
| #include "acpi/superio.asl" |
| } |
| |
| } |
| |
| |
| |