mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-10 23:29:46 +00:00
Bluetooth: Limit BR/EDR switching for LE only with secure connections
When a powered on dual-mode controller has been configured to operate as LE only with secure connections, then the BR/EDR side of things can not be switched back on. Do reconfigure the controller it first needs to be powered down. The secure connections feature is implemented in the BR/EDR controller while for LE it is implemented in the host. So explicitly forbid such a transaction to avoid inconsistent states. Signed-off-by: Marcel Holtmann <marcel@holtmann.org> Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
This commit is contained in:
parent
574ea3c713
commit
3a5486e1fd
@ -4691,9 +4691,16 @@ static int set_bredr(struct sock *sk, struct hci_dev *hdev, void *data, u16 len)
|
||||
* Dual-mode controllers shall operate with the public
|
||||
* address as its identity address for BR/EDR and LE. So
|
||||
* reject the attempt to create an invalid configuration.
|
||||
*
|
||||
* The same restrictions applies when secure connections
|
||||
* has been enabled. For BR/EDR this is a controller feature
|
||||
* while for LE it is a host stack feature. This means that
|
||||
* switching BR/EDR back on when secure connections has been
|
||||
* enabled is not a supported transaction.
|
||||
*/
|
||||
if (!test_bit(HCI_BREDR_ENABLED, &hdev->dev_flags) &&
|
||||
bacmp(&hdev->static_addr, BDADDR_ANY)) {
|
||||
(bacmp(&hdev->static_addr, BDADDR_ANY) ||
|
||||
test_bit(HCI_SC_ENABLED, &hdev->dev_flags))) {
|
||||
err = cmd_status(sk, hdev->id, MGMT_OP_SET_BREDR,
|
||||
MGMT_STATUS_REJECTED);
|
||||
goto unlock;
|
||||
|
Loading…
x
Reference in New Issue
Block a user