]> git.baikalelectronics.ru Git - kernel.git/commit
drivers: dma-mapping: Do not leave an invalid area->pages pointer in dma_common_conti...
authorCatalin Marinas <catalin.marinas@arm.com>
Thu, 25 May 2017 16:26:47 +0000 (17:26 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 3 Jun 2017 09:51:12 +0000 (18:51 +0900)
commitfb611f5e0b2a9b822c58f3f1f5fa88d9f350e63e
treea1abb7f86a98eb1cdc2459e3289b6ce38675d0bd
parenta81a4e0b763db12c3dab900940f301d43d1c2f4a
drivers: dma-mapping: Do not leave an invalid area->pages pointer in dma_common_contiguous_remap()

The dma_common_pages_remap() function allocates a vm_struct object and
initialises the pages pointer to value passed as argument. However, when
this function is called dma_common_contiguous_remap(), the pages array
is only temporarily allocated, being freed shortly after
dma_common_contiguous_remap() returns. Architecture code checking the
validity of an area->pages pointer would incorrectly dereference already
freed pointers. This has been exposed by the arm64 commit 3c7313baf946
("arm64: Add support for DMA_ATTR_FORCE_CONTIGUOUS to IOMMU").

Fixes: d04ff7c74a62 ("common: dma-mapping: introduce common remapping functions")
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Reported-by: Andrzej Hajda <a.hajda@samsung.com>
Acked-by: Laura Abbott <labbott@redhat.com>
Reviewed-by: Robin Murphy <robin.murphy@arm.com>
Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/base/dma-mapping.c