ArmPkg/ArmDmaLib: fix incorrect device address of double buffer

If double buffering is not required in DmaMap(), the returned device
address is passed through ConvertToPhysicalAddress () to convert the
host address (which in case of DebugUncachedMemoryAllocationLib is not
1:1 mapped) to a physical address, which is what a device would expect
to be able to perform DMA.

By the same reasoning, a double buffer allocated using DmaAllocateBuffer ()
should be converted in the same way, considering that the buffer is allocated
using UncachedAllocatePages (), to which the above equally applies.

So add the missing ConvertToPhysicalAddress () invocation.

Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Tested-by: Ryan Harkin <ryan.harkin@linaro.org>
Reviewed-by: Leif Lindholm <leif.lindholm@linaro.org>
This commit is contained in:
Ard Biesheuvel 2016-11-12 14:02:26 +01:00 committed by Leif Lindholm
parent de2ec785e2
commit 0a99a65d2c
1 changed files with 1 additions and 1 deletions

View File

@ -126,7 +126,7 @@ DmaMap (
CopyMem (Buffer, HostAddress, *NumberOfBytes); CopyMem (Buffer, HostAddress, *NumberOfBytes);
} }
*DeviceAddress = (PHYSICAL_ADDRESS)(UINTN)Buffer; *DeviceAddress = ConvertToPhysicalAddress ((UINTN)Buffer);
} else { } else {
Map->DoubleBuffer = FALSE; Map->DoubleBuffer = FALSE;
} }