From: Masakazu Mokuno Date: Wed, 24 Aug 2011 23:47:36 +0000 (+1000) Subject: The memory for struct led_trigger should be kfreed in the X-Git-Tag: next-20110909~1^2~27 X-Git-Url: https://git.karo-electronics.de/?a=commitdiff_plain;h=56b4e12cbc56b048539449ade701958fb0c67cdf;p=karo-tx-linux.git 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 Cc: Richard Purdie Signed-off-by: Andrew Morton --- 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) if (trigger) { trigger->name = name; err = led_trigger_register(trigger); - if (err < 0) + if (err < 0) { + kfree(trigger); + trigger = NULL; printk(KERN_WARNING "LED trigger %s failed to register" " (%d)\n", name, err); + } } else printk(KERN_WARNING "LED trigger %s failed to register" " (no memory)\n", name);