diff options
author | Michael Brown | 2020-11-04 16:18:49 +0100 |
---|---|---|
committer | Michael Brown | 2020-11-05 21:03:50 +0100 |
commit | dda03c884d70d18546bb2d02f92acb4c4da28fc8 (patch) | |
tree | 775637d2c67340a945df274ff5da3d88353d43c8 /src/config/defaults/efi.h | |
parent | [malloc] Rename malloc_dma() to malloc_phys() (diff) | |
download | ipxe-dda03c884d70d18546bb2d02f92acb4c4da28fc8.tar.gz ipxe-dda03c884d70d18546bb2d02f92acb4c4da28fc8.tar.xz ipxe-dda03c884d70d18546bb2d02f92acb4c4da28fc8.zip |
[dma] Define a DMA API to allow for non-flat device address spaces
iPXE currently assumes that DMA-capable devices can directly address
physical memory using host addresses. This assumption fails when
using an IOMMU.
Define an internal DMA API with two implementations: a "flat"
implementation for use in legacy BIOS or other environments in which
flat physical addressing is guaranteed to be used and all allocated
physical addresses are guaranteed to be within a 32-bit address space,
and an "operations-based" implementation for use in UEFI or other
environments in which DMA mapping may require bus-specific handling.
The purpose of the fully inlined "flat" implementation is to allow the
trivial identity DMA mappings to be optimised out at build time,
thereby avoiding an increase in code size for legacy BIOS builds.
Signed-off-by: Michael Brown <mcb30@ipxe.org>
Diffstat (limited to 'src/config/defaults/efi.h')
-rw-r--r-- | src/config/defaults/efi.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/src/config/defaults/efi.h b/src/config/defaults/efi.h index 0979887f..9ef34ab6 100644 --- a/src/config/defaults/efi.h +++ b/src/config/defaults/efi.h @@ -12,6 +12,7 @@ FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL ); #define UACCESS_EFI #define IOMAP_VIRT #define PCIAPI_EFI +#define DMAAPI_OP #define CONSOLE_EFI #define TIMER_EFI #define UMALLOC_EFI |