2007-07-23 09:06:23 +02:00
|
|
|
/**@file
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2007-07-23 09:06:23 +02:00
|
|
|
Copyright (c) 2006, Intel Corporation
|
2007-06-28 16:02:17 +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-28 16:02:17 +02:00
|
|
|
|
|
|
|
|
|
|
|
#ifndef _EFI_PCI_HOT_PLUG_SUPPORT_H
|
|
|
|
#define _EFI_PCI_HOT_PLUG_SUPPORT_H
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
// stall 1 second
|
|
|
|
//
|
|
|
|
#define STALL_1_SECOND 1000000
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
EFI_EVENT Event;
|
|
|
|
BOOLEAN Initialized;
|
|
|
|
VOID *Padding;
|
|
|
|
} ROOT_HPC_DATA;
|
|
|
|
|
|
|
|
extern EFI_PCI_HOT_PLUG_INIT_PROTOCOL *gPciHotPlugInit;
|
|
|
|
extern EFI_HPC_LOCATION *gPciRootHpcPool;
|
|
|
|
extern UINTN gPciRootHpcCount;
|
|
|
|
extern ROOT_HPC_DATA *gPciRootHpcData;
|
|
|
|
|
2008-04-16 11:24:58 +02:00
|
|
|
/**
|
|
|
|
Init HPC private data.
|
|
|
|
|
|
|
|
@param Event event object
|
|
|
|
@param Context HPC private data.
|
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
PciHPCInitialized (
|
|
|
|
IN EFI_EVENT Event,
|
|
|
|
IN VOID *Context
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-16 11:24:58 +02:00
|
|
|
/**
|
|
|
|
Compare two device path
|
|
|
|
|
|
|
|
@param DevicePath1 the first device path want to be compared
|
|
|
|
@param DevicePath2 the first device path want to be compared
|
|
|
|
|
|
|
|
@retval TRUE equal
|
|
|
|
@retval FALSE different
|
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
BOOLEAN
|
|
|
|
EfiCompareDevicePath (
|
|
|
|
IN EFI_DEVICE_PATH_PROTOCOL *DevicePath1,
|
|
|
|
IN EFI_DEVICE_PATH_PROTOCOL *DevicePath2
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-16 11:24:58 +02:00
|
|
|
/**
|
|
|
|
Init hot plug support and root hot plug private data.
|
|
|
|
|
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
EFI_STATUS
|
|
|
|
InitializeHotPlugSupport (
|
|
|
|
VOID
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-16 11:24:58 +02:00
|
|
|
/**
|
|
|
|
Test whether PCI device is hot plug bus.
|
|
|
|
|
|
|
|
@param PciIoDevice PCI device instance
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS PCI device is hot plug bus
|
|
|
|
@retval EFI_NOT_FOUND PCI device is not hot plug bus
|
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
EFI_STATUS
|
|
|
|
IsPciHotPlugBus (
|
|
|
|
PCI_IO_DEVICE *PciIoDevice
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-16 11:24:58 +02:00
|
|
|
/**
|
|
|
|
Test whether device path is for root pci hot plug bus
|
|
|
|
|
|
|
|
@param HpbdevicePath tested device path
|
|
|
|
@param HpIndex Return the index of root hot plug in global array.
|
|
|
|
|
|
|
|
@retval TRUE device path is for root pci hot plug
|
|
|
|
@retval FALSE device path is not for root pci hot plug
|
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
BOOLEAN
|
|
|
|
IsRootPciHotPlugBus (
|
|
|
|
IN EFI_DEVICE_PATH_PROTOCOL *HpbDevicePath,
|
|
|
|
OUT UINTN *HpIndex
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-16 11:24:58 +02:00
|
|
|
/**
|
|
|
|
Test whether device path is for root pci hot plug controller
|
|
|
|
|
|
|
|
@param HpbdevicePath tested device path
|
|
|
|
@param HpIndex Return the index of root hot plug in global array.
|
|
|
|
|
|
|
|
@retval TRUE device path is for root pci hot plug controller
|
|
|
|
@retval FALSE device path is not for root pci hot plug controller
|
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
BOOLEAN
|
|
|
|
IsRootPciHotPlugController (
|
|
|
|
IN EFI_DEVICE_PATH_PROTOCOL *HpcDevicePath,
|
|
|
|
OUT UINTN *HpIndex
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-16 11:24:58 +02:00
|
|
|
/**
|
|
|
|
Wrapper for creating event object for HPC
|
|
|
|
|
|
|
|
@param HpIndex index of hot plug device in global array
|
|
|
|
@param Event event object
|
|
|
|
|
|
|
|
@return status of create event invoken
|
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
EFI_STATUS
|
|
|
|
CreateEventForHpc (
|
|
|
|
IN UINTN HpIndex,
|
|
|
|
OUT EFI_EVENT *Event
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-16 11:24:58 +02:00
|
|
|
/**
|
|
|
|
Wait for all root HPC initialized.
|
|
|
|
|
|
|
|
@param TimeoutInMicroSeconds microseconds to wait for all root hpc's initialization
|
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
EFI_STATUS
|
|
|
|
AllRootHPCInitialized (
|
|
|
|
IN UINTN TimeoutInMicroSeconds
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-16 11:24:58 +02:00
|
|
|
/**
|
|
|
|
Check HPC capability register block
|
|
|
|
|
|
|
|
@param PciIoDevice PCI device instance
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS PCI device is HPC
|
|
|
|
@retval EFI_NOT_FOUND PCI device is not HPC
|
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
EFI_STATUS
|
|
|
|
IsSHPC (
|
|
|
|
PCI_IO_DEVICE *PciIoDevice
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
2008-04-16 11:24:58 +02:00
|
|
|
/**
|
|
|
|
Get resource padding for hot plug bus
|
|
|
|
|
|
|
|
@param PciIoDevice PCI device instance
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS success get padding and set it into PCI device instance
|
|
|
|
@retval EFI_NOT_FOUND PCI device is not a hot plug bus.
|
|
|
|
**/
|
2007-06-28 16:02:17 +02:00
|
|
|
EFI_STATUS
|
|
|
|
GetResourcePaddingForHpb (
|
|
|
|
IN PCI_IO_DEVICE *PciIoDevice
|
2008-09-04 11:37:28 +02:00
|
|
|
);
|
2007-06-28 16:02:17 +02:00
|
|
|
|
|
|
|
#endif
|