LEDS: memory leak in blinkm_led_common_set()
authorDan Carpenter <dan.carpenter@oracle.com>
Thu, 26 Jul 2012 07:59:51 +0000 (15:59 +0800)
committerBryan Wu <bryan.wu@canonical.com>
Fri, 27 Jul 2012 00:13:58 +0000 (08:13 +0800)
This can return without freeing the bl_work struct.  Also there was no
check for allocation failure.

Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Acked-by: Jan-Simon Möller <jansimon.moeller@gmx.de>
Signed-off-by: Bryan Wu <bryan.wu@canonical.com>
drivers/leds/leds-blinkm.c

index 5a9df43..ae6ad63 100644 (file)
@@ -468,8 +468,7 @@ static int blinkm_led_common_set(struct led_classdev *led_cdev,
        /* led_brightness is 0, 127 or 255 - we just use it here as-is */
        struct blinkm_led *led = cdev_to_blmled(led_cdev);
        struct blinkm_data *data = i2c_get_clientdata(led->i2c_client);
-       struct blinkm_work *bl_work = kzalloc(sizeof(struct blinkm_work),
-                                             GFP_ATOMIC);
+       struct blinkm_work *bl_work;
 
        switch (color) {
        case RED:
@@ -511,6 +510,10 @@ static int blinkm_led_common_set(struct led_classdev *led_cdev,
                return -EINVAL;
        }
 
+       bl_work = kzalloc(sizeof(*bl_work), GFP_ATOMIC);
+       if (!bl_work)
+               return -ENOMEM;
+
        atomic_inc(&led->active);
        dev_dbg(&led->i2c_client->dev,
                        "#TO_SCHED# next_red = %d, next_green = %d,"