According to the documentation, Sunrise PCH-H [1,2] and Lewisburg PCH [3] supports up to 16 PCIe ports. However, ACPI contains a description for only 12 ports. This patch adds ACPI code for missing ports [1] page 182, Intel (R) 100 Series and Intel (R) C230 Series PCH Family Platform Controller Hub (PCH), Datasheet, Vol 1 of 2, December 2018, Document Number: 332690-005EN [2] page 180, Intel (R) 200 Series and Intel (R) Z370 Series PCH Family Platform Controller Hub (PCH), Datasheet, Vol 1 of 2, October 2017, Document Number: 335192-003 [3] page 39, Intel(R) C620 Series Chipset Platform Controller Hub (PCH) Datasheet, May 2019. Document Number: 336067-007US Change-Id: I954870136e0c8e5ff5d7ff623c7a6432b829abaf Signed-off-by: Maxim Polyakov <max.senia.poliak@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/35072 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Angel Pons <th3fanbus@gmail.com>
385 lines
6.6 KiB
Plaintext
385 lines
6.6 KiB
Plaintext
/*
|
|
* This file is part of the coreboot project.
|
|
*
|
|
* Copyright (C) 2007-2009 coresystems GmbH
|
|
* Copyright (C) 2014 Google Inc.
|
|
* Copyright (C) 2015-2018 Intel Corporation.
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
/* Intel PCH PCIe support */
|
|
|
|
Method (IRQM, 1, Serialized) {
|
|
|
|
/* Interrupt Map INTA->INTA, INTB->INTB, INTC->INTC, INTD->INTD */
|
|
Name (IQAA, Package () {
|
|
Package () { 0x0000ffff, 0, 0, 16 },
|
|
Package () { 0x0000ffff, 1, 0, 17 },
|
|
Package () { 0x0000ffff, 2, 0, 18 },
|
|
Package () { 0x0000ffff, 3, 0, 19 } })
|
|
Name (IQAP, Package () {
|
|
Package () { 0x0000ffff, 0, \_SB.PCI0.LNKA, 0 },
|
|
Package () { 0x0000ffff, 1, \_SB.PCI0.LNKB, 0 },
|
|
Package () { 0x0000ffff, 2, \_SB.PCI0.LNKC, 0 },
|
|
Package () { 0x0000ffff, 3, \_SB.PCI0.LNKD, 0 } })
|
|
|
|
/* Interrupt Map INTA->INTB, INTB->INTC, INTC->INTD, INTD->INTA */
|
|
Name (IQBA, Package () {
|
|
Package () { 0x0000ffff, 0, 0, 17 },
|
|
Package () { 0x0000ffff, 1, 0, 18 },
|
|
Package () { 0x0000ffff, 2, 0, 19 },
|
|
Package () { 0x0000ffff, 3, 0, 16 } })
|
|
Name (IQBP, Package () {
|
|
Package () { 0x0000ffff, 0, \_SB.PCI0.LNKB, 0 },
|
|
Package () { 0x0000ffff, 1, \_SB.PCI0.LNKC, 0 },
|
|
Package () { 0x0000ffff, 2, \_SB.PCI0.LNKD, 0 },
|
|
Package () { 0x0000ffff, 3, \_SB.PCI0.LNKA, 0 } })
|
|
|
|
/* Interrupt Map INTA->INTC, INTB->INTD, INTC->INTA, INTD->INTB */
|
|
Name (IQCA, Package () {
|
|
Package () { 0x0000ffff, 0, 0, 18 },
|
|
Package () { 0x0000ffff, 1, 0, 19 },
|
|
Package () { 0x0000ffff, 2, 0, 16 },
|
|
Package () { 0x0000ffff, 3, 0, 17 } })
|
|
Name (IQCP, Package () {
|
|
Package () { 0x0000ffff, 0, \_SB.PCI0.LNKC, 0 },
|
|
Package () { 0x0000ffff, 1, \_SB.PCI0.LNKD, 0 },
|
|
Package () { 0x0000ffff, 2, \_SB.PCI0.LNKA, 0 },
|
|
Package () { 0x0000ffff, 3, \_SB.PCI0.LNKB, 0 } })
|
|
|
|
/* Interrupt Map INTA->INTD, INTB->INTA, INTC->INTB, INTD->INTC */
|
|
Name (IQDA, Package () {
|
|
Package () { 0x0000ffff, 0, 0, 19 },
|
|
Package () { 0x0000ffff, 1, 0, 16 },
|
|
Package () { 0x0000ffff, 2, 0, 17 },
|
|
Package () { 0x0000ffff, 3, 0, 18 } })
|
|
Name (IQDP, Package () {
|
|
Package () { 0x0000ffff, 0, \_SB.PCI0.LNKD, 0 },
|
|
Package () { 0x0000ffff, 1, \_SB.PCI0.LNKA, 0 },
|
|
Package () { 0x0000ffff, 2, \_SB.PCI0.LNKB, 0 },
|
|
Package () { 0x0000ffff, 3, \_SB.PCI0.LNKC, 0 } })
|
|
|
|
Switch (ToInteger (Arg0))
|
|
{
|
|
Case (Package () { 1, 5, 9, 13 }) {
|
|
If (PICM) {
|
|
Return (IQAA)
|
|
} Else {
|
|
Return (IQAP)
|
|
}
|
|
}
|
|
|
|
Case (Package () { 2, 6, 10, 14 }) {
|
|
If (PICM) {
|
|
Return (IQBA)
|
|
} Else {
|
|
Return (IQBP)
|
|
}
|
|
}
|
|
|
|
Case (Package () { 3, 7, 11, 15 }) {
|
|
If (PICM) {
|
|
Return (IQCA)
|
|
} Else {
|
|
Return (IQCP)
|
|
}
|
|
}
|
|
|
|
Case (Package () { 4, 8, 12, 16 }) {
|
|
If (PICM) {
|
|
Return (IQDA)
|
|
} Else {
|
|
Return (IQDP)
|
|
}
|
|
}
|
|
|
|
Default {
|
|
If (PICM) {
|
|
Return (IQDA)
|
|
} Else {
|
|
Return (IQDP)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
Device (RP01)
|
|
{
|
|
Name (_ADR, 0x001C0000)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP02)
|
|
{
|
|
Name (_ADR, 0x001C0001)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP03)
|
|
{
|
|
Name (_ADR, 0x001C0002)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP04)
|
|
{
|
|
Name (_ADR, 0x001C0003)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP05)
|
|
{
|
|
Name (_ADR, 0x001C0004)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP06)
|
|
{
|
|
Name (_ADR, 0x001C0005)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP07)
|
|
{
|
|
Name (_ADR, 0x001C0006)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP08)
|
|
{
|
|
Name (_ADR, 0x001C0007)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP09)
|
|
{
|
|
Name (_ADR, 0x001D0000)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP10)
|
|
{
|
|
Name (_ADR, 0x001D0001)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP11)
|
|
{
|
|
Name (_ADR, 0x001D0002)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP12)
|
|
{
|
|
Name (_ADR, 0x001D0003)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP13)
|
|
{
|
|
Name (_ADR, 0x001D0004)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP14)
|
|
{
|
|
Name (_ADR, 0x001D0005)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP15)
|
|
{
|
|
Name (_ADR, 0x001D0006)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|
|
|
|
Device (RP16)
|
|
{
|
|
Name (_ADR, 0x001D0007)
|
|
|
|
OperationRegion (RPCS, PCI_Config, 0x4c, 4)
|
|
Field (RPCS, AnyAcc, NoLock, Preserve)
|
|
{
|
|
, 24,
|
|
RPPN, 8, /* Root Port Number */
|
|
}
|
|
|
|
Method (_PRT)
|
|
{
|
|
Return (IRQM (RPPN))
|
|
}
|
|
}
|