2016-10-31 16:36:50 +01:00
|
|
|
/** @file
|
|
|
|
|
|
|
|
Copyright (C) 2016, Linaro Ltd. All rights reserved.<BR>
|
|
|
|
|
2019-04-04 01:05:13 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2016-10-31 16:36:50 +01:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __NON_DISCOVERABLE_PCI_DEVICE_IO_H__
|
|
|
|
#define __NON_DISCOVERABLE_PCI_DEVICE_IO_H__
|
|
|
|
|
2016-12-09 16:04:34 +01:00
|
|
|
#include <PiDxe.h>
|
|
|
|
|
2016-10-31 16:36:50 +01:00
|
|
|
#include <Library/BaseMemoryLib.h>
|
|
|
|
#include <Library/DebugLib.h>
|
|
|
|
#include <Library/MemoryAllocationLib.h>
|
|
|
|
#include <Library/UefiBootServicesTableLib.h>
|
|
|
|
#include <Library/UefiLib.h>
|
|
|
|
|
|
|
|
#include <IndustryStandard/Pci.h>
|
|
|
|
|
|
|
|
#include <Protocol/ComponentName.h>
|
|
|
|
#include <Protocol/NonDiscoverableDevice.h>
|
2016-12-09 16:04:34 +01:00
|
|
|
#include <Protocol/Cpu.h>
|
2016-10-31 16:36:50 +01:00
|
|
|
#include <Protocol/PciIo.h>
|
|
|
|
|
|
|
|
#define NON_DISCOVERABLE_PCI_DEVICE_SIG SIGNATURE_32 ('P', 'P', 'I', 'D')
|
|
|
|
|
|
|
|
#define NON_DISCOVERABLE_PCI_DEVICE_FROM_PCI_IO(PciIoPointer) \
|
|
|
|
CR (PciIoPointer, NON_DISCOVERABLE_PCI_DEVICE, PciIo, \
|
|
|
|
NON_DISCOVERABLE_PCI_DEVICE_SIG)
|
|
|
|
|
2020-02-25 13:00:41 +01:00
|
|
|
#define DEV_SUPPORTED_ATTRIBUTES \
|
|
|
|
(EFI_PCI_DEVICE_ENABLE | EFI_PCI_IO_ATTRIBUTE_DUAL_ADDRESS_CYCLE)
|
|
|
|
|
2016-10-31 16:36:50 +01:00
|
|
|
#define PCI_ID_VENDOR_UNKNOWN 0xffff
|
|
|
|
#define PCI_ID_DEVICE_DONTCARE 0x0000
|
|
|
|
|
2016-12-09 16:04:34 +01:00
|
|
|
extern EFI_CPU_ARCH_PROTOCOL *mCpu;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
//
|
|
|
|
// The linked-list next pointer
|
|
|
|
//
|
|
|
|
LIST_ENTRY List;
|
|
|
|
//
|
|
|
|
// The address of the uncached allocation
|
|
|
|
//
|
|
|
|
VOID *HostAddress;
|
|
|
|
//
|
|
|
|
// The number of pages in the allocation
|
|
|
|
//
|
|
|
|
UINTN NumPages;
|
|
|
|
//
|
|
|
|
// The attributes of the allocation
|
|
|
|
//
|
|
|
|
UINT64 Attributes;
|
|
|
|
} NON_DISCOVERABLE_DEVICE_UNCACHED_ALLOCATION;
|
|
|
|
|
2016-10-31 16:36:50 +01:00
|
|
|
typedef struct {
|
|
|
|
UINT32 Signature;
|
|
|
|
//
|
|
|
|
// The bound non-discoverable device protocol instance
|
|
|
|
//
|
|
|
|
NON_DISCOVERABLE_DEVICE *Device;
|
|
|
|
//
|
|
|
|
// The exposed PCI I/O protocol instance.
|
|
|
|
//
|
|
|
|
EFI_PCI_IO_PROTOCOL PciIo;
|
|
|
|
//
|
|
|
|
// The emulated PCI config space of the device. Only the minimally required
|
|
|
|
// items are assigned.
|
|
|
|
//
|
|
|
|
PCI_TYPE00 ConfigSpace;
|
|
|
|
//
|
|
|
|
// The first virtual BAR to assign based on the resources described
|
|
|
|
// by the non-discoverable device.
|
|
|
|
//
|
|
|
|
UINT32 BarOffset;
|
|
|
|
//
|
|
|
|
// The number of virtual BARs we expose based on the number of
|
|
|
|
// resources
|
|
|
|
//
|
|
|
|
UINT32 BarCount;
|
|
|
|
//
|
|
|
|
// The PCI I/O attributes for this device
|
|
|
|
//
|
|
|
|
UINT64 Attributes;
|
|
|
|
//
|
|
|
|
// Whether this device has been enabled
|
|
|
|
//
|
|
|
|
BOOLEAN Enabled;
|
2016-12-09 16:04:34 +01:00
|
|
|
//
|
|
|
|
// Linked list to keep track of uncached allocations performed
|
|
|
|
// on behalf of this device
|
|
|
|
//
|
|
|
|
LIST_ENTRY UncachedAllocationList;
|
2018-10-10 10:34:50 +02:00
|
|
|
//
|
|
|
|
// Unique ID for this device instance: needed so that we can report unique
|
|
|
|
// segment/bus/device number for each device instance. Note that this number
|
|
|
|
// may change when disconnecting/reconnecting the driver.
|
|
|
|
//
|
|
|
|
UINTN UniqueId;
|
2016-10-31 16:36:50 +01:00
|
|
|
} NON_DISCOVERABLE_PCI_DEVICE;
|
|
|
|
|
2016-12-15 13:52:52 +01:00
|
|
|
/**
|
|
|
|
Initialize PciIo Protocol.
|
|
|
|
|
|
|
|
@param Device Point to NON_DISCOVERABLE_PCI_DEVICE instance.
|
|
|
|
|
|
|
|
**/
|
2016-10-31 16:36:50 +01:00
|
|
|
VOID
|
|
|
|
InitializePciIoProtocol (
|
|
|
|
NON_DISCOVERABLE_PCI_DEVICE *Device
|
|
|
|
);
|
|
|
|
|
|
|
|
extern EFI_COMPONENT_NAME_PROTOCOL gComponentName;
|
|
|
|
extern EFI_COMPONENT_NAME2_PROTOCOL gComponentName2;
|
|
|
|
|
|
|
|
#endif
|