blob: 7303811b679f020c93dc131aa68325336a05745e [file] [log] [blame]
Patrick Georgiea063cb2020-05-08 19:28:13 +02001/* inteltool - dump all registers on an Intel CPU + chipset based system */
Patrick Georgi7333a112020-05-08 20:48:04 +02002/* SPDX-License-Identifier: GPL-2.0-only */
Stefan Reinauer23190272008-08-20 13:41:24 +00003
4#include <stdio.h>
5#include <stdlib.h>
Stefan Reinauera7b296d2011-11-14 12:40:34 -08006#include <inttypes.h>
Stefan Reinauer23190272008-08-20 13:41:24 +00007#include "inteltool.h"
8
Stefan Taunerdbc6fcd2013-06-20 18:05:06 +02009/* 320766 */
10static const io_register_t nehalem_dmi_registers[] = {
11 { 0x00, 4, "DMIVCH" }, // DMI Virtual Channel Capability Header
12 { 0x04, 4, "DMIVCCAP1" }, // DMI Port VC Capability Register 1
13 { 0x08, 4, "DMIVCCAP2" }, // DMI Port VC Capability Register 2
14 { 0x0C, 4, "DMIVCCTL" }, // DMI Port VC Control
15 { 0x10, 4, "DMIVC0RCAP" }, // DMI VC0 Resource Capability
16 { 0x14, 4, "DMIVC0RCTL" }, // DMI VC0 Resource Control
17/* { 0x18, 2, "RSVD" }, // Reserved */
18 { 0x1A, 2, "DMIVC0RSTS" }, // DMI VC0 Resource Status
19 { 0x1C, 4, "DMIVC1RCAP" }, // DMI VC1 Resource Capability
20 { 0x20, 4, "DMIVC1RCTL" }, // DMI VC1 Resource Control
21/* { 0x24, 2, "RSVD" }, // Reserved */
22 { 0x26, 2, "DMIVC1RSTS" }, // DMI VC1 Resource Status
23/* ... - Reserved */
24 { 0x84, 4, "DMILCAP" }, // DMI Link Capabilities
25 { 0x88, 2, "DMILCTL" }, // DMI Link Control
26 { 0x8A, 2, "DMILSTS" }, // DMI Link Status
27/* ... - Reserved */
28};
29
30/* 322812 */
31static const io_register_t westmere_dmi_registers[] = {
32 { 0x00, 4, "DMIVCECH" }, // DMI Virtual Channel Enhanced Capability
33 { 0x04, 4, "DMIPVCCAP1" }, // DMI Port VC Capability Register 1
34 { 0x08, 4, "DMIPVCCAP2" }, // DMI Port VC Capability Register 2
35 { 0x0C, 2, "DMIPVCCTL" }, // DMI Port VC Control
36/* { 0x0E, 2, "RSVD" }, // Reserved */
37 { 0x10, 4, "DMIVC0RCAP" }, // DMI VC0 Resource Capability
38 { 0x14, 4, "DMIVC0RCTL" }, // DMI VC0 Resource Control
39/* { 0x18, 2, "RSVD" }, // Reserved */
40 { 0x1A, 2, "DMIVC0RSTS" }, // DMI VC0 Resource Status
41 { 0x1C, 4, "DMIVC1RCAP" }, // DMI VC1 Resource Capability
42 { 0x20, 4, "DMIVC1RCTL1" }, // DMI VC1 Resource Control
43/* { 0x24, 2, "RSVD" }, // Reserved */
44 { 0x26, 2, "DMIC1RSTS" }, // DMI VC1 Resource Status
45/* ... - Reserved */
46 { 0x84, 4, "DMILCAP" }, // DMI Link Capabilities
47 { 0x88, 2, "DMILCTL" }, // DMI Link Control
48 { 0x8A, 2, "DMILSTS" }, // DMI Link Status
49/* ... - Reserved */
50};
51
Anton Kochkovc7fc4422012-07-21 06:36:47 +040052static const io_register_t sandybridge_dmi_registers[] = {
53 { 0x00, 4, "DMI VCECH" }, // DMI Virtual Channel Enhanced Capability
54 { 0x04, 4, "DMI PVCCAP1" }, // DMI Port VC Capability Register 1
55 { 0x08, 4, "DMI PVVAP2" }, // DMI Port VC Capability Register 2
56 { 0x0C, 2, "DMI PVCCTL" }, // DMI Port VC Control
57/* { 0x0E, 2, "RSVD" }, // Reserved */
58 { 0x10, 4, "DMI VC0RCAP" }, // DMI VC0 Resource Capability
59 { 0x14, 4, "DMI VC0RCTL" }, // DMI VC0 Resource Control
60/* { 0x18, 2, "RSVD" }, // Reserved */
61 { 0x1A, 2, "DMI VC0RSTS" }, // DMI VC0 Resource Status
62 { 0x1C, 4, "DMI VC1RCAP" }, // DMI VC1 Resource Capability
63 { 0x20, 4, "DMI VC1RCTL" }, // DMI VC1 Resource Control
64/* { 0x24, 2, "RSVD" }, // Reserved */
65 { 0x26, 2, "DMI VC1RSTS" }, // DMI VC1 Resource Status
66 { 0x28, 4, "DMI VCPRCAP" }, // DMI VCp Resource Capability
67 { 0x2C, 4, "DMI VCPRCTL" }, // DMI VCp Resource Control
68/* { 0x30, 2, "RSVD" }, // Reserved */
69 { 0x32, 2, "DMI VCPRSTS" }, // DMI VCp Resource Status
70 { 0x34, 4, "DMI VCMRCAP" }, // DMI VCm Resource Capability
71 { 0x38, 4, "DMI VCMRCTL" }, // DMI VCm Resource Control
72/* { 0x3C, 2, "RSVD" }, // Reserved */
73 { 0x3E, 2, "DMI VCMRSTS" }, // DMI VCm Resource Status
74/* { 0x40, 4, "RSVD" }, // Reserved */
75 { 0x44, 4, "DMI ESC" }, // DMI Element Self Description
76/* { 0x48, 8, "RSVD" }, // Reserved */
77 { 0x50, 4, "DMI LE1D" }, // DMI Link Entry 1 Description
78/* { 0x54, 4, "RSVD" }, // Reserved */
79 { 0x58, 4, "DMI LE1A" }, // DMI Link Entry 1 Address
80 { 0x5C, 4, "DMI LUE1A" }, // DMI Link Upper Entry 1 Address
81 { 0x60, 4, "DMI LE2D" }, // DMI Link Entry 2 Description
82/* { 0x64, 4, "RSVD" }, // Reserved */
83 { 0x68, 4, "DMI LE2A" }, // DMI Link Entry 2 Address
84/* { 0x6C, 4, "RSVD" }, // Reserved
85 { 0x70, 8, "RSVD" }, // Reserved
86 { 0x78, 8, "RSVD" }, // Reserved
87 { 0x80, 4, "RSVD" }, // Reserved */
88 { 0x84, 4, "LCAP" }, // Link Capabilities
89 { 0x88, 2, "LCTL" }, // Link Control
90 { 0x8A, 2, "LSTS" }, // Link Status
91/* { 0x8C, 4, "RSVD" }, // Reserved
92 { 0x90, 4, "RSVD" }, // Reserved
93 { 0x94, 4, "RSVD" }, // Reserved */
94 { 0x98, 2, "LCTL2" }, // Link Control 2
95 { 0x9A, 2, "LSTS2" }, // Link Status 2
96/* ... - Reserved */
97 { 0xBC0, 4, "AFE_BMUF0" }, // AFE BMU Configuration Function 0
98 { 0xBC4, 4, "RSVD" }, // Reserved
99 { 0xBC8, 4, "RSVD" }, // Reserved
100 { 0xBCC, 4, "AFE_BMUT0" }, // AFE BMU Configuration Test 0
101/* ... - Reserved */
102};
103
Stefan Reinauer23190272008-08-20 13:41:24 +0000104/*
Dennis Wassenbergae6685f2014-10-30 10:30:40 +0100105 * All Haswell DMI Registers per
106 *
107 * Mobile 4th Generation Intel Core TM Processor Family, Mobile Intel Pentium Processor Family,
108 * and Mobile Intel Celeron Processor Family
109 * Datasheet Volume 2
110 * 329002-002
111 */
112static const io_register_t haswell_ult_dmi_registers[] = {
Elyes HAOUAS94501502016-10-19 17:59:10 +0200113 { 0x00, 4, "DMIVCECH" }, // DMI Virtual Channel Enhanced Capability
114 { 0x04, 4, "DMIPVCCAP1" }, // DMI Port VC Capability Register 1
115 { 0x08, 4, "DMIPVCCAP2" }, // DMI Port VC Capability Register 2
116 { 0x0C, 2, "DMI PVCCTL" }, // DMI Port VC Control
117/* { 0x0E, 2, "RSVD" }, // Reserved */
118 { 0x10, 4, "DMIVC0RCAP" }, // DMI VC0 Resource Capability
119 { 0x14, 4, "DMIVC0RCTL" }, // DMI VC0 Resource Control
120/* { 0x18, 2, "RSVD" }, // Reserved */
121 { 0x1A, 2, "DMIVC0RSTS" }, // DMI VC0 Resource Status
122 { 0x1C, 4, "DMIVC1RCAP" }, // DMI VC1 Resource Capability
123 { 0x20, 4, "DMIVC1RCTL" }, // DMI VC1 Resource Control
124/* { 0x24, 2, "RSVD" }, // Reserved */
125 { 0x26, 2, "DMIVC1RSTS" }, // DMI VC1 Resource Status
126 { 0x28, 4, "DMIVCPRCAP" }, // DMI VCp Resource Capability
127 { 0x2C, 4, "DMIVCPRCTL" }, // DMI VCp Resource Control
128/* { 0x30, 2, "RSVD" }, // Reserved */
129 { 0x32, 2, "DMIVCPRSTS" }, // DMI VCp Resource Status
130 { 0x34, 4, "DMIVCMRCAP" }, // DMI VCm Resource Capability
131 { 0x38, 4, "DMIVCMRCTL" }, // DMI VCm Resource Control
132/* { 0x3C, 2, "RSVD" }, // Reserved */
133 { 0x3E, 2, "DMIVCMRSTS" }, // DMI VCm Resource Status
134 { 0x40, 4, "DMIRCLDECH" }, // DMI Root Complex Link Declaration */
135 { 0x44, 4, "DMIESD" }, // DMI Element Self Description
136/* { 0x48, 4, "RSVD" }, // Reserved */
137/* { 0x4C, 4, "RSVD" }, // Reserved */
138 { 0x50, 4, "DMILE1D" }, // DMI Link Entry 1 Description
139/* { 0x54, 4, "RSVD" }, // Reserved */
140 { 0x58, 4, "DMILE1A" }, // DMI Link Entry 1 Address
141 { 0x5C, 4, "DMILUE1A" }, // DMI Link Upper Entry 1 Address
142 { 0x60, 4, "DMILE2D" }, // DMI Link Entry 2 Description
143/* { 0x64, 4, "RSVD" }, // Reserved */
144 { 0x68, 4, "DMILE2A" }, // DMI Link Entry 2 Address
145/* { 0x6C, 4, "RSVD" }, // Reserved */
146/* { 0x70, 4, "RSVD" }, // Reserved */
147/* { 0x74, 4, "RSVD" }, // Reserved */
148/* { 0x78, 4, "RSVD" }, // Reserved */
149/* { 0x7C, 4, "RSVD" }, // Reserved */
150/* { 0x80, 4, "RSVD" }, // Reserved */
151/* { 0x84, 4, "RSVD" }, // Reserved */
152 { 0x88, 2, "LCTL" }, // Link Control
153 /* ... - Reserved */
154 { 0x1C4, 4, "DMIUESTS" }, // DMI Uncorrectable Error Status
155 { 0x1C8, 4, "DMIUEMSK" }, // DMI Uncorrectable Error Mask
156 { 0x1D0, 4, "DMICESTS" }, // DMI Correctable Error Status
157 { 0x1D4, 4, "DMICEMSK" }, // DMI Correctable Error Mask
Dennis Wassenbergae6685f2014-10-30 10:30:40 +0100158/* ... - Reserved */
159};
160
161/*
Maximilian Schander98c11dd2017-11-05 05:52:13 +0100162 * All Skylake-S/H DMI Registers per
163 *
164 * 6th Generation Intel Processor Families for S-Platform Volume 2 of 2
165 * Page 117
166 * 332688-003E
167 *
168 * 6th Generation Intel Processor Families for H-Platform Volume 2 of 2
169 * Page 117
170 * 332987-002EN
171 */
172static const io_register_t skylake_dmi_registers[] = {
173 { 0x00, 4, "DMIVCECH" }, // DMI Virtual Channel Enhanced Capability
174 { 0x04, 4, "DMIPVCCAP1" }, // DMI Port VC Capability Register 1
175 { 0x08, 4, "DMIPVCCAP2" }, // DMI Port VC Capability Register 2
176 { 0x0C, 2, "DMIPVCCTL" }, // DMI Port VC Control
177 { 0x10, 4, "DMIVC0RCAP" }, // DMI VC0 Resource Capability
178 { 0x14, 4, "DMIVC0RCTL" }, // DMI VC0 Resource Control
179 { 0x1A, 2, "DMIVC0RSTS" }, // DMI VC0 Resource Status
180 { 0x1C, 4, "DMIVC1RCAP" }, // DMI VC1 Resource Capability
181 { 0x20, 4, "DMIVC1RCTL" }, // DMI VC1 Resource Control
182 { 0x26, 2, "DMIVC1RSTS" }, // DMI VC1 Resource Status
183 { 0x34, 4, "DMIVCMRCAP" }, // DMI VCm Resource Capability
184 { 0x38, 4, "DMIVCMRCTL" }, // DMI VCm Resource Control
185 { 0x3E, 2, "DMIVCMRSTS" }, // DMI VCm Resource Status
186 { 0x40, 4, "DMIRCLDECH" }, // DMI Root Complex Link Declaration */
187 { 0x44, 4, "DMIESD" }, // DMI Element Self Description
188 { 0x50, 4, "DMILE1D" }, // DMI Link Entry 1 Description
189 { 0x58, 4, "DMILE1A" }, // DMI Link Entry 1 Address
190 { 0x5C, 4, "DMILUE1A" }, // DMI Link Upper Entry 1 Address
191 { 0x60, 4, "DMILE2D" }, // DMI Link Entry 2 Description
192 { 0x68, 4, "DMILE2A" }, // DMI Link Entry 2 Address
193 { 0x84, 4, "LCAP" }, // Link Capabilities
194 { 0x88, 2, "LCTL" }, // Link Control
195 { 0x8A, 2, "LSTS" }, // DMI Link Status
196 { 0x98, 2, "LCTL2" }, // Link Control 2
197 { 0x9A, 2, "LSTS2" }, // DMI Link Status 2
198 { 0x1C4, 4, "DMIUESTS" }, // DMI Uncorrectable Error Status
199 { 0x1C8, 4, "DMIUEMSK" }, // DMI Uncorrectable Error Mask
200 { 0x1CC, 4, "DMIUESEV" }, // DMI Uncorrectable Error Mask
201 { 0x1D0, 4, "DMICESTS" }, // DMI Correctable Error Status
202 { 0x1D4, 4, "DMICEMSK" }, // DMI Correctable Error Mask
203};
204
Brandon Weeks7ee7b132023-12-26 15:55:03 -0800205static const io_register_t alderlake_dmi_registers[] = {
206 { 0x00, 4, "DMIVCECH" }, // DMI Virtual Channel Enhanced Capability
207 { 0x04, 4, "DMIPVCCAP1" }, // DMI Port VC Capability Register 1
208 { 0x08, 4, "DMIPVCCAP2" }, // DMI Port VC Capability Register 2
209 { 0x0C, 2, "DMIPVCCTL" }, // DMI Port VC Control
210 { 0x10, 4, "DMIVC0RCAP" }, // DMI VC0 Resource Capability
211 { 0x1C, 4, "DMIVC1RCAP" }, // DMI VC1 Resource Capability
212 { 0x26, 2, "DMIVC1RSTS" }, // DMI VC1 Resource Status
213 { 0x34, 4, "DMIVCMRCAP" }, // DMI VCm Resource Capability
214 { 0x38, 4, "DMIVCMRCTL" }, // DMI VCm Resource Control
215 { 0x3E, 2, "DMIVCMRSTS" }, // DMI VCm Resource Status
216 { 0x40, 4, "DMIRCLDECH" }, // DMI Root Complex Link Declaration */
217 { 0x44, 4, "DMIESD" }, // DMI Element Self Description
218 { 0x50, 4, "DMILE1D" }, // DMI Link Entry 1 Description
219 { 0x5C, 4, "DMILUE1A" }, // DMI Link Upper Entry 1 Address
220 { 0x60, 4, "DMILE2D" }, // DMI Link Entry 2 Description
221 { 0x68, 4, "DMILE2A" }, // DMI Link Entry 2 Address
222 { 0x88, 2, "LCTL" }, // Link Control
223 { 0x1C4, 4, "DMIUESTS" }, // DMI Uncorrectable Error Status
224 { 0x1C8, 4, "DMIUEMSK" }, // DMI Uncorrectable Error Mask
225 { 0x1CC, 4, "DMIUESEV" }, // DMI Uncorrectable Error Mask
226 { 0x1D0, 4, "DMICESTS" }, // DMI Correctable Error Status
227 { 0x1D4, 4, "DMICEMSK" }, // DMI Correctable Error Mask
228};
Maximilian Schander98c11dd2017-11-05 05:52:13 +0100229
230/*
Stefan Reinauer23190272008-08-20 13:41:24 +0000231 * Egress Port Root Complex MMIO configuration space
232 */
233int print_epbar(struct pci_dev *nb)
234{
235 int i, size = (4 * 1024);
236 volatile uint8_t *epbar;
Stefan Reinauer1162f252008-12-04 15:18:20 +0000237 uint64_t epbar_phys;
Stefan Reinauer23190272008-08-20 13:41:24 +0000238
239 printf("\n============= EPBAR =============\n\n");
240
241 switch (nb->device_id) {
Pat Erleyca3548e2010-04-21 06:23:19 +0000242 case PCI_DEVICE_ID_INTEL_82915:
Stefan Reinauer23190272008-08-20 13:41:24 +0000243 case PCI_DEVICE_ID_INTEL_82945GM:
Björn Busse2d33dc42010-08-01 15:33:30 +0000244 case PCI_DEVICE_ID_INTEL_82945GSE:
Stefan Reinauer3d9a12f2008-11-02 11:11:40 +0000245 case PCI_DEVICE_ID_INTEL_82945P:
Stefan Tauner1a00cf02012-10-13 06:23:52 +0200246 case PCI_DEVICE_ID_INTEL_82946:
Stefan Reinauer1162f252008-12-04 15:18:20 +0000247 case PCI_DEVICE_ID_INTEL_82975X:
Stefan Reinauer23190272008-08-20 13:41:24 +0000248 epbar_phys = pci_read_long(nb, 0x40) & 0xfffffffe;
249 break;
Stefan Tauner04c06002012-10-13 02:19:30 +0200250 case PCI_DEVICE_ID_INTEL_82965PM:
251 case PCI_DEVICE_ID_INTEL_82Q965:
252 case PCI_DEVICE_ID_INTEL_82Q35:
253 case PCI_DEVICE_ID_INTEL_82G33:
254 case PCI_DEVICE_ID_INTEL_82Q33:
255 case PCI_DEVICE_ID_INTEL_82X38:
Ruud Schrampbb41f502011-04-04 07:53:19 +0200256 case PCI_DEVICE_ID_INTEL_32X0:
Damien Zammit9c986642015-08-17 21:04:41 +1000257 case PCI_DEVICE_ID_INTEL_82XX4X:
258 case PCI_DEVICE_ID_INTEL_82Q45:
259 case PCI_DEVICE_ID_INTEL_82G45:
260 case PCI_DEVICE_ID_INTEL_82G41:
261 case PCI_DEVICE_ID_INTEL_82B43:
262 case PCI_DEVICE_ID_INTEL_82B43_2:
Corey Osgood23d98c72010-07-29 19:25:31 +0000263 case PCI_DEVICE_ID_INTEL_ATOM_DXXX:
264 case PCI_DEVICE_ID_INTEL_ATOM_NXXX:
Felix Heldfac95e32014-11-09 00:11:28 +0100265 case PCI_DEVICE_ID_INTEL_CORE_2ND_GEN_D:
266 case PCI_DEVICE_ID_INTEL_CORE_2ND_GEN_M:
267 case PCI_DEVICE_ID_INTEL_CORE_2ND_GEN_E3:
268 case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_D:
269 case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_M:
270 case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_E3:
271 case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_015c:
272 case PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_D:
273 case PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_M:
274 case PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_E3:
Dennis Wassenbergae6685f2014-10-30 10:30:40 +0100275 case PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_U:
Matt DeVillier5b667df2015-05-14 21:58:33 -0500276 case PCI_DEVICE_ID_INTEL_CORE_5TH_GEN_U:
Angel Ponsf007ab72022-10-07 00:25:33 +0200277 case PCI_DEVICE_ID_INTEL_CORE_5TH_GEN_D:
278 case PCI_DEVICE_ID_INTEL_CORE_5TH_GEN_M:
Nico Huber54fe32f2017-10-03 16:03:07 +0200279 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_D2:
Benjamin Doronc01fa5a2020-07-01 19:20:40 +0000280 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_U:
281 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_Y:
Maximilian Schander79856432017-11-05 06:14:55 +0100282 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_M:
283 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_WST:
Christoph Pomaska48ac29e2018-01-01 01:48:21 +0100284 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_D:
Maxim Polyakov13176892019-08-27 18:20:08 +0300285 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_E:
Matthew Garrett2bf28e52018-07-23 21:09:47 -0700286 case PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_U:
287 case PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_Y:
288 case PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_U_Q:
Christian Walter9a8c5e72019-05-06 17:50:57 +0200289 case PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_E3:
Matt DeVillier3c784452019-06-11 23:23:46 -0500290 case PCI_DEVICE_ID_INTEL_CORE_8TH_GEN_U_1:
291 case PCI_DEVICE_ID_INTEL_CORE_8TH_GEN_U_2:
Brandon Weeks7ee7b132023-12-26 15:55:03 -0800292 case PCI_DEVICE_ID_INTEL_CORE_ADL_ID_N_0_8:
293 case PCI_DEVICE_ID_INTEL_CORE_ADL_ID_N_0_4:
294 case PCI_DEVICE_ID_INTEL_CORE_ADL_ID_N_0_4_1:
Stefan Tauner04c06002012-10-13 02:19:30 +0200295 epbar_phys = pci_read_long(nb, 0x40) & 0xfffffffe;
296 epbar_phys |= ((uint64_t)pci_read_long(nb, 0x44)) << 32;
297 break;
Stefan Reinauerb2aedb12009-08-29 15:45:43 +0000298 case PCI_DEVICE_ID_INTEL_82810:
Stefan Tauner04c06002012-10-13 02:19:30 +0200299 case PCI_DEVICE_ID_INTEL_82810_DC:
300 case PCI_DEVICE_ID_INTEL_82810E_DC:
Stefan Reinauer04844812010-02-22 11:26:06 +0000301 case PCI_DEVICE_ID_INTEL_82830M:
Idwer Vollering312fc962010-12-17 22:34:58 +0000302 case PCI_DEVICE_ID_INTEL_82865:
303 printf("This northbridge does not have EPBAR.\n");
Stefan Reinauer23190272008-08-20 13:41:24 +0000304 return 1;
305 default:
306 printf("Error: Dumping EPBAR on this northbridge is not (yet) supported.\n");
307 return 1;
308 }
309
Stefan Reinauer1162f252008-12-04 15:18:20 +0000310 epbar = map_physical(epbar_phys, size);
Stefan Reinauer14e22772010-04-27 06:56:47 +0000311
Stefan Reinauer1162f252008-12-04 15:18:20 +0000312 if (epbar == NULL) {
Stefan Reinauer23190272008-08-20 13:41:24 +0000313 perror("Error mapping EPBAR");
314 exit(1);
315 }
316
Stefan Reinauera7b296d2011-11-14 12:40:34 -0800317 printf("EPBAR = 0x%08" PRIx64 " (MEM)\n\n", epbar_phys);
Stefan Reinauer23190272008-08-20 13:41:24 +0000318 for (i = 0; i < size; i += 4) {
Michael Niewöhner10d52212020-03-13 19:08:21 +0100319 if (read32(epbar + i))
320 printf("0x%04x: 0x%08x\n", i, read32(epbar+i));
Stefan Reinauer23190272008-08-20 13:41:24 +0000321 }
322
Stefan Reinauer1162f252008-12-04 15:18:20 +0000323 unmap_physical((void *)epbar, size);
Stefan Reinauer23190272008-08-20 13:41:24 +0000324 return 0;
325}
326
327/*
328 * MCH-ICH Serial Interconnect Ingress Root Complex MMIO configuration space
329 */
330int print_dmibar(struct pci_dev *nb)
331{
332 int i, size = (4 * 1024);
333 volatile uint8_t *dmibar;
Stefan Reinauer1162f252008-12-04 15:18:20 +0000334 uint64_t dmibar_phys;
Anton Kochkovc7fc4422012-07-21 06:36:47 +0400335 const io_register_t *dmi_registers = NULL;
Stefan Reinauer23190272008-08-20 13:41:24 +0000336
337 printf("\n============= DMIBAR ============\n\n");
338
339 switch (nb->device_id) {
Pat Erleyca3548e2010-04-21 06:23:19 +0000340 case PCI_DEVICE_ID_INTEL_82915:
Stefan Reinauer23190272008-08-20 13:41:24 +0000341 case PCI_DEVICE_ID_INTEL_82945GM:
Björn Busse2d33dc42010-08-01 15:33:30 +0000342 case PCI_DEVICE_ID_INTEL_82945GSE:
Stefan Reinauer3d9a12f2008-11-02 11:11:40 +0000343 case PCI_DEVICE_ID_INTEL_82945P:
Stefan Reinauer1162f252008-12-04 15:18:20 +0000344 case PCI_DEVICE_ID_INTEL_82975X:
Stefan Reinauer23190272008-08-20 13:41:24 +0000345 dmibar_phys = pci_read_long(nb, 0x4c) & 0xfffffffe;
346 break;
Stefan Tauner1a00cf02012-10-13 06:23:52 +0200347 case PCI_DEVICE_ID_INTEL_82946:
Stefan Tauner04c06002012-10-13 02:19:30 +0200348 case PCI_DEVICE_ID_INTEL_82965PM:
349 case PCI_DEVICE_ID_INTEL_82Q965:
Warren Turkal53291952010-09-03 09:32:17 +0000350 case PCI_DEVICE_ID_INTEL_82Q35:
351 case PCI_DEVICE_ID_INTEL_82G33:
352 case PCI_DEVICE_ID_INTEL_82Q33:
Stefan Tauner04c06002012-10-13 02:19:30 +0200353 case PCI_DEVICE_ID_INTEL_82X38:
Ruud Schrampbb41f502011-04-04 07:53:19 +0200354 case PCI_DEVICE_ID_INTEL_32X0:
Damien Zammit9c986642015-08-17 21:04:41 +1000355 case PCI_DEVICE_ID_INTEL_82XX4X:
356 case PCI_DEVICE_ID_INTEL_82Q45:
357 case PCI_DEVICE_ID_INTEL_82G45:
358 case PCI_DEVICE_ID_INTEL_82G41:
359 case PCI_DEVICE_ID_INTEL_82B43:
360 case PCI_DEVICE_ID_INTEL_82B43_2:
Corey Osgood23d98c72010-07-29 19:25:31 +0000361 case PCI_DEVICE_ID_INTEL_ATOM_DXXX:
362 case PCI_DEVICE_ID_INTEL_ATOM_NXXX:
Warren Turkal53291952010-09-03 09:32:17 +0000363 dmibar_phys = pci_read_long(nb, 0x68) & 0xfffffffe;
364 dmibar_phys |= ((uint64_t)pci_read_long(nb, 0x6c)) << 32;
365 break;
Stefan Reinauerb2aedb12009-08-29 15:45:43 +0000366 case PCI_DEVICE_ID_INTEL_82810:
Stefan Tauner04c06002012-10-13 02:19:30 +0200367 case PCI_DEVICE_ID_INTEL_82810_DC:
368 case PCI_DEVICE_ID_INTEL_82810E_DC:
Idwer Vollering312fc962010-12-17 22:34:58 +0000369 case PCI_DEVICE_ID_INTEL_82865:
370 printf("This northbridge does not have DMIBAR.\n");
Stefan Reinauer23190272008-08-20 13:41:24 +0000371 return 1;
Stefan Tauner04c06002012-10-13 02:19:30 +0200372 case PCI_DEVICE_ID_INTEL_82X58:
Warren Turkal3235eea2010-09-03 09:31:13 +0000373 dmibar_phys = pci_read_long(nb, 0x50) & 0xfffff000;
374 break;
Stefan Taunerdbc6fcd2013-06-20 18:05:06 +0200375 case PCI_DEVICE_ID_INTEL_CORE_0TH_GEN:
376 /* DMIBAR is called DMIRCBAR in Nehalem */
377 dmibar_phys = pci_read_long(nb, 0x50) & 0xfffff000; /* 31:12 */
378 dmi_registers = nehalem_dmi_registers;
379 size = ARRAY_SIZE(nehalem_dmi_registers);
380 break;
Stefan Tauner04c06002012-10-13 02:19:30 +0200381 case PCI_DEVICE_ID_INTEL_CORE_1ST_GEN:
382 dmibar_phys = pci_read_long(nb, 0x68);
383 dmibar_phys |= ((uint64_t)pci_read_long(nb, 0x6c)) << 32;
384 dmibar_phys &= 0x0000000ffffff000UL; /* 35:12 */
Stefan Taunerdbc6fcd2013-06-20 18:05:06 +0200385 dmi_registers = westmere_dmi_registers;
386 size = ARRAY_SIZE(westmere_dmi_registers);
Stefan Tauner04c06002012-10-13 02:19:30 +0200387 break;
Felix Held0cc8f292014-11-05 03:18:44 +0100388 case PCI_DEVICE_ID_INTEL_CORE_2ND_GEN_D:
389 case PCI_DEVICE_ID_INTEL_CORE_2ND_GEN_M:
Felix Heldfac95e32014-11-09 00:11:28 +0100390 case PCI_DEVICE_ID_INTEL_CORE_2ND_GEN_E3:
Anton Kochkovc7fc4422012-07-21 06:36:47 +0400391 dmi_registers = sandybridge_dmi_registers;
392 size = ARRAY_SIZE(sandybridge_dmi_registers);
Paul Menzelceac7872017-03-19 20:12:43 +0100393 /* fall through */
Felix Heldfac95e32014-11-09 00:11:28 +0100394 case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_D: /* pretty printing not implemented yet */
395 case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_M:
396 case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_E3:
397 case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_015c:
398 case PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_D:
399 case PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_M:
400 case PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_E3:
Angel Ponsf007ab72022-10-07 00:25:33 +0200401 case PCI_DEVICE_ID_INTEL_CORE_5TH_GEN_D:
402 case PCI_DEVICE_ID_INTEL_CORE_5TH_GEN_M:
Stefan Tauner04c06002012-10-13 02:19:30 +0200403 dmibar_phys = pci_read_long(nb, 0x68);
404 dmibar_phys |= ((uint64_t)pci_read_long(nb, 0x6c)) << 32;
405 dmibar_phys &= 0x0000007ffffff000UL; /* 38:12 */
Anton Kochkovc7fc4422012-07-21 06:36:47 +0400406 break;
Dennis Wassenbergae6685f2014-10-30 10:30:40 +0100407 case PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_U:
Matt DeVillier5b667df2015-05-14 21:58:33 -0500408 case PCI_DEVICE_ID_INTEL_CORE_5TH_GEN_U:
Dennis Wassenbergae6685f2014-10-30 10:30:40 +0100409 dmi_registers = haswell_ult_dmi_registers;
410 size = ARRAY_SIZE(haswell_ult_dmi_registers);
411 dmibar_phys = pci_read_long(nb, 0x68);
412 dmibar_phys |= ((uint64_t)pci_read_long(nb, 0x6c)) << 32;
413 dmibar_phys &= 0x0000007ffffff000UL; /* 38:12 */
414 break;
Nico Huber54fe32f2017-10-03 16:03:07 +0200415 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_D2:
Benjamin Doronc01fa5a2020-07-01 19:20:40 +0000416 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_U:
417 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_Y:
Maximilian Schander98c11dd2017-11-05 05:52:13 +0100418 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_M:
419 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_WST:
Christoph Pomaska48ac29e2018-01-01 01:48:21 +0100420 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_D:
Maxim Polyakov13176892019-08-27 18:20:08 +0300421 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_E:
Matthew Garrett2bf28e52018-07-23 21:09:47 -0700422 case PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_U:
423 case PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_Y:
424 case PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_U_Q:
Christian Walter9a8c5e72019-05-06 17:50:57 +0200425 case PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_E3:
Matt DeVillier3c784452019-06-11 23:23:46 -0500426 case PCI_DEVICE_ID_INTEL_CORE_8TH_GEN_U_1:
427 case PCI_DEVICE_ID_INTEL_CORE_8TH_GEN_U_2:
Maximilian Schander98c11dd2017-11-05 05:52:13 +0100428 dmi_registers = skylake_dmi_registers;
429 size = ARRAY_SIZE(skylake_dmi_registers);
430 dmibar_phys = pci_read_long(nb, 0x68);
431 dmibar_phys |= ((uint64_t)pci_read_long(nb, 0x6c)) << 32;
432 dmibar_phys &= 0x0000007ffffff000UL; /* 38:12 */
433 break;
Brandon Weeks7ee7b132023-12-26 15:55:03 -0800434 case PCI_DEVICE_ID_INTEL_CORE_ADL_ID_N_0_8:
435 case PCI_DEVICE_ID_INTEL_CORE_ADL_ID_N_0_4:
436 case PCI_DEVICE_ID_INTEL_CORE_ADL_ID_N_0_4_1:
437 dmibar_phys = pci_read_long(nb, 0x68) & 0xfffffffe;
438 dmibar_phys |= ((uint64_t)pci_read_long(nb, 0x6c)) << 32;
439 dmi_registers = alderlake_dmi_registers;
440 size = ARRAY_SIZE(alderlake_dmi_registers);
441 break;
Stefan Reinauer23190272008-08-20 13:41:24 +0000442 default:
443 printf("Error: Dumping DMIBAR on this northbridge is not (yet) supported.\n");
444 return 1;
445 }
446
Stefan Reinauer1162f252008-12-04 15:18:20 +0000447 dmibar = map_physical(dmibar_phys, size);
Stefan Reinauer14e22772010-04-27 06:56:47 +0000448
Stefan Reinauer1162f252008-12-04 15:18:20 +0000449 if (dmibar == NULL) {
Stefan Reinauer23190272008-08-20 13:41:24 +0000450 perror("Error mapping DMIBAR");
451 exit(1);
452 }
453
Stefan Reinauera7b296d2011-11-14 12:40:34 -0800454 printf("DMIBAR = 0x%08" PRIx64 " (MEM)\n\n", dmibar_phys);
Anton Kochkovc7fc4422012-07-21 06:36:47 +0400455 if (dmi_registers != NULL) {
456 for (i = 0; i < size; i++) {
457 switch (dmi_registers[i].size) {
458 case 4:
459 printf("dmibase+0x%04x: 0x%08x (%s)\n",
460 dmi_registers[i].addr,
Michael Niewöhner10d52212020-03-13 19:08:21 +0100461 read32(dmibar+dmi_registers[i].addr),
Anton Kochkovc7fc4422012-07-21 06:36:47 +0400462 dmi_registers[i].name);
463 break;
464 case 2:
465 printf("dmibase+0x%04x: 0x%04x (%s)\n",
466 dmi_registers[i].addr,
Michael Niewöhner10d52212020-03-13 19:08:21 +0100467 read16(dmibar+dmi_registers[i].addr),
Anton Kochkovc7fc4422012-07-21 06:36:47 +0400468 dmi_registers[i].name);
469 break;
470 case 1:
471 printf("dmibase+0x%04x: 0x%02x (%s)\n",
472 dmi_registers[i].addr,
Michael Niewöhner10d52212020-03-13 19:08:21 +0100473 read8(dmibar+dmi_registers[i].addr),
Anton Kochkovc7fc4422012-07-21 06:36:47 +0400474 dmi_registers[i].name);
475 break;
476 }
477 }
478 } else {
479 for (i = 0; i < size; i += 4) {
Michael Niewöhner10d52212020-03-13 19:08:21 +0100480 if (read32(dmibar + i))
481 printf("0x%04x: 0x%08x\n", i, read32(dmibar+i));
Anton Kochkovc7fc4422012-07-21 06:36:47 +0400482 }
Stefan Reinauer23190272008-08-20 13:41:24 +0000483 }
484
Stefan Reinauer1162f252008-12-04 15:18:20 +0000485 unmap_physical((void *)dmibar, size);
Stefan Reinauer23190272008-08-20 13:41:24 +0000486 return 0;
487}
488
489/*
490 * PCIe MMIO configuration space
491 */
492int print_pciexbar(struct pci_dev *nb)
493{
Stefan Reinauer1162f252008-12-04 15:18:20 +0000494 uint64_t pciexbar_reg;
495 uint64_t pciexbar_phys;
Stefan Reinauer23190272008-08-20 13:41:24 +0000496 volatile uint8_t *pciexbar;
497 int max_busses, devbase, i;
498 int bus, dev, fn;
499
500 printf("========= PCIEXBAR ========\n\n");
501
502 switch (nb->device_id) {
Pat Erleyca3548e2010-04-21 06:23:19 +0000503 case PCI_DEVICE_ID_INTEL_82915:
Stefan Reinauer23190272008-08-20 13:41:24 +0000504 case PCI_DEVICE_ID_INTEL_82945GM:
Björn Busse2d33dc42010-08-01 15:33:30 +0000505 case PCI_DEVICE_ID_INTEL_82945GSE:
Stefan Reinauer3d9a12f2008-11-02 11:11:40 +0000506 case PCI_DEVICE_ID_INTEL_82945P:
Stefan Reinauer1162f252008-12-04 15:18:20 +0000507 case PCI_DEVICE_ID_INTEL_82975X:
Stefan Reinauer23190272008-08-20 13:41:24 +0000508 pciexbar_reg = pci_read_long(nb, 0x48);
509 break;
Stefan Tauner1a00cf02012-10-13 06:23:52 +0200510 case PCI_DEVICE_ID_INTEL_82946:
Stefan Tauner04c06002012-10-13 02:19:30 +0200511 case PCI_DEVICE_ID_INTEL_82965PM:
512 case PCI_DEVICE_ID_INTEL_82Q965:
513 case PCI_DEVICE_ID_INTEL_82Q35:
514 case PCI_DEVICE_ID_INTEL_82G33:
515 case PCI_DEVICE_ID_INTEL_82Q33:
516 case PCI_DEVICE_ID_INTEL_82X38:
Ruud Schrampbb41f502011-04-04 07:53:19 +0200517 case PCI_DEVICE_ID_INTEL_32X0:
Damien Zammit9c986642015-08-17 21:04:41 +1000518 case PCI_DEVICE_ID_INTEL_82XX4X:
519 case PCI_DEVICE_ID_INTEL_82Q45:
520 case PCI_DEVICE_ID_INTEL_82G45:
521 case PCI_DEVICE_ID_INTEL_82G41:
522 case PCI_DEVICE_ID_INTEL_82B43:
523 case PCI_DEVICE_ID_INTEL_82B43_2:
Corey Osgood23d98c72010-07-29 19:25:31 +0000524 case PCI_DEVICE_ID_INTEL_ATOM_DXXX:
525 case PCI_DEVICE_ID_INTEL_ATOM_NXXX:
Felix Heldfac95e32014-11-09 00:11:28 +0100526 case PCI_DEVICE_ID_INTEL_CORE_2ND_GEN_D:
527 case PCI_DEVICE_ID_INTEL_CORE_2ND_GEN_M:
528 case PCI_DEVICE_ID_INTEL_CORE_2ND_GEN_E3:
529 case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_D:
530 case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_M:
531 case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_E3:
532 case PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_015c:
533 case PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_D:
534 case PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_M:
535 case PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_E3:
Dennis Wassenbergae6685f2014-10-30 10:30:40 +0100536 case PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_U:
Matt DeVillier5b667df2015-05-14 21:58:33 -0500537 case PCI_DEVICE_ID_INTEL_CORE_5TH_GEN_U:
Angel Ponsf007ab72022-10-07 00:25:33 +0200538 case PCI_DEVICE_ID_INTEL_CORE_5TH_GEN_D:
539 case PCI_DEVICE_ID_INTEL_CORE_5TH_GEN_M:
Nico Huber54fe32f2017-10-03 16:03:07 +0200540 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_D2:
Benjamin Doronc01fa5a2020-07-01 19:20:40 +0000541 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_U:
542 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_Y:
Maximilian Schander79856432017-11-05 06:14:55 +0100543 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_M:
544 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_WST:
Christoph Pomaska48ac29e2018-01-01 01:48:21 +0100545 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_D:
Maxim Polyakov13176892019-08-27 18:20:08 +0300546 case PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_E:
Matthew Garrett2bf28e52018-07-23 21:09:47 -0700547 case PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_U:
548 case PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_Y:
549 case PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_U_Q:
Christian Walter9a8c5e72019-05-06 17:50:57 +0200550 case PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_E3:
Matt DeVillier3c784452019-06-11 23:23:46 -0500551 case PCI_DEVICE_ID_INTEL_CORE_8TH_GEN_U_1:
552 case PCI_DEVICE_ID_INTEL_CORE_8TH_GEN_U_2:
Brandon Weeks7ee7b132023-12-26 15:55:03 -0800553 case PCI_DEVICE_ID_INTEL_CORE_ADL_ID_N_0_8:
554 case PCI_DEVICE_ID_INTEL_CORE_ADL_ID_N_0_4:
555 case PCI_DEVICE_ID_INTEL_CORE_ADL_ID_N_0_4_1:
Stefan Tauner04c06002012-10-13 02:19:30 +0200556 pciexbar_reg = pci_read_long(nb, 0x60);
557 pciexbar_reg |= ((uint64_t)pci_read_long(nb, 0x64)) << 32;
558 break;
Stefan Reinauerb2aedb12009-08-29 15:45:43 +0000559 case PCI_DEVICE_ID_INTEL_82810:
Stefan Tauner04c06002012-10-13 02:19:30 +0200560 case PCI_DEVICE_ID_INTEL_82810_DC:
561 case PCI_DEVICE_ID_INTEL_82810E_DC:
Idwer Vollering312fc962010-12-17 22:34:58 +0000562 case PCI_DEVICE_ID_INTEL_82865:
563 printf("Error: This northbridge does not have PCIEXBAR.\n");
Stefan Reinauer23190272008-08-20 13:41:24 +0000564 return 1;
565 default:
566 printf("Error: Dumping PCIEXBAR on this northbridge is not (yet) supported.\n");
567 return 1;
568 }
569
570 if (!(pciexbar_reg & (1 << 0))) {
571 printf("PCIEXBAR register is disabled.\n");
572 return 0;
573 }
574
575 switch ((pciexbar_reg >> 1) & 3) {
576 case 0: // 256MB
Paul Menzel17c05f22013-04-03 10:00:33 +0200577 pciexbar_phys = pciexbar_reg & (0xffULL << 28);
Stefan Reinauer23190272008-08-20 13:41:24 +0000578 max_busses = 256;
579 break;
580 case 1: // 128M
Paul Menzel17c05f22013-04-03 10:00:33 +0200581 pciexbar_phys = pciexbar_reg & (0x1ffULL << 27);
Stefan Reinauer23190272008-08-20 13:41:24 +0000582 max_busses = 128;
583 break;
584 case 2: // 64M
Paul Menzel17c05f22013-04-03 10:00:33 +0200585 pciexbar_phys = pciexbar_reg & (0x3ffULL << 26);
Stefan Reinauer23190272008-08-20 13:41:24 +0000586 max_busses = 64;
587 break;
588 default: // RSVD
589 printf("Undefined address base. Bailing out.\n");
590 return 1;
Stefan Reinauer14e22772010-04-27 06:56:47 +0000591 }
Stefan Reinauer23190272008-08-20 13:41:24 +0000592
Stefan Reinauera7b296d2011-11-14 12:40:34 -0800593 printf("PCIEXBAR: 0x%08" PRIx64 "\n", pciexbar_phys);
Stefan Reinauer23190272008-08-20 13:41:24 +0000594
Stefan Reinauer1162f252008-12-04 15:18:20 +0000595 pciexbar = map_physical(pciexbar_phys, (max_busses * 1024 * 1024));
Stefan Reinauer14e22772010-04-27 06:56:47 +0000596
Stefan Reinauer1162f252008-12-04 15:18:20 +0000597 if (pciexbar == NULL) {
Stefan Reinauer23190272008-08-20 13:41:24 +0000598 perror("Error mapping PCIEXBAR");
599 exit(1);
600 }
Stefan Reinauer14e22772010-04-27 06:56:47 +0000601
Stefan Reinauer23190272008-08-20 13:41:24 +0000602 for (bus = 0; bus < max_busses; bus++) {
603 for (dev = 0; dev < 32; dev++) {
604 for (fn = 0; fn < 8; fn++) {
605 devbase = (bus * 1024 * 1024) + (dev * 32 * 1024) + (fn * 4 * 1024);
606
Michael Niewöhner10d52212020-03-13 19:08:21 +0100607 if (read16(pciexbar + devbase) == 0xffff)
Stefan Reinauer23190272008-08-20 13:41:24 +0000608 continue;
Stefan Reinauer14e22772010-04-27 06:56:47 +0000609
Stefan Reinauer23190272008-08-20 13:41:24 +0000610 /* This is a heuristics. Anyone got a better check? */
Michael Niewöhner10d52212020-03-13 19:08:21 +0100611 if( (read32(pciexbar + devbase + 256) == 0xffffffff) &&
612 (read32(pciexbar + devbase + 512) == 0xffffffff) ) {
Stefan Reinauer23190272008-08-20 13:41:24 +0000613#if DEBUG
614 printf("Skipped non-PCIe device %02x:%02x.%01x\n", bus, dev, fn);
615#endif
616 continue;
617 }
618
619 printf("\nPCIe %02x:%02x.%01x extended config space:", bus, dev, fn);
620 for (i = 0; i < 4096; i++) {
621 if((i % 0x10) == 0)
622 printf("\n%04x:", i);
623 printf(" %02x", *(pciexbar+devbase+i));
624 }
625 printf("\n");
626 }
627 }
628 }
629
Stefan Reinauer1162f252008-12-04 15:18:20 +0000630 unmap_physical((void *)pciexbar, (max_busses * 1024 * 1024));
Stefan Reinauer23190272008-08-20 13:41:24 +0000631
632 return 0;
633}