TianoCore EDK2 master
Loading...
Searching...
No Matches
IoLib.c File Reference

Go to the source code of this file.

Functions

UINT64 EFIAPI IoRead64 (IN UINTN Port)
 
UINT64 EFIAPI IoWrite64 (IN UINTN Port, IN UINT64 Value)
 
UINT8 EFIAPI MmioRead8 (IN UINTN Address)
 
UINT8 EFIAPI MmioWrite8 (IN UINTN Address, IN UINT8 Value)
 
UINT16 EFIAPI MmioRead16 (IN UINTN Address)
 
UINT16 EFIAPI MmioWrite16 (IN UINTN Address, IN UINT16 Value)
 
UINT32 EFIAPI MmioRead32 (IN UINTN Address)
 
UINT32 EFIAPI MmioWrite32 (IN UINTN Address, IN UINT32 Value)
 
UINT64 EFIAPI MmioRead64 (IN UINTN Address)
 
UINT64 EFIAPI MmioWrite64 (IN UINTN Address, IN UINT64 Value)
 

Detailed Description

Common I/O Library routines.

Copyright (c) 2006 - 2021, Intel Corporation. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent

Definition in file IoLib.c.

Function Documentation

◆ IoRead64()

UINT64 EFIAPI IoRead64 ( IN UINTN  Port)

Reads a 64-bit I/O port.

Reads the 64-bit I/O port specified by Port. The 64-bit read value is returned. This function must guarantee that all I/O read and write operations are serialized.

If 64-bit I/O port operations are not supported, then ASSERT(). If Port is not aligned on a 64-bit boundary, then ASSERT().

Parameters
PortThe I/O port to read.
Returns
The value read.

Definition at line 29 of file IoLib.c.

◆ IoWrite64()

UINT64 EFIAPI IoWrite64 ( IN UINTN  Port,
IN UINT64  Value 
)

Writes a 64-bit I/O port.

Writes the 64-bit I/O port specified by Port with the value specified by Value and returns Value. This function must guarantee that all I/O read and write operations are serialized.

If 64-bit I/O port operations are not supported, then ASSERT(). If Port is not aligned on a 64-bit boundary, then ASSERT().

Parameters
PortThe I/O port to write.
ValueThe value to write to the I/O port.
Returns
The value written the I/O port.

Definition at line 55 of file IoLib.c.

◆ MmioRead16()

UINT16 EFIAPI MmioRead16 ( IN UINTN  Address)

Reads a 16-bit MMIO register.

Reads the 16-bit MMIO register specified by Address. The 16-bit read value is returned. This function must guarantee that all MMIO read and write operations are serialized.

If 16-bit MMIO register operations are not supported, then ASSERT(). If Address is not aligned on a 16-bit boundary, then ASSERT().

For Td guest TDVMCALL_MMIO is invoked to read MMIO registers.

Parameters
AddressThe MMIO register to read.
Returns
The value read.

Definition at line 170 of file IoLib.c.

◆ MmioRead32()

UINT32 EFIAPI MmioRead32 ( IN UINTN  Address)

Reads a 32-bit MMIO register.

Reads the 32-bit MMIO register specified by Address. The 32-bit read value is returned. This function must guarantee that all MMIO read and write operations are serialized.

If 32-bit MMIO register operations are not supported, then ASSERT(). If Address is not aligned on a 32-bit boundary, then ASSERT().

For Td guest TDVMCALL_MMIO is invoked to read MMIO registers.

Parameters
AddressThe MMIO register to read.
Returns
The value read.

Definition at line 262 of file IoLib.c.

◆ MmioRead64()

UINT64 EFIAPI MmioRead64 ( IN UINTN  Address)

Reads a 64-bit MMIO register.

Reads the 64-bit MMIO register specified by Address. The 64-bit read value is returned. This function must guarantee that all MMIO read and write operations are serialized.

If 64-bit MMIO register operations are not supported, then ASSERT(). If Address is not aligned on a 64-bit boundary, then ASSERT().

For Td guest TDVMCALL_MMIO is invoked to read MMIO registers.

Parameters
AddressThe MMIO register to read.
Returns
The value read.

Definition at line 355 of file IoLib.c.

◆ MmioRead8()

UINT8 EFIAPI MmioRead8 ( IN UINTN  Address)

Reads an 8-bit MMIO register.

Reads the 8-bit MMIO register specified by Address. The 8-bit read value is returned. This function must guarantee that all MMIO read and write operations are serialized.

If 8-bit MMIO register operations are not supported, then ASSERT().

For Td guest TDVMCALL_MMIO is invoked to read MMIO registers.

Parameters
AddressThe MMIO register to read.
Returns
The value read.

Definition at line 82 of file IoLib.c.

◆ MmioWrite16()

UINT16 EFIAPI MmioWrite16 ( IN UINTN  Address,
IN UINT16  Value 
)

Writes a 16-bit MMIO register.

Writes the 16-bit MMIO register specified by Address with the value specified by Value and returns Value. This function must guarantee that all MMIO read and write operations are serialized.

If 16-bit MMIO register operations are not supported, then ASSERT(). If Address is not aligned on a 16-bit boundary, then ASSERT().

For Td guest TDVMCALL_MMIO is invoked to write MMIO registers.

Parameters
AddressThe MMIO register to write.
ValueThe value to write to the MMIO register.
Returns
Value.

Definition at line 216 of file IoLib.c.

◆ MmioWrite32()

UINT32 EFIAPI MmioWrite32 ( IN UINTN  Address,
IN UINT32  Value 
)

Writes a 32-bit MMIO register.

Writes the 32-bit MMIO register specified by Address with the value specified by Value and returns Value. This function must guarantee that all MMIO read and write operations are serialized.

If 32-bit MMIO register operations are not supported, then ASSERT(). If Address is not aligned on a 32-bit boundary, then ASSERT().

For Td guest TDVMCALL_MMIO is invoked to write MMIO registers.

Parameters
AddressThe MMIO register to write.
ValueThe value to write to the MMIO register.
Returns
Value.

Definition at line 309 of file IoLib.c.

◆ MmioWrite64()

UINT64 EFIAPI MmioWrite64 ( IN UINTN  Address,
IN UINT64  Value 
)

Writes a 64-bit MMIO register.

Writes the 64-bit MMIO register specified by Address with the value specified by Value and returns Value. This function must guarantee that all MMIO read and write operations are serialized.

If 64-bit MMIO register operations are not supported, then ASSERT(). If Address is not aligned on a 64-bit boundary, then ASSERT().

For Td guest TDVMCALL_MMIO is invoked to write MMIO registers.

Parameters
AddressThe MMIO register to write.
ValueThe value to write to the MMIO register.

Definition at line 400 of file IoLib.c.

◆ MmioWrite8()

UINT8 EFIAPI MmioWrite8 ( IN UINTN  Address,
IN UINT8  Value 
)

Writes an 8-bit MMIO register.

Writes the 8-bit MMIO register specified by Address with the value specified by Value and returns Value. This function must guarantee that all MMIO read and write operations are serialized.

If 8-bit MMIO register operations are not supported, then ASSERT().

For Td guest TDVMCALL_MMIO is invoked to write MMIO registers.

Parameters
AddressThe MMIO register to write.
ValueThe value to write to the MMIO register.
Returns
Value.

Definition at line 126 of file IoLib.c.