2009-10-20 05:43:40 +02:00
|
|
|
/** @file
|
|
|
|
Set up ROM Table for PCI Bus module.
|
|
|
|
|
2017-10-26 09:54:30 +02:00
|
|
|
Copyright (c) 2006 - 2017, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:05:13 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2009-10-20 05:43:40 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include "PciBus.h"
|
|
|
|
|
|
|
|
//
|
|
|
|
// PCI ROM image information
|
|
|
|
//
|
|
|
|
typedef struct {
|
2021-12-05 23:54:02 +01:00
|
|
|
EFI_HANDLE ImageHandle;
|
|
|
|
UINTN Seg;
|
|
|
|
UINT8 Bus;
|
|
|
|
UINT8 Dev;
|
|
|
|
UINT8 Func;
|
|
|
|
VOID *RomImage;
|
|
|
|
UINT64 RomSize;
|
2017-10-26 09:54:30 +02:00
|
|
|
} PCI_ROM_IMAGE;
|
2009-10-20 05:43:40 +02:00
|
|
|
|
2021-12-05 23:54:02 +01:00
|
|
|
UINTN mNumberOfPciRomImages = 0;
|
|
|
|
UINTN mMaxNumberOfPciRomImages = 0;
|
|
|
|
PCI_ROM_IMAGE *mRomImageTable = NULL;
|
2009-10-20 05:43:40 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
Add the Rom Image to internal database for later PCI light enumeration.
|
|
|
|
|
|
|
|
@param ImageHandle Option Rom image handle.
|
|
|
|
@param Seg Segment of PCI space.
|
|
|
|
@param Bus Bus NO of PCI space.
|
|
|
|
@param Dev Dev NO of PCI space.
|
|
|
|
@param Func Func NO of PCI space.
|
2017-10-26 09:54:30 +02:00
|
|
|
@param RomImage Option Rom buffer.
|
|
|
|
@param RomSize Size of Option Rom buffer.
|
2009-10-20 05:43:40 +02:00
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
PciRomAddImageMapping (
|
|
|
|
IN EFI_HANDLE ImageHandle,
|
|
|
|
IN UINTN Seg,
|
|
|
|
IN UINT8 Bus,
|
|
|
|
IN UINT8 Dev,
|
|
|
|
IN UINT8 Func,
|
2017-10-26 09:54:30 +02:00
|
|
|
IN VOID *RomImage,
|
|
|
|
IN UINT64 RomSize
|
2009-10-20 05:43:40 +02:00
|
|
|
)
|
|
|
|
{
|
2021-12-05 23:54:02 +01:00
|
|
|
UINTN Index;
|
|
|
|
PCI_ROM_IMAGE *NewTable;
|
2009-10-20 05:43:40 +02:00
|
|
|
|
2017-10-27 05:37:18 +02:00
|
|
|
for (Index = 0; Index < mNumberOfPciRomImages; Index++) {
|
2021-12-05 23:54:02 +01:00
|
|
|
if ((mRomImageTable[Index].Seg == Seg) &&
|
|
|
|
(mRomImageTable[Index].Bus == Bus) &&
|
|
|
|
(mRomImageTable[Index].Dev == Dev) &&
|
|
|
|
(mRomImageTable[Index].Func == Func))
|
|
|
|
{
|
2017-10-27 05:37:18 +02:00
|
|
|
//
|
|
|
|
// Expect once RomImage and RomSize are recorded, they will be passed in
|
2022-01-22 01:48:47 +01:00
|
|
|
// later when updating ImageHandle. They may also be updated with new
|
|
|
|
// values if the platform provides an override of RomImage and RomSize.
|
2017-10-27 05:37:18 +02:00
|
|
|
//
|
|
|
|
break;
|
2009-10-20 05:43:40 +02:00
|
|
|
}
|
2017-10-27 05:37:18 +02:00
|
|
|
}
|
2009-10-20 05:43:40 +02:00
|
|
|
|
2017-10-27 05:37:18 +02:00
|
|
|
if (Index == mNumberOfPciRomImages) {
|
|
|
|
//
|
|
|
|
// Rom Image Table buffer needs to grow.
|
|
|
|
//
|
|
|
|
if (mNumberOfPciRomImages == mMaxNumberOfPciRomImages) {
|
|
|
|
NewTable = ReallocatePool (
|
|
|
|
mMaxNumberOfPciRomImages * sizeof (PCI_ROM_IMAGE),
|
|
|
|
(mMaxNumberOfPciRomImages + 0x20) * sizeof (PCI_ROM_IMAGE),
|
|
|
|
mRomImageTable
|
|
|
|
);
|
|
|
|
if (NewTable == NULL) {
|
2021-12-05 23:54:02 +01:00
|
|
|
return;
|
2017-10-27 05:37:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
mRomImageTable = NewTable;
|
|
|
|
mMaxNumberOfPciRomImages += 0x20;
|
|
|
|
}
|
2021-12-05 23:54:02 +01:00
|
|
|
|
2017-10-27 05:37:18 +02:00
|
|
|
//
|
|
|
|
// Record the new PCI device
|
|
|
|
//
|
|
|
|
mRomImageTable[Index].Seg = Seg;
|
|
|
|
mRomImageTable[Index].Bus = Bus;
|
|
|
|
mRomImageTable[Index].Dev = Dev;
|
|
|
|
mRomImageTable[Index].Func = Func;
|
|
|
|
mNumberOfPciRomImages++;
|
2009-10-20 05:43:40 +02:00
|
|
|
}
|
|
|
|
|
2017-10-27 05:37:18 +02:00
|
|
|
mRomImageTable[Index].ImageHandle = ImageHandle;
|
|
|
|
mRomImageTable[Index].RomImage = RomImage;
|
|
|
|
mRomImageTable[Index].RomSize = RomSize;
|
2009-10-20 05:43:40 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Get Option rom driver's mapping for PCI device.
|
|
|
|
|
|
|
|
@param PciIoDevice Device instance.
|
|
|
|
|
|
|
|
@retval TRUE Found Image mapping.
|
|
|
|
@retval FALSE Cannot found image mapping.
|
|
|
|
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
|
|
|
PciRomGetImageMapping (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN PCI_IO_DEVICE *PciIoDevice
|
2009-10-20 05:43:40 +02:00
|
|
|
)
|
|
|
|
{
|
2021-12-05 23:54:02 +01:00
|
|
|
EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL *PciRootBridgeIo;
|
|
|
|
UINTN Index;
|
2009-10-20 05:43:40 +02:00
|
|
|
|
|
|
|
PciRootBridgeIo = PciIoDevice->PciRootBridgeIo;
|
|
|
|
|
|
|
|
for (Index = 0; Index < mNumberOfPciRomImages; Index++) {
|
2021-12-05 23:54:02 +01:00
|
|
|
if ((mRomImageTable[Index].Seg == PciRootBridgeIo->SegmentNumber) &&
|
|
|
|
(mRomImageTable[Index].Bus == PciIoDevice->BusNumber) &&
|
|
|
|
(mRomImageTable[Index].Dev == PciIoDevice->DeviceNumber) &&
|
|
|
|
(mRomImageTable[Index].Func == PciIoDevice->FunctionNumber))
|
|
|
|
{
|
2009-10-20 05:43:40 +02:00
|
|
|
if (mRomImageTable[Index].ImageHandle != NULL) {
|
2017-10-23 07:52:15 +02:00
|
|
|
AddDriver (PciIoDevice, mRomImageTable[Index].ImageHandle, NULL);
|
2009-10-20 05:43:40 +02:00
|
|
|
}
|
2021-12-05 23:54:02 +01:00
|
|
|
|
2017-10-27 05:37:18 +02:00
|
|
|
PciIoDevice->PciIo.RomImage = mRomImageTable[Index].RomImage;
|
|
|
|
PciIoDevice->PciIo.RomSize = mRomImageTable[Index].RomSize;
|
|
|
|
return TRUE;
|
2009-10-20 05:43:40 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-27 05:37:18 +02:00
|
|
|
return FALSE;
|
2009-10-20 05:43:40 +02:00
|
|
|
}
|