summaryrefslogtreecommitdiffstats
path: root/drivers/video/fbdev/n411.c
diff options
context:
space:
mode:
authorSudip Mukherjee <sudipm.mukherjee@gmail.com>2016-02-23 13:44:17 +0100
committerTomi Valkeinen <tomi.valkeinen@ti.com>2016-02-26 11:16:58 +0100
commit7fdfc702d301a127d875e5608342a249201fdb4a (patch)
tree46ea50c5e8bad93e8113915a7e57f173f5daac4b /drivers/video/fbdev/n411.c
parentfbdev: exynos: fix IS_ERR_VALUE usage (diff)
downloadlinux-7fdfc702d301a127d875e5608342a249201fdb4a.tar.xz
linux-7fdfc702d301a127d875e5608342a249201fdb4a.zip
fbdev: n411: check return value
We were not checking the return value of platform_device_add_data() which can fail. Signed-off-by: Sudip Mukherjee <sudip.mukherjee@codethink.co.uk> Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
Diffstat (limited to 'drivers/video/fbdev/n411.c')
-rw-r--r--drivers/video/fbdev/n411.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/drivers/video/fbdev/n411.c b/drivers/video/fbdev/n411.c
index 935830fea7b6..053deacad7cc 100644
--- a/drivers/video/fbdev/n411.c
+++ b/drivers/video/fbdev/n411.c
@@ -165,16 +165,22 @@ static int __init n411_init(void)
if (!n411_device)
return -ENOMEM;
- platform_device_add_data(n411_device, &n411_board, sizeof(n411_board));
+ ret = platform_device_add_data(n411_device, &n411_board,
+ sizeof(n411_board));
+ if (ret)
+ goto put_plat_device;
/* this _add binds hecubafb to n411. hecubafb refcounts n411 */
ret = platform_device_add(n411_device);
if (ret)
- platform_device_put(n411_device);
+ goto put_plat_device;
- return ret;
+ return 0;
+put_plat_device:
+ platform_device_put(n411_device);
+ return ret;
}
static void __exit n411_exit(void)