diff options
author | Sudip Mukherjee <sudipm.mukherjee@gmail.com> | 2016-02-23 13:44:17 +0100 |
---|---|---|
committer | Tomi Valkeinen <tomi.valkeinen@ti.com> | 2016-02-26 11:16:58 +0100 |
commit | 7fdfc702d301a127d875e5608342a249201fdb4a (patch) | |
tree | 46ea50c5e8bad93e8113915a7e57f173f5daac4b /drivers/video/fbdev/n411.c | |
parent | fbdev: exynos: fix IS_ERR_VALUE usage (diff) | |
download | linux-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.c | 12 |
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) |