mirror of https://github.com/acidanthera/audk.git
53 lines
1.4 KiB
C
53 lines
1.4 KiB
C
/** @file
|
|
PEI Phase Early Platform Hook Library instance for 16550 Uart.
|
|
|
|
Copyright (c) 2020 - 2023, Arm Ltd. All rights reserved.<BR>
|
|
Copyright (c) 2024 Loongson Technology Corporation Limited. All rights reserved.<BR>
|
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
**/
|
|
|
|
#include <Library/BaseLib.h>
|
|
#include <Library/FdtSerialPortAddressLib.h>
|
|
#include <Library/PcdLib.h>
|
|
#include <Library/PlatformHookLib.h>
|
|
#include <Register/LoongArch64/Csr.h>
|
|
|
|
/** Platform hook to retrieve the 16550 UART base address from the platform
|
|
Device tree and store it in the reigster LOONGARCH_CSR_KS1.
|
|
|
|
@retval RETURN_SUCCESS Success.
|
|
@retval RETURN_INVALID_PARAMETER A parameter was invalid.
|
|
@retval RETURN_NOT_FOUND Serial port information not found.
|
|
|
|
**/
|
|
RETURN_STATUS
|
|
EFIAPI
|
|
PlatformHookSerialPortInitialize (
|
|
VOID
|
|
)
|
|
{
|
|
RETURN_STATUS Status;
|
|
VOID *DeviceTreeBase;
|
|
UINT64 SerialConsoleAddress;
|
|
|
|
if (PcdGet64 (PcdSerialRegisterBase) != 0) {
|
|
return RETURN_SUCCESS;
|
|
}
|
|
|
|
DeviceTreeBase = (VOID *)(UINTN)PcdGet64 (PcdDeviceTreeInitialBaseAddress);
|
|
if (DeviceTreeBase == NULL) {
|
|
return RETURN_NOT_FOUND;
|
|
}
|
|
|
|
Status = FdtSerialGetConsolePort (DeviceTreeBase, &SerialConsoleAddress);
|
|
if (RETURN_ERROR (Status)) {
|
|
return Status;
|
|
}
|
|
|
|
CsrWrite (LOONGARCH_CSR_KS1, (UINTN)SerialConsoleAddress);
|
|
|
|
return RETURN_SUCCESS;
|
|
}
|