aboutsummaryrefslogtreecommitdiffstats
path: root/net/bluetooth
diff options
context:
space:
mode:
Diffstat (limited to 'net/bluetooth')
-rw-r--r--net/bluetooth/mgmt.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c
index e531da805923..cae612658ba9 100644
--- a/net/bluetooth/mgmt.c
+++ b/net/bluetooth/mgmt.c
@@ -4683,6 +4683,21 @@ static int set_bredr(struct sock *sk, struct hci_dev *hdev, void *data, u16 len)
4683 err = cmd_status(sk, hdev->id, MGMT_OP_SET_BREDR, 4683 err = cmd_status(sk, hdev->id, MGMT_OP_SET_BREDR,
4684 MGMT_STATUS_REJECTED); 4684 MGMT_STATUS_REJECTED);
4685 goto unlock; 4685 goto unlock;
4686 } else {
4687 /* When configuring a dual-mode controller to operate
4688 * with LE only and using a static address, then switching
4689 * BR/EDR back on is not allowed.
4690 *
4691 * Dual-mode controllers shall operate with the public
4692 * address as its identity address for BR/EDR and LE. So
4693 * reject the attempt to create an invalid configuration.
4694 */
4695 if (!test_bit(HCI_BREDR_ENABLED, &hdev->dev_flags) &&
4696 bacmp(&hdev->static_addr, BDADDR_ANY)) {
4697 err = cmd_status(sk, hdev->id, MGMT_OP_SET_BREDR,
4698 MGMT_STATUS_REJECTED);
4699 goto unlock;
4700 }
4686 } 4701 }
4687 4702
4688 if (mgmt_pending_find(MGMT_OP_SET_BREDR, hdev)) { 4703 if (mgmt_pending_find(MGMT_OP_SET_BREDR, hdev)) {