]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
Bluetooth: MGMT: Add error handling to pair_device()
authorGriffin Kroah-Hartman <griffin@kroah.com>
Thu, 15 Aug 2024 11:51:00 +0000 (13:51 +0200)
committerLuiz Augusto von Dentz <luiz.von.dentz@intel.com>
Thu, 15 Aug 2024 17:09:35 +0000 (13:09 -0400)
hci_conn_params_add() never checks for a NULL value and could lead to a NULL
pointer dereference causing a crash.

Fixed by adding error handling in the function.

Cc: Stable <stable@kernel.org>
Fixes: 5157b8a503fa ("Bluetooth: Fix initializing conn_params in scan phase")
Signed-off-by: Griffin Kroah-Hartman <griffin@kroah.com>
Reported-by: Yiwei Zhang <zhan4630@purdue.edu>
Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
net/bluetooth/mgmt.c

index 40d4887c7f791314040a292a5f363e993e6d384e..25979f4283a6ff413a2cb49b7f8b677dba1569de 100644 (file)
@@ -3456,6 +3456,10 @@ static int pair_device(struct sock *sk, struct hci_dev *hdev, void *data,
                 * will be kept and this function does nothing.
                 */
                p = hci_conn_params_add(hdev, &cp->addr.bdaddr, addr_type);
+               if (!p) {
+                       err = -EIO;
+                       goto unlock;
+               }
 
                if (p->auto_connect == HCI_AUTO_CONN_EXPLICIT)
                        p->auto_connect = HCI_AUTO_CONN_DISABLED;