Bluetooth: Bind the SMP channel registration to management power state
When the controller gets powered on via the management interface, then register the supported SMP channels. There is no point in registering these channels earlier since it is not know what identity address the controller is going to operate with. When powering down a controller unregister all SMP channels. This is required since a powered down controller is allowed to change its identity address. In addition the SMP channels are only available when the controller is powered via the management interface. When using legacy ioctl, then Bluetooth Low Energy is not supported and registering kernel side SMP integration may actually cause confusion. Signed-off-by: Marcel Holtmann <marcel@holtmann.org> Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
This commit is contained in:
committed by
Johan Hedberg
parent
7e7ec44564
commit
162a3bac8d
@@ -933,10 +933,8 @@ static int __hci_init(struct hci_dev *hdev)
|
||||
if (lmp_bredr_capable(hdev))
|
||||
hci_debugfs_create_bredr(hdev);
|
||||
|
||||
if (lmp_le_capable(hdev)) {
|
||||
if (lmp_le_capable(hdev))
|
||||
hci_debugfs_create_le(hdev);
|
||||
smp_register(hdev);
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
@@ -2133,6 +2131,8 @@ static void hci_power_off(struct work_struct *work)
|
||||
BT_DBG("%s", hdev->name);
|
||||
|
||||
hci_dev_do_close(hdev);
|
||||
|
||||
smp_unregister(hdev);
|
||||
}
|
||||
|
||||
static void hci_discov_off(struct work_struct *work)
|
||||
|
||||
Reference in New Issue
Block a user