The kbuild test robot reported:

drivers/staging/android/ion/ion_system_heap.c:122 alloc_largest_available() 
error: potential null dereference 'info'.  (kmalloc returns null)

Where the pointer returned from kmalloc goes unchecked for failure.

This patch adds a simple check for a null return, and handles the error.

XXX: Not sure if continue or 'return NULL' is the right thing to do.

Cc: Colin Cross <ccr...@android.com>
Cc: Greg KH <gre...@linuxfoundation.org>
Cc: Android Kernel Team <kernel-t...@android.com>
Cc: kbuild test robot <fengguang...@intel.com>
Reported-by: kbuild test robot <fengguang...@intel.com>
Signed-off-by: John Stultz <john.stu...@linaro.org>
---
 drivers/staging/android/ion/ion_system_heap.c | 5 +++++
 1 file changed, 5 insertions(+)

diff --git a/drivers/staging/android/ion/ion_system_heap.c 
b/drivers/staging/android/ion/ion_system_heap.c
index 144b2272..cc2e4da 100644
--- a/drivers/staging/android/ion/ion_system_heap.c
+++ b/drivers/staging/android/ion/ion_system_heap.c
@@ -119,6 +119,11 @@ static struct page_info *alloc_largest_available(struct 
ion_system_heap *heap,
                        continue;
 
                info = kmalloc(sizeof(struct page_info), GFP_KERNEL);
+               if(!info) {
+                       free_buffer_page(heap, buffer, page, orders[i]);
+                       continue;
+               }
+
                info->page = page;
                info->order = orders[i];
                return info;
-- 
1.8.3.2

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to