From: Colin Cross Date: Tue, 26 Nov 2013 23:34:50 +0000 (-0800) Subject: ion: check return value from remap_pfn_range X-Git-Tag: firefly_0821_release~4090^2~446 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=3b8da00c6c5e42af7b532dbf51b2d5007095d844;p=firefly-linux-kernel-4.4.55.git ion: check return value from remap_pfn_range Check the return value of remap_pfn_range and return an error if it fails. Change-Id: I206cf95a24607ebe1c80274e3ed15cc7c076d007 Signed-off-by: Colin Cross --- diff --git a/drivers/staging/android/ion/ion_heap.c b/drivers/staging/android/ion/ion_heap.c index 0d30f9f7eeb7..403fdc7d7453 100644 --- a/drivers/staging/android/ion/ion_heap.c +++ b/drivers/staging/android/ion/ion_heap.c @@ -76,6 +76,7 @@ int ion_heap_map_user(struct ion_heap *heap, struct ion_buffer *buffer, unsigned long offset = vma->vm_pgoff * PAGE_SIZE; struct scatterlist *sg; int i; + int ret; for_each_sg(table->sgl, sg, table->nents, i) { struct page *page = sg_page(sg); @@ -91,8 +92,10 @@ int ion_heap_map_user(struct ion_heap *heap, struct ion_buffer *buffer, offset = 0; } len = min(len, remainder); - remap_pfn_range(vma, addr, page_to_pfn(page), len, + ret = remap_pfn_range(vma, addr, page_to_pfn(page), len, vma->vm_page_prot); + if (ret) + return ret; addr += len; if (addr >= vma->vm_end) return 0;