soc/intel/denverton_ns: add common device function macros
Add device function macros for Denverton similar to other SoCs Signed-off-by: Jeff Daly <jeffd@silicom-usa.com> Change-Id: I75daaf4907515f80a10c003eb473bbe557a42acc Reviewed-on: https://review.coreboot.org/c/coreboot/+/60990 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Mariusz Szafrański <mariuszx.szafranski@intel.com>
This commit is contained in:
parent
29cad5a59e
commit
dc5d3f368b
|
@ -3,19 +3,28 @@
|
|||
#ifndef _DENVERTON_NS_PCI_DEVS_H_
|
||||
#define _DENVERTON_NS_PCI_DEVS_H_
|
||||
|
||||
#include <device/pci_def.h>
|
||||
|
||||
/* All these devices live on bus 0 with the associated device and function */
|
||||
|
||||
#define _PCH_DEVFN(slot, func) PCI_DEVFN(PCH_DEV_SLOT_##slot, func)
|
||||
|
||||
#if !defined(__SIMPLE_DEVICE__)
|
||||
#include <device/device.h>
|
||||
#include <device/pci_def.h>
|
||||
#define _PCH_DEV(slot, func) pcidev_path_on_root(_PCH_DEVFN(slot, func))
|
||||
#else
|
||||
#define _PCH_DEV(slot, func) PCI_DEV(0, PCH_DEV_SLOT_##slot, func)
|
||||
#endif
|
||||
|
||||
/* SoC transaction router */
|
||||
#define SA_DEV_SLOT_ROOT 0x0
|
||||
#define SA_DEVFN_ROOT PCI_DEVFN(SA_DEV_SLOT_ROOT, 0)
|
||||
#if defined(__SIMPLE_DEVICE__)
|
||||
#define SA_DEV_ROOT PCI_DEV(0, SA_DEV_SLOT_ROOT, 0)
|
||||
#else
|
||||
#include <device/device.h>
|
||||
#define SA_DEV_ROOT pcidev_path_on_root(PCI_DEVFN(SA_DEV_SLOT_ROOT, 0))
|
||||
#endif
|
||||
#define SA_DEV 0x0
|
||||
#define SA_FUNC 0
|
||||
#define SOC_DEV SA_DEV
|
||||
|
@ -26,14 +35,45 @@
|
|||
#define RAS_FUNC 0
|
||||
|
||||
/* Root Complex Event Collector */
|
||||
#define PCH_DEV_SLOT_RCEC 0x5
|
||||
#define PCH_DEVFN_RCEC _PCH_DEVFN(RCEC, 0)
|
||||
#define PCH_DEV_RCEC _PCH_DEV(RCEC, 0)
|
||||
#define RCEC_DEV 0x5
|
||||
#define RCEC_FUNC 0
|
||||
|
||||
/* Virtual Root Port 2 */
|
||||
#define PCH_DEV_SLOT_QAT 0x6
|
||||
#define PCH_DEVFN_QAT _PCH_DEVFN(QAT, 0)
|
||||
#define PCH_DEV_QAT _PCH_DEV(QAT, 0)
|
||||
#define VRP2_DEV 0x6
|
||||
#define VRP2_FUNC 0
|
||||
|
||||
/* PCIe Root Ports */
|
||||
#define PCH_DEV_SLOT_PCIE1 0x9
|
||||
#define PCH_DEVFN_PCIE1 _PCH_DEVFN(PCIE1, 0)
|
||||
#define PCH_DEV_PCIE1 _PCH_DEV(PCIE1, 0)
|
||||
#define PCH_DEV_SLOT_PCIE2 0xa
|
||||
#define PCH_DEVFN_PCIE2 _PCH_DEVFN(PCIE2, 0)
|
||||
#define PCH_DEV_PCIE2 _PCH_DEV(PCIE2, 0)
|
||||
#define PCH_DEV_SLOT_PCIE3 0xb
|
||||
#define PCH_DEVFN_PCIE3 _PCH_DEVFN(PCIE3, 0)
|
||||
#define PCH_DEV_PCIE3 _PCH_DEV(PCIE3, 0)
|
||||
#define PCH_DEV_SLOT_PCIE4 0xc
|
||||
#define PCH_DEVFN_PCIE4 _PCH_DEVFN(PCIE4, 0)
|
||||
#define PCH_DEV_PCIE4 _PCH_DEV(PCIE4, 0)
|
||||
#define PCH_DEV_SLOT_PCIE5 0xe
|
||||
#define PCH_DEVFN_PCIE5 _PCH_DEVFN(PCIE5, 0)
|
||||
#define PCH_DEV_PCIE5 _PCH_DEV(PCIE5, 0)
|
||||
#define PCH_DEV_SLOT_PCIE6 0xf
|
||||
#define PCH_DEVFN_PCIE6 _PCH_DEVFN(PCIE6, 0)
|
||||
#define PCH_DEV_PCIE6 _PCH_DEV(PCIE6, 0)
|
||||
#define PCH_DEV_SLOT_PCIE7 0x10
|
||||
#define PCH_DEVFN_PCIE7 _PCH_DEVFN(PCIE7, 0)
|
||||
#define PCH_DEV_PCIE7 _PCH_DEV(PCIE7, 0)
|
||||
#define PCH_DEV_SLOT_PCIE8 0x11
|
||||
#define PCH_DEVFN_PCIE8 _PCH_DEVFN(PCIE8, 0)
|
||||
#define PCH_DEV_PCIE8 _PCH_DEV(PCIE8, 0)
|
||||
|
||||
#define PCIE_DEV 0x09
|
||||
#define MAX_PCIE_PORT 0x8
|
||||
#define PCIE_PORT1_DEV 0x09
|
||||
|
@ -54,28 +94,56 @@
|
|||
#define PCIE_PORT8_FUNC 0
|
||||
|
||||
/* SMBUS 2 */
|
||||
#define PCH_DEV_SLOT_SMBUS_HOST 0x12
|
||||
#define PCH_DEVFN_SMBUS_HOST _PCH_DEVFN(SMBUS_HOST, 0)
|
||||
#define PCH_DEV_SMBUS_HOST _PCH_DEV(SMBUS_HOST, 0)
|
||||
#define SMBUS2_DEV 0x12
|
||||
#define SMBUS2_FUNC 0
|
||||
|
||||
/* SATA */
|
||||
#define PCH_DEV_SLOT_SATA_0 0x13
|
||||
#define PCH_DEVFN_SATA_0 _PCH_DEVFN(SATA_0, 0)
|
||||
#define PCH_DEV_SATA_0 _PCH_DEV(SATA_0, 0)
|
||||
#define PCH_DEV_SLOT_SATA_1 0x14
|
||||
#define PCH_DEVFN_SATA_1 _PCH_DEVFN(SATA_1, 0)
|
||||
#define PCH_DEV_SATA_1 _PCH_DEV(SATA_1, 0)
|
||||
#define SATA_DEV 0x13
|
||||
#define SATA_FUNC 0
|
||||
#define SATA2_DEV 0x14
|
||||
#define SATA2_FUNC 0
|
||||
|
||||
/* xHCI */
|
||||
#define PCH_DEV_SLOT_XHCI 0x15
|
||||
#define PCH_DEVFN_XHCI _PCH_DEVFN(XHCI, 0)
|
||||
#define PCH_DEV_XHCI _PCH_DEV(XHCI, 0)
|
||||
#define XHCI_DEV 0x15
|
||||
#define XHCI_FUNC 0
|
||||
|
||||
/* Virtual Root Port 0 */
|
||||
#define PCH_DEV_SLOT_LAN0 0x16
|
||||
#define PCH_DEVFN_LAN0 _PCH_DEVFN(LAN0, 0)
|
||||
#define PCH_DEV_LAN0 _PCH_DEV(LAN0, 0)
|
||||
#define VRP0_DEV 0x16
|
||||
#define VRP0_FUNC 0
|
||||
|
||||
/* Virtual Root Port 1 */
|
||||
#define PCH_DEV_SLOT_LAN1 0x17
|
||||
#define PCH_DEVFN_LAN1 _PCH_DEVFN(LAN1, 0)
|
||||
#define PCH_DEV_LAN1 _PCH_DEVFN(LAN1, 0)
|
||||
#define VRP1_DEV 0x17
|
||||
#define VRP1_FUNC 0
|
||||
|
||||
/* CSME */
|
||||
#define PCH_DEV_SLOT_ME 0x18
|
||||
#define PCH_DEVFN_ME_HECI1 _PCH_DEVFN(ME, 0)
|
||||
#define PCH_DEVFN_ME_HECI2 _PCH_DEVFN(ME, 1)
|
||||
#define PCH_DEVFN_ME_HECI3 _PCH_DEVFN(ME, 4)
|
||||
#define PCH_DEVFN_ME_KT _PCH_DEVFN(ME, 3)
|
||||
#define PCH_DEV_ME_HECI1 _PCH_DEV(ME, 0)
|
||||
#define PCH_DEV_ME_HECI2 _PCH_DEV(ME, 1)
|
||||
#define PCH_DEV_ME_HECI3 _PCH_DEV(ME, 4)
|
||||
#define PCH_DEV_ME_KT _PCH_DEV(ME, 3)
|
||||
|
||||
#define ME_HECI_DEV 0x18
|
||||
#define ME_HECI1_DEV ME_HECI_DEV
|
||||
#define ME_HECI1_FUNC 0
|
||||
|
@ -89,6 +157,13 @@
|
|||
#define ME_HECI3_FUNC 4
|
||||
|
||||
/* HSUART */
|
||||
#define PCH_DEV_SLOT_UART 0x1a
|
||||
#define PCH_DEVFN_UART0 _PCH_DEVFN(UART, 0)
|
||||
#define PCH_DEVFN_UART1 _PCH_DEVFN(UART, 1)
|
||||
#define PCH_DEVFN_UART2 _PCH_DEVFN(UART, 2)
|
||||
#define PCH_DEV_UART0 _PCH_DEV(UART, 0)
|
||||
#define PCH_DEV_UART1 _PCH_DEV(UART, 1)
|
||||
#define PCH_DEV_UART2 _PCH_DEV(UART, 2)
|
||||
#define HSUART_DEV 0x1a
|
||||
#define HSUART1_DEV HSUART_DEV
|
||||
#define HSUART1_FUNC 0
|
||||
|
@ -98,6 +173,15 @@
|
|||
#define HSUART3_FUNC 2
|
||||
|
||||
/* IE */
|
||||
#define PCH_DEV_SLOT_IE 0x1b
|
||||
#define PCH_DEVFN_IE_HECI1 _PCH_DEVFN(IE, 0)
|
||||
#define PCH_DEVFN_IE_HECI2 _PCH_DEVFN(IE, 1)
|
||||
#define PCH_DEVFN_IE_HECI3 _PCH_DEVFN(IE, 4)
|
||||
#define PCH_DEVFN_IE_KT _PCH_DEVFN(IE, 3)
|
||||
#define PCH_DEV_IE_HECI1 _PCH_DEV(IE, 0)
|
||||
#define PCH_DEV_IE_HECI2 _PCH_DEV(IE, 1)
|
||||
#define PCH_DEV_IE_HECI3 _PCH_DEV(IE, 4)
|
||||
#define PCH_DEV_IE_KT _PCH_DEV(IE, 3)
|
||||
#define IE_HECI_DEV 0x1b
|
||||
#define IE_HECI1_DEV IE_HECI_DEV
|
||||
#define IE_HECI1_FUNC 0
|
||||
|
@ -111,10 +195,26 @@
|
|||
#define IE_HECI3_FUNC 4
|
||||
|
||||
/* MMC Port */
|
||||
#define PCH_DEV_SLOT_EMMC 0x1c
|
||||
#define PCH_DEVFN_EMMC _PCH_DEVFN(EMMC, 0)
|
||||
#define PCH_DEV_EMMC _PCH_DEV(EMMC, 0)
|
||||
#define MMC_DEV 0x1c
|
||||
#define MMC_FUNC 0
|
||||
|
||||
/* Platform Controller Unit */
|
||||
#define PCH_DEV_SLOT_LPC 0x1f
|
||||
#define PCH_DEVFN_LPC _PCH_DEVFN(LPC, 0)
|
||||
#define PCH_DEVFN_P2SB _PCH_DEVFN(LPC, 1)
|
||||
#define PCH_DEVFN_PMC _PCH_DEVFN(LPC, 2)
|
||||
#define PCH_DEVFN_SMBUS _PCH_DEVFN(LPC, 4)
|
||||
#define PCH_DEVFN_SPI _PCH_DEVFN(LPC, 5)
|
||||
#define PCH_DEVFN_TRACE _PCH_DEVFN(LPC, 7)
|
||||
#define PCH_DEV_LPC _PCH_DEV(LPC, 0)
|
||||
#define PCH_DEV_P2SB _PCH_DEV(LPC, 1)
|
||||
#define PCH_DEV_PMC _PCH_DEV(LPC, 2)
|
||||
#define PCH_DEV_SMBUS _PCH_DEV(LPC, 4)
|
||||
#define PCH_DEV_SPI _PCH_DEV(LPC, 5)
|
||||
#define PCH_DEV_TRACE _PCH_DEV(LPC, 7)
|
||||
#define PCU_DEV 0x1f
|
||||
#define LPC_DEV PCU_DEV
|
||||
#define LPC_FUNC 0
|
||||
|
@ -129,25 +229,6 @@
|
|||
#define NPK_DEV PCU_DEV
|
||||
#define NPK_FUNC 7
|
||||
|
||||
/* TODO - New added */
|
||||
#define SA_DEV_SLOT_ROOT 0x00
|
||||
#define SA_DEVFN_ROOT PCI_DEVFN(SA_DEV_SLOT_ROOT, 0)
|
||||
#if defined(__SIMPLE_DEVICE__)
|
||||
#define SA_DEV_ROOT PCI_DEV(0, SA_DEV_SLOT_ROOT, 0)
|
||||
#endif
|
||||
|
||||
#define PCH_DEV_SLOT_LPC 0x1f
|
||||
#define PCH_DEVFN_LPC _PCH_DEVFN(LPC, 0)
|
||||
#define PCH_DEVFN_P2SB _PCH_DEVFN(LPC, 1)
|
||||
#define PCH_DEVFN_PMC _PCH_DEVFN(LPC, 2)
|
||||
#define PCH_DEVFN_SMBUS _PCH_DEVFN(LPC, 4)
|
||||
#define PCH_DEVFN_SPI _PCH_DEVFN(LPC, 5)
|
||||
#define PCH_DEV_LPC _PCH_DEV(LPC, 0)
|
||||
#define PCH_DEV_P2SB _PCH_DEV(LPC, 1)
|
||||
#define PCH_DEV_PMC _PCH_DEV(LPC, 2)
|
||||
#define PCH_DEV_SMBUS _PCH_DEV(LPC, 4)
|
||||
#define PCH_DEV_SPI _PCH_DEV(LPC, 5)
|
||||
|
||||
/* VT-d support value to match FSP settings */
|
||||
/* "PCH IOAPIC Config" */
|
||||
#define PCH_IOAPIC_PCI_BUS 0xf0
|
||||
|
|
Loading…
Reference in New Issue