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>
diff --git a/src/soc/intel/denverton_ns/include/soc/pci_devs.h b/src/soc/intel/denverton_ns/include/soc/pci_devs.h
index a337b0d..f62ea2b 100644
--- a/src/soc/intel/denverton_ns/include/soc/pci_devs.h
+++ b/src/soc/intel/denverton_ns/include/soc/pci_devs.h
@@ -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