iommu: Fix integer truncation
authorArnd Bergmann <arnd@arndb.de>
Mon, 17 Jun 2019 13:30:54 +0000 (15:30 +0200)
committerJoerg Roedel <jroedel@suse.de>
Tue, 18 Jun 2019 15:24:42 +0000 (17:24 +0200)
commit29fcea8ce7f3c16ebd267f8cb2f4a07887530aa9
tree87843c08754266b1e890b157ad2b21ff8d44ba18
parent58b55c859ac00c6845b6aed8852c541bc204c935
iommu: Fix integer truncation

On 32-bit architectures, phys_addr_t may be different from dma_add_t,
both smaller and bigger. This can lead to an overflow during an assignment
that clang warns about:

drivers/iommu/dma-iommu.c:230:10: error: implicit conversion from 'dma_addr_t' (aka 'unsigned long long') to
      'phys_addr_t' (aka 'unsigned int') changes value from 18446744073709551615 to 4294967295 [-Werror,-Wconstant-conversion]

Use phys_addr_t here because that is the type that the variable was
declared as.

Fixes: aadad097cd46 ("iommu/dma: Reserve IOVA for PCIe inaccessible DMA address")
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Joerg Roedel <jroedel@suse.de>
drivers/iommu/dma-iommu.c