TianoCore EDK2 master
Loading...
Searching...
No Matches
FdtPL011SerialPortLib.c File Reference
#include <Base.h>
#include <Library/PcdLib.h>
#include <Library/PL011UartLib.h>
#include <Library/SerialPortLib.h>
#include <Pi/PiBootMode.h>
#include <Uefi/UefiBaseType.h>
#include <Uefi/UefiMultiPhase.h>
#include <Pi/PiHob.h>
#include <Library/HobLib.h>
#include <Guid/EarlyPL011BaseAddress.h>

Go to the source code of this file.

Functions

RETURN_STATUS EFIAPI SerialPortInitialize (VOID)
 
UINTN EFIAPI SerialPortWrite (IN UINT8 *Buffer, IN UINTN NumberOfBytes)
 
UINTN EFIAPI SerialPortRead (OUT UINT8 *Buffer, IN UINTN NumberOfBytes)
 
BOOLEAN EFIAPI SerialPortPoll (VOID)
 
RETURN_STATUS EFIAPI SerialPortSetAttributes (IN OUT UINT64 *BaudRate, IN OUT UINT32 *ReceiveFifoDepth, IN OUT UINT32 *Timeout, IN OUT EFI_PARITY_TYPE *Parity, IN OUT UINT8 *DataBits, IN OUT EFI_STOP_BITS_TYPE *StopBits)
 
RETURN_STATUS EFIAPI SerialPortSetControl (IN UINT32 Control)
 
RETURN_STATUS EFIAPI SerialPortGetControl (OUT UINT32 *Control)
 

Variables

STATIC UINTN mSerialBaseAddress
 
STATIC RETURN_STATUS mPermanentStatus = RETURN_SUCCESS
 

Detailed Description

Serial I/O Port library functions with base address discovered from FDT

Copyright (c) 2008 - 2010, Apple Inc. All rights reserved.
Copyright (c) 2012 - 2013, ARM Ltd. All rights reserved.
Copyright (c) 2014, Linaro Ltd. All rights reserved.
Copyright (c) 2014, Red Hat, Inc.
Copyright (c) 2015, Intel Corporation. All rights reserved.

SPDX-License-Identifier: BSD-2-Clause-Patent

Definition in file FdtPL011SerialPortLib.c.

Function Documentation

◆ SerialPortGetControl()

RETURN_STATUS EFIAPI SerialPortGetControl ( OUT UINT32 *  Control)

Retrieve the status of the control bits on a serial device.

Parameters
ControlA pointer to return the current control signals from the serial device.
Return values
RETURN_SUCCESSThe control bits were read from the serial device.
RETURN_UNSUPPORTEDThe serial device does not support this operation.
RETURN_DEVICE_ERRORThe serial device is not functioning correctly.

Definition at line 276 of file FdtPL011SerialPortLib.c.

◆ SerialPortInitialize()

RETURN_STATUS EFIAPI SerialPortInitialize ( VOID  )

Program hardware of Serial port

Return values
RETURN_SUCCESSIf the serial port was initialized successfully by this call, or an earlier call, to SerialPortInitialize().
RETURN_NOT_FOUNDIf no PL011 base address could be found.
Returns
Error codes forwarded from PL011UartInitializePort().

Definition at line 43 of file FdtPL011SerialPortLib.c.

◆ SerialPortPoll()

BOOLEAN EFIAPI SerialPortPoll ( VOID  )

Check to see if any data is available to be read from the debug device.

Return values
TRUEAt least one byte of data is available to be read
FALSENo data is available to be read

Definition at line 163 of file FdtPL011SerialPortLib.c.

◆ SerialPortRead()

UINTN EFIAPI SerialPortRead ( OUT UINT8 *  Buffer,
IN UINTN  NumberOfBytes 
)

Read data from serial device and save the data in buffer.

Parameters
BufferPoint of data buffer which need to be written.
NumberOfBytesNumber of output bytes which are cached in Buffer.
Return values
0Read data failed.
!0Actual number of bytes read from serial device.

Definition at line 142 of file FdtPL011SerialPortLib.c.

◆ SerialPortSetAttributes()

RETURN_STATUS EFIAPI SerialPortSetAttributes ( IN OUT UINT64 *  BaudRate,
IN OUT UINT32 *  ReceiveFifoDepth,
IN OUT UINT32 *  Timeout,
IN OUT EFI_PARITY_TYPE Parity,
IN OUT UINT8 *  DataBits,
IN OUT EFI_STOP_BITS_TYPE StopBits 
)

Sets the baud rate, receive FIFO depth, transmit/receive time out, parity, data bits, and stop bits on a serial device.

Parameters
BaudRateThe requested baud rate. A BaudRate value of 0 will use the device's default interface speed. On output, the value actually set.
ReceiveFifoDepthThe requested depth of the FIFO on the receive side of the serial interface. A ReceiveFifoDepth value of 0 will use the device's default FIFO depth. On output, the value actually set.
TimeoutThe requested time out for a single character in microseconds. This timeout applies to both the transmit and receive side of the interface. A Timeout value of 0 will use the device's default time out value. On output, the value actually set.
ParityThe type of parity to use on this serial device. A Parity value of DefaultParity will use the device's default parity value. On output, the value actually set.
DataBitsThe number of data bits to use on the serial device. A DataBits value of 0 will use the device's default data bit setting. On output, the value actually set.
StopBitsThe number of stop bits to use on this serial device. A StopBits value of DefaultStopBits will use the device's default number of stop bits. On output, the value actually set.
Return values
RETURN_SUCCESSThe new attributes were set on the serial device.
RETURN_UNSUPPORTEDThe serial device does not support this operation.
RETURN_INVALID_PARAMETEROne or more of the attributes has an unsupported value.
RETURN_DEVICE_ERRORThe serial device is not functioning correctly.

Definition at line 209 of file FdtPL011SerialPortLib.c.

◆ SerialPortSetControl()

RETURN_STATUS EFIAPI SerialPortSetControl ( IN UINT32  Control)

Sets the control bits on a serial device.

Parameters
ControlSets the bits of Control that are settable.
Return values
RETURN_SUCCESSThe new control bits were set on the serial device.
RETURN_UNSUPPORTEDThe serial device does not support this operation.
RETURN_DEVICE_ERRORThe serial device is not functioning correctly.

Definition at line 249 of file FdtPL011SerialPortLib.c.

◆ SerialPortWrite()

UINTN EFIAPI SerialPortWrite ( IN UINT8 *  Buffer,
IN UINTN  NumberOfBytes 
)

Write data to serial device.

Parameters
BufferPoint of data buffer which need to be written.
NumberOfBytesNumber of output bytes which are cached in Buffer.
Return values
0Write data failed.
!0Actual number of bytes written to serial device.

Definition at line 118 of file FdtPL011SerialPortLib.c.

Variable Documentation

◆ mPermanentStatus

STATIC RETURN_STATUS mPermanentStatus = RETURN_SUCCESS

Definition at line 27 of file FdtPL011SerialPortLib.c.

◆ mSerialBaseAddress

STATIC UINTN mSerialBaseAddress

Definition at line 26 of file FdtPL011SerialPortLib.c.