From: Andrew Morton Date: Tue, 2 Dec 2014 23:59:31 +0000 (-0800) Subject: drivers/input/evdev.c: don't kfree() a vmalloc address X-Git-Tag: v3.17.7~45 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=3abaac9510bbdf474567e19b6bb5c32e5260d2bd;p=thirdparty%2Fkernel%2Fstable.git drivers/input/evdev.c: don't kfree() a vmalloc address commit 92788ac1eb06e69a822de45e2a8a63fa45eb5be2 upstream. If kzalloc() failed and then evdev_open_device() fails, evdev_open() will pass a vmalloc'ed pointer to kfree. This might fix https://bugzilla.kernel.org/show_bug.cgi?id=88401, where there was a crash in kfree(). Reported-by: Christian Casteyde Belatedly-Acked-by: Dmitry Torokhov Cc: Henrik Rydberg Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/input/evdev.c b/drivers/input/evdev.c index de055451d1af6..b535322a36dbc 100644 --- a/drivers/input/evdev.c +++ b/drivers/input/evdev.c @@ -421,7 +421,7 @@ static int evdev_open(struct inode *inode, struct file *file) err_free_client: evdev_detach_client(evdev, client); - kfree(client); + kvfree(client); return error; }