|
@@ -3072,6 +3072,12 @@ int smp_register(struct hci_dev *hdev)
|
|
if (!lmp_le_capable(hdev))
|
|
if (!lmp_le_capable(hdev))
|
|
return 0;
|
|
return 0;
|
|
|
|
|
|
|
|
+ if (WARN_ON(hdev->smp_data)) {
|
|
|
|
+ chan = hdev->smp_data;
|
|
|
|
+ hdev->smp_data = NULL;
|
|
|
|
+ smp_del_chan(chan);
|
|
|
|
+ }
|
|
|
|
+
|
|
chan = smp_add_cid(hdev, L2CAP_CID_SMP);
|
|
chan = smp_add_cid(hdev, L2CAP_CID_SMP);
|
|
if (IS_ERR(chan))
|
|
if (IS_ERR(chan))
|
|
return PTR_ERR(chan);
|
|
return PTR_ERR(chan);
|
|
@@ -3091,6 +3097,12 @@ int smp_register(struct hci_dev *hdev)
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ if (WARN_ON(hdev->smp_bredr_data)) {
|
|
|
|
+ chan = hdev->smp_bredr_data;
|
|
|
|
+ hdev->smp_bredr_data = NULL;
|
|
|
|
+ smp_del_chan(chan);
|
|
|
|
+ }
|
|
|
|
+
|
|
chan = smp_add_cid(hdev, L2CAP_CID_SMP_BREDR);
|
|
chan = smp_add_cid(hdev, L2CAP_CID_SMP_BREDR);
|
|
if (IS_ERR(chan)) {
|
|
if (IS_ERR(chan)) {
|
|
int err = PTR_ERR(chan);
|
|
int err = PTR_ERR(chan);
|