]> git.hungrycats.org Git - linux/commitdiff
Bluetooth: Fix using uninitialized variable when pairing
authorJohan Hedberg <johan.hedberg@intel.com>
Thu, 17 Jul 2014 08:56:33 +0000 (11:56 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 17 Sep 2014 16:22:14 +0000 (09:22 -0700)
commit 9f743d7499bc2c4dc8c35af33bdb2a29bea663b9 upstream.

Commit 6c53823ae0e10e723131055e1e65dd6a328a228e reshuffled the way the
authentication requirement gets set in the hci_io_capa_request_evt()
function, but at the same time it failed to update an if-statement where
cp.authentication is used before it has been initialized. The correct
value the code should be looking for in this if-statement is
conn->auth_type.

Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
net/bluetooth/hci_event.c

index 4dac1d2ffefb69072fce02fa0d67dcaea3ef4cac..3787be160c2b8916c2557de1aed450f9a9e953f1 100644 (file)
@@ -3542,7 +3542,7 @@ static void hci_io_capa_request_evt(struct hci_dev *hdev, struct sk_buff *skb)
                         * except for the no-bonding case.
                         */
                        if (conn->io_capability != HCI_IO_NO_INPUT_OUTPUT &&
-                           cp.authentication != HCI_AT_NO_BONDING)
+                           conn->auth_type != HCI_AT_NO_BONDING)
                                conn->auth_type |= 0x01;
 
                        cp.authentication = conn->auth_type;