Message ID | 20211219170339.630659-1-remi@remlab.net (mailing list archive) |
---|---|
State | Accepted |
Commit | 75a2f31520095600f650597c0ac41f48b5ba0068 |
Delegated to: | Netdev Maintainers |
Headers | show |
Series | phonet/pep: refuse to enable an unbound pipe | expand |
Hello: This patch was applied to netdev/net.git (master) by David S. Miller <davem@davemloft.net>: On Sun, 19 Dec 2021 19:03:39 +0200 you wrote: > From: Rémi Denis-Courmont <remi@remlab.net> > > 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. > > [...] Here is the summary with links: - phonet/pep: refuse to enable an unbound pipe https://git.kernel.org/netdev/net/c/75a2f3152009 You are awesome, thank you!
diff --git a/net/phonet/pep.c b/net/phonet/pep.c index b4f90afb0638..65d463ad8770 100644 --- a/net/phonet/pep.c +++ b/net/phonet/pep.c @@ -947,6 +947,8 @@ static int pep_ioctl(struct sock *sk, int cmd, unsigned long arg) ret = -EBUSY; else if (sk->sk_state == TCP_ESTABLISHED) ret = -EISCONN; + else if (!pn->pn_sk.sobject) + ret = -EADDRNOTAVAIL; else ret = pep_sock_enable(sk, NULL, 0); release_sock(sk);