Bluetooth: Attempt to clear HCI_LE_ADV on adv set terminated error event
We should clear the flag if the adv instance removed due to receiving this error status is the last one we have. Signed-off-by: Archie Pusaka <apusaka@chromium.org> Reviewed-by: Miao-chen Chou <mcchou@chromium.org> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
This commit is contained in:
Родитель
0f281a5e5b
Коммит
1f9d565743
|
@ -5527,7 +5527,7 @@ static void hci_le_ext_adv_term_evt(struct hci_dev *hdev, struct sk_buff *skb)
|
||||||
{
|
{
|
||||||
struct hci_evt_le_ext_adv_set_term *ev = (void *) skb->data;
|
struct hci_evt_le_ext_adv_set_term *ev = (void *) skb->data;
|
||||||
struct hci_conn *conn;
|
struct hci_conn *conn;
|
||||||
struct adv_info *adv;
|
struct adv_info *adv, *n;
|
||||||
|
|
||||||
BT_DBG("%s status 0x%2.2x", hdev->name, ev->status);
|
BT_DBG("%s status 0x%2.2x", hdev->name, ev->status);
|
||||||
|
|
||||||
|
@ -5553,6 +5553,13 @@ static void hci_le_ext_adv_term_evt(struct hci_dev *hdev, struct sk_buff *skb)
|
||||||
hci_remove_adv_instance(hdev, ev->handle);
|
hci_remove_adv_instance(hdev, ev->handle);
|
||||||
mgmt_advertising_removed(NULL, hdev, ev->handle);
|
mgmt_advertising_removed(NULL, hdev, ev->handle);
|
||||||
|
|
||||||
|
list_for_each_entry_safe(adv, n, &hdev->adv_instances, list) {
|
||||||
|
if (adv->enabled)
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* We are no longer advertising, clear HCI_LE_ADV */
|
||||||
|
hci_dev_clear_flag(hdev, HCI_LE_ADV);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче