mirror of https://github.com/acidanthera/audk.git
OvmfPkg: PlatformBdsLib: debug log interrupt line assignments
These messages are helpful for comparing the assignments made by OVMF against those made by SeaBIOS. To SeaBIOS a small debug patch like the following can be applied: > diff --git a/src/fw/pciinit.c b/src/fw/pciinit.c > index ac39d23..9e61c22 100644 > --- a/src/fw/pciinit.c > +++ b/src/fw/pciinit.c > @@ -308,8 +308,12 @@ static void pci_bios_init_device(struct pci_device *pci) > > /* map the interrupt */ > int pin = pci_config_readb(bdf, PCI_INTERRUPT_PIN); > - if (pin != 0) > - pci_config_writeb(bdf, PCI_INTERRUPT_LINE, pci_slot_get_irq(pci, pin)); > + if (pin != 0) { > + int irqline = pci_slot_get_irq(pci, pin); > + > + pci_config_writeb(bdf, PCI_INTERRUPT_LINE, irqline); > + dprintf(1, "assigned irq line %d\n", irqline); > + } > > pci_init_device(pci_device_tbl, pci, NULL); > Cc: Jordan Justen <jordan.l.justen@intel.com> Cc: Gabriel Somlo <somlo@cmu.edu> Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Laszlo Ersek <lersek@redhat.com> Acked-by: Gabriel Somlo <somlo@cmu.edu> Reviewed-by: Jordan Justen <jordan.l.justen@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@17952 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
d52bde1c29
commit
fcd1e5de52
|
@ -749,6 +749,7 @@ SetPciIntLine (
|
|||
)
|
||||
{
|
||||
EFI_DEVICE_PATH_PROTOCOL *DevPathNode;
|
||||
EFI_DEVICE_PATH_PROTOCOL *DevPath;
|
||||
UINTN RootSlot;
|
||||
UINTN Idx;
|
||||
UINT8 IrqLine;
|
||||
|
@ -760,6 +761,7 @@ SetPciIntLine (
|
|||
|
||||
DevPathNode = DevicePathFromHandle (Handle);
|
||||
ASSERT (DevPathNode != NULL);
|
||||
DevPath = DevPathNode;
|
||||
|
||||
//
|
||||
// Compute index into PciHostIrqs[] table by walking
|
||||
|
@ -832,6 +834,29 @@ SetPciIntLine (
|
|||
Idx %= ARRAY_SIZE (PciHostIrqs);
|
||||
IrqLine = PciHostIrqs[Idx];
|
||||
|
||||
DEBUG_CODE_BEGIN ();
|
||||
{
|
||||
CHAR16 *DevPathString;
|
||||
STATIC CHAR16 Fallback[] = L"<failed to convert>";
|
||||
UINTN Segment, Bus, Device, Function;
|
||||
|
||||
DevPathString = ConvertDevicePathToText (DevPath, FALSE, FALSE);
|
||||
if (DevPathString == NULL) {
|
||||
DevPathString = Fallback;
|
||||
}
|
||||
Status = PciIo->GetLocation (PciIo, &Segment, &Bus, &Device, &Function);
|
||||
ASSERT_EFI_ERROR (Status);
|
||||
|
||||
DEBUG ((EFI_D_VERBOSE, "%a: [%02x:%02x.%x] %s -> 0x%02x\n", __FUNCTION__,
|
||||
(UINT32)Bus, (UINT32)Device, (UINT32)Function, DevPathString,
|
||||
IrqLine));
|
||||
|
||||
if (DevPathString != Fallback) {
|
||||
FreePool (DevPathString);
|
||||
}
|
||||
}
|
||||
DEBUG_CODE_END ();
|
||||
|
||||
//
|
||||
// Set PCI Interrupt Line register for this device to PciHostIrqs[Idx]
|
||||
//
|
||||
|
|
Loading…
Reference in New Issue