blob: 9f1fcc970a0a6a4f1998ec2896ea8b1b170e7232 [file] [log] [blame]
/** @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;
}