Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 4be5a281 authored by Eric Biggers's avatar Eric Biggers Committed by Greg Kroah-Hartman
Browse files

binder: check for binder_thread allocation failure in binder_poll()



commit f88982679f54f75daa5b8eff3da72508f1e7422f upstream.

If the kzalloc() in binder_get_thread() fails, binder_poll()
dereferences the resulting NULL pointer.

Fix it by returning POLLERR if the memory allocation failed.

This bug was found by syzkaller using fault injection.

Reported-by: default avatarsyzbot <syzkaller@googlegroups.com>
Fixes: 457b9a6f ("Staging: android: add binder driver")
Cc: stable@vger.kernel.org
Signed-off-by: default avatarEric Biggers <ebiggers@google.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 2dfe49da
Loading
Loading
Loading
Loading
+2 −0
Original line number Diff line number Diff line
@@ -2628,6 +2628,8 @@ static unsigned int binder_poll(struct file *filp,
	binder_lock(__func__);

	thread = binder_get_thread(proc);
	if (!thread)
		return POLLERR;

	wait_for_proc_work = thread->transaction_stack == NULL &&
		list_empty(&thread->todo) && thread->return_error == BR_OK;