TianoCore EDK2 master
Loading...
Searching...
No Matches
CoherentDmaLib.c File Reference
#include <Uefi.h>
#include <Library/DebugLib.h>
#include <Library/DmaLib.h>
#include <Library/MemoryAllocationLib.h>

Go to the source code of this file.

Functions

STATIC PHYSICAL_ADDRESS HostToDeviceAddress (IN VOID *Address)
 
EFI_STATUS EFIAPI DmaMap (IN DMA_MAP_OPERATION Operation, IN VOID *HostAddress, IN OUT UINTN *NumberOfBytes, OUT PHYSICAL_ADDRESS *DeviceAddress, OUT VOID **Mapping)
 
EFI_STATUS EFIAPI DmaUnmap (IN VOID *Mapping)
 
EFI_STATUS EFIAPI DmaAllocateBuffer (IN EFI_MEMORY_TYPE MemoryType, IN UINTN Pages, OUT VOID **HostAddress)
 
EFI_STATUS EFIAPI DmaAllocateAlignedBuffer (IN EFI_MEMORY_TYPE MemoryType, IN UINTN Pages, IN UINTN Alignment, OUT VOID **HostAddress)
 
EFI_STATUS EFIAPI DmaFreeBuffer (IN UINTN Pages, IN VOID *HostAddress)
 

Detailed Description

Generic ARM implementation of DmaLib.h

Copyright (c) 2008 - 2010, Apple Inc. All rights reserved.

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

Definition in file CoherentDmaLib.c.

Function Documentation

◆ DmaAllocateAlignedBuffer()

EFI_STATUS EFIAPI DmaAllocateAlignedBuffer ( IN EFI_MEMORY_TYPE  MemoryType,
IN UINTN  Pages,
IN UINTN  Alignment,
OUT VOID **  HostAddress 
)

Allocates pages that are suitable for an DmaMap() of type MapOperationBusMasterCommonBuffer mapping, at the requested alignment.

Parameters
MemoryTypeThe type of memory to allocate, EfiBootServicesData or EfiRuntimeServicesData.
PagesThe number of pages to allocate.
AlignmentAlignment in bytes of the base of the returned buffer (must be a power of 2)
HostAddressA pointer to store the base system memory address of the allocated range.
Return values
EFI_SUCCESSThe requested memory pages were allocated.
EFI_UNSUPPORTEDAttributes is unsupported. The only legal attribute bits are MEMORY_WRITE_COMBINE and MEMORY_CACHED.
EFI_INVALID_PARAMETEROne or more parameters are invalid.
EFI_OUT_OF_RESOURCESThe memory pages could not be allocated.

Definition at line 135 of file CoherentDmaLib.c.

◆ DmaAllocateBuffer()

EFI_STATUS EFIAPI DmaAllocateBuffer ( IN EFI_MEMORY_TYPE  MemoryType,
IN UINTN  Pages,
OUT VOID **  HostAddress 
)

Allocates pages that are suitable for an DmaMap() of type MapOperationBusMasterCommonBuffer. mapping.

Parameters
MemoryTypeThe type of memory to allocate, EfiBootServicesData or EfiRuntimeServicesData.
PagesThe number of pages to allocate.
HostAddressA pointer to store the base system memory address of the allocated range.
Return values
EFI_SUCCESSThe requested memory pages were allocated.
EFI_UNSUPPORTEDAttributes is unsupported. The only legal attribute bits are MEMORY_WRITE_COMBINE and MEMORY_CACHED.
EFI_INVALID_PARAMETEROne or more parameters are invalid.
EFI_OUT_OF_RESOURCESThe memory pages could not be allocated.

Definition at line 105 of file CoherentDmaLib.c.

◆ DmaFreeBuffer()

EFI_STATUS EFIAPI DmaFreeBuffer ( IN UINTN  Pages,
IN VOID *  HostAddress 
)

Frees memory that was allocated with DmaAllocateBuffer().

Parameters
PagesThe number of pages to free.
HostAddressThe base system memory address of the allocated range.
Return values
EFI_SUCCESSThe requested memory pages were freed.
EFI_INVALID_PARAMETERThe memory range specified by HostAddress and Pages was not allocated with DmaAllocateBuffer().

Definition at line 183 of file CoherentDmaLib.c.

◆ DmaMap()

EFI_STATUS EFIAPI DmaMap ( IN DMA_MAP_OPERATION  Operation,
IN VOID *  HostAddress,
IN OUT UINTN NumberOfBytes,
OUT PHYSICAL_ADDRESS *  DeviceAddress,
OUT VOID **  Mapping 
)

Provides the DMA controller-specific addresses needed to access system memory.

Operation is relative to the DMA bus master.

Parameters
OperationIndicates if the bus master is going to read or write to system memory.
HostAddressThe system memory address to map to the DMA controller.
NumberOfBytesOn input the number of bytes to map. On output the number of bytes that were mapped.
DeviceAddressThe resulting map address for the bus master controller to use to access the hosts HostAddress.
MappingA resulting value to pass to Unmap().
Return values
EFI_SUCCESSThe range was mapped for the returned NumberOfBytes.
EFI_UNSUPPORTEDThe HostAddress cannot be mapped as a common buffer.
EFI_INVALID_PARAMETEROne or more parameters are invalid.
EFI_OUT_OF_RESOURCESThe request could not be completed due to a lack of resources.
EFI_DEVICE_ERRORThe system hardware could not map the requested address.

Definition at line 46 of file CoherentDmaLib.c.

◆ DmaUnmap()

EFI_STATUS EFIAPI DmaUnmap ( IN VOID *  Mapping)

Completes the DmaMapBusMasterRead(), DmaMapBusMasterWrite(), or DmaMapBusMasterCommonBuffer() operation and releases any corresponding resources.

Parameters
MappingThe mapping value returned from DmaMap*().
Return values
EFI_SUCCESSThe range was unmapped.
EFI_DEVICE_ERRORThe data was not committed to the target system memory.

Definition at line 79 of file CoherentDmaLib.c.

◆ HostToDeviceAddress()

STATIC PHYSICAL_ADDRESS HostToDeviceAddress ( IN VOID *  Address)

Definition at line 17 of file CoherentDmaLib.c.