/** @file | |
Serial I/O Port library functions with no library constructor/destructor | |
Copyright (c) 2008-2010, Apple Inc. All rights reserved. | |
All rights reserved. This program and the accompanying materials | |
are licensed and made available under the terms and conditions of the BSD License | |
which accompanies this distribution. The full text of the license may be found at | |
http://opensource.org/licenses/bsd-license.php | |
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | |
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |
**/ | |
#include <Base.h> | |
#include <Library/DebugLib.h> | |
#include <Library/SerialPortLib.h> | |
#include <Library/PcdLib.h> | |
#include <Library/IoLib.h> | |
#include <ArmEbUart.h> | |
/* | |
Programmed hardware of Serial port. | |
@return Always return EFI_UNSUPPORTED. | |
**/ | |
RETURN_STATUS | |
EFIAPI | |
SerialPortInitialize ( | |
VOID | |
) | |
{ | |
UINT32 Base = PcdGet32 (PcdConsoleUart); | |
// initialize baud rate generator to 115200 based on EB clock REFCLK24MHZ | |
MmioWrite32 (Base + UARTIBRD, UART_115200_IDIV); | |
MmioWrite32 (Base + UARTFBRD, UART_115200_FDIV); | |
// no parity, 1 stop, no fifo, 8 data bits | |
MmioWrite32 (Base + UARTLCR_H, 0x60); | |
// clear any pending errors | |
MmioWrite32 (Base + UARTECR, 0); | |
// enable tx, rx, and uart overall | |
MmioWrite32 (Base + UARTCR, 0x301); | |
return RETURN_SUCCESS; | |
} | |
/** | |
Write data to serial device. | |
@param Buffer Point of data buffer which need to be writed. | |
@param NumberOfBytes Number of output bytes which are cached in Buffer. | |
@retval 0 Write data failed. | |
@retval !0 Actual number of bytes writed to serial device. | |
**/ | |
UINTN | |
EFIAPI | |
SerialPortWrite ( | |
IN UINT8 *Buffer, | |
IN UINTN NumberOfBytes | |
) | |
{ | |
UINT32 FR = PcdGet32(PcdConsoleUart) + UARTFR; | |
UINT32 DR = PcdGet32(PcdConsoleUart) + UARTDR; | |
UINTN Count; | |
for (Count = 0; Count < NumberOfBytes; Count++, Buffer++) { | |
while ((MmioRead32 (FR) & UART_TX_EMPTY_FLAG_MASK) != 0); | |
MmioWrite8 (DR, *Buffer); | |
} | |
return NumberOfBytes; | |
} | |
/** | |
Read data from serial device and save the datas in buffer. | |
@param Buffer Point of data buffer which need to be writed. | |
@param NumberOfBytes Number of output bytes which are cached in Buffer. | |
@retval 0 Read data failed. | |
@retval !0 Aactual number of bytes read from serial device. | |
**/ | |
UINTN | |
EFIAPI | |
SerialPortRead ( | |
OUT UINT8 *Buffer, | |
IN UINTN NumberOfBytes | |
) | |
{ | |
UINT32 FR = PcdGet32(PcdConsoleUart) + UARTFR; | |
UINT32 DR = PcdGet32(PcdConsoleUart) + UARTDR; | |
UINTN Count; | |
for (Count = 0; Count < NumberOfBytes; Count++, Buffer++) { | |
while ((MmioRead32 (FR) & UART_RX_EMPTY_FLAG_MASK) == 0); | |
*Buffer = MmioRead8 (DR); | |
} | |
return NumberOfBytes; | |
} | |
/** | |
Check to see if any data is avaiable to be read from the debug device. | |
@retval EFI_SUCCESS At least one byte of data is avaiable to be read | |
@retval EFI_NOT_READY No data is avaiable to be read | |
@retval EFI_DEVICE_ERROR The serial device is not functioning properly | |
**/ | |
BOOLEAN | |
EFIAPI | |
SerialPortPoll ( | |
VOID | |
) | |
{ | |
UINT32 FR = PcdGet32(PcdConsoleUart) + UARTFR; | |
if ((MmioRead32 (FR) & UART_RX_EMPTY_FLAG_MASK) == 0) { | |
return TRUE; | |
} else { | |
return FALSE; | |
} | |
} | |