diff options
author | Gustavo Padovan <gustavo@padovan.org> | 2012-05-13 03:20:07 -0300 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2012-05-14 13:51:25 -0400 |
commit | a7d7723ae7c0178d715c06c5621e8fd8014ba92f (patch) | |
tree | 8e09cd37ed267e792481c2ad699bcaff9596e5e7 /net/bluetooth/af_bluetooth.c | |
parent | 574e02abaf816b582685805f0c1150ca9f1f18ee (diff) | |
download | lwn-a7d7723ae7c0178d715c06c5621e8fd8014ba92f.tar.gz lwn-a7d7723ae7c0178d715c06c5621e8fd8014ba92f.zip |
Bluetooth: notify userspace of security level change
It fixes L2CAP socket based security level elevation during a
connection. The HID profile needs this (for keyboards) and it is the only
way to achieve the security level elevation when using the management
interface to talk to the kernel (hence the management enabling patch
being the one that exposes this issue).
It enables the userspace a security level change when the socket is
already connected and create a way to notify the socket the result of the
request. At the moment of the request the socket is made non writable, if
the request fails the connections closes, otherwise the socket is made
writable again, POLL_OUT is emmited.
Signed-off-by: Gustavo Padovan <gustavo@padovan.org>
Acked-by: Marcel Holtmann <marcel@holtmann.org>
Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/bluetooth/af_bluetooth.c')
-rw-r--r-- | net/bluetooth/af_bluetooth.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/bluetooth/af_bluetooth.c b/net/bluetooth/af_bluetooth.c index 72eb187a5f60..6fb68a9743af 100644 --- a/net/bluetooth/af_bluetooth.c +++ b/net/bluetooth/af_bluetooth.c @@ -450,7 +450,7 @@ unsigned int bt_sock_poll(struct file *file, struct socket *sock, poll_table *wa sk->sk_state == BT_CONFIG) return mask; - if (sock_writeable(sk)) + if (!bt_sk(sk)->suspended && sock_writeable(sk)) mask |= POLLOUT | POLLWRNORM | POLLWRBAND; else set_bit(SOCK_ASYNC_NOSPACE, &sk->sk_socket->flags); |