diff options
author | Masakazu Mokuno <Masakazu.Mokuno@jp.sony.com> | 2011-10-31 20:11:59 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-10-31 20:30:55 -0400 |
commit | cba4c2ac080e170732a030afc27664b00f838e03 (patch) | |
tree | b230c60335225f533b10b570f323662f7ed9cfe0 /drivers/leds | |
parent | f59b6f9f323ff1b4567a69f9063cdd8bb57805e6 (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.c | 5 |
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); |