blob: f475eb7e23eaed4798db072b38c2ae9001938d13 [file] [log] [blame]
jljusten21b404d2009-05-27 21:09:52 +00001/** @file
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +00002 The Header file of the Pci Host Bridge Driver
jljusten21b404d2009-05-27 21:09:52 +00003
rsun3cac2ab92010-06-18 09:21:47 +00004 Copyright (c) 2008 - 2010, Intel Corporation. All rights reserved.<BR>
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +00005
6 This program and the accompanying materials are licensed and made available
7 under the terms and conditions of the BSD License which accompanies this
8 distribution. The full text of the license may be found at
jljusten21b404d2009-05-27 21:09:52 +00009 http://opensource.org/licenses/bsd-license.php
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +000010
jljusten21b404d2009-05-27 21:09:52 +000011 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
12 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +000013**/
jljusten21b404d2009-05-27 21:09:52 +000014
15#ifndef _PCI_HOST_BRIDGE_H_
16#define _PCI_HOST_BRIDGE_H_
17
18#include <PiDxe.h>
19
20#include <IndustryStandard/Pci.h>
21#include <IndustryStandard/Acpi.h>
22
23#include <Protocol/PciHostBridgeResourceAllocation.h>
24#include <Protocol/PciRootBridgeIo.h>
jljusten21b404d2009-05-27 21:09:52 +000025#include <Protocol/Metronome.h>
26#include <Protocol/DevicePath.h>
27
28
29#include <Library/BaseLib.h>
30#include <Library/DebugLib.h>
31#include <Library/BaseMemoryLib.h>
32#include <Library/MemoryAllocationLib.h>
33#include <Library/UefiLib.h>
34#include <Library/UefiBootServicesTableLib.h>
35#include <Library/DxeServicesTableLib.h>
36#include <Library/DevicePathLib.h>
rsun3cac2ab92010-06-18 09:21:47 +000037#include <Library/IoLib.h>
38#include <Library/PciLib.h>
jljusten21b404d2009-05-27 21:09:52 +000039
40//
41// Hard code the host bridge number in the platform.
42// In this chipset, there is only one host bridge.
43//
44#define HOST_BRIDGE_NUMBER 1
45
rsun3cac2ab92010-06-18 09:21:47 +000046#define MAX_PCI_DEVICE_NUMBER 31
47#define MAX_PCI_FUNCTION_NUMBER 7
48#define MAX_PCI_REG_ADDRESS 0xFF
49
50typedef enum {
51 IoOperation,
52 MemOperation,
53 PciOperation
54} OPERATION_TYPE;
55
jljusten21b404d2009-05-27 21:09:52 +000056#define PCI_HOST_BRIDGE_SIGNATURE SIGNATURE_32('e', 'h', 's', 't')
57typedef struct {
58 UINTN Signature;
59 EFI_HANDLE HostBridgeHandle;
60 UINTN RootBridgeNumber;
61 LIST_ENTRY Head;
Laszlo Ersek947b1f32015-07-14 12:01:11 +000062 BOOLEAN ResourceSubmited;
63 BOOLEAN CanRestarted;
jljusten21b404d2009-05-27 21:09:52 +000064 EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL ResAlloc;
65} PCI_HOST_BRIDGE_INSTANCE;
66
67#define INSTANCE_FROM_RESOURCE_ALLOCATION_THIS(a) \
68 CR(a, PCI_HOST_BRIDGE_INSTANCE, ResAlloc, PCI_HOST_BRIDGE_SIGNATURE)
Laszlo Ersek947b1f32015-07-14 12:01:11 +000069
jljusten21b404d2009-05-27 21:09:52 +000070//
71// HostBridge Resource Allocation interface
72//
ydong1024115e42010-09-17 10:42:10 +000073
74/**
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +000075 These are the notifications from the PCI bus driver that it is about to enter
76 a certain phase of the PCI enumeration process.
ydong1024115e42010-09-17 10:42:10 +000077
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +000078 This member function can be used to notify the host bridge driver to perform
79 specific actions, including any chipset-specific initialization, so that the
80 chipset is ready to enter the next phase. Eight notification points are
81 defined at this time. See belows:
ydong1024115e42010-09-17 10:42:10 +000082
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +000083 EfiPciHostBridgeBeginEnumeration Resets the host bridge PCI apertures
84 and internal data structures. The PCI
85 enumerator should issue this
86 notification before starting a fresh
87 enumeration process. Enumeration
88 cannot be restarted after sending any
89 other notification such as
90 EfiPciHostBridgeBeginBusAllocation.
ydong1024115e42010-09-17 10:42:10 +000091
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +000092 EfiPciHostBridgeBeginBusAllocation The bus allocation phase is about to
93 begin. No specific action is required
94 here. This notification can be used to
95 perform any chipset-specific
96 programming.
ydong1024115e42010-09-17 10:42:10 +000097
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +000098 EfiPciHostBridgeEndBusAllocation The bus allocation and bus programming
99 phase is complete. No specific action
100 is required here. This notification
101 can be used to perform any
102 chipset-specific programming.
103
104 EfiPciHostBridgeBeginResourceAllocation
105 The resource allocation phase is about
106 to begin. No specific action is
107 required here. This notification can
108 be used to perform any
109 chipset-specific programming.
110
111 EfiPciHostBridgeAllocateResources Allocates resources per previously
112 submitted requests for all the PCI
113 root bridges. These resource settings
114 are returned on the next call to
115 GetProposedResources(). Before calling
116 NotifyPhase() with a Phase of
117 EfiPciHostBridgeAllocateResource, the
118 PCI bus enumerator is responsible for
119 gathering I/O and memory requests for
120 all the PCI root bridges and
121 submitting these requests using
122 SubmitResources(). This function pads
123 the resource amount to suit the root
124 bridge hardware, takes care of
125 dependencies between the PCI root
126 bridges, and calls the Global
127 Coherency Domain (GCD) with the
128 allocation request. In the case of
129 padding, the allocated range could be
130 bigger than what was requested.
131
132 EfiPciHostBridgeSetResources Programs the host bridge hardware to
133 decode previously allocated resources
134 (proposed resources) for all the PCI
135 root bridges. After the hardware is
136 programmed, reassigning resources will
137 not be supported. The bus settings are
138 not affected.
139
140 EfiPciHostBridgeFreeResources Deallocates resources that were
141 previously allocated for all the PCI
142 root bridges and resets the I/O and
143 memory apertures to their initial
144 state. The bus settings are not
145 affected. If the request to allocate
146 resources fails, the PCI enumerator
147 can use this notification to
148 deallocate previous resources, adjust
149 the requests, and retry allocation.
150
151 EfiPciHostBridgeEndResourceAllocation The resource allocation phase is
152 completed. No specific action is
153 required here. This notification can
154 be used to perform any chipsetspecific
155 programming.
156
157 @param[in] This The instance pointer of
158 EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL
159
160 @param[in] Phase The phase during enumeration
161
162 @retval EFI_NOT_READY This phase cannot be entered at this time. For
163 example, this error is valid for a Phase of
164 EfiPciHostBridgeAllocateResources if
165 SubmitResources() has not been called for one
166 or more PCI root bridges before this call
167
168 @retval EFI_DEVICE_ERROR Programming failed due to a hardware error.
169 This error is valid for a Phase of
170 EfiPciHostBridgeSetResources.
171
172 @retval EFI_INVALID_PARAMETER Invalid phase parameter
173
174 @retval EFI_OUT_OF_RESOURCES The request could not be completed due to a
175 lack of resources. This error is valid for a
176 Phase of EfiPciHostBridgeAllocateResources if
177 the previously submitted resource requests
178 cannot be fulfilled or were only partially
179 fulfilled.
180
181 @retval EFI_SUCCESS The notification was accepted without any
182 errors.
ydong1024115e42010-09-17 10:42:10 +0000183**/
jljusten21b404d2009-05-27 21:09:52 +0000184EFI_STATUS
185EFIAPI
186NotifyPhase(
187 IN EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL *This,
188 IN EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PHASE Phase
189 );
190
ydong1024115e42010-09-17 10:42:10 +0000191/**
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000192 Return the device handle of the next PCI root bridge that is associated with
193 this Host Bridge.
ydong1024115e42010-09-17 10:42:10 +0000194
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000195 This function is called multiple times to retrieve the device handles of all
196 the PCI root bridges that are associated with this PCI host bridge. Each PCI
197 host bridge is associated with one or more PCI root bridges. On each call,
198 the handle that was returned by the previous call is passed into the
199 interface, and on output the interface returns the device handle of the next
200 PCI root bridge. The caller can use the handle to obtain the instance of the
201 EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL for that root bridge. When there are no more
202 PCI root bridges to report, the interface returns EFI_NOT_FOUND. A PCI
203 enumerator must enumerate the PCI root bridges in the order that they are
204 returned by this function.
ydong1024115e42010-09-17 10:42:10 +0000205
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000206 For D945 implementation, there is only one root bridge in PCI host bridge.
207
208 @param[in] This The instance pointer of
209 EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL
210
211 @param[in, out] RootBridgeHandle Returns the device handle of the next PCI
212 root bridge.
213
214 @retval EFI_SUCCESS If parameter RootBridgeHandle = NULL, then
215 return the first Rootbridge handle of the
216 specific Host bridge and return EFI_SUCCESS.
217
218 @retval EFI_NOT_FOUND Can not find the any more root bridge in
219 specific host bridge.
220
221 @retval EFI_INVALID_PARAMETER RootBridgeHandle is not an EFI_HANDLE that was
222 returned on a previous call to
223 GetNextRootBridge().
ydong1024115e42010-09-17 10:42:10 +0000224**/
jljusten21b404d2009-05-27 21:09:52 +0000225EFI_STATUS
226EFIAPI
227GetNextRootBridge(
228 IN EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL *This,
229 IN OUT EFI_HANDLE *RootBridgeHandle
230 );
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000231
ydong1024115e42010-09-17 10:42:10 +0000232/**
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000233 Returns the allocation attributes of a PCI root bridge.
ydong1024115e42010-09-17 10:42:10 +0000234
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000235 The function returns the allocation attributes of a specific PCI root bridge.
236 The attributes can vary from one PCI root bridge to another. These attributes
237 are different from the decode-related attributes that are returned by the
238 EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL.GetAttributes() member function. The
239 RootBridgeHandle parameter is used to specify the instance of the PCI root
240 bridge. The device handles of all the root bridges that are associated with
241 this host bridge must be obtained by calling GetNextRootBridge(). The
242 attributes are static in the sense that they do not change during or after
243 the enumeration process. The hardware may provide mechanisms to change the
244 attributes on the fly, but such changes must be completed before
245 EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL is installed. The permitted
246 values of EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_ATTRIBUTES are defined in
247 "Related Definitions" below. The caller uses these attributes to combine
248 multiple resource requests.
ydong1024115e42010-09-17 10:42:10 +0000249
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000250 For example, if the flag EFI_PCI_HOST_BRIDGE_COMBINE_MEM_PMEM is set, the PCI
251 bus enumerator needs to include requests for the prefetchable memory in the
252 nonprefetchable memory pool and not request any prefetchable memory.
ydong1024115e42010-09-17 10:42:10 +0000253
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000254 Attribute Description
255 ------------------------------------ ---------------------------------------
256 EFI_PCI_HOST_BRIDGE_COMBINE_MEM_PMEM If this bit is set, then the PCI root
257 bridge does not support separate
258 windows for nonprefetchable and
259 prefetchable memory. A PCI bus driver
260 needs to include requests for
261 prefetchable memory in the
262 nonprefetchable memory pool.
ydong1024115e42010-09-17 10:42:10 +0000263
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000264 EFI_PCI_HOST_BRIDGE_MEM64_DECODE If this bit is set, then the PCI root
265 bridge supports 64-bit memory windows.
266 If this bit is not set, the PCI bus
267 driver needs to include requests for a
268 64-bit memory address in the
269 corresponding 32-bit memory pool.
270
271 @param[in] This The instance pointer of
272 EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL
273
274 @param[in] RootBridgeHandle The device handle of the PCI root bridge in
275 which the caller is interested. Type
276 EFI_HANDLE is defined in
277 InstallProtocolInterface() in the UEFI 2.0
278 Specification.
279
280 @param[out] Attributes The pointer to attribte of root bridge, it is
281 output parameter
282
283 @retval EFI_INVALID_PARAMETER Attribute pointer is NULL
284
285 @retval EFI_INVALID_PARAMETER RootBridgehandle is invalid.
286
287 @retval EFI_SUCCESS Success to get attribute of interested root
288 bridge.
289**/
jljusten21b404d2009-05-27 21:09:52 +0000290EFI_STATUS
291EFIAPI
292GetAttributes(
293 IN EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL *This,
294 IN EFI_HANDLE RootBridgeHandle,
295 OUT UINT64 *Attributes
296 );
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000297
ydong1024115e42010-09-17 10:42:10 +0000298/**
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000299 Sets up the specified PCI root bridge for the bus enumeration process.
ydong1024115e42010-09-17 10:42:10 +0000300
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000301 This member function sets up the root bridge for bus enumeration and returns
302 the PCI bus range over which the search should be performed in ACPI 2.0
303 resource descriptor format.
ydong1024115e42010-09-17 10:42:10 +0000304
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000305 @param[in] This The
306 EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL
307 instance.
ydong1024115e42010-09-17 10:42:10 +0000308
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000309 @param[in] RootBridgeHandle The PCI Root Bridge to be set up.
310
311 @param[out] Configuration Pointer to the pointer to the PCI bus resource
312 descriptor.
313
314 @retval EFI_INVALID_PARAMETER Invalid Root bridge's handle
315
316 @retval EFI_OUT_OF_RESOURCES Fail to allocate ACPI resource descriptor tag.
317
318 @retval EFI_SUCCESS Sucess to allocate ACPI resource descriptor.
ydong1024115e42010-09-17 10:42:10 +0000319**/
jljusten21b404d2009-05-27 21:09:52 +0000320EFI_STATUS
321EFIAPI
322StartBusEnumeration(
323 IN EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL *This,
324 IN EFI_HANDLE RootBridgeHandle,
325 OUT VOID **Configuration
326 );
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000327
ydong1024115e42010-09-17 10:42:10 +0000328/**
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000329 Programs the PCI root bridge hardware so that it decodes the specified PCI
330 bus range.
ydong1024115e42010-09-17 10:42:10 +0000331
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000332 This member function programs the specified PCI root bridge to decode the bus
333 range that is specified by the input parameter Configuration.
334 The bus range information is specified in terms of the ACPI 2.0 resource
335 descriptor format.
ydong1024115e42010-09-17 10:42:10 +0000336
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000337 @param[in] This The
338 EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL
339 instance
ydong1024115e42010-09-17 10:42:10 +0000340
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000341 @param[in] RootBridgeHandle The PCI Root Bridge whose bus range is to be
342 programmed
343
344 @param[in] Configuration The pointer to the PCI bus resource descriptor
345
346 @retval EFI_INVALID_PARAMETER RootBridgeHandle is not a valid root bridge
347 handle.
348
349 @retval EFI_INVALID_PARAMETER Configuration is NULL.
350
351 @retval EFI_INVALID_PARAMETER Configuration does not point to a valid ACPI
352 2.0 resource descriptor.
353
354 @retval EFI_INVALID_PARAMETER Configuration does not include a valid ACPI
355 2.0 bus resource descriptor.
356
357 @retval EFI_INVALID_PARAMETER Configuration includes valid ACPI 2.0 resource
358 descriptors other than bus descriptors.
359
360 @retval EFI_INVALID_PARAMETER Configuration contains one or more invalid
361 ACPI resource descriptors.
362
363 @retval EFI_INVALID_PARAMETER "Address Range Minimum" is invalid for this
364 root bridge.
365
366 @retval EFI_INVALID_PARAMETER "Address Range Length" is invalid for this
367 root bridge.
368
369 @retval EFI_DEVICE_ERROR Programming failed due to a hardware error.
370
371 @retval EFI_SUCCESS The bus range for the PCI root bridge was
372 programmed.
ydong1024115e42010-09-17 10:42:10 +0000373**/
jljusten21b404d2009-05-27 21:09:52 +0000374EFI_STATUS
375EFIAPI
376SetBusNumbers(
377 IN EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL *This,
378 IN EFI_HANDLE RootBridgeHandle,
379 IN VOID *Configuration
380 );
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000381
ydong1024115e42010-09-17 10:42:10 +0000382/**
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000383 Submits the I/O and memory resource requirements for the specified PCI root
384 bridge.
ydong1024115e42010-09-17 10:42:10 +0000385
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000386 This function is used to submit all the I/O and memory resources that are
387 required by the specified PCI root bridge. The input parameter Configuration
388 is used to specify the following:
389 - The various types of resources that are required
390 - The associated lengths in terms of ACPI 2.0 resource descriptor format
ydong1024115e42010-09-17 10:42:10 +0000391
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000392 @param[in] This Pointer to the
393 EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL
394 instance.
ydong1024115e42010-09-17 10:42:10 +0000395
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000396 @param[in] RootBridgeHandle The PCI root bridge whose I/O and memory
397 resource requirements are being submitted.
398
399 @param[in] Configuration The pointer to the PCI I/O and PCI memory
400 resource descriptor.
401
402 @retval EFI_SUCCESS The I/O and memory resource requests for a PCI
403 root bridge were accepted.
404
405 @retval EFI_INVALID_PARAMETER RootBridgeHandle is not a valid root bridge
406 handle.
407
408 @retval EFI_INVALID_PARAMETER Configuration is NULL.
409
410 @retval EFI_INVALID_PARAMETER Configuration does not point to a valid ACPI
411 2.0 resource descriptor.
412
413 @retval EFI_INVALID_PARAMETER Configuration includes requests for one or
414 more resource types that are not supported by
415 this PCI root bridge. This error will happen
416 if the caller did not combine resources
417 according to Attributes that were returned by
418 GetAllocAttributes().
419
420 @retval EFI_INVALID_PARAMETER Address Range Maximum" is invalid.
421
422 @retval EFI_INVALID_PARAMETER "Address Range Length" is invalid for this PCI
423 root bridge.
424
425 @retval EFI_INVALID_PARAMETER "Address Space Granularity" is invalid for
426 this PCI root bridge.
ydong1024115e42010-09-17 10:42:10 +0000427**/
jljusten21b404d2009-05-27 21:09:52 +0000428EFI_STATUS
429EFIAPI
430SubmitResources(
431 IN EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL *This,
432 IN EFI_HANDLE RootBridgeHandle,
433 IN VOID *Configuration
434 );
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000435
ydong1024115e42010-09-17 10:42:10 +0000436/**
437 Returns the proposed resource settings for the specified PCI root bridge.
438
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000439 This member function returns the proposed resource settings for the
440 specified PCI root bridge. The proposed resource settings are prepared when
441 NotifyPhase() is called with a Phase of EfiPciHostBridgeAllocateResources.
442 The output parameter Configuration specifies the following:
443 - The various types of resources, excluding bus resources, that are
444 allocated
ydong1024115e42010-09-17 10:42:10 +0000445 - The associated lengths in terms of ACPI 2.0 resource descriptor format
446
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000447 @param[in] This Pointer to the
448 EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL
449 instance.
ydong1024115e42010-09-17 10:42:10 +0000450
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000451 @param[in] RootBridgeHandle The PCI root bridge handle. Type EFI_HANDLE is
452 defined in InstallProtocolInterface() in the
453 UEFI 2.0 Specification.
454
455 @param[out] Configuration The pointer to the pointer to the PCI I/O and
456 memory resource descriptor.
457
458 @retval EFI_SUCCESS The requested parameters were returned.
459
460 @retval EFI_INVALID_PARAMETER RootBridgeHandle is not a valid root bridge
461 handle.
462
463 @retval EFI_DEVICE_ERROR Programming failed due to a hardware error.
464
465 @retval EFI_OUT_OF_RESOURCES The request could not be completed due to a
466 lack of resources.
ydong1024115e42010-09-17 10:42:10 +0000467**/
jljusten21b404d2009-05-27 21:09:52 +0000468EFI_STATUS
469EFIAPI
470GetProposedResources(
471 IN EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL *This,
472 IN EFI_HANDLE RootBridgeHandle,
473 OUT VOID **Configuration
474 );
475
ydong1024115e42010-09-17 10:42:10 +0000476/**
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000477 Provides the hooks from the PCI bus driver to every PCI controller
478 (device/function) at various stages of the PCI enumeration process that allow
479 the host bridge driver to preinitialize individual PCI controllers before
480 enumeration.
ydong1024115e42010-09-17 10:42:10 +0000481
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000482 This function is called during the PCI enumeration process. No specific
483 action is expected from this member function. It allows the host bridge
484 driver to preinitialize individual PCI controllers before enumeration.
ydong1024115e42010-09-17 10:42:10 +0000485
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000486 @param This Pointer to the
487 EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL
488 instance.
ydong1024115e42010-09-17 10:42:10 +0000489
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000490 @param RootBridgeHandle The associated PCI root bridge handle. Type
491 EFI_HANDLE is defined in InstallProtocolInterface()
492 in the UEFI 2.0 Specification.
493
494 @param PciAddress The address of the PCI device on the PCI bus. This
495 address can be passed to the
496 EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL member functions to
497 access the PCI configuration space of the device.
498 See Table 12-1 in the UEFI 2.0 Specification for the
499 definition of
500 EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL_PCI_ADDRESS.
501
502 @param Phase The phase of the PCI device enumeration.
503
504 @retval EFI_SUCCESS The requested parameters were returned.
505
506 @retval EFI_INVALID_PARAMETER RootBridgeHandle is not a valid root bridge
507 handle.
508
509 @retval EFI_INVALID_PARAMETER Phase is not a valid phase that is defined
510 in
511 EFI_PCI_CONTROLLER_RESOURCE_ALLOCATION_PHASE.
512
513 @retval EFI_DEVICE_ERROR Programming failed due to a hardware error.
514 The PCI enumerator should not enumerate this
515 device, including its child devices if it is
516 a PCI-to-PCI bridge.
ydong1024115e42010-09-17 10:42:10 +0000517**/
jljusten21b404d2009-05-27 21:09:52 +0000518EFI_STATUS
519EFIAPI
520PreprocessController (
521 IN EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL *This,
522 IN EFI_HANDLE RootBridgeHandle,
523 IN EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL_PCI_ADDRESS PciAddress,
524 IN EFI_PCI_CONTROLLER_RESOURCE_ALLOCATION_PHASE Phase
525 );
526
527
528//
Laszlo Ersek90ac6ac2015-07-14 12:01:07 +0000529// Define resource status constant
jljusten21b404d2009-05-27 21:09:52 +0000530//
531#define EFI_RESOURCE_NONEXISTENT 0xFFFFFFFFFFFFFFFFULL
532#define EFI_RESOURCE_LESS 0xFFFFFFFFFFFFFFFEULL
533
534
535//
536// Driver Instance Data Prototypes
537//
538
539typedef struct {
540 EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL_OPERATION Operation;
541 UINTN NumberOfBytes;
542 UINTN NumberOfPages;
543 EFI_PHYSICAL_ADDRESS HostAddress;
544 EFI_PHYSICAL_ADDRESS MappedHostAddress;
545} MAP_INFO;
546
547typedef struct {
548 ACPI_HID_DEVICE_PATH AcpiDevicePath;
549 EFI_DEVICE_PATH_PROTOCOL EndDevicePath;
550} EFI_PCI_ROOT_BRIDGE_DEVICE_PATH;
551
552typedef struct {
553 UINT64 BusBase;
Laszlo Ersek947b1f32015-07-14 12:01:11 +0000554 UINT64 BusLimit;
555
556 UINT64 MemBase;
557 UINT64 MemLimit;
558
559 UINT64 IoBase;
560 UINT64 IoLimit;
Laszlo Ersek0b7c6cd2015-02-23 16:02:34 +0000561} PCI_ROOT_BRIDGE_RESOURCE_APERTURE;
jljusten21b404d2009-05-27 21:09:52 +0000562
563typedef enum {
564 TypeIo = 0,
565 TypeMem32,
566 TypePMem32,
567 TypeMem64,
568 TypePMem64,
569 TypeBus,
570 TypeMax
571} PCI_RESOURCE_TYPE;
572
573typedef enum {
574 ResNone = 0,
575 ResSubmitted,
576 ResRequested,
577 ResAllocated,
578 ResStatusMax
579} RES_STATUS;
580
581typedef struct {
582 PCI_RESOURCE_TYPE Type;
583 UINT64 Base;
584 UINT64 Length;
585 UINT64 Alignment;
586 RES_STATUS Status;
587} PCI_RES_NODE;
588
589#define PCI_ROOT_BRIDGE_SIGNATURE SIGNATURE_32('e', '2', 'p', 'b')
590
591typedef struct {
592 UINT32 Signature;
593 LIST_ENTRY Link;
594 EFI_HANDLE Handle;
595 UINT64 RootBridgeAttrib;
596 UINT64 Attributes;
597 UINT64 Supports;
Laszlo Ersek947b1f32015-07-14 12:01:11 +0000598
jljusten21b404d2009-05-27 21:09:52 +0000599 //
600 // Specific for this memory controller: Bus, I/O, Mem
601 //
602 PCI_RES_NODE ResAllocNode[6];
Laszlo Ersek947b1f32015-07-14 12:01:11 +0000603
jljusten21b404d2009-05-27 21:09:52 +0000604 //
605 // Addressing for Memory and I/O and Bus arrange
606 //
607 UINT64 BusBase;
Laszlo Ersek947b1f32015-07-14 12:01:11 +0000608 UINT64 MemBase;
609 UINT64 IoBase;
610 UINT64 BusLimit;
611 UINT64 MemLimit;
612 UINT64 IoLimit;
jljusten21b404d2009-05-27 21:09:52 +0000613
jljusten21b404d2009-05-27 21:09:52 +0000614 EFI_DEVICE_PATH_PROTOCOL *DevicePath;
615 EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL Io;
616
617} PCI_ROOT_BRIDGE_INSTANCE;
618
619
620//
621// Driver Instance Data Macros
622//
623#define DRIVER_INSTANCE_FROM_PCI_ROOT_BRIDGE_IO_THIS(a) \
624 CR(a, PCI_ROOT_BRIDGE_INSTANCE, Io, PCI_ROOT_BRIDGE_SIGNATURE)
625
626
627#define DRIVER_INSTANCE_FROM_LIST_ENTRY(a) \
628 CR(a, PCI_ROOT_BRIDGE_INSTANCE, Link, PCI_ROOT_BRIDGE_SIGNATURE)
629
ydong1024115e42010-09-17 10:42:10 +0000630/**
jljusten21b404d2009-05-27 21:09:52 +0000631
ydong1024115e42010-09-17 10:42:10 +0000632 Construct the Pci Root Bridge Io protocol
633
634 @param Protocol Point to protocol instance
635 @param HostBridgeHandle Handle of host bridge
636 @param Attri Attribute of host bridge
Laszlo Ersek0b7c6cd2015-02-23 16:02:34 +0000637 @param ResAperture ResourceAperture for host bridge
ydong1024115e42010-09-17 10:42:10 +0000638
639 @retval EFI_SUCCESS Success to initialize the Pci Root Bridge.
ydong1024115e42010-09-17 10:42:10 +0000640**/
jljusten21b404d2009-05-27 21:09:52 +0000641EFI_STATUS
642RootBridgeConstructor (
643 IN EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL *Protocol,
644 IN EFI_HANDLE HostBridgeHandle,
645 IN UINT64 Attri,
Laszlo Ersek0b7c6cd2015-02-23 16:02:34 +0000646 IN PCI_ROOT_BRIDGE_RESOURCE_APERTURE *ResAperture
jljusten21b404d2009-05-27 21:09:52 +0000647 );
648
649#endif