aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/leds
diff options
context:
space:
mode:
authorMasakazu Mokuno <Masakazu.Mokuno@jp.sony.com>2011-10-31 20:11:59 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2011-10-31 20:30:55 -0400
commitcba4c2ac080e170732a030afc27664b00f838e03 (patch)
treeb230c60335225f533b10b570f323662f7ed9cfe0 /drivers/leds
parentf59b6f9f323ff1b4567a69f9063cdd8bb57805e6 (diff)
drivers/leds/led-triggers.c: fix memory leak
The memory for struct led_trigger should be kfreed in the led_trigger_register() error path. Also this function should return NULL on error. Signed-off-by: Masakazu Mokuno <mokuno@sm.sony.co.jp> Cc: Richard Purdie <rpurdie@rpsys.net> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/leds')
-rw-r--r--drivers/leds/led-triggers.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/leds/led-triggers.c b/drivers/leds/led-triggers.c
index 4bebae733349..6f1ff93d7cec 100644
--- a/drivers/leds/led-triggers.c
+++ b/drivers/leds/led-triggers.c
@@ -261,9 +261,12 @@ void led_trigger_register_simple(const char *name, struct led_trigger **tp)
261 if (trigger) { 261 if (trigger) {
262 trigger->name = name; 262 trigger->name = name;
263 err = led_trigger_register(trigger); 263 err = led_trigger_register(trigger);
264 if (err < 0) 264 if (err < 0) {
265 kfree(trigger);
266 trigger = NULL;
265 printk(KERN_WARNING "LED trigger %s failed to register" 267 printk(KERN_WARNING "LED trigger %s failed to register"
266 " (%d)\n", name, err); 268 " (%d)\n", name, err);
269 }
267 } else 270 } else
268 printk(KERN_WARNING "LED trigger %s failed to register" 271 printk(KERN_WARNING "LED trigger %s failed to register"
269 " (no memory)\n", name); 272 " (no memory)\n", name);