coreboot
coreboot is an Open Source project aimed at replacing the proprietary BIOS found in most computers.
pci_devs.h
Go to the documentation of this file.
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 
3 #ifndef _SOC_TIGERLAKE_PCI_DEVS_H_
4 #define _SOC_TIGERLAKE_PCI_DEVS_H_
5 
6 #include <device/pci_def.h>
7 
8 #define _SA_DEVFN(slot) PCI_DEVFN(SA_DEV_SLOT_ ## slot, 0)
9 #define _PCH_DEVFN(slot, func) PCI_DEVFN(PCH_DEV_SLOT_ ## slot, func)
10 
11 #if !defined(__SIMPLE_DEVICE__)
12 #include <device/device.h>
13 #define _SA_DEV(slot) pcidev_path_on_root(_SA_DEVFN(slot))
14 #define _PCH_DEV(slot, func) pcidev_path_on_root_debug(_PCH_DEVFN(slot, func), __func__)
15 #else
16 #define _SA_DEV(slot) PCI_DEV(0, SA_DEV_SLOT_ ## slot, 0)
17 #define _PCH_DEV(slot, func) PCI_DEV(0, PCH_DEV_SLOT_ ## slot, func)
18 #endif
19 
20 /* System Agent Devices */
21 
22 #define SA_DEV_SLOT_ROOT 0x00
23 #define SA_DEVFN_ROOT PCI_DEVFN(SA_DEV_SLOT_ROOT, 0)
24 #if defined(__SIMPLE_DEVICE__)
25 #define SA_DEV_ROOT PCI_DEV(0, SA_DEV_SLOT_ROOT, 0)
26 #endif
27 
28 #define SA_DEV_SLOT_PEG 0x01
29 #define SA_DEVFN_PEG1 PCI_DEVFN(SA_DEV_SLOT_PEG, 0)
30 #define SA_DEVFN_PEG2 PCI_DEVFN(SA_DEV_SLOT_PEG, 1)
31 #define SA_DEVFN_PEG3 PCI_DEVFN(SA_DEV_SLOT_PEG, 2)
32 
33 #define SA_DEV_SLOT_IGD 0x02
34 #define SA_DEVFN_IGD PCI_DEVFN(SA_DEV_SLOT_IGD, 0)
35 #define SA_DEV_IGD PCI_DEV(0, SA_DEV_SLOT_IGD, 0)
36 
37 #define SA_DEV_SLOT_DPTF 0x04
38 #define SA_DEVFN_DPTF PCI_DEVFN(SA_DEV_SLOT_DPTF, 0)
39 #define SA_DEV_DPTF PCI_DEV(0, SA_DEV_SLOT_DPTF, 0)
40 
41 #define SA_DEV_SLOT_IPU 0x05
42 #define SA_DEVFN_IPU PCI_DEVFN(SA_DEV_SLOT_IPU, 0)
43 #define SA_DEV_IPU PCI_DEV(0, SA_DEV_SLOT_IPU, 0)
44 
45 #define SA_DEV_SLOT_CPU_PCIE 0x06
46 #define SA_DEVFN_CPU_PCIE PCI_DEVFN(SA_DEV_SLOT_CPU_PCIE, 0)
47 
48 #define SA_DEV_SLOT_TBT 0x07
49 #define SA_DEVFN_TBT(x) PCI_DEVFN(SA_DEV_SLOT_TBT, (x))
50 #define NUM_TBT_FUNCTIONS 4
51 #define SA_DEVFN_TBT0 PCI_DEVFN(SA_DEV_SLOT_TBT, 0)
52 #define SA_DEVFN_TBT1 PCI_DEVFN(SA_DEV_SLOT_TBT, 1)
53 #define SA_DEVFN_TBT2 PCI_DEVFN(SA_DEV_SLOT_TBT, 2)
54 #define SA_DEVFN_TBT3 PCI_DEVFN(SA_DEV_SLOT_TBT, 3)
55 #define SA_DEV_TBT0 PCI_DEV(0, SA_DEV_SLOT_TBT, 0)
56 #define SA_DEV_TBT1 PCI_DEV(0, SA_DEV_SLOT_TBT, 1)
57 #define SA_DEV_TBT2 PCI_DEV(0, SA_DEV_SLOT_TBT, 2)
58 #define SA_DEV_TBT3 PCI_DEV(0, SA_DEV_SLOT_TBT, 3)
59 
60 #define SA_DEV_SLOT_TMT 0x0A
61 #define SA_DEVFN_TMT _SA_DEVFN(TMT)
62 #define SA_DEV_TMT _SA_DEV(TMT)
63 
64 #define SA_DEV_SLOT_TCSS 0x0d
65 #define NUM_TCSS_DMA_FUNCTIONS 2
66 #define SA_DEVFN_TCSS_DMA(x) PCI_DEVFN(SA_DEV_SLOT_TCSS, ((x) + 2))
67 #define SA_DEVFN_TCSS_XHCI PCI_DEVFN(SA_DEV_SLOT_TCSS, 0)
68 #define SA_DEVFN_TCSS_XDCI PCI_DEVFN(SA_DEV_SLOT_TCSS, 1)
69 #define SA_DEVFN_TCSS_DMA0 SA_DEVFN_TCSS_DMA(0)
70 #define SA_DEVFN_TCSS_DMA1 SA_DEVFN_TCSS_DMA(1)
71 #define SA_DEV_TCSS_XHCI PCI_DEV(0, SA_DEV_SLOT_TCSS, 0)
72 #define SA_DEV_TCSS_XDCI PCI_DEV(0, SA_DEV_SLOT_TCSS, 1)
73 #define SA_DEV_TCSS_DMA0 PCI_DEV(0, SA_DEV_SLOT_TCSS, 2)
74 #define SA_DEV_TCSS_DMA1 PCI_DEV(0, SA_DEV_SLOT_TCSS, 3)
75 
76 #define SA_DEV_SLOT_VMD 0x0e
77 #define SA_DEVFN_VMD PCI_DEVFN(SA_DEV_SLOT_VMD, 0)
78 #define SA_DEV_VMD PCI_DEV(0, SA_DEV_SLOT_VMD, 0)
79 
80 /* PCH Devices */
81 #define MIN_PCH_SLOT PCH_DEV_SLOT_SIO0
82 #define PCH_DEV_SLOT_SIO0 0x10
83 #define PCH_DEVFN_THC0 _PCH_DEVFN(SIO0, 6)
84 #define PCH_DEVFN_THC1 _PCH_DEVFN(SIO0, 7)
85 #define PCH_DEV_THC0 _PCH_DEV(SIO0, 6)
86 #define PCH_DEV_THC1 _PCH_DEV(SIO0, 7)
87 
88 #define PCH_DEV_SLOT_SIO1 0x11
89 #define PCH_DEVFN_UART3 _PCH_DEVFN(SIO1, 0)
90 #define PCH_DEV_UART3 _PCH_DEV(SIO1, 0)
91 
92 #define PCH_DEV_SLOT_ISH 0x12
93 #define PCH_DEVFN_ISH _PCH_DEVFN(ISH, 0)
94 #define PCH_DEVFN_GSPI2 _PCH_DEVFN(ISH, 6)
95 #define PCH_DEV_ISH _PCH_DEV(ISH, 0)
96 #define PCH_DEV_GSPI2 _PCH_DEV(ISH, 6)
97 
98 #define PCH_DEV_SLOT_SIO2 0x13
99 #define PCH_DEVFN_GSPI3 _PCH_DEVFN(SIO2, 0)
100 #define PCH_DEV_GSPI3 _PCH_DEV(SIO2, 0)
101 
102 #define PCH_DEV_SLOT_XHCI 0x14
103 #define PCH_DEVFN_XHCI _PCH_DEVFN(XHCI, 0)
104 #define PCH_DEVFN_USBOTG _PCH_DEVFN(XHCI, 1)
105 #define PCH_DEVFN_SRAM _PCH_DEVFN(XHCI, 2)
106 #define PCH_DEVFN_CNVI_WIFI _PCH_DEVFN(XHCI, 3)
107 #define PCH_DEV_XHCI _PCH_DEV(XHCI, 0)
108 #define PCH_DEV_USBOTG _PCH_DEV(XHCI, 1)
109 #define PCH_DEV_SRAM _PCH_DEV(XHCI, 2)
110 #define PCH_DEV_CNVI_WIFI _PCH_DEV(XHCI, 3)
111 
112 #define PCH_DEV_SLOT_SIO3 0x15
113 #define PCH_DEVFN_I2C0 _PCH_DEVFN(SIO3, 0)
114 #define PCH_DEVFN_I2C1 _PCH_DEVFN(SIO3, 1)
115 #define PCH_DEVFN_I2C2 _PCH_DEVFN(SIO3, 2)
116 #define PCH_DEVFN_I2C3 _PCH_DEVFN(SIO3, 3)
117 #define PCH_DEV_I2C0 _PCH_DEV(SIO3, 0)
118 #define PCH_DEV_I2C1 _PCH_DEV(SIO3, 1)
119 #define PCH_DEV_I2C2 _PCH_DEV(SIO3, 2)
120 #define PCH_DEV_I2C3 _PCH_DEV(SIO3, 3)
121 
122 #define PCH_DEV_SLOT_CSE 0x16
123 #define PCH_DEVFN_CSE _PCH_DEVFN(CSE, 0)
124 #define PCH_DEVFN_CSE_2 _PCH_DEVFN(CSE, 1)
125 #define PCH_DEVFN_CSE_IDER _PCH_DEVFN(CSE, 2)
126 #define PCH_DEVFN_CSE_KT _PCH_DEVFN(CSE, 3)
127 #define PCH_DEVFN_CSE_3 _PCH_DEVFN(CSE, 4)
128 #define PCH_DEVFN_CSE_4 _PCH_DEVFN(CSE, 5)
129 #define PCH_DEV_CSE _PCH_DEV(CSE, 0)
130 #define PCH_DEV_CSE_2 _PCH_DEV(CSE, 1)
131 #define PCH_DEV_CSE_IDER _PCH_DEV(CSE, 2)
132 #define PCH_DEV_CSE_KT _PCH_DEV(CSE, 3)
133 #define PCH_DEV_CSE_3 _PCH_DEV(CSE, 4)
134 #define PCH_DEV_CSE_4 _PCH_DEV(CSE, 5)
135 
136 #define PCH_DEV_SLOT_SATA 0x17
137 #define PCH_DEVFN_SATA _PCH_DEVFN(SATA, 0)
138 #define PCH_DEV_SATA _PCH_DEV(SATA, 0)
139 
140 #define PCH_DEV_SLOT_SIO4 0x19
141 #define PCH_DEVFN_I2C4 _PCH_DEVFN(SIO4, 0)
142 #define PCH_DEVFN_I2C5 _PCH_DEVFN(SIO4, 1)
143 #define PCH_DEVFN_UART2 _PCH_DEVFN(SIO4, 2)
144 #define PCH_DEV_I2C4 _PCH_DEV(SIO4, 0)
145 #define PCH_DEV_I2C5 _PCH_DEV(SIO4, 1)
146 #define PCH_DEV_UART2 _PCH_DEV(SIO4, 2)
147 
148 #define PCH_DEV_SLOT_PCIE 0x1c
149 #define PCH_DEVFN_PCIE1 _PCH_DEVFN(PCIE, 0)
150 #define PCH_DEVFN_PCIE2 _PCH_DEVFN(PCIE, 1)
151 #define PCH_DEVFN_PCIE3 _PCH_DEVFN(PCIE, 2)
152 #define PCH_DEVFN_PCIE4 _PCH_DEVFN(PCIE, 3)
153 #define PCH_DEVFN_PCIE5 _PCH_DEVFN(PCIE, 4)
154 #define PCH_DEVFN_PCIE6 _PCH_DEVFN(PCIE, 5)
155 #define PCH_DEVFN_PCIE7 _PCH_DEVFN(PCIE, 6)
156 #define PCH_DEVFN_PCIE8 _PCH_DEVFN(PCIE, 7)
157 #define PCH_DEV_PCIE1 _PCH_DEV(PCIE, 0)
158 #define PCH_DEV_PCIE2 _PCH_DEV(PCIE, 1)
159 #define PCH_DEV_PCIE3 _PCH_DEV(PCIE, 2)
160 #define PCH_DEV_PCIE4 _PCH_DEV(PCIE, 3)
161 #define PCH_DEV_PCIE5 _PCH_DEV(PCIE, 4)
162 #define PCH_DEV_PCIE6 _PCH_DEV(PCIE, 5)
163 #define PCH_DEV_PCIE7 _PCH_DEV(PCIE, 6)
164 #define PCH_DEV_PCIE8 _PCH_DEV(PCIE, 7)
165 
166 #define PCH_DEV_SLOT_PCIE_1 0x1d
167 #define PCH_DEVFN_PCIE9 _PCH_DEVFN(PCIE_1, 0)
168 #define PCH_DEVFN_PCIE10 _PCH_DEVFN(PCIE_1, 1)
169 #define PCH_DEVFN_PCIE11 _PCH_DEVFN(PCIE_1, 2)
170 #define PCH_DEVFN_PCIE12 _PCH_DEVFN(PCIE_1, 3)
171 #define PCH_DEVFN_PCIE13 _PCH_DEVFN(PCIE_1, 4)
172 #define PCH_DEVFN_PCIE14 _PCH_DEVFN(PCIE_1, 5)
173 #define PCH_DEVFN_PCIE15 _PCH_DEVFN(PCIE_1, 6)
174 #define PCH_DEVFN_PCIE16 _PCH_DEVFN(PCIE_1, 7)
175 #define PCH_DEV_PCIE9 _PCH_DEV(PCIE_1, 0)
176 #define PCH_DEV_PCIE10 _PCH_DEV(PCIE_1, 1)
177 #define PCH_DEV_PCIE11 _PCH_DEV(PCIE_1, 2)
178 #define PCH_DEV_PCIE12 _PCH_DEV(PCIE_1, 3)
179 #define PCH_DEV_PCIE13 _PCH_DEV(PCIE_1, 4)
180 #define PCH_DEV_PCIE14 _PCH_DEV(PCIE_1, 5)
181 #define PCH_DEV_PCIE15 _PCH_DEV(PCIE_1, 6)
182 #define PCH_DEV_PCIE16 _PCH_DEV(PCIE_1, 7)
183 
184 #define PCH_DEV_SLOT_PCIE_2 0x1b
185 #define PCH_DEVFN_PCIE17 _PCH_DEVFN(PCIE_2, 0)
186 #define PCH_DEVFN_PCIE18 _PCH_DEVFN(PCIE_2, 1)
187 #define PCH_DEVFN_PCIE19 _PCH_DEVFN(PCIE_2, 2)
188 #define PCH_DEVFN_PCIE20 _PCH_DEVFN(PCIE_2, 3)
189 #define PCH_DEVFN_PCIE21 _PCH_DEVFN(PCIE_2, 4)
190 #define PCH_DEVFN_PCIE22 _PCH_DEVFN(PCIE_2, 5)
191 #define PCH_DEVFN_PCIE23 _PCH_DEVFN(PCIE_2, 6)
192 #define PCH_DEVFN_PCIE24 _PCH_DEVFN(PCIE_2, 7)
193 #define PCH_DEV_PCIE17 _PCH_DEV(PCIE_2, 0)
194 #define PCH_DEV_PCIE18 _PCH_DEV(PCIE_2, 1)
195 #define PCH_DEV_PCIE19 _PCH_DEV(PCIE_2, 2)
196 #define PCH_DEV_PCIE20 _PCH_DEV(PCIE_2, 3)
197 #define PCH_DEV_PCIE21 _PCH_DEV(PCIE_2, 4)
198 #define PCH_DEV_PCIE22 _PCH_DEV(PCIE_2, 5)
199 #define PCH_DEV_PCIE23 _PCH_DEV(PCIE_2, 6)
200 #define PCH_DEV_PCIE24 _PCH_DEV(PCIE_2, 7)
201 
202 #define PCH_DEV_SLOT_SIO5 0x1e
203 #define PCH_DEVFN_UART0 _PCH_DEVFN(SIO5, 0)
204 #define PCH_DEVFN_UART1 _PCH_DEVFN(SIO5, 1)
205 #define PCH_DEVFN_GSPI0 _PCH_DEVFN(SIO5, 2)
206 #define PCH_DEVFN_GSPI1 _PCH_DEVFN(SIO5, 3)
207 #define PCH_DEV_UART0 _PCH_DEV(SIO5, 0)
208 #define PCH_DEV_UART1 _PCH_DEV(SIO5, 1)
209 #define PCH_DEV_GSPI0 _PCH_DEV(SIO5, 2)
210 #define PCH_DEV_GSPI1 _PCH_DEV(SIO5, 3)
211 
212 #define PCH_DEV_SLOT_ESPI 0x1f
213 #define PCH_DEV_SLOT_LPC PCH_DEV_SLOT_ESPI
214 #define PCH_DEVFN_ESPI _PCH_DEVFN(ESPI, 0)
215 #define PCH_DEVFN_P2SB _PCH_DEVFN(ESPI, 1)
216 #define PCH_DEVFN_PMC _PCH_DEVFN(ESPI, 2)
217 #define PCH_DEVFN_HDA _PCH_DEVFN(ESPI, 3)
218 #define PCH_DEVFN_SMBUS _PCH_DEVFN(ESPI, 4)
219 #define PCH_DEVFN_SPI _PCH_DEVFN(ESPI, 5)
220 #define PCH_DEVFN_GBE _PCH_DEVFN(ESPI, 6)
221 #define PCH_DEVFN_TRACEHUB _PCH_DEVFN(ESPI, 7)
222 #define PCH_DEV_ESPI _PCH_DEV(ESPI, 0)
223 #define PCH_DEV_LPC PCH_DEV_ESPI
224 #define PCH_DEV_P2SB _PCH_DEV(ESPI, 1)
225 
226 #if !ENV_RAMSTAGE
227 /*
228  * PCH_DEV_PMC is intentionally not defined in RAMSTAGE since PMC device gets
229  * hidden from PCI bus after call to FSP-S. This leads to resource allocator
230  * dropping it from the root bus as unused device. All references to PCH_DEV_PMC
231  * would then return NULL and can go unnoticed if not handled properly. Since,
232  * this device does not have any special chip config associated with it, it is
233  * okay to not provide the definition for it in ramstage.
234  */
235 #define PCH_DEV_PMC _PCH_DEV(ESPI, 2)
236 #endif
237 
238 #define PCH_DEV_HDA _PCH_DEV(ESPI, 3)
239 #define PCH_DEV_SMBUS _PCH_DEV(ESPI, 4)
240 #define PCH_DEV_SPI _PCH_DEV(ESPI, 5)
241 #define PCH_DEV_GBE _PCH_DEV(ESPI, 6)
242 #define PCH_DEV_TRACEHUB _PCH_DEV(ESPI, 7)
243 
244 #endif