mm: cma: fix incorrect type conversion for size during dma allocation
authorRohit Vaswani <rvaswani@codeaurora.org>
Thu, 22 Oct 2015 20:32:11 +0000 (13:32 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 2 Sep 2017 05:05:46 +0000 (07:05 +0200)
commitf0c8d9367c9232fa54e592bad095140f987031fd
tree5af369217b417b37b40cde5e7bd7cf2650aef147
parent30a847400ea9fba0c605256aa51f65d13cc1b01e
mm: cma: fix incorrect type conversion for size during dma allocation

commit 67a2e213e7e937c41c52ab5bc46bf3f4de469f6e upstream.

This was found during userspace fuzzing test when a large size dma cma
allocation is made by driver(like ion) through userspace.

  show_stack+0x10/0x1c
  dump_stack+0x74/0xc8
  kasan_report_error+0x2b0/0x408
  kasan_report+0x34/0x40
  __asan_storeN+0x15c/0x168
  memset+0x20/0x44
  __dma_alloc_coherent+0x114/0x18c

Signed-off-by: Rohit Vaswani <rvaswani@codeaurora.org>
Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: Marek Szyprowski <m.szyprowski@samsung.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Miles Chen <miles.chen@mediatek.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/base/dma-contiguous.c
include/linux/cma.h
include/linux/dma-contiguous.h
mm/cma.c