Bluetooth: Refuse peer RFCOMM address reading when not connected
When we're not connected the peer address information is undefined. This patch fixes the remote address getting to return a proper error in case the sate is anything else than BT_CONNECTED. Signed-off-by: Johan Hedberg <johan.hedberg@intel.com> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
This commit is contained in:
parent
b783fbc3a5
commit
35364c99d2
@ -528,6 +528,9 @@ static int rfcomm_sock_getname(struct socket *sock, struct sockaddr *addr, int *
|
|||||||
|
|
||||||
BT_DBG("sock %p, sk %p", sock, sk);
|
BT_DBG("sock %p, sk %p", sock, sk);
|
||||||
|
|
||||||
|
if (peer && sk->sk_state != BT_CONNECTED)
|
||||||
|
return -ENOTCONN;
|
||||||
|
|
||||||
memset(sa, 0, sizeof(*sa));
|
memset(sa, 0, sizeof(*sa));
|
||||||
sa->rc_family = AF_BLUETOOTH;
|
sa->rc_family = AF_BLUETOOTH;
|
||||||
sa->rc_channel = rfcomm_pi(sk)->channel;
|
sa->rc_channel = rfcomm_pi(sk)->channel;
|
||||||
|
Loading…
Reference in New Issue
Block a user