From: Stefan Wahren Date: Mon, 31 Oct 2016 14:39:31 +0000 (+0000) Subject: staging: vchiq_arm: handle error case of get_user_pages X-Git-Tag: v4.14-rc1~1919^2~338 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=0feb1ed5c51acd5cea3d65221e8693c3c4bb4c8d;p=platform%2Fkernel%2Flinux-rpi.git staging: vchiq_arm: handle error case of get_user_pages It's possible that get_user_pages() could fail. So evaluate its return code and handle this error case properly. This issue has been found by Cppcheck. Signed-off-by: Stefan Wahren Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c b/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c index 6ea8f13..90296c2 100644 --- a/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c +++ b/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c @@ -1579,6 +1579,12 @@ dump_phys_mem(void *virt_addr, uint32_t num_bytes) prev_idx = -1; page = NULL; + if (rc < 0) { + vchiq_log_error(vchiq_arm_log_level, + "Failed to get user pages: %d\n", rc); + goto out; + } + while (offset < end_offset) { int page_offset = offset % PAGE_SIZE; @@ -1602,6 +1608,8 @@ dump_phys_mem(void *virt_addr, uint32_t num_bytes) offset += 16; } + +out: if (page != NULL) kunmap(page);