forked from tianocore/edk2-platforms
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Silicon/Bosc:Added PciHostBridgeLib to NanHuDev
Reviewed-by: Evan Chai <[email protected]> Reviewed-by: Ran Wang <[email protected]> Reviewed-by: Jian Zhang <[email protected]> Cc: Leif Lindholm <[email protected]> Cc: Michael D Kinney <[email protected]> Cc: Sunil V L <[email protected]> Cc: Daniel Schaefer <[email protected]> Cc: Ray Ni <[email protected]> Signed-off-by: Yang Wang <[email protected]>
- Loading branch information
Yang Wang
committed
Sep 13, 2024
1 parent
7dcf45f
commit 8f8ae61
Showing
6 changed files
with
308 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
177 changes: 177 additions & 0 deletions
177
Silicon/Bosc/NanHuPkg/Library/PciHostBridgeLib/PciHostBridgeLib.c
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,177 @@ | ||
/** @file | ||
PCI host bridge library instance for NanHuDev SOC. | ||
Copyright (C) 2020, Phytium Technology Co Ltd. All rights reserved.<BR> | ||
Copyright (c) 2024, Bosc. All rights reserved.<BR>ved.<BR> | ||
SPDX-License-Identifier: BSD-2-Clause-Patent | ||
**/ | ||
|
||
#include <Library/DebugLib.h> | ||
#include <Library/DevicePathLib.h> | ||
#include <Library/PciHostBridgeLib.h> | ||
#include <Library/IoLib.h> | ||
|
||
#include "PciHostBridgeLib.h" | ||
|
||
#pragma pack(1) | ||
|
||
typedef struct { | ||
ACPI_HID_DEVICE_PATH AcpiDevicePath; | ||
EFI_DEVICE_PATH_PROTOCOL EndDevicePath; | ||
} EFI_PCI_ROOT_BRIDGE_DEVICE_PATH; | ||
|
||
#pragma pack () | ||
|
||
STATIC CONST EFI_PCI_ROOT_BRIDGE_DEVICE_PATH mEfiPciRootBridgeDevicePath[] = { | ||
{ | ||
ACPI_DEVICE_PATH_DEF (0), | ||
END_DEVICE_PATH_DEF | ||
}, | ||
}; | ||
|
||
GLOBAL_REMOVE_IF_UNREFERENCED | ||
CHAR16 *mPciHostBridgeLibAcpiAddressSpaceTypeStr[] = { | ||
L"Mem", L"I/O", L"Bus" | ||
}; | ||
|
||
STATIC PCI_ROOT_BRIDGE mRootBridge = { | ||
0, // Segment | ||
0, // Supports | ||
0, // Attributes | ||
FALSE, // DmaAbove4G | ||
FALSE, // NoExtendedConfigSpace | ||
FALSE, // ResourceAssigned | ||
0, // AllocationAttributes | ||
{ | ||
// Bus | ||
FixedPcdGet32 (PcdPciBusMin), | ||
FixedPcdGet32 (PcdPciBusMax) | ||
}, { | ||
// Io | ||
FixedPcdGet64 (PcdPciIoBase), | ||
FixedPcdGet64 (PcdPciIoBase) + FixedPcdGet64 (PcdPciIoSize) - 1 | ||
}, { | ||
// Mem | ||
FixedPcdGet32 (PcdPciMmio32Base), | ||
FixedPcdGet32 (PcdPciMmio32Base) + (FixedPcdGet32 (PcdPciMmio32Size) - 1) | ||
//0x7FFFFFFF | ||
}, { | ||
// MemAbove4G | ||
FixedPcdGet64 (PcdPciMmio64Base), | ||
FixedPcdGet64 (PcdPciMmio64Base) + FixedPcdGet64 (PcdPciMmio64Size) - 1 | ||
}, { | ||
// PMem | ||
MAX_UINT64, | ||
0 | ||
}, { | ||
// PMemAbove4G | ||
MAX_UINT64, | ||
0 | ||
}, | ||
(EFI_DEVICE_PATH_PROTOCOL *)&mEfiPciRootBridgeDevicePath | ||
}; | ||
|
||
/** | ||
Return all the root bridge instances in an array. | ||
@param[out] Count Return the count of root bridge instances. | ||
@return All the root bridge instances in an array. | ||
The array should be passed into PciHostBridgeFreeRootBridges() | ||
when it's not used. | ||
**/ | ||
PCI_ROOT_BRIDGE * | ||
EFIAPI | ||
PciHostBridgeGetRootBridges ( | ||
OUT UINTN *Count | ||
) | ||
{ | ||
/* Enable the Bridge enable bit */ | ||
UINT64 PciConfigBase = FixedPcdGet64 (PcdPciConfigBase); | ||
UINT32 Rpsc = MmioRead32 (PciConfigBase + XILINX_PCIE_REG_RPSC); | ||
MmioWrite32 (PciConfigBase + XILINX_PCIE_REG_RPSC, Rpsc | XILINX_PCIE_REG_RPSC_BEN); | ||
DEBUG ((DEBUG_INFO, "PciHostBridgeGetRootBridges():%d PciConfigBase:0x%x Rpsc:0x%x XILINX_PCIE_REG_RPSC_BEN:0x%x\n", \ | ||
__LINE__, PciConfigBase, Rpsc, Rpsc | XILINX_PCIE_REG_RPSC_BEN)); | ||
|
||
*Count = 1; | ||
return &mRootBridge; | ||
} | ||
|
||
|
||
/** | ||
Free the root bridge instances array returned from PciHostBridgeGetRootBridges(). | ||
@param[in] Bridges The root bridge instances array. | ||
@param[in] Count The count of the array. | ||
**/ | ||
VOID | ||
EFIAPI | ||
PciHostBridgeFreeRootBridges ( | ||
IN PCI_ROOT_BRIDGE *Bridges, | ||
IN UINTN Count | ||
) | ||
{ | ||
|
||
} | ||
|
||
|
||
/** | ||
Inform the platform that the resource conflict happens. | ||
@param[in] HostBridgeHandle Handle of the Host Bridge. | ||
@param[in] Configuration Pointer to PCI I/O and PCI memory resource | ||
descriptors. The Configuration contains the resources | ||
for all the root bridges. The resource for each root | ||
bridge is terminated with END descriptor and an | ||
additional END is appended indicating the end of the | ||
entire resources. The resource descriptor field | ||
values follow the description in | ||
EFI_PCI_HOST_BRIDGE_RESOURCE_ALLOCATION_PROTOCOL | ||
SubmitResources(). | ||
**/ | ||
VOID | ||
EFIAPI | ||
PciHostBridgeResourceConflict ( | ||
IN EFI_HANDLE HostBridgeHandle, | ||
IN VOID *Configuration | ||
) | ||
{ | ||
EFI_ACPI_ADDRESS_SPACE_DESCRIPTOR *Descriptor; | ||
BOOLEAN IsPrefetchable; | ||
|
||
Descriptor = (EFI_ACPI_ADDRESS_SPACE_DESCRIPTOR *) Configuration; | ||
while (Descriptor->Desc == ACPI_ADDRESS_SPACE_DESCRIPTOR) { | ||
for (; Descriptor->Desc == ACPI_ADDRESS_SPACE_DESCRIPTOR; Descriptor++) { | ||
ASSERT (Descriptor->ResType < | ||
ARRAY_SIZE (mPciHostBridgeLibAcpiAddressSpaceTypeStr)); | ||
DEBUG ((DEBUG_INFO, " %s: Length/Alignment = 0x%lx / 0x%lx\n", | ||
mPciHostBridgeLibAcpiAddressSpaceTypeStr[Descriptor->ResType], | ||
Descriptor->AddrLen, | ||
Descriptor->AddrRangeMax | ||
)); | ||
if (Descriptor->ResType == ACPI_ADDRESS_SPACE_TYPE_MEM) { | ||
|
||
IsPrefetchable = (Descriptor->SpecificFlag & | ||
EFI_ACPI_MEMORY_RESOURCE_SPECIFIC_FLAG_CACHEABLE_PREFETCHABLE) != 0; | ||
|
||
DEBUG ((DEBUG_INFO, " Granularity/SpecificFlag = %ld / %02x%s\n", | ||
Descriptor->AddrSpaceGranularity, | ||
Descriptor->SpecificFlag, | ||
(IsPrefetchable) ? L" (Prefetchable)" : L"" | ||
)); | ||
} | ||
} | ||
// | ||
// Skip the end descriptor for root bridge | ||
// | ||
ASSERT (Descriptor->Desc == ACPI_END_TAG_DESCRIPTOR); | ||
Descriptor = (EFI_ACPI_ADDRESS_SPACE_DESCRIPTOR *) ( | ||
(EFI_ACPI_END_TAG_DESCRIPTOR *)Descriptor + 1 | ||
); | ||
} | ||
} |
33 changes: 33 additions & 0 deletions
33
Silicon/Bosc/NanHuPkg/Library/PciHostBridgeLib/PciHostBridgeLib.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
/** @file | ||
Main Header file for the PciHostBridgeLib | ||
Copyright (c) 2024, Bosc. All rights reserved.<BR>ved.<BR> | ||
SPDX-License-Identifier: BSD-2-Clause-Patent | ||
**/ | ||
#ifndef __PCIHOSTBRIDGELIB_H | ||
#define __PCIHOSTBRIDGELIB_H | ||
|
||
#define BIT(nr) (1UL << (nr)) | ||
#define GENMASK(h, l) \ | ||
(((~0UL) - (1UL << (l)) + 1) & (~0UL >> (BITS_PER_LONG - 1 - (h)))) | ||
|
||
/* Register definitions */ | ||
#define XILINX_PCIE_REG_RPSC (0x00000148) | ||
|
||
/* Root Port Status/control Register definitions */ | ||
#define XILINX_PCIE_REG_RPSC_BEN BIT(0) | ||
|
||
#define END_DEVICE_PATH_DEF { END_DEVICE_PATH_TYPE, \ | ||
END_ENTIRE_DEVICE_PATH_SUBTYPE, \ | ||
{ END_DEVICE_PATH_LENGTH, 0 } \ | ||
} | ||
|
||
#define ACPI_DEVICE_PATH_DEF(UID) {{ ACPI_DEVICE_PATH, ACPI_DP, \ | ||
{ (UINT8) (sizeof (ACPI_HID_DEVICE_PATH)), \ | ||
(UINT8) (sizeof (ACPI_HID_DEVICE_PATH) >> 8)} \ | ||
}, \ | ||
EISA_PNP_ID (0x0A03), UID \ | ||
} | ||
#endif |
49 changes: 49 additions & 0 deletions
49
Silicon/Bosc/NanHuPkg/Library/PciHostBridgeLib/PciHostBridgeLib.inf
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
#/** @file | ||
# PCI Host Bridge Library instance for Bosc SOC. | ||
# | ||
# Copyright (C) 2020, Bosc Technology Co, Ltd. All rights reserved.<BR> | ||
# Copyright (c) 2024, Bosc. All rights reserved.<BR>ved.<BR> | ||
# | ||
# SPDX-License-Identifier: BSD-2-Clause-Patent | ||
# | ||
#**/ | ||
|
||
[Defines] | ||
INF_VERSION = 0x0001001b | ||
BASE_NAME = PciHostBridgeLib | ||
FILE_GUID = 7F418E45-0127-454E-9CBB-F5FCF237E383 | ||
MODULE_TYPE = DXE_DRIVER | ||
VERSION_STRING = 1.0 | ||
LIBRARY_CLASS = PciHostBridgeLib|DXE_DRIVER | ||
|
||
# | ||
# The following information is for reference only and not required by the build | ||
# tools. | ||
# | ||
# VALID_ARCHITECTURES = RISCV64 | ||
# | ||
|
||
[Sources] | ||
PciHostBridgeLib.h | ||
PciHostBridgeLib.c | ||
|
||
[Packages] | ||
MdePkg/MdePkg.dec | ||
MdeModulePkg/MdeModulePkg.dec | ||
Silicon/Bosc/NanHuPkg/NanHuDevPkg.dec | ||
|
||
[LibraryClasses] | ||
DebugLib | ||
|
||
[Guids] | ||
|
||
[FixedPcd] | ||
gBoscNanHuDdevPlatformPkgTokenSpaceGuid.PcdPciBusMin | ||
gBoscNanHuDdevPlatformPkgTokenSpaceGuid.PcdPciBusMax | ||
gBoscNanHuDdevPlatformPkgTokenSpaceGuid.PcdPciIoBase | ||
gBoscNanHuDdevPlatformPkgTokenSpaceGuid.PcdPciIoSize | ||
gBoscNanHuDdevPlatformPkgTokenSpaceGuid.PcdPciMmio32Base | ||
gBoscNanHuDdevPlatformPkgTokenSpaceGuid.PcdPciMmio32Size | ||
gBoscNanHuDdevPlatformPkgTokenSpaceGuid.PcdPciMmio64Base | ||
gBoscNanHuDdevPlatformPkgTokenSpaceGuid.PcdPciMmio64Size | ||
gBoscNanHuDdevPlatformPkgTokenSpaceGuid.PcdPciConfigBase |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters