Bluetooth: Fix l2cap conn failures for ssp devices
authorPeter Hurley <peter@xxxxxxxxxxxxxxxxxx>
Tue, 9 Aug 2011 20:26:55 +0000 (16:26 -0400)
committerJaikumar Ganesh <jaikumarg@android.com>
Mon, 29 Aug 2011 22:24:13 +0000 (15:24 -0700)
Commit 330605423c fixed l2cap conn establishment for non-ssp remote
devices by not setting HCI_CONN_ENCRYPT_PEND every time conn security
is tested (which was always returning failure on any subsequent
security checks).

However, this broke l2cap conn establishment for ssp remote devices
when an ACL link was already established at SDP-level security. This
fix ensures that encryption must be pending whenever authentication
is also pending.

Change-Id: I6876ea5134e90d1f3d0f84e8ed40b92977b3df64
Signed-off-by: Peter Hurley <peter@xxxxxxxxxxxxxxxxxx>
net/bluetooth/hci_conn.c

index 5ec0db423169e0598a929dc7d6396b1a380d084c..33c4e0cd83b1b5387dfb4824f64b34b704e4ea67 100644 (file)
@@ -619,6 +619,10 @@ static int hci_conn_auth(struct hci_conn *conn, __u8 sec_level, __u8 auth_type)
 
        if (!test_and_set_bit(HCI_CONN_AUTH_PEND, &conn->pend)) {
                struct hci_cp_auth_requested cp;
+
+               /* encrypt must be pending if auth is also pending */
+               set_bit(HCI_CONN_ENCRYPT_PEND, &conn->pend);
+
                cp.handle = cpu_to_le16(conn->handle);
                hci_send_cmd(conn->hdev, HCI_OP_AUTH_REQUESTED,
                                                        sizeof(cp), &cp);