diff options
author | Gerald Schaefer <gerald.schaefer@de.ibm.com> | 2015-11-16 13:35:48 (GMT) |
---|---|---|
committer | Martin Schwidefsky <schwidefsky@de.ibm.com> | 2015-11-27 08:24:15 (GMT) |
commit | 69eea95c48857c9dfcac120d6acea43027627b28 (patch) | |
tree | ca93e959a34a2551e4aa1fb71d1487d8d28273f3 /drivers/s390/cio | |
parent | 406123517b5b3cd5855774f80d685cf393c950f6 (diff) | |
download | linux-69eea95c48857c9dfcac120d6acea43027627b28.tar.xz |
s390/pci_dma: fix DMA table corruption with > 4 TB main memory
DMA addresses returned from map_page() are calculated by using an iommu
bitmap plus a start_dma offset. The size of this bitmap is based on the main
memory size. If we have more than (4 TB - start_dma) main memory, the DMA
address calculation will also produce addresses > 4 TB. Such addresses
cannot be inserted in the 3-level DMA page table, instead the entries
modulo 4 TB will be overwritten.
Fix this by restricting the iommu bitmap size to (4 TB - start_dma).
Also set zdev->end_dma to the actual end address of the usable
range, instead of the theoretical maximum as reported by the hardware,
which fixes a sanity check in dma_map() and also the IOMMU API domain
geometry aperture calculation.
Signed-off-by: Gerald Schaefer <gerald.schaefer@de.ibm.com>
Reviewed-by: Sebastian Ott <sebott@linux.vnet.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'drivers/s390/cio')
0 files changed, 0 insertions, 0 deletions