mirror of
				https://git.proxmox.com/git/mirror_edk2
				synced 2025-11-04 10:19:50 +00:00 
			
		
		
		
	git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@10420 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			127 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			127 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/** @file
 | 
						|
  Set up ROM Table for PCI Bus module.
 | 
						|
 | 
						|
Copyright (c) 2006 - 2009, Intel Corporation. All rights reserved.<BR>
 | 
						|
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.
 | 
						|
 | 
						|
**/
 | 
						|
 | 
						|
#include "PciBus.h"
 | 
						|
 | 
						|
//
 | 
						|
// PCI ROM image information
 | 
						|
//
 | 
						|
typedef struct {
 | 
						|
  EFI_HANDLE  ImageHandle;
 | 
						|
  UINTN       Seg;
 | 
						|
  UINT8       Bus;
 | 
						|
  UINT8       Dev;
 | 
						|
  UINT8       Func;
 | 
						|
  UINT64      RomAddress;
 | 
						|
  UINT64      RomLength;
 | 
						|
} EFI_PCI_ROM_IMAGE_MAPPING;
 | 
						|
 | 
						|
UINTN                      mNumberOfPciRomImages     = 0;
 | 
						|
UINTN                      mMaxNumberOfPciRomImages  = 0;
 | 
						|
EFI_PCI_ROM_IMAGE_MAPPING  *mRomImageTable           = NULL;
 | 
						|
 | 
						|
/**
 | 
						|
  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.
 | 
						|
  @param RomAddress     Base address of OptionRom.
 | 
						|
  @param RomLength      Length of rom image.
 | 
						|
 | 
						|
**/
 | 
						|
VOID
 | 
						|
PciRomAddImageMapping (
 | 
						|
  IN  EFI_HANDLE  ImageHandle,
 | 
						|
  IN  UINTN       Seg,
 | 
						|
  IN  UINT8       Bus,
 | 
						|
  IN  UINT8       Dev,
 | 
						|
  IN  UINT8       Func,
 | 
						|
  IN  UINT64      RomAddress,
 | 
						|
  IN  UINT64      RomLength
 | 
						|
  )
 | 
						|
{
 | 
						|
  EFI_PCI_ROM_IMAGE_MAPPING *TempMapping;
 | 
						|
 | 
						|
  if (mNumberOfPciRomImages >= mMaxNumberOfPciRomImages) {
 | 
						|
 | 
						|
    mMaxNumberOfPciRomImages += 0x20;
 | 
						|
 | 
						|
    TempMapping = NULL;
 | 
						|
    TempMapping = AllocatePool (mMaxNumberOfPciRomImages * sizeof (EFI_PCI_ROM_IMAGE_MAPPING));
 | 
						|
    if (TempMapping == NULL) {
 | 
						|
      return ;
 | 
						|
    }
 | 
						|
 | 
						|
    CopyMem (TempMapping, mRomImageTable, mNumberOfPciRomImages * sizeof (EFI_PCI_ROM_IMAGE_MAPPING));
 | 
						|
 | 
						|
    if (mRomImageTable != NULL) {
 | 
						|
      FreePool (mRomImageTable);
 | 
						|
    }
 | 
						|
 | 
						|
    mRomImageTable = TempMapping;
 | 
						|
  }
 | 
						|
 | 
						|
  mRomImageTable[mNumberOfPciRomImages].ImageHandle = ImageHandle;
 | 
						|
  mRomImageTable[mNumberOfPciRomImages].Seg         = Seg;
 | 
						|
  mRomImageTable[mNumberOfPciRomImages].Bus         = Bus;
 | 
						|
  mRomImageTable[mNumberOfPciRomImages].Dev         = Dev;
 | 
						|
  mRomImageTable[mNumberOfPciRomImages].Func        = Func;
 | 
						|
  mRomImageTable[mNumberOfPciRomImages].RomAddress  = RomAddress;
 | 
						|
  mRomImageTable[mNumberOfPciRomImages].RomLength   = RomLength;
 | 
						|
  mNumberOfPciRomImages++;
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
  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 (
 | 
						|
  IN  PCI_IO_DEVICE                       *PciIoDevice
 | 
						|
  )
 | 
						|
{
 | 
						|
  EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL *PciRootBridgeIo;
 | 
						|
  UINTN                           Index;
 | 
						|
  BOOLEAN                         Found;
 | 
						|
 | 
						|
  PciRootBridgeIo = PciIoDevice->PciRootBridgeIo;
 | 
						|
  Found           = FALSE;
 | 
						|
 | 
						|
  for (Index = 0; Index < mNumberOfPciRomImages; Index++) {
 | 
						|
    if (mRomImageTable[Index].Seg  == PciRootBridgeIo->SegmentNumber &&
 | 
						|
        mRomImageTable[Index].Bus  == PciIoDevice->BusNumber         &&
 | 
						|
        mRomImageTable[Index].Dev  == PciIoDevice->DeviceNumber      &&
 | 
						|
        mRomImageTable[Index].Func == PciIoDevice->FunctionNumber    ) {
 | 
						|
        Found = TRUE;
 | 
						|
 | 
						|
      if (mRomImageTable[Index].ImageHandle != NULL) {
 | 
						|
        AddDriver (PciIoDevice, mRomImageTable[Index].ImageHandle);
 | 
						|
      } else {
 | 
						|
        PciIoDevice->PciIo.RomImage = (VOID *) (UINTN) mRomImageTable[Index].RomAddress;
 | 
						|
        PciIoDevice->PciIo.RomSize  = (UINTN) mRomImageTable[Index].RomLength;
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  return Found;
 | 
						|
}
 |