mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-02-21 21:02:24 +00:00
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>
This commit is contained in:
parent
f59b6f9f32
commit
cba4c2ac08
@ -261,9 +261,12 @@ void led_trigger_register_simple(const char *name, struct led_trigger **tp)
|
|||||||
if (trigger) {
|
if (trigger) {
|
||||||
trigger->name = name;
|
trigger->name = name;
|
||||||
err = led_trigger_register(trigger);
|
err = led_trigger_register(trigger);
|
||||||
if (err < 0)
|
if (err < 0) {
|
||||||
|
kfree(trigger);
|
||||||
|
trigger = NULL;
|
||||||
printk(KERN_WARNING "LED trigger %s failed to register"
|
printk(KERN_WARNING "LED trigger %s failed to register"
|
||||||
" (%d)\n", name, err);
|
" (%d)\n", name, err);
|
||||||
|
}
|
||||||
} else
|
} else
|
||||||
printk(KERN_WARNING "LED trigger %s failed to register"
|
printk(KERN_WARNING "LED trigger %s failed to register"
|
||||||
" (no memory)\n", name);
|
" (no memory)\n", name);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user