phonet/pep: refuse to enable an unbound pipe
authorRémi Denis-Courmont <remi@remlab.net>
Sun, 19 Dec 2021 17:03:39 +0000 (19:03 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 29 Dec 2021 11:29:03 +0000 (12:29 +0100)
commit53ccdc73eedaf0e922c45b569b797d2796fbaafa
tree89807d03982726f2e9af2ee7a2f0d6ff1f07c651
parent3cb5ae77799e8ed6ec3fec0b6b4cd07f01650cc5
phonet/pep: refuse to enable an unbound pipe

commit 75a2f31520095600f650597c0ac41f48b5ba0068 upstream.

This ioctl() implicitly assumed that the socket was already bound to
a valid local socket name, i.e. Phonet object. If the socket was not
bound, two separate problems would occur:

1) We'd send an pipe enablement request with an invalid source object.
2) Later socket calls could BUG on the socket unexpectedly being
   connected yet not bound to a valid object.

Reported-by: syzbot+2dc91e7fc3dea88b1e8a@syzkaller.appspotmail.com
Signed-off-by: Rémi Denis-Courmont <remi@remlab.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
net/phonet/pep.c