2008-12-25 09:59:02 +01:00
|
|
|
/** @file
|
2009-06-23 09:19:00 +02:00
|
|
|
Supporting functions declaration for PCI devices management.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-25 15:47:45 +02:00
|
|
|
Copyright (c) 2006 - 2009, Intel Corporation
|
|
|
|
All rights reserved. This program and the accompanying materials
|
|
|
|
are licensed and made available under the terms and conditions of the BSD License
|
|
|
|
which accompanies this distribution. The full text of the license may be found at
|
|
|
|
http://opensource.org/licenses/bsd-license.php
|
|
|
|
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2007-07-23 09:06:23 +02:00
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-01-08 09:48:15 +01:00
|
|
|
#ifndef _EFI_PCI_DEVICE_SUPPORT_H_
|
|
|
|
#define _EFI_PCI_DEVICE_SUPPORT_H_
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
2009-06-23 09:19:00 +02:00
|
|
|
Initialize the PCI devices pool.
|
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
**/
|
2009-06-23 09:19:00 +02:00
|
|
|
VOID
|
2007-06-28 16:02:17 +02:00
|
|
|
InitializePciDevicePool (
|
|
|
|
VOID
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
2009-06-23 09:19:00 +02:00
|
|
|
Insert a root bridge into PCI device pool.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@param RootBridge A pointer to the PCI_IO_DEVICE.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-14 05:12:57 +02:00
|
|
|
**/
|
2009-06-23 09:19:00 +02:00
|
|
|
VOID
|
2007-06-28 16:02:17 +02:00
|
|
|
InsertRootBridge (
|
2009-06-23 09:19:00 +02:00
|
|
|
IN PCI_IO_DEVICE *RootBridge
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
|
|
|
This function is used to insert a PCI device node under
|
2009-06-23 09:19:00 +02:00
|
|
|
a bridge.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@param Bridge The PCI bridge.
|
|
|
|
@param PciDeviceNode The PCI device needs inserting.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-14 05:12:57 +02:00
|
|
|
**/
|
2009-06-23 09:19:00 +02:00
|
|
|
VOID
|
2007-06-28 16:02:17 +02:00
|
|
|
InsertPciDevice (
|
2009-06-23 09:19:00 +02:00
|
|
|
IN PCI_IO_DEVICE *Bridge,
|
|
|
|
IN PCI_IO_DEVICE *PciDeviceNode
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
|
|
|
Destroy root bridge and remove it from deivce tree.
|
2009-06-25 15:47:45 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@param RootBridge The bridge want to be removed.
|
2009-06-25 15:47:45 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
**/
|
2009-06-23 09:19:00 +02:00
|
|
|
VOID
|
2007-06-28 16:02:17 +02:00
|
|
|
DestroyRootBridge (
|
2009-06-23 09:19:00 +02:00
|
|
|
IN PCI_IO_DEVICE *RootBridge
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
|
|
|
Destroy all the pci device node under the bridge.
|
|
|
|
Bridge itself is not included.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@param Bridge A pointer to the PCI_IO_DEVICE.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-14 05:12:57 +02:00
|
|
|
**/
|
2009-06-23 09:19:00 +02:00
|
|
|
VOID
|
2007-06-28 16:02:17 +02:00
|
|
|
DestroyPciDeviceTree (
|
2009-06-23 09:19:00 +02:00
|
|
|
IN PCI_IO_DEVICE *Bridge
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
|
|
|
Destroy all device nodes under the root bridge
|
|
|
|
specified by Controller.
|
2009-06-23 09:19:00 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
The root bridge itself is also included.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@param Controller Root bridge handle.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Destory all devcie nodes successfully.
|
|
|
|
@retval EFI_NOT_FOUND Cannot find any PCI device under specified
|
|
|
|
root bridge.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-14 05:12:57 +02:00
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
EFI_STATUS
|
|
|
|
DestroyRootBridgeByHandle (
|
2009-06-23 09:19:00 +02:00
|
|
|
IN EFI_HANDLE Controller
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
2009-06-25 15:47:45 +02:00
|
|
|
This function registers the PCI IO device.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-25 15:47:45 +02:00
|
|
|
It creates a handle for this PCI IO device (if the handle does not exist), attaches
|
|
|
|
appropriate protocols onto the handle, does necessary initialization, and sets up
|
2009-06-23 09:19:00 +02:00
|
|
|
parent/child relationship with its bus controller.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@param Controller An EFI handle for the PCI bus controller.
|
|
|
|
@param PciIoDevice A PCI_IO_DEVICE pointer to the PCI IO device to be registered.
|
|
|
|
@param Handle A pointer to hold the returned EFI handle for the PCI IO device.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The PCI device is successfully registered.
|
2009-06-25 15:47:45 +02:00
|
|
|
@retval other An error occurred when registering the PCI device.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-14 05:12:57 +02:00
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
EFI_STATUS
|
|
|
|
RegisterPciDevice (
|
2009-06-23 09:19:00 +02:00
|
|
|
IN EFI_HANDLE Controller,
|
|
|
|
IN PCI_IO_DEVICE *PciIoDevice,
|
|
|
|
OUT EFI_HANDLE *Handle OPTIONAL
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
2009-06-23 09:19:00 +02:00
|
|
|
This function is used to remove the whole PCI devices on the specified bridge from
|
|
|
|
the root bridge.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@param RootBridgeHandle The root bridge device handle.
|
|
|
|
@param Bridge The bridge device to be removed.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-14 05:12:57 +02:00
|
|
|
**/
|
2009-06-23 09:19:00 +02:00
|
|
|
VOID
|
2007-06-28 16:02:17 +02:00
|
|
|
RemoveAllPciDeviceOnBridge (
|
|
|
|
EFI_HANDLE RootBridgeHandle,
|
|
|
|
PCI_IO_DEVICE *Bridge
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
2009-06-23 09:19:00 +02:00
|
|
|
This function is used to de-register the PCI IO device.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
That includes un-installing PciIo protocol from the specified PCI
|
|
|
|
device handle.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@param Controller An EFI handle for the PCI bus controller.
|
|
|
|
@param Handle PCI device handle.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The PCI device is successfully de-registered.
|
2009-06-25 15:47:45 +02:00
|
|
|
@retval other An error occurred when de-registering the PCI device.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-14 05:12:57 +02:00
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
EFI_STATUS
|
|
|
|
DeRegisterPciDevice (
|
|
|
|
IN EFI_HANDLE Controller,
|
|
|
|
IN EFI_HANDLE Handle
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
|
|
|
Start to manage the PCI device on specified the root bridge or PCI-PCI Bridge
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-25 15:47:45 +02:00
|
|
|
@param Controller The root bridge handle.
|
2008-04-15 10:52:18 +02:00
|
|
|
@param RootBridge A pointer to the PCI_IO_DEVICE.
|
|
|
|
@param RemainingDevicePath A pointer to the EFI_DEVICE_PATH_PROTOCOL.
|
|
|
|
@param NumberOfChildren Children number.
|
|
|
|
@param ChildHandleBuffer A pointer to the child handle buffer.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@retval EFI_NOT_READY Device is not allocated.
|
2008-04-15 10:52:18 +02:00
|
|
|
@retval EFI_UNSUPPORTED Device only support PCI-PCI bridge.
|
2009-06-25 15:47:45 +02:00
|
|
|
@retval EFI_NOT_FOUND Can not find the specific device.
|
|
|
|
@retval EFI_SUCCESS Success to start Pci device on bridge.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-14 05:12:57 +02:00
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
EFI_STATUS
|
|
|
|
StartPciDevicesOnBridge (
|
|
|
|
IN EFI_HANDLE Controller,
|
|
|
|
IN PCI_IO_DEVICE *RootBridge,
|
|
|
|
IN EFI_DEVICE_PATH_PROTOCOL *RemainingDevicePath,
|
|
|
|
IN OUT UINT8 *NumberOfChildren,
|
|
|
|
IN OUT EFI_HANDLE *ChildHandleBuffer
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
2009-06-25 15:47:45 +02:00
|
|
|
Start to manage all the PCI devices it found previously under
|
2008-04-15 10:52:18 +02:00
|
|
|
the entire host bridge.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-25 15:47:45 +02:00
|
|
|
@param Controller The root bridge handle.
|
|
|
|
|
|
|
|
@retval EFI_NOT_READY Device is not allocated.
|
|
|
|
@retval EFI_SUCCESS Success to start Pci device on host bridge.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-14 05:12:57 +02:00
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
EFI_STATUS
|
|
|
|
StartPciDevices (
|
2008-02-19 05:17:05 +01:00
|
|
|
IN EFI_HANDLE Controller
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
2009-06-23 09:19:00 +02:00
|
|
|
Create root bridge device.
|
|
|
|
|
|
|
|
@param RootBridgeHandle Specified root bridge hanle.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@return The crated root bridge device instance, NULL means no
|
|
|
|
root bridge device instance created.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-14 05:12:57 +02:00
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
PCI_IO_DEVICE *
|
|
|
|
CreateRootBridge (
|
2009-06-23 09:19:00 +02:00
|
|
|
IN EFI_HANDLE RootBridgeHandle
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
2009-06-23 09:19:00 +02:00
|
|
|
Get root bridge device instance by specific root bridge handle.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-12-25 09:59:02 +01:00
|
|
|
@param RootBridgeHandle Given root bridge handle.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@return The root bridge device instance, NULL means no root bridge
|
|
|
|
device instance found.
|
|
|
|
|
2008-04-14 05:12:57 +02:00
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
PCI_IO_DEVICE *
|
|
|
|
GetRootBridgeByHandle (
|
|
|
|
EFI_HANDLE RootBridgeHandle
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
2008-12-25 09:59:02 +01:00
|
|
|
Judege whether Pci device existed.
|
2009-06-25 15:47:45 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@param Bridge Parent bridege instance.
|
2008-12-25 09:59:02 +01:00
|
|
|
@param PciIoDevice Device instance.
|
2009-06-25 15:47:45 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@retval TRUE Pci device existed.
|
|
|
|
@retval FALSE Pci device did not exist.
|
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
BOOLEAN
|
|
|
|
PciDeviceExisted (
|
|
|
|
IN PCI_IO_DEVICE *Bridge,
|
|
|
|
IN PCI_IO_DEVICE *PciIoDevice
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
2009-06-23 09:19:00 +02:00
|
|
|
Get the active VGA device on the same segment.
|
2009-06-25 15:47:45 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@param VgaDevice PCI IO instance for the VGA device.
|
2009-06-25 15:47:45 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@return The active VGA device on the same segment.
|
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
PCI_IO_DEVICE *
|
|
|
|
ActiveVGADeviceOnTheSameSegment (
|
|
|
|
IN PCI_IO_DEVICE *VgaDevice
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
2009-06-23 09:19:00 +02:00
|
|
|
Get the active VGA device on the root bridge.
|
2009-06-25 15:47:45 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@param RootBridge PCI IO instance for the root bridge.
|
2009-06-25 15:47:45 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@return The active VGA device.
|
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
PCI_IO_DEVICE *
|
|
|
|
ActiveVGADeviceOnTheRootBridge (
|
|
|
|
IN PCI_IO_DEVICE *RootBridge
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
2008-12-25 09:59:02 +01:00
|
|
|
Get HPC PCI address according to its device path.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-12-25 09:59:02 +01:00
|
|
|
@param RootBridge Root bridege Io instance.
|
|
|
|
@param RemainingDevicePath Given searching device path.
|
|
|
|
@param PciAddress Buffer holding searched result.
|
2009-06-25 15:47:45 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
@retval EFI_SUCCESS PCI address was stored in PciAddress.
|
|
|
|
@retval EFI_NOT_FOUND Can not find the specific device path.
|
2009-06-25 15:47:45 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
EFI_STATUS
|
|
|
|
GetHpcPciAddressFromRootBridge (
|
|
|
|
IN PCI_IO_DEVICE *RootBridge,
|
|
|
|
IN EFI_DEVICE_PATH_PROTOCOL *RemainingDevicePath,
|
|
|
|
OUT UINT64 *PciAddress
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-15 10:52:18 +02:00
|
|
|
/**
|
|
|
|
Destroy a pci device node.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2009-06-23 09:19:00 +02:00
|
|
|
All direct or indirect allocated resource for this node will be freed.
|
|
|
|
|
|
|
|
@param PciIoDevice A pointer to the PCI_IO_DEVICE to be destoried.
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-14 05:12:57 +02:00
|
|
|
**/
|
2009-06-23 09:19:00 +02:00
|
|
|
VOID
|
2007-06-28 16:02:17 +02:00
|
|
|
FreePciDevice (
|
2009-06-23 09:19:00 +02:00
|
|
|
IN PCI_IO_DEVICE *PciIoDevice
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
|
|
|
#endif
|