2009-01-19 08:00:28 +01:00
|
|
|
|
/** @file
|
2009-06-12 11:02:15 +02:00
|
|
|
|
Provides services to notify PCI bus driver that some events have happened in a hot-plug controller
|
|
|
|
|
(for example, PC Card socket, or PHPC), and ask PCI bus driver to create or destroy handles for the
|
|
|
|
|
PCI-like devices.
|
2007-06-26 10:14:44 +02:00
|
|
|
|
|
2009-06-08 08:59:54 +02:00
|
|
|
|
Copyright (c) 2006 - 2009, Intel Corporation
|
2007-06-26 10:14:44 +02:00
|
|
|
|
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-07-23 09:06:23 +02:00
|
|
|
|
**/
|
2007-06-26 10:14:44 +02:00
|
|
|
|
|
|
|
|
|
#ifndef __PCI_HOTPLUG_REQUEST_H_
|
|
|
|
|
#define __PCI_HOTPLUG_REQUEST_H_
|
|
|
|
|
|
|
|
|
|
#define EFI_PCI_HOTPLUG_REQUEST_PROTOCOL_GUID \
|
2009-06-12 11:02:15 +02:00
|
|
|
|
{0x19cb87ab,0x2cb9,{0x4665,0x83,0x60,0xdd,0xcf,0x60,0x54,0xf7,0x9d}}
|
2007-06-26 10:14:44 +02:00
|
|
|
|
|
|
|
|
|
typedef enum {
|
2009-06-12 11:02:15 +02:00
|
|
|
|
///
|
|
|
|
|
/// The PCI bus driver is requested to create handles for the specified devices. An array of
|
|
|
|
|
/// EFI_HANDLE is returned, a NULL element marks the end of the array.
|
|
|
|
|
///
|
2007-06-26 10:14:44 +02:00
|
|
|
|
EfiPciHotPlugRequestAdd,
|
2009-06-12 11:02:15 +02:00
|
|
|
|
|
|
|
|
|
///
|
|
|
|
|
/// The PCI bus driver is requested to destroy handles for the specified devices.
|
|
|
|
|
///
|
2007-06-26 10:14:44 +02:00
|
|
|
|
EfiPciHotplugRequestRemove
|
|
|
|
|
} EFI_PCI_HOTPLUG_OPERATION;
|
|
|
|
|
|
|
|
|
|
typedef struct _EFI_PCI_HOTPLUG_REQUEST_PROTOCOL EFI_PCI_HOTPLUG_REQUEST_PROTOCOL;
|
|
|
|
|
|
2009-06-08 08:59:54 +02:00
|
|
|
|
/**
|
2009-06-12 11:02:15 +02:00
|
|
|
|
This function allows the PCI bus driver to be notified to act as requested when a hot-plug event has
|
|
|
|
|
happened on the hot-plug controller. Currently, the operations include add operation and remove operation..
|
2009-06-08 08:59:54 +02:00
|
|
|
|
|
|
|
|
|
@param This A pointer to the hot plug request protocol.
|
2009-06-12 11:02:15 +02:00
|
|
|
|
@param Operation The operation the PCI bus driver is requested to make.
|
|
|
|
|
@param Controller The handle of the hot-plug controller.
|
|
|
|
|
@param RemainingDevicePath The remaining device path for the PCI-like hot-plug device.
|
|
|
|
|
@param NumberOfChildren The number of child handles.
|
|
|
|
|
For a add operation, it is an output parameter.
|
|
|
|
|
For a remove operation, it<EFBFBD><EFBFBD>s an input parameter.
|
|
|
|
|
@param ChildHandleBuffer The buffer which contains the child handles.
|
2009-06-08 08:59:54 +02:00
|
|
|
|
|
2009-06-12 11:02:15 +02:00
|
|
|
|
@retval EFI_INVALID_PARAMETER Operation is not a legal value.
|
|
|
|
|
Controller is NULL or not a valid handle.
|
|
|
|
|
NumberOfChildren is NULL.
|
|
|
|
|
ChildHandleBuffer is NULL while Operation is add.
|
|
|
|
|
@retval EFI_OUT_OF_RESOURCES There are no enough resources to start the devices.
|
|
|
|
|
@retval EFI_NOT_FOUND Can not find bridge according to controller handle.
|
|
|
|
|
@retval EFI_SUCCESS The handles for the specified device have been created or destroyed
|
|
|
|
|
as requested, and for an add operation, the new handles are
|
|
|
|
|
returned in ChildHandleBuffer.
|
2009-06-08 08:59:54 +02:00
|
|
|
|
**/
|
2007-06-26 10:14:44 +02:00
|
|
|
|
typedef
|
|
|
|
|
EFI_STATUS
|
|
|
|
|
(EFIAPI *EFI_PCI_HOTPLUG_REQUEST_NOTIFY) (
|
|
|
|
|
IN EFI_PCI_HOTPLUG_REQUEST_PROTOCOL *This,
|
|
|
|
|
IN EFI_PCI_HOTPLUG_OPERATION Operation,
|
|
|
|
|
IN EFI_HANDLE Controller,
|
|
|
|
|
IN EFI_DEVICE_PATH_PROTOCOL *RemainingDevicePath OPTIONAL,
|
|
|
|
|
IN OUT UINT8 *NumberOfChildren,
|
|
|
|
|
IN OUT EFI_HANDLE *ChildHandleBuffer
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
struct _EFI_PCI_HOTPLUG_REQUEST_PROTOCOL {
|
|
|
|
|
EFI_PCI_HOTPLUG_REQUEST_NOTIFY Notify;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
extern EFI_GUID gEfiPciHotPlugRequestProtocolGuid;
|
|
|
|
|
|
|
|
|
|
#endif
|