• Home
  • Raw
  • Download

Lines Matching refs:hdev

44 static void hci_cc_inquiry_cancel(struct hci_dev *hdev, struct sk_buff *skb)  in hci_cc_inquiry_cancel()  argument
48 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_inquiry_cancel()
53 clear_bit(HCI_INQUIRY, &hdev->flags); in hci_cc_inquiry_cancel()
55 wake_up_bit(&hdev->flags, HCI_INQUIRY); in hci_cc_inquiry_cancel()
57 hci_dev_lock(hdev); in hci_cc_inquiry_cancel()
61 if (!hci_dev_test_flag(hdev, HCI_LE_SCAN) || in hci_cc_inquiry_cancel()
62 hdev->le_scan_type != LE_SCAN_ACTIVE) in hci_cc_inquiry_cancel()
63 hci_discovery_set_state(hdev, DISCOVERY_STOPPED); in hci_cc_inquiry_cancel()
64 hci_dev_unlock(hdev); in hci_cc_inquiry_cancel()
66 hci_conn_check_pending(hdev); in hci_cc_inquiry_cancel()
69 static void hci_cc_periodic_inq(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_periodic_inq() argument
73 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_periodic_inq()
78 hci_dev_set_flag(hdev, HCI_PERIODIC_INQ); in hci_cc_periodic_inq()
81 static void hci_cc_exit_periodic_inq(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_exit_periodic_inq() argument
85 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_exit_periodic_inq()
90 hci_dev_clear_flag(hdev, HCI_PERIODIC_INQ); in hci_cc_exit_periodic_inq()
92 hci_conn_check_pending(hdev); in hci_cc_exit_periodic_inq()
95 static void hci_cc_remote_name_req_cancel(struct hci_dev *hdev, in hci_cc_remote_name_req_cancel() argument
98 BT_DBG("%s", hdev->name); in hci_cc_remote_name_req_cancel()
101 static void hci_cc_role_discovery(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_role_discovery() argument
106 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_role_discovery()
111 hci_dev_lock(hdev); in hci_cc_role_discovery()
113 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(rp->handle)); in hci_cc_role_discovery()
117 hci_dev_unlock(hdev); in hci_cc_role_discovery()
120 static void hci_cc_read_link_policy(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_read_link_policy() argument
125 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_link_policy()
130 hci_dev_lock(hdev); in hci_cc_read_link_policy()
132 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(rp->handle)); in hci_cc_read_link_policy()
136 hci_dev_unlock(hdev); in hci_cc_read_link_policy()
139 static void hci_cc_write_link_policy(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_write_link_policy() argument
145 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_write_link_policy()
150 sent = hci_sent_cmd_data(hdev, HCI_OP_WRITE_LINK_POLICY); in hci_cc_write_link_policy()
154 hci_dev_lock(hdev); in hci_cc_write_link_policy()
156 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(rp->handle)); in hci_cc_write_link_policy()
160 hci_dev_unlock(hdev); in hci_cc_write_link_policy()
163 static void hci_cc_read_def_link_policy(struct hci_dev *hdev, in hci_cc_read_def_link_policy() argument
168 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_def_link_policy()
173 hdev->link_policy = __le16_to_cpu(rp->policy); in hci_cc_read_def_link_policy()
176 static void hci_cc_write_def_link_policy(struct hci_dev *hdev, in hci_cc_write_def_link_policy() argument
182 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_write_def_link_policy()
187 sent = hci_sent_cmd_data(hdev, HCI_OP_WRITE_DEF_LINK_POLICY); in hci_cc_write_def_link_policy()
191 hdev->link_policy = get_unaligned_le16(sent); in hci_cc_write_def_link_policy()
194 static void hci_cc_reset(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_reset() argument
198 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_reset()
200 clear_bit(HCI_RESET, &hdev->flags); in hci_cc_reset()
206 hci_dev_clear_volatile_flags(hdev); in hci_cc_reset()
208 hci_discovery_set_state(hdev, DISCOVERY_STOPPED); in hci_cc_reset()
210 hdev->inq_tx_power = HCI_TX_POWER_INVALID; in hci_cc_reset()
211 hdev->adv_tx_power = HCI_TX_POWER_INVALID; in hci_cc_reset()
213 memset(hdev->adv_data, 0, sizeof(hdev->adv_data)); in hci_cc_reset()
214 hdev->adv_data_len = 0; in hci_cc_reset()
216 memset(hdev->scan_rsp_data, 0, sizeof(hdev->scan_rsp_data)); in hci_cc_reset()
217 hdev->scan_rsp_data_len = 0; in hci_cc_reset()
219 hdev->le_scan_type = LE_SCAN_PASSIVE; in hci_cc_reset()
221 hdev->ssp_debug_mode = 0; in hci_cc_reset()
223 hci_bdaddr_list_clear(&hdev->le_white_list); in hci_cc_reset()
226 static void hci_cc_read_stored_link_key(struct hci_dev *hdev, in hci_cc_read_stored_link_key() argument
232 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_stored_link_key()
234 sent = hci_sent_cmd_data(hdev, HCI_OP_READ_STORED_LINK_KEY); in hci_cc_read_stored_link_key()
239 hdev->stored_max_keys = rp->max_keys; in hci_cc_read_stored_link_key()
240 hdev->stored_num_keys = rp->num_keys; in hci_cc_read_stored_link_key()
244 static void hci_cc_delete_stored_link_key(struct hci_dev *hdev, in hci_cc_delete_stored_link_key() argument
249 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_delete_stored_link_key()
254 if (rp->num_keys <= hdev->stored_num_keys) in hci_cc_delete_stored_link_key()
255 hdev->stored_num_keys -= rp->num_keys; in hci_cc_delete_stored_link_key()
257 hdev->stored_num_keys = 0; in hci_cc_delete_stored_link_key()
260 static void hci_cc_write_local_name(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_write_local_name() argument
265 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_write_local_name()
267 sent = hci_sent_cmd_data(hdev, HCI_OP_WRITE_LOCAL_NAME); in hci_cc_write_local_name()
271 hci_dev_lock(hdev); in hci_cc_write_local_name()
273 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_cc_write_local_name()
274 mgmt_set_local_name_complete(hdev, sent, status); in hci_cc_write_local_name()
276 memcpy(hdev->dev_name, sent, HCI_MAX_NAME_LENGTH); in hci_cc_write_local_name()
278 hci_dev_unlock(hdev); in hci_cc_write_local_name()
281 static void hci_cc_read_local_name(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_read_local_name() argument
285 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_local_name()
290 if (hci_dev_test_flag(hdev, HCI_SETUP) || in hci_cc_read_local_name()
291 hci_dev_test_flag(hdev, HCI_CONFIG)) in hci_cc_read_local_name()
292 memcpy(hdev->dev_name, rp->name, HCI_MAX_NAME_LENGTH); in hci_cc_read_local_name()
295 static void hci_cc_write_auth_enable(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_write_auth_enable() argument
300 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_write_auth_enable()
302 sent = hci_sent_cmd_data(hdev, HCI_OP_WRITE_AUTH_ENABLE); in hci_cc_write_auth_enable()
306 hci_dev_lock(hdev); in hci_cc_write_auth_enable()
312 set_bit(HCI_AUTH, &hdev->flags); in hci_cc_write_auth_enable()
314 clear_bit(HCI_AUTH, &hdev->flags); in hci_cc_write_auth_enable()
317 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_cc_write_auth_enable()
318 mgmt_auth_enable_complete(hdev, status); in hci_cc_write_auth_enable()
320 hci_dev_unlock(hdev); in hci_cc_write_auth_enable()
323 static void hci_cc_write_encrypt_mode(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_write_encrypt_mode() argument
329 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_write_encrypt_mode()
334 sent = hci_sent_cmd_data(hdev, HCI_OP_WRITE_ENCRYPT_MODE); in hci_cc_write_encrypt_mode()
341 set_bit(HCI_ENCRYPT, &hdev->flags); in hci_cc_write_encrypt_mode()
343 clear_bit(HCI_ENCRYPT, &hdev->flags); in hci_cc_write_encrypt_mode()
346 static void hci_cc_write_scan_enable(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_write_scan_enable() argument
352 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_write_scan_enable()
354 sent = hci_sent_cmd_data(hdev, HCI_OP_WRITE_SCAN_ENABLE); in hci_cc_write_scan_enable()
360 hci_dev_lock(hdev); in hci_cc_write_scan_enable()
363 hdev->discov_timeout = 0; in hci_cc_write_scan_enable()
368 set_bit(HCI_ISCAN, &hdev->flags); in hci_cc_write_scan_enable()
370 clear_bit(HCI_ISCAN, &hdev->flags); in hci_cc_write_scan_enable()
373 set_bit(HCI_PSCAN, &hdev->flags); in hci_cc_write_scan_enable()
375 clear_bit(HCI_PSCAN, &hdev->flags); in hci_cc_write_scan_enable()
378 hci_dev_unlock(hdev); in hci_cc_write_scan_enable()
381 static void hci_cc_read_class_of_dev(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_read_class_of_dev() argument
385 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_class_of_dev()
390 memcpy(hdev->dev_class, rp->dev_class, 3); in hci_cc_read_class_of_dev()
392 BT_DBG("%s class 0x%.2x%.2x%.2x", hdev->name, in hci_cc_read_class_of_dev()
393 hdev->dev_class[2], hdev->dev_class[1], hdev->dev_class[0]); in hci_cc_read_class_of_dev()
396 static void hci_cc_write_class_of_dev(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_write_class_of_dev() argument
401 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_write_class_of_dev()
403 sent = hci_sent_cmd_data(hdev, HCI_OP_WRITE_CLASS_OF_DEV); in hci_cc_write_class_of_dev()
407 hci_dev_lock(hdev); in hci_cc_write_class_of_dev()
410 memcpy(hdev->dev_class, sent, 3); in hci_cc_write_class_of_dev()
412 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_cc_write_class_of_dev()
413 mgmt_set_class_of_dev_complete(hdev, sent, status); in hci_cc_write_class_of_dev()
415 hci_dev_unlock(hdev); in hci_cc_write_class_of_dev()
418 static void hci_cc_read_voice_setting(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_read_voice_setting() argument
423 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_voice_setting()
430 if (hdev->voice_setting == setting) in hci_cc_read_voice_setting()
433 hdev->voice_setting = setting; in hci_cc_read_voice_setting()
435 BT_DBG("%s voice setting 0x%4.4x", hdev->name, setting); in hci_cc_read_voice_setting()
437 if (hdev->notify) in hci_cc_read_voice_setting()
438 hdev->notify(hdev, HCI_NOTIFY_VOICE_SETTING); in hci_cc_read_voice_setting()
441 static void hci_cc_write_voice_setting(struct hci_dev *hdev, in hci_cc_write_voice_setting() argument
448 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_write_voice_setting()
453 sent = hci_sent_cmd_data(hdev, HCI_OP_WRITE_VOICE_SETTING); in hci_cc_write_voice_setting()
459 if (hdev->voice_setting == setting) in hci_cc_write_voice_setting()
462 hdev->voice_setting = setting; in hci_cc_write_voice_setting()
464 BT_DBG("%s voice setting 0x%4.4x", hdev->name, setting); in hci_cc_write_voice_setting()
466 if (hdev->notify) in hci_cc_write_voice_setting()
467 hdev->notify(hdev, HCI_NOTIFY_VOICE_SETTING); in hci_cc_write_voice_setting()
470 static void hci_cc_read_num_supported_iac(struct hci_dev *hdev, in hci_cc_read_num_supported_iac() argument
475 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_num_supported_iac()
480 hdev->num_iac = rp->num_iac; in hci_cc_read_num_supported_iac()
482 BT_DBG("%s num iac %d", hdev->name, hdev->num_iac); in hci_cc_read_num_supported_iac()
485 static void hci_cc_write_ssp_mode(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_write_ssp_mode() argument
490 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_write_ssp_mode()
492 sent = hci_sent_cmd_data(hdev, HCI_OP_WRITE_SSP_MODE); in hci_cc_write_ssp_mode()
496 hci_dev_lock(hdev); in hci_cc_write_ssp_mode()
500 hdev->features[1][0] |= LMP_HOST_SSP; in hci_cc_write_ssp_mode()
502 hdev->features[1][0] &= ~LMP_HOST_SSP; in hci_cc_write_ssp_mode()
505 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_cc_write_ssp_mode()
506 mgmt_ssp_enable_complete(hdev, sent->mode, status); in hci_cc_write_ssp_mode()
509 hci_dev_set_flag(hdev, HCI_SSP_ENABLED); in hci_cc_write_ssp_mode()
511 hci_dev_clear_flag(hdev, HCI_SSP_ENABLED); in hci_cc_write_ssp_mode()
514 hci_dev_unlock(hdev); in hci_cc_write_ssp_mode()
517 static void hci_cc_write_sc_support(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_write_sc_support() argument
522 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_write_sc_support()
524 sent = hci_sent_cmd_data(hdev, HCI_OP_WRITE_SC_SUPPORT); in hci_cc_write_sc_support()
528 hci_dev_lock(hdev); in hci_cc_write_sc_support()
532 hdev->features[1][0] |= LMP_HOST_SC; in hci_cc_write_sc_support()
534 hdev->features[1][0] &= ~LMP_HOST_SC; in hci_cc_write_sc_support()
537 if (!hci_dev_test_flag(hdev, HCI_MGMT) && !status) { in hci_cc_write_sc_support()
539 hci_dev_set_flag(hdev, HCI_SC_ENABLED); in hci_cc_write_sc_support()
541 hci_dev_clear_flag(hdev, HCI_SC_ENABLED); in hci_cc_write_sc_support()
544 hci_dev_unlock(hdev); in hci_cc_write_sc_support()
547 static void hci_cc_read_local_version(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_read_local_version() argument
551 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_local_version()
556 if (hci_dev_test_flag(hdev, HCI_SETUP) || in hci_cc_read_local_version()
557 hci_dev_test_flag(hdev, HCI_CONFIG)) { in hci_cc_read_local_version()
558 hdev->hci_ver = rp->hci_ver; in hci_cc_read_local_version()
559 hdev->hci_rev = __le16_to_cpu(rp->hci_rev); in hci_cc_read_local_version()
560 hdev->lmp_ver = rp->lmp_ver; in hci_cc_read_local_version()
561 hdev->manufacturer = __le16_to_cpu(rp->manufacturer); in hci_cc_read_local_version()
562 hdev->lmp_subver = __le16_to_cpu(rp->lmp_subver); in hci_cc_read_local_version()
566 static void hci_cc_read_local_commands(struct hci_dev *hdev, in hci_cc_read_local_commands() argument
571 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_local_commands()
576 if (hci_dev_test_flag(hdev, HCI_SETUP) || in hci_cc_read_local_commands()
577 hci_dev_test_flag(hdev, HCI_CONFIG)) in hci_cc_read_local_commands()
578 memcpy(hdev->commands, rp->commands, sizeof(hdev->commands)); in hci_cc_read_local_commands()
581 static void hci_cc_read_local_features(struct hci_dev *hdev, in hci_cc_read_local_features() argument
586 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_local_features()
591 memcpy(hdev->features, rp->features, 8); in hci_cc_read_local_features()
596 if (hdev->features[0][0] & LMP_3SLOT) in hci_cc_read_local_features()
597 hdev->pkt_type |= (HCI_DM3 | HCI_DH3); in hci_cc_read_local_features()
599 if (hdev->features[0][0] & LMP_5SLOT) in hci_cc_read_local_features()
600 hdev->pkt_type |= (HCI_DM5 | HCI_DH5); in hci_cc_read_local_features()
602 if (hdev->features[0][1] & LMP_HV2) { in hci_cc_read_local_features()
603 hdev->pkt_type |= (HCI_HV2); in hci_cc_read_local_features()
604 hdev->esco_type |= (ESCO_HV2); in hci_cc_read_local_features()
607 if (hdev->features[0][1] & LMP_HV3) { in hci_cc_read_local_features()
608 hdev->pkt_type |= (HCI_HV3); in hci_cc_read_local_features()
609 hdev->esco_type |= (ESCO_HV3); in hci_cc_read_local_features()
612 if (lmp_esco_capable(hdev)) in hci_cc_read_local_features()
613 hdev->esco_type |= (ESCO_EV3); in hci_cc_read_local_features()
615 if (hdev->features[0][4] & LMP_EV4) in hci_cc_read_local_features()
616 hdev->esco_type |= (ESCO_EV4); in hci_cc_read_local_features()
618 if (hdev->features[0][4] & LMP_EV5) in hci_cc_read_local_features()
619 hdev->esco_type |= (ESCO_EV5); in hci_cc_read_local_features()
621 if (hdev->features[0][5] & LMP_EDR_ESCO_2M) in hci_cc_read_local_features()
622 hdev->esco_type |= (ESCO_2EV3); in hci_cc_read_local_features()
624 if (hdev->features[0][5] & LMP_EDR_ESCO_3M) in hci_cc_read_local_features()
625 hdev->esco_type |= (ESCO_3EV3); in hci_cc_read_local_features()
627 if (hdev->features[0][5] & LMP_EDR_3S_ESCO) in hci_cc_read_local_features()
628 hdev->esco_type |= (ESCO_2EV5 | ESCO_3EV5); in hci_cc_read_local_features()
631 static void hci_cc_read_local_ext_features(struct hci_dev *hdev, in hci_cc_read_local_ext_features() argument
636 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_local_ext_features()
641 if (hdev->max_page < rp->max_page) in hci_cc_read_local_ext_features()
642 hdev->max_page = rp->max_page; in hci_cc_read_local_ext_features()
645 memcpy(hdev->features[rp->page], rp->features, 8); in hci_cc_read_local_ext_features()
648 static void hci_cc_read_flow_control_mode(struct hci_dev *hdev, in hci_cc_read_flow_control_mode() argument
653 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_flow_control_mode()
658 hdev->flow_ctl_mode = rp->mode; in hci_cc_read_flow_control_mode()
661 static void hci_cc_read_buffer_size(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_read_buffer_size() argument
665 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_buffer_size()
670 hdev->acl_mtu = __le16_to_cpu(rp->acl_mtu); in hci_cc_read_buffer_size()
671 hdev->sco_mtu = rp->sco_mtu; in hci_cc_read_buffer_size()
672 hdev->acl_pkts = __le16_to_cpu(rp->acl_max_pkt); in hci_cc_read_buffer_size()
673 hdev->sco_pkts = __le16_to_cpu(rp->sco_max_pkt); in hci_cc_read_buffer_size()
675 if (test_bit(HCI_QUIRK_FIXUP_BUFFER_SIZE, &hdev->quirks)) { in hci_cc_read_buffer_size()
676 hdev->sco_mtu = 64; in hci_cc_read_buffer_size()
677 hdev->sco_pkts = 8; in hci_cc_read_buffer_size()
680 hdev->acl_cnt = hdev->acl_pkts; in hci_cc_read_buffer_size()
681 hdev->sco_cnt = hdev->sco_pkts; in hci_cc_read_buffer_size()
683 BT_DBG("%s acl mtu %d:%d sco mtu %d:%d", hdev->name, hdev->acl_mtu, in hci_cc_read_buffer_size()
684 hdev->acl_pkts, hdev->sco_mtu, hdev->sco_pkts); in hci_cc_read_buffer_size()
687 static void hci_cc_read_bd_addr(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_read_bd_addr() argument
691 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_bd_addr()
696 if (test_bit(HCI_INIT, &hdev->flags)) in hci_cc_read_bd_addr()
697 bacpy(&hdev->bdaddr, &rp->bdaddr); in hci_cc_read_bd_addr()
699 if (hci_dev_test_flag(hdev, HCI_SETUP)) in hci_cc_read_bd_addr()
700 bacpy(&hdev->setup_addr, &rp->bdaddr); in hci_cc_read_bd_addr()
703 static void hci_cc_read_page_scan_activity(struct hci_dev *hdev, in hci_cc_read_page_scan_activity() argument
708 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_page_scan_activity()
713 if (test_bit(HCI_INIT, &hdev->flags)) { in hci_cc_read_page_scan_activity()
714 hdev->page_scan_interval = __le16_to_cpu(rp->interval); in hci_cc_read_page_scan_activity()
715 hdev->page_scan_window = __le16_to_cpu(rp->window); in hci_cc_read_page_scan_activity()
719 static void hci_cc_write_page_scan_activity(struct hci_dev *hdev, in hci_cc_write_page_scan_activity() argument
725 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_write_page_scan_activity()
730 sent = hci_sent_cmd_data(hdev, HCI_OP_WRITE_PAGE_SCAN_ACTIVITY); in hci_cc_write_page_scan_activity()
734 hdev->page_scan_interval = __le16_to_cpu(sent->interval); in hci_cc_write_page_scan_activity()
735 hdev->page_scan_window = __le16_to_cpu(sent->window); in hci_cc_write_page_scan_activity()
738 static void hci_cc_read_page_scan_type(struct hci_dev *hdev, in hci_cc_read_page_scan_type() argument
743 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_page_scan_type()
748 if (test_bit(HCI_INIT, &hdev->flags)) in hci_cc_read_page_scan_type()
749 hdev->page_scan_type = rp->type; in hci_cc_read_page_scan_type()
752 static void hci_cc_write_page_scan_type(struct hci_dev *hdev, in hci_cc_write_page_scan_type() argument
758 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_write_page_scan_type()
763 type = hci_sent_cmd_data(hdev, HCI_OP_WRITE_PAGE_SCAN_TYPE); in hci_cc_write_page_scan_type()
765 hdev->page_scan_type = *type; in hci_cc_write_page_scan_type()
768 static void hci_cc_read_data_block_size(struct hci_dev *hdev, in hci_cc_read_data_block_size() argument
773 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_data_block_size()
778 hdev->block_mtu = __le16_to_cpu(rp->max_acl_len); in hci_cc_read_data_block_size()
779 hdev->block_len = __le16_to_cpu(rp->block_len); in hci_cc_read_data_block_size()
780 hdev->num_blocks = __le16_to_cpu(rp->num_blocks); in hci_cc_read_data_block_size()
782 hdev->block_cnt = hdev->num_blocks; in hci_cc_read_data_block_size()
784 BT_DBG("%s blk mtu %d cnt %d len %d", hdev->name, hdev->block_mtu, in hci_cc_read_data_block_size()
785 hdev->block_cnt, hdev->block_len); in hci_cc_read_data_block_size()
788 static void hci_cc_read_clock(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_read_clock() argument
794 BT_DBG("%s", hdev->name); in hci_cc_read_clock()
802 hci_dev_lock(hdev); in hci_cc_read_clock()
804 cp = hci_sent_cmd_data(hdev, HCI_OP_READ_CLOCK); in hci_cc_read_clock()
809 hdev->clock = le32_to_cpu(rp->clock); in hci_cc_read_clock()
813 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(rp->handle)); in hci_cc_read_clock()
820 hci_dev_unlock(hdev); in hci_cc_read_clock()
823 static void hci_cc_read_local_amp_info(struct hci_dev *hdev, in hci_cc_read_local_amp_info() argument
828 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_local_amp_info()
833 hdev->amp_status = rp->amp_status; in hci_cc_read_local_amp_info()
834 hdev->amp_total_bw = __le32_to_cpu(rp->total_bw); in hci_cc_read_local_amp_info()
835 hdev->amp_max_bw = __le32_to_cpu(rp->max_bw); in hci_cc_read_local_amp_info()
836 hdev->amp_min_latency = __le32_to_cpu(rp->min_latency); in hci_cc_read_local_amp_info()
837 hdev->amp_max_pdu = __le32_to_cpu(rp->max_pdu); in hci_cc_read_local_amp_info()
838 hdev->amp_type = rp->amp_type; in hci_cc_read_local_amp_info()
839 hdev->amp_pal_cap = __le16_to_cpu(rp->pal_cap); in hci_cc_read_local_amp_info()
840 hdev->amp_assoc_size = __le16_to_cpu(rp->max_assoc_size); in hci_cc_read_local_amp_info()
841 hdev->amp_be_flush_to = __le32_to_cpu(rp->be_flush_to); in hci_cc_read_local_amp_info()
842 hdev->amp_max_flush_to = __le32_to_cpu(rp->max_flush_to); in hci_cc_read_local_amp_info()
845 static void hci_cc_read_inq_rsp_tx_power(struct hci_dev *hdev, in hci_cc_read_inq_rsp_tx_power() argument
850 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_inq_rsp_tx_power()
855 hdev->inq_tx_power = rp->tx_power; in hci_cc_read_inq_rsp_tx_power()
858 static void hci_cc_pin_code_reply(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_pin_code_reply() argument
864 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_pin_code_reply()
866 hci_dev_lock(hdev); in hci_cc_pin_code_reply()
868 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_cc_pin_code_reply()
869 mgmt_pin_code_reply_complete(hdev, &rp->bdaddr, rp->status); in hci_cc_pin_code_reply()
874 cp = hci_sent_cmd_data(hdev, HCI_OP_PIN_CODE_REPLY); in hci_cc_pin_code_reply()
878 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &cp->bdaddr); in hci_cc_pin_code_reply()
883 hci_dev_unlock(hdev); in hci_cc_pin_code_reply()
886 static void hci_cc_pin_code_neg_reply(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_pin_code_neg_reply() argument
890 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_pin_code_neg_reply()
892 hci_dev_lock(hdev); in hci_cc_pin_code_neg_reply()
894 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_cc_pin_code_neg_reply()
895 mgmt_pin_code_neg_reply_complete(hdev, &rp->bdaddr, in hci_cc_pin_code_neg_reply()
898 hci_dev_unlock(hdev); in hci_cc_pin_code_neg_reply()
901 static void hci_cc_le_read_buffer_size(struct hci_dev *hdev, in hci_cc_le_read_buffer_size() argument
906 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_le_read_buffer_size()
911 hdev->le_mtu = __le16_to_cpu(rp->le_mtu); in hci_cc_le_read_buffer_size()
912 hdev->le_pkts = rp->le_max_pkt; in hci_cc_le_read_buffer_size()
914 hdev->le_cnt = hdev->le_pkts; in hci_cc_le_read_buffer_size()
916 BT_DBG("%s le mtu %d:%d", hdev->name, hdev->le_mtu, hdev->le_pkts); in hci_cc_le_read_buffer_size()
919 static void hci_cc_le_read_local_features(struct hci_dev *hdev, in hci_cc_le_read_local_features() argument
924 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_le_read_local_features()
929 memcpy(hdev->le_features, rp->features, 8); in hci_cc_le_read_local_features()
932 static void hci_cc_le_read_adv_tx_power(struct hci_dev *hdev, in hci_cc_le_read_adv_tx_power() argument
937 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_le_read_adv_tx_power()
942 hdev->adv_tx_power = rp->tx_power; in hci_cc_le_read_adv_tx_power()
945 static void hci_cc_user_confirm_reply(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_user_confirm_reply() argument
949 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_user_confirm_reply()
951 hci_dev_lock(hdev); in hci_cc_user_confirm_reply()
953 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_cc_user_confirm_reply()
954 mgmt_user_confirm_reply_complete(hdev, &rp->bdaddr, ACL_LINK, 0, in hci_cc_user_confirm_reply()
957 hci_dev_unlock(hdev); in hci_cc_user_confirm_reply()
960 static void hci_cc_user_confirm_neg_reply(struct hci_dev *hdev, in hci_cc_user_confirm_neg_reply() argument
965 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_user_confirm_neg_reply()
967 hci_dev_lock(hdev); in hci_cc_user_confirm_neg_reply()
969 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_cc_user_confirm_neg_reply()
970 mgmt_user_confirm_neg_reply_complete(hdev, &rp->bdaddr, in hci_cc_user_confirm_neg_reply()
973 hci_dev_unlock(hdev); in hci_cc_user_confirm_neg_reply()
976 static void hci_cc_user_passkey_reply(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_user_passkey_reply() argument
980 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_user_passkey_reply()
982 hci_dev_lock(hdev); in hci_cc_user_passkey_reply()
984 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_cc_user_passkey_reply()
985 mgmt_user_passkey_reply_complete(hdev, &rp->bdaddr, ACL_LINK, in hci_cc_user_passkey_reply()
988 hci_dev_unlock(hdev); in hci_cc_user_passkey_reply()
991 static void hci_cc_user_passkey_neg_reply(struct hci_dev *hdev, in hci_cc_user_passkey_neg_reply() argument
996 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_user_passkey_neg_reply()
998 hci_dev_lock(hdev); in hci_cc_user_passkey_neg_reply()
1000 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_cc_user_passkey_neg_reply()
1001 mgmt_user_passkey_neg_reply_complete(hdev, &rp->bdaddr, in hci_cc_user_passkey_neg_reply()
1004 hci_dev_unlock(hdev); in hci_cc_user_passkey_neg_reply()
1007 static void hci_cc_read_local_oob_data(struct hci_dev *hdev, in hci_cc_read_local_oob_data() argument
1012 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_local_oob_data()
1015 static void hci_cc_read_local_oob_ext_data(struct hci_dev *hdev, in hci_cc_read_local_oob_ext_data() argument
1020 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_local_oob_ext_data()
1023 static void hci_cc_le_set_random_addr(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_le_set_random_addr() argument
1028 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_le_set_random_addr()
1033 sent = hci_sent_cmd_data(hdev, HCI_OP_LE_SET_RANDOM_ADDR); in hci_cc_le_set_random_addr()
1037 hci_dev_lock(hdev); in hci_cc_le_set_random_addr()
1039 bacpy(&hdev->random_addr, sent); in hci_cc_le_set_random_addr()
1041 hci_dev_unlock(hdev); in hci_cc_le_set_random_addr()
1044 static void hci_cc_le_set_adv_enable(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_le_set_adv_enable() argument
1048 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_le_set_adv_enable()
1053 sent = hci_sent_cmd_data(hdev, HCI_OP_LE_SET_ADV_ENABLE); in hci_cc_le_set_adv_enable()
1057 hci_dev_lock(hdev); in hci_cc_le_set_adv_enable()
1065 hci_dev_set_flag(hdev, HCI_LE_ADV); in hci_cc_le_set_adv_enable()
1067 conn = hci_lookup_le_connect(hdev); in hci_cc_le_set_adv_enable()
1069 queue_delayed_work(hdev->workqueue, in hci_cc_le_set_adv_enable()
1073 hci_dev_clear_flag(hdev, HCI_LE_ADV); in hci_cc_le_set_adv_enable()
1076 hci_dev_unlock(hdev); in hci_cc_le_set_adv_enable()
1079 static void hci_cc_le_set_scan_param(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_le_set_scan_param() argument
1084 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_le_set_scan_param()
1089 cp = hci_sent_cmd_data(hdev, HCI_OP_LE_SET_SCAN_PARAM); in hci_cc_le_set_scan_param()
1093 hci_dev_lock(hdev); in hci_cc_le_set_scan_param()
1095 hdev->le_scan_type = cp->type; in hci_cc_le_set_scan_param()
1097 hci_dev_unlock(hdev); in hci_cc_le_set_scan_param()
1100 static bool has_pending_adv_report(struct hci_dev *hdev) in has_pending_adv_report() argument
1102 struct discovery_state *d = &hdev->discovery; in has_pending_adv_report()
1107 static void clear_pending_adv_report(struct hci_dev *hdev) in clear_pending_adv_report() argument
1109 struct discovery_state *d = &hdev->discovery; in clear_pending_adv_report()
1115 static void store_pending_adv_report(struct hci_dev *hdev, bdaddr_t *bdaddr, in store_pending_adv_report() argument
1119 struct discovery_state *d = &hdev->discovery; in store_pending_adv_report()
1129 static void hci_cc_le_set_scan_enable(struct hci_dev *hdev, in hci_cc_le_set_scan_enable() argument
1135 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_le_set_scan_enable()
1140 cp = hci_sent_cmd_data(hdev, HCI_OP_LE_SET_SCAN_ENABLE); in hci_cc_le_set_scan_enable()
1144 hci_dev_lock(hdev); in hci_cc_le_set_scan_enable()
1148 hci_dev_set_flag(hdev, HCI_LE_SCAN); in hci_cc_le_set_scan_enable()
1149 if (hdev->le_scan_type == LE_SCAN_ACTIVE) in hci_cc_le_set_scan_enable()
1150 clear_pending_adv_report(hdev); in hci_cc_le_set_scan_enable()
1158 if (has_pending_adv_report(hdev)) { in hci_cc_le_set_scan_enable()
1159 struct discovery_state *d = &hdev->discovery; in hci_cc_le_set_scan_enable()
1161 mgmt_device_found(hdev, &d->last_adv_addr, LE_LINK, in hci_cc_le_set_scan_enable()
1171 cancel_delayed_work(&hdev->le_scan_disable); in hci_cc_le_set_scan_enable()
1173 hci_dev_clear_flag(hdev, HCI_LE_SCAN); in hci_cc_le_set_scan_enable()
1182 if (hci_dev_test_and_clear_flag(hdev, HCI_LE_SCAN_INTERRUPTED)) in hci_cc_le_set_scan_enable()
1183 hci_discovery_set_state(hdev, DISCOVERY_STOPPED); in hci_cc_le_set_scan_enable()
1184 else if (!hci_dev_test_flag(hdev, HCI_LE_ADV) && in hci_cc_le_set_scan_enable()
1185 hdev->discovery.state == DISCOVERY_FINDING) in hci_cc_le_set_scan_enable()
1186 hci_req_reenable_advertising(hdev); in hci_cc_le_set_scan_enable()
1195 hci_dev_unlock(hdev); in hci_cc_le_set_scan_enable()
1198 static void hci_cc_le_read_white_list_size(struct hci_dev *hdev, in hci_cc_le_read_white_list_size() argument
1203 BT_DBG("%s status 0x%2.2x size %u", hdev->name, rp->status, rp->size); in hci_cc_le_read_white_list_size()
1208 hdev->le_white_list_size = rp->size; in hci_cc_le_read_white_list_size()
1211 static void hci_cc_le_clear_white_list(struct hci_dev *hdev, in hci_cc_le_clear_white_list() argument
1216 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_le_clear_white_list()
1221 hci_bdaddr_list_clear(&hdev->le_white_list); in hci_cc_le_clear_white_list()
1224 static void hci_cc_le_add_to_white_list(struct hci_dev *hdev, in hci_cc_le_add_to_white_list() argument
1230 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_le_add_to_white_list()
1235 sent = hci_sent_cmd_data(hdev, HCI_OP_LE_ADD_TO_WHITE_LIST); in hci_cc_le_add_to_white_list()
1239 hci_bdaddr_list_add(&hdev->le_white_list, &sent->bdaddr, in hci_cc_le_add_to_white_list()
1243 static void hci_cc_le_del_from_white_list(struct hci_dev *hdev, in hci_cc_le_del_from_white_list() argument
1249 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_le_del_from_white_list()
1254 sent = hci_sent_cmd_data(hdev, HCI_OP_LE_DEL_FROM_WHITE_LIST); in hci_cc_le_del_from_white_list()
1258 hci_bdaddr_list_del(&hdev->le_white_list, &sent->bdaddr, in hci_cc_le_del_from_white_list()
1262 static void hci_cc_le_read_supported_states(struct hci_dev *hdev, in hci_cc_le_read_supported_states() argument
1267 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_le_read_supported_states()
1272 memcpy(hdev->le_states, rp->le_states, 8); in hci_cc_le_read_supported_states()
1275 static void hci_cc_le_read_def_data_len(struct hci_dev *hdev, in hci_cc_le_read_def_data_len() argument
1280 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_le_read_def_data_len()
1285 hdev->le_def_tx_len = le16_to_cpu(rp->tx_len); in hci_cc_le_read_def_data_len()
1286 hdev->le_def_tx_time = le16_to_cpu(rp->tx_time); in hci_cc_le_read_def_data_len()
1289 static void hci_cc_le_write_def_data_len(struct hci_dev *hdev, in hci_cc_le_write_def_data_len() argument
1295 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_le_write_def_data_len()
1300 sent = hci_sent_cmd_data(hdev, HCI_OP_LE_WRITE_DEF_DATA_LEN); in hci_cc_le_write_def_data_len()
1304 hdev->le_def_tx_len = le16_to_cpu(sent->tx_len); in hci_cc_le_write_def_data_len()
1305 hdev->le_def_tx_time = le16_to_cpu(sent->tx_time); in hci_cc_le_write_def_data_len()
1308 static void hci_cc_le_read_max_data_len(struct hci_dev *hdev, in hci_cc_le_read_max_data_len() argument
1313 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_le_read_max_data_len()
1318 hdev->le_max_tx_len = le16_to_cpu(rp->tx_len); in hci_cc_le_read_max_data_len()
1319 hdev->le_max_tx_time = le16_to_cpu(rp->tx_time); in hci_cc_le_read_max_data_len()
1320 hdev->le_max_rx_len = le16_to_cpu(rp->rx_len); in hci_cc_le_read_max_data_len()
1321 hdev->le_max_rx_time = le16_to_cpu(rp->rx_time); in hci_cc_le_read_max_data_len()
1324 static void hci_cc_write_le_host_supported(struct hci_dev *hdev, in hci_cc_write_le_host_supported() argument
1330 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_write_le_host_supported()
1335 sent = hci_sent_cmd_data(hdev, HCI_OP_WRITE_LE_HOST_SUPPORTED); in hci_cc_write_le_host_supported()
1339 hci_dev_lock(hdev); in hci_cc_write_le_host_supported()
1342 hdev->features[1][0] |= LMP_HOST_LE; in hci_cc_write_le_host_supported()
1343 hci_dev_set_flag(hdev, HCI_LE_ENABLED); in hci_cc_write_le_host_supported()
1345 hdev->features[1][0] &= ~LMP_HOST_LE; in hci_cc_write_le_host_supported()
1346 hci_dev_clear_flag(hdev, HCI_LE_ENABLED); in hci_cc_write_le_host_supported()
1347 hci_dev_clear_flag(hdev, HCI_ADVERTISING); in hci_cc_write_le_host_supported()
1351 hdev->features[1][0] |= LMP_HOST_LE_BREDR; in hci_cc_write_le_host_supported()
1353 hdev->features[1][0] &= ~LMP_HOST_LE_BREDR; in hci_cc_write_le_host_supported()
1355 hci_dev_unlock(hdev); in hci_cc_write_le_host_supported()
1358 static void hci_cc_set_adv_param(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_set_adv_param() argument
1363 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_set_adv_param()
1368 cp = hci_sent_cmd_data(hdev, HCI_OP_LE_SET_ADV_PARAM); in hci_cc_set_adv_param()
1372 hci_dev_lock(hdev); in hci_cc_set_adv_param()
1373 hdev->adv_addr_type = cp->own_address_type; in hci_cc_set_adv_param()
1374 hci_dev_unlock(hdev); in hci_cc_set_adv_param()
1377 static void hci_cc_read_rssi(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_read_rssi() argument
1382 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_rssi()
1387 hci_dev_lock(hdev); in hci_cc_read_rssi()
1389 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(rp->handle)); in hci_cc_read_rssi()
1393 hci_dev_unlock(hdev); in hci_cc_read_rssi()
1396 static void hci_cc_read_tx_power(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_read_tx_power() argument
1402 BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); in hci_cc_read_tx_power()
1407 sent = hci_sent_cmd_data(hdev, HCI_OP_READ_TX_POWER); in hci_cc_read_tx_power()
1411 hci_dev_lock(hdev); in hci_cc_read_tx_power()
1413 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(rp->handle)); in hci_cc_read_tx_power()
1427 hci_dev_unlock(hdev); in hci_cc_read_tx_power()
1430 static void hci_cc_write_ssp_debug_mode(struct hci_dev *hdev, struct sk_buff *skb) in hci_cc_write_ssp_debug_mode() argument
1435 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cc_write_ssp_debug_mode()
1440 mode = hci_sent_cmd_data(hdev, HCI_OP_WRITE_SSP_DEBUG_MODE); in hci_cc_write_ssp_debug_mode()
1442 hdev->ssp_debug_mode = *mode; in hci_cc_write_ssp_debug_mode()
1445 static void hci_cs_inquiry(struct hci_dev *hdev, __u8 status) in hci_cs_inquiry() argument
1447 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_inquiry()
1450 hci_conn_check_pending(hdev); in hci_cs_inquiry()
1454 set_bit(HCI_INQUIRY, &hdev->flags); in hci_cs_inquiry()
1457 static void hci_cs_create_conn(struct hci_dev *hdev, __u8 status) in hci_cs_create_conn() argument
1462 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_create_conn()
1464 cp = hci_sent_cmd_data(hdev, HCI_OP_CREATE_CONN); in hci_cs_create_conn()
1468 hci_dev_lock(hdev); in hci_cs_create_conn()
1470 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &cp->bdaddr); in hci_cs_create_conn()
1472 BT_DBG("%s bdaddr %pMR hcon %p", hdev->name, &cp->bdaddr, conn); in hci_cs_create_conn()
1485 conn = hci_conn_add(hdev, ACL_LINK, &cp->bdaddr, in hci_cs_create_conn()
1492 hci_dev_unlock(hdev); in hci_cs_create_conn()
1495 static void hci_cs_add_sco(struct hci_dev *hdev, __u8 status) in hci_cs_add_sco() argument
1501 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_add_sco()
1506 cp = hci_sent_cmd_data(hdev, HCI_OP_ADD_SCO); in hci_cs_add_sco()
1512 BT_DBG("%s handle 0x%4.4x", hdev->name, handle); in hci_cs_add_sco()
1514 hci_dev_lock(hdev); in hci_cs_add_sco()
1516 acl = hci_conn_hash_lookup_handle(hdev, handle); in hci_cs_add_sco()
1527 hci_dev_unlock(hdev); in hci_cs_add_sco()
1530 static void hci_cs_auth_requested(struct hci_dev *hdev, __u8 status) in hci_cs_auth_requested() argument
1535 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_auth_requested()
1540 cp = hci_sent_cmd_data(hdev, HCI_OP_AUTH_REQUESTED); in hci_cs_auth_requested()
1544 hci_dev_lock(hdev); in hci_cs_auth_requested()
1546 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(cp->handle)); in hci_cs_auth_requested()
1554 hci_dev_unlock(hdev); in hci_cs_auth_requested()
1557 static void hci_cs_set_conn_encrypt(struct hci_dev *hdev, __u8 status) in hci_cs_set_conn_encrypt() argument
1562 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_set_conn_encrypt()
1567 cp = hci_sent_cmd_data(hdev, HCI_OP_SET_CONN_ENCRYPT); in hci_cs_set_conn_encrypt()
1571 hci_dev_lock(hdev); in hci_cs_set_conn_encrypt()
1573 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(cp->handle)); in hci_cs_set_conn_encrypt()
1581 hci_dev_unlock(hdev); in hci_cs_set_conn_encrypt()
1584 static int hci_outgoing_auth_needed(struct hci_dev *hdev, in hci_outgoing_auth_needed() argument
1606 static int hci_resolve_name(struct hci_dev *hdev, in hci_resolve_name() argument
1618 return hci_send_cmd(hdev, HCI_OP_REMOTE_NAME_REQ, sizeof(cp), &cp); in hci_resolve_name()
1621 static bool hci_resolve_next_name(struct hci_dev *hdev) in hci_resolve_next_name() argument
1623 struct discovery_state *discov = &hdev->discovery; in hci_resolve_next_name()
1629 e = hci_inquiry_cache_lookup_resolve(hdev, BDADDR_ANY, NAME_NEEDED); in hci_resolve_next_name()
1633 if (hci_resolve_name(hdev, e) == 0) { in hci_resolve_next_name()
1641 static void hci_check_pending_name(struct hci_dev *hdev, struct hci_conn *conn, in hci_check_pending_name() argument
1644 struct discovery_state *discov = &hdev->discovery; in hci_check_pending_name()
1655 mgmt_device_connected(hdev, conn, 0, name, name_len); in hci_check_pending_name()
1666 e = hci_inquiry_cache_lookup_resolve(hdev, bdaddr, NAME_PENDING); in hci_check_pending_name()
1677 mgmt_remote_name(hdev, bdaddr, ACL_LINK, 0x00, in hci_check_pending_name()
1683 if (hci_resolve_next_name(hdev)) in hci_check_pending_name()
1687 hci_discovery_set_state(hdev, DISCOVERY_STOPPED); in hci_check_pending_name()
1690 static void hci_cs_remote_name_req(struct hci_dev *hdev, __u8 status) in hci_cs_remote_name_req() argument
1695 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_remote_name_req()
1702 cp = hci_sent_cmd_data(hdev, HCI_OP_REMOTE_NAME_REQ); in hci_cs_remote_name_req()
1706 hci_dev_lock(hdev); in hci_cs_remote_name_req()
1708 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &cp->bdaddr); in hci_cs_remote_name_req()
1710 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_cs_remote_name_req()
1711 hci_check_pending_name(hdev, conn, &cp->bdaddr, NULL, 0); in hci_cs_remote_name_req()
1716 if (!hci_outgoing_auth_needed(hdev, conn)) in hci_cs_remote_name_req()
1725 hci_send_cmd(hdev, HCI_OP_AUTH_REQUESTED, in hci_cs_remote_name_req()
1730 hci_dev_unlock(hdev); in hci_cs_remote_name_req()
1733 static void hci_cs_read_remote_features(struct hci_dev *hdev, __u8 status) in hci_cs_read_remote_features() argument
1738 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_read_remote_features()
1743 cp = hci_sent_cmd_data(hdev, HCI_OP_READ_REMOTE_FEATURES); in hci_cs_read_remote_features()
1747 hci_dev_lock(hdev); in hci_cs_read_remote_features()
1749 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(cp->handle)); in hci_cs_read_remote_features()
1757 hci_dev_unlock(hdev); in hci_cs_read_remote_features()
1760 static void hci_cs_read_remote_ext_features(struct hci_dev *hdev, __u8 status) in hci_cs_read_remote_ext_features() argument
1765 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_read_remote_ext_features()
1770 cp = hci_sent_cmd_data(hdev, HCI_OP_READ_REMOTE_EXT_FEATURES); in hci_cs_read_remote_ext_features()
1774 hci_dev_lock(hdev); in hci_cs_read_remote_ext_features()
1776 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(cp->handle)); in hci_cs_read_remote_ext_features()
1784 hci_dev_unlock(hdev); in hci_cs_read_remote_ext_features()
1787 static void hci_cs_setup_sync_conn(struct hci_dev *hdev, __u8 status) in hci_cs_setup_sync_conn() argument
1793 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_setup_sync_conn()
1798 cp = hci_sent_cmd_data(hdev, HCI_OP_SETUP_SYNC_CONN); in hci_cs_setup_sync_conn()
1804 BT_DBG("%s handle 0x%4.4x", hdev->name, handle); in hci_cs_setup_sync_conn()
1806 hci_dev_lock(hdev); in hci_cs_setup_sync_conn()
1808 acl = hci_conn_hash_lookup_handle(hdev, handle); in hci_cs_setup_sync_conn()
1819 hci_dev_unlock(hdev); in hci_cs_setup_sync_conn()
1822 static void hci_cs_sniff_mode(struct hci_dev *hdev, __u8 status) in hci_cs_sniff_mode() argument
1827 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_sniff_mode()
1832 cp = hci_sent_cmd_data(hdev, HCI_OP_SNIFF_MODE); in hci_cs_sniff_mode()
1836 hci_dev_lock(hdev); in hci_cs_sniff_mode()
1838 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(cp->handle)); in hci_cs_sniff_mode()
1846 hci_dev_unlock(hdev); in hci_cs_sniff_mode()
1849 static void hci_cs_exit_sniff_mode(struct hci_dev *hdev, __u8 status) in hci_cs_exit_sniff_mode() argument
1854 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_exit_sniff_mode()
1859 cp = hci_sent_cmd_data(hdev, HCI_OP_EXIT_SNIFF_MODE); in hci_cs_exit_sniff_mode()
1863 hci_dev_lock(hdev); in hci_cs_exit_sniff_mode()
1865 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(cp->handle)); in hci_cs_exit_sniff_mode()
1873 hci_dev_unlock(hdev); in hci_cs_exit_sniff_mode()
1876 static void hci_cs_disconnect(struct hci_dev *hdev, u8 status) in hci_cs_disconnect() argument
1884 cp = hci_sent_cmd_data(hdev, HCI_OP_DISCONNECT); in hci_cs_disconnect()
1888 hci_dev_lock(hdev); in hci_cs_disconnect()
1890 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(cp->handle)); in hci_cs_disconnect()
1892 mgmt_disconnect_failed(hdev, &conn->dst, conn->type, in hci_cs_disconnect()
1895 hci_dev_unlock(hdev); in hci_cs_disconnect()
1898 static void hci_cs_le_create_conn(struct hci_dev *hdev, u8 status) in hci_cs_le_create_conn() argument
1903 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_le_create_conn()
1912 cp = hci_sent_cmd_data(hdev, HCI_OP_LE_CREATE_CONN); in hci_cs_le_create_conn()
1916 hci_dev_lock(hdev); in hci_cs_le_create_conn()
1918 conn = hci_conn_hash_lookup_le(hdev, &cp->peer_addr, in hci_cs_le_create_conn()
1929 bacpy(&conn->init_addr, &hdev->random_addr); in hci_cs_le_create_conn()
1931 bacpy(&conn->init_addr, &hdev->bdaddr); in hci_cs_le_create_conn()
1942 queue_delayed_work(conn->hdev->workqueue, in hci_cs_le_create_conn()
1947 hci_dev_unlock(hdev); in hci_cs_le_create_conn()
1950 static void hci_cs_le_read_remote_features(struct hci_dev *hdev, u8 status) in hci_cs_le_read_remote_features() argument
1955 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_le_read_remote_features()
1960 cp = hci_sent_cmd_data(hdev, HCI_OP_LE_READ_REMOTE_FEATURES); in hci_cs_le_read_remote_features()
1964 hci_dev_lock(hdev); in hci_cs_le_read_remote_features()
1966 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(cp->handle)); in hci_cs_le_read_remote_features()
1974 hci_dev_unlock(hdev); in hci_cs_le_read_remote_features()
1977 static void hci_cs_le_start_enc(struct hci_dev *hdev, u8 status) in hci_cs_le_start_enc() argument
1982 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_le_start_enc()
1987 hci_dev_lock(hdev); in hci_cs_le_start_enc()
1989 cp = hci_sent_cmd_data(hdev, HCI_OP_LE_START_ENC); in hci_cs_le_start_enc()
1993 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(cp->handle)); in hci_cs_le_start_enc()
2004 hci_dev_unlock(hdev); in hci_cs_le_start_enc()
2007 static void hci_cs_switch_role(struct hci_dev *hdev, u8 status) in hci_cs_switch_role() argument
2012 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_cs_switch_role()
2017 cp = hci_sent_cmd_data(hdev, HCI_OP_SWITCH_ROLE); in hci_cs_switch_role()
2021 hci_dev_lock(hdev); in hci_cs_switch_role()
2023 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &cp->bdaddr); in hci_cs_switch_role()
2027 hci_dev_unlock(hdev); in hci_cs_switch_role()
2030 static void hci_inquiry_complete_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_inquiry_complete_evt() argument
2033 struct discovery_state *discov = &hdev->discovery; in hci_inquiry_complete_evt()
2036 BT_DBG("%s status 0x%2.2x", hdev->name, status); in hci_inquiry_complete_evt()
2038 hci_conn_check_pending(hdev); in hci_inquiry_complete_evt()
2040 if (!test_and_clear_bit(HCI_INQUIRY, &hdev->flags)) in hci_inquiry_complete_evt()
2044 wake_up_bit(&hdev->flags, HCI_INQUIRY); in hci_inquiry_complete_evt()
2046 if (!hci_dev_test_flag(hdev, HCI_MGMT)) in hci_inquiry_complete_evt()
2049 hci_dev_lock(hdev); in hci_inquiry_complete_evt()
2062 if (!hci_dev_test_flag(hdev, HCI_LE_SCAN) || in hci_inquiry_complete_evt()
2063 !test_bit(HCI_QUIRK_SIMULTANEOUS_DISCOVERY, &hdev->quirks)) in hci_inquiry_complete_evt()
2064 hci_discovery_set_state(hdev, DISCOVERY_STOPPED); in hci_inquiry_complete_evt()
2068 e = hci_inquiry_cache_lookup_resolve(hdev, BDADDR_ANY, NAME_NEEDED); in hci_inquiry_complete_evt()
2069 if (e && hci_resolve_name(hdev, e) == 0) { in hci_inquiry_complete_evt()
2071 hci_discovery_set_state(hdev, DISCOVERY_RESOLVING); in hci_inquiry_complete_evt()
2080 if (!hci_dev_test_flag(hdev, HCI_LE_SCAN) || in hci_inquiry_complete_evt()
2081 !test_bit(HCI_QUIRK_SIMULTANEOUS_DISCOVERY, &hdev->quirks)) in hci_inquiry_complete_evt()
2082 hci_discovery_set_state(hdev, DISCOVERY_STOPPED); in hci_inquiry_complete_evt()
2086 hci_dev_unlock(hdev); in hci_inquiry_complete_evt()
2089 static void hci_inquiry_result_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_inquiry_result_evt() argument
2095 BT_DBG("%s num_rsp %d", hdev->name, num_rsp); in hci_inquiry_result_evt()
2100 if (hci_dev_test_flag(hdev, HCI_PERIODIC_INQ)) in hci_inquiry_result_evt()
2103 hci_dev_lock(hdev); in hci_inquiry_result_evt()
2117 flags = hci_inquiry_cache_update(hdev, &data, false); in hci_inquiry_result_evt()
2119 mgmt_device_found(hdev, &info->bdaddr, ACL_LINK, 0x00, in hci_inquiry_result_evt()
2124 hci_dev_unlock(hdev); in hci_inquiry_result_evt()
2127 static void hci_conn_complete_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_conn_complete_evt() argument
2132 BT_DBG("%s", hdev->name); in hci_conn_complete_evt()
2134 hci_dev_lock(hdev); in hci_conn_complete_evt()
2136 conn = hci_conn_hash_lookup_ba(hdev, ev->link_type, &ev->bdaddr); in hci_conn_complete_evt()
2141 conn = hci_conn_hash_lookup_ba(hdev, ESCO_LINK, &ev->bdaddr); in hci_conn_complete_evt()
2156 !hci_find_link_key(hdev, &ev->bdaddr)) in hci_conn_complete_evt()
2166 if (test_bit(HCI_AUTH, &hdev->flags)) in hci_conn_complete_evt()
2169 if (test_bit(HCI_ENCRYPT, &hdev->flags)) in hci_conn_complete_evt()
2176 hci_send_cmd(hdev, HCI_OP_READ_REMOTE_FEATURES, in hci_conn_complete_evt()
2179 hci_req_update_scan(hdev); in hci_conn_complete_evt()
2183 if (!conn->out && hdev->hci_ver < BLUETOOTH_VER_2_0) { in hci_conn_complete_evt()
2187 hci_send_cmd(hdev, HCI_OP_CHANGE_CONN_PTYPE, sizeof(cp), in hci_conn_complete_evt()
2193 mgmt_connect_failed(hdev, &conn->dst, conn->type, in hci_conn_complete_evt()
2207 hci_dev_unlock(hdev); in hci_conn_complete_evt()
2209 hci_conn_check_pending(hdev); in hci_conn_complete_evt()
2212 static void hci_reject_conn(struct hci_dev *hdev, bdaddr_t *bdaddr) in hci_reject_conn() argument
2218 hci_send_cmd(hdev, HCI_OP_REJECT_CONN_REQ, sizeof(cp), &cp); in hci_reject_conn()
2221 static void hci_conn_request_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_conn_request_evt() argument
2224 int mask = hdev->link_mode; in hci_conn_request_evt()
2229 BT_DBG("%s bdaddr %pMR type 0x%x", hdev->name, &ev->bdaddr, in hci_conn_request_evt()
2232 mask |= hci_proto_connect_ind(hdev, &ev->bdaddr, ev->link_type, in hci_conn_request_evt()
2236 hci_reject_conn(hdev, &ev->bdaddr); in hci_conn_request_evt()
2240 if (hci_bdaddr_list_lookup(&hdev->blacklist, &ev->bdaddr, in hci_conn_request_evt()
2242 hci_reject_conn(hdev, &ev->bdaddr); in hci_conn_request_evt()
2250 if (hci_dev_test_flag(hdev, HCI_MGMT) && in hci_conn_request_evt()
2251 !hci_dev_test_flag(hdev, HCI_CONNECTABLE) && in hci_conn_request_evt()
2252 !hci_bdaddr_list_lookup(&hdev->whitelist, &ev->bdaddr, in hci_conn_request_evt()
2254 hci_reject_conn(hdev, &ev->bdaddr); in hci_conn_request_evt()
2260 hci_dev_lock(hdev); in hci_conn_request_evt()
2262 ie = hci_inquiry_cache_lookup(hdev, &ev->bdaddr); in hci_conn_request_evt()
2266 conn = hci_conn_hash_lookup_ba(hdev, ev->link_type, in hci_conn_request_evt()
2269 conn = hci_conn_add(hdev, ev->link_type, &ev->bdaddr, in hci_conn_request_evt()
2273 hci_dev_unlock(hdev); in hci_conn_request_evt()
2280 hci_dev_unlock(hdev); in hci_conn_request_evt()
2283 (!(flags & HCI_PROTO_DEFER) && !lmp_esco_capable(hdev))) { in hci_conn_request_evt()
2289 if (lmp_rswitch_capable(hdev) && (mask & HCI_LM_MASTER)) in hci_conn_request_evt()
2294 hci_send_cmd(hdev, HCI_OP_ACCEPT_CONN_REQ, sizeof(cp), &cp); in hci_conn_request_evt()
2305 cp.content_format = cpu_to_le16(hdev->voice_setting); in hci_conn_request_evt()
2308 hci_send_cmd(hdev, HCI_OP_ACCEPT_SYNC_CONN_REQ, sizeof(cp), in hci_conn_request_evt()
2332 static void hci_disconn_complete_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_disconn_complete_evt() argument
2341 BT_DBG("%s status 0x%2.2x", hdev->name, ev->status); in hci_disconn_complete_evt()
2343 hci_dev_lock(hdev); in hci_disconn_complete_evt()
2345 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(ev->handle)); in hci_disconn_complete_evt()
2350 mgmt_disconnect_failed(hdev, &conn->dst, conn->type, in hci_disconn_complete_evt()
2364 mgmt_device_disconnected(hdev, &conn->dst, conn->type, conn->dst_type, in hci_disconn_complete_evt()
2369 hci_remove_link_key(hdev, &conn->dst); in hci_disconn_complete_evt()
2371 hci_req_update_scan(hdev); in hci_disconn_complete_evt()
2374 params = hci_conn_params_lookup(hdev, &conn->dst, conn->dst_type); in hci_disconn_complete_evt()
2385 list_add(&params->action, &hdev->pend_le_conns); in hci_disconn_complete_evt()
2386 hci_update_background_scan(hdev); in hci_disconn_complete_evt()
2410 hci_req_reenable_advertising(hdev); in hci_disconn_complete_evt()
2413 hci_dev_unlock(hdev); in hci_disconn_complete_evt()
2416 static void hci_auth_complete_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_auth_complete_evt() argument
2421 BT_DBG("%s status 0x%2.2x", hdev->name, ev->status); in hci_auth_complete_evt()
2423 hci_dev_lock(hdev); in hci_auth_complete_evt()
2425 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(ev->handle)); in hci_auth_complete_evt()
2454 hci_send_cmd(hdev, HCI_OP_SET_CONN_ENCRYPT, sizeof(cp), in hci_auth_complete_evt()
2474 hci_send_cmd(hdev, HCI_OP_SET_CONN_ENCRYPT, sizeof(cp), in hci_auth_complete_evt()
2483 hci_dev_unlock(hdev); in hci_auth_complete_evt()
2486 static void hci_remote_name_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_remote_name_evt() argument
2491 BT_DBG("%s", hdev->name); in hci_remote_name_evt()
2493 hci_conn_check_pending(hdev); in hci_remote_name_evt()
2495 hci_dev_lock(hdev); in hci_remote_name_evt()
2497 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &ev->bdaddr); in hci_remote_name_evt()
2499 if (!hci_dev_test_flag(hdev, HCI_MGMT)) in hci_remote_name_evt()
2503 hci_check_pending_name(hdev, conn, &ev->bdaddr, ev->name, in hci_remote_name_evt()
2506 hci_check_pending_name(hdev, conn, &ev->bdaddr, NULL, 0); in hci_remote_name_evt()
2512 if (!hci_outgoing_auth_needed(hdev, conn)) in hci_remote_name_evt()
2521 hci_send_cmd(hdev, HCI_OP_AUTH_REQUESTED, sizeof(cp), &cp); in hci_remote_name_evt()
2525 hci_dev_unlock(hdev); in hci_remote_name_evt()
2528 static void read_enc_key_size_complete(struct hci_dev *hdev, u8 status, in read_enc_key_size_complete() argument
2535 BT_DBG("%s status 0x%02x", hdev->name, status); in read_enc_key_size_complete()
2539 hdev->name); in read_enc_key_size_complete()
2546 hci_dev_lock(hdev); in read_enc_key_size_complete()
2548 conn = hci_conn_hash_lookup_handle(hdev, handle); in read_enc_key_size_complete()
2557 BT_ERR("%s failed to read key size for handle %u", hdev->name, in read_enc_key_size_complete()
2582 hci_dev_unlock(hdev); in read_enc_key_size_complete()
2585 static void hci_encrypt_change_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_encrypt_change_evt() argument
2590 BT_DBG("%s status 0x%2.2x", hdev->name, ev->status); in hci_encrypt_change_evt()
2592 hci_dev_lock(hdev); in hci_encrypt_change_evt()
2594 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(ev->handle)); in hci_encrypt_change_evt()
2622 hci_dev_set_flag(hdev, HCI_RPA_EXPIRED); in hci_encrypt_change_evt()
2639 if (hci_dev_test_flag(hdev, HCI_SC_ONLY) && in hci_encrypt_change_evt()
2656 if (!(hdev->commands[20] & 0x10)) { in hci_encrypt_change_evt()
2661 hci_req_init(&req, hdev); in hci_encrypt_change_evt()
2686 hci_dev_unlock(hdev); in hci_encrypt_change_evt()
2689 static void hci_change_link_key_complete_evt(struct hci_dev *hdev, in hci_change_link_key_complete_evt() argument
2695 BT_DBG("%s status 0x%2.2x", hdev->name, ev->status); in hci_change_link_key_complete_evt()
2697 hci_dev_lock(hdev); in hci_change_link_key_complete_evt()
2699 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(ev->handle)); in hci_change_link_key_complete_evt()
2709 hci_dev_unlock(hdev); in hci_change_link_key_complete_evt()
2712 static void hci_remote_features_evt(struct hci_dev *hdev, in hci_remote_features_evt() argument
2718 BT_DBG("%s status 0x%2.2x", hdev->name, ev->status); in hci_remote_features_evt()
2720 hci_dev_lock(hdev); in hci_remote_features_evt()
2722 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(ev->handle)); in hci_remote_features_evt()
2732 if (!ev->status && lmp_ext_feat_capable(hdev) && in hci_remote_features_evt()
2737 hci_send_cmd(hdev, HCI_OP_READ_REMOTE_EXT_FEATURES, in hci_remote_features_evt()
2747 hci_send_cmd(hdev, HCI_OP_REMOTE_NAME_REQ, sizeof(cp), &cp); in hci_remote_features_evt()
2749 mgmt_device_connected(hdev, conn, 0, NULL, 0); in hci_remote_features_evt()
2751 if (!hci_outgoing_auth_needed(hdev, conn)) { in hci_remote_features_evt()
2758 hci_dev_unlock(hdev); in hci_remote_features_evt()
2761 static void hci_cmd_complete_evt(struct hci_dev *hdev, struct sk_buff *skb, in hci_cmd_complete_evt() argument
2775 hci_cc_inquiry_cancel(hdev, skb); in hci_cmd_complete_evt()
2779 hci_cc_periodic_inq(hdev, skb); in hci_cmd_complete_evt()
2783 hci_cc_exit_periodic_inq(hdev, skb); in hci_cmd_complete_evt()
2787 hci_cc_remote_name_req_cancel(hdev, skb); in hci_cmd_complete_evt()
2791 hci_cc_role_discovery(hdev, skb); in hci_cmd_complete_evt()
2795 hci_cc_read_link_policy(hdev, skb); in hci_cmd_complete_evt()
2799 hci_cc_write_link_policy(hdev, skb); in hci_cmd_complete_evt()
2803 hci_cc_read_def_link_policy(hdev, skb); in hci_cmd_complete_evt()
2807 hci_cc_write_def_link_policy(hdev, skb); in hci_cmd_complete_evt()
2811 hci_cc_reset(hdev, skb); in hci_cmd_complete_evt()
2815 hci_cc_read_stored_link_key(hdev, skb); in hci_cmd_complete_evt()
2819 hci_cc_delete_stored_link_key(hdev, skb); in hci_cmd_complete_evt()
2823 hci_cc_write_local_name(hdev, skb); in hci_cmd_complete_evt()
2827 hci_cc_read_local_name(hdev, skb); in hci_cmd_complete_evt()
2831 hci_cc_write_auth_enable(hdev, skb); in hci_cmd_complete_evt()
2835 hci_cc_write_encrypt_mode(hdev, skb); in hci_cmd_complete_evt()
2839 hci_cc_write_scan_enable(hdev, skb); in hci_cmd_complete_evt()
2843 hci_cc_read_class_of_dev(hdev, skb); in hci_cmd_complete_evt()
2847 hci_cc_write_class_of_dev(hdev, skb); in hci_cmd_complete_evt()
2851 hci_cc_read_voice_setting(hdev, skb); in hci_cmd_complete_evt()
2855 hci_cc_write_voice_setting(hdev, skb); in hci_cmd_complete_evt()
2859 hci_cc_read_num_supported_iac(hdev, skb); in hci_cmd_complete_evt()
2863 hci_cc_write_ssp_mode(hdev, skb); in hci_cmd_complete_evt()
2867 hci_cc_write_sc_support(hdev, skb); in hci_cmd_complete_evt()
2871 hci_cc_read_local_version(hdev, skb); in hci_cmd_complete_evt()
2875 hci_cc_read_local_commands(hdev, skb); in hci_cmd_complete_evt()
2879 hci_cc_read_local_features(hdev, skb); in hci_cmd_complete_evt()
2883 hci_cc_read_local_ext_features(hdev, skb); in hci_cmd_complete_evt()
2887 hci_cc_read_buffer_size(hdev, skb); in hci_cmd_complete_evt()
2891 hci_cc_read_bd_addr(hdev, skb); in hci_cmd_complete_evt()
2895 hci_cc_read_page_scan_activity(hdev, skb); in hci_cmd_complete_evt()
2899 hci_cc_write_page_scan_activity(hdev, skb); in hci_cmd_complete_evt()
2903 hci_cc_read_page_scan_type(hdev, skb); in hci_cmd_complete_evt()
2907 hci_cc_write_page_scan_type(hdev, skb); in hci_cmd_complete_evt()
2911 hci_cc_read_data_block_size(hdev, skb); in hci_cmd_complete_evt()
2915 hci_cc_read_flow_control_mode(hdev, skb); in hci_cmd_complete_evt()
2919 hci_cc_read_local_amp_info(hdev, skb); in hci_cmd_complete_evt()
2923 hci_cc_read_clock(hdev, skb); in hci_cmd_complete_evt()
2927 hci_cc_read_inq_rsp_tx_power(hdev, skb); in hci_cmd_complete_evt()
2931 hci_cc_pin_code_reply(hdev, skb); in hci_cmd_complete_evt()
2935 hci_cc_pin_code_neg_reply(hdev, skb); in hci_cmd_complete_evt()
2939 hci_cc_read_local_oob_data(hdev, skb); in hci_cmd_complete_evt()
2943 hci_cc_read_local_oob_ext_data(hdev, skb); in hci_cmd_complete_evt()
2947 hci_cc_le_read_buffer_size(hdev, skb); in hci_cmd_complete_evt()
2951 hci_cc_le_read_local_features(hdev, skb); in hci_cmd_complete_evt()
2955 hci_cc_le_read_adv_tx_power(hdev, skb); in hci_cmd_complete_evt()
2959 hci_cc_user_confirm_reply(hdev, skb); in hci_cmd_complete_evt()
2963 hci_cc_user_confirm_neg_reply(hdev, skb); in hci_cmd_complete_evt()
2967 hci_cc_user_passkey_reply(hdev, skb); in hci_cmd_complete_evt()
2971 hci_cc_user_passkey_neg_reply(hdev, skb); in hci_cmd_complete_evt()
2975 hci_cc_le_set_random_addr(hdev, skb); in hci_cmd_complete_evt()
2979 hci_cc_le_set_adv_enable(hdev, skb); in hci_cmd_complete_evt()
2983 hci_cc_le_set_scan_param(hdev, skb); in hci_cmd_complete_evt()
2987 hci_cc_le_set_scan_enable(hdev, skb); in hci_cmd_complete_evt()
2991 hci_cc_le_read_white_list_size(hdev, skb); in hci_cmd_complete_evt()
2995 hci_cc_le_clear_white_list(hdev, skb); in hci_cmd_complete_evt()
2999 hci_cc_le_add_to_white_list(hdev, skb); in hci_cmd_complete_evt()
3003 hci_cc_le_del_from_white_list(hdev, skb); in hci_cmd_complete_evt()
3007 hci_cc_le_read_supported_states(hdev, skb); in hci_cmd_complete_evt()
3011 hci_cc_le_read_def_data_len(hdev, skb); in hci_cmd_complete_evt()
3015 hci_cc_le_write_def_data_len(hdev, skb); in hci_cmd_complete_evt()
3019 hci_cc_le_read_max_data_len(hdev, skb); in hci_cmd_complete_evt()
3023 hci_cc_write_le_host_supported(hdev, skb); in hci_cmd_complete_evt()
3027 hci_cc_set_adv_param(hdev, skb); in hci_cmd_complete_evt()
3031 hci_cc_read_rssi(hdev, skb); in hci_cmd_complete_evt()
3035 hci_cc_read_tx_power(hdev, skb); in hci_cmd_complete_evt()
3039 hci_cc_write_ssp_debug_mode(hdev, skb); in hci_cmd_complete_evt()
3043 BT_DBG("%s opcode 0x%4.4x", hdev->name, *opcode); in hci_cmd_complete_evt()
3048 cancel_delayed_work(&hdev->cmd_timer); in hci_cmd_complete_evt()
3050 if (ev->ncmd && !test_bit(HCI_RESET, &hdev->flags)) in hci_cmd_complete_evt()
3051 atomic_set(&hdev->cmd_cnt, 1); in hci_cmd_complete_evt()
3053 hci_req_cmd_complete(hdev, *opcode, *status, req_complete, in hci_cmd_complete_evt()
3056 if (atomic_read(&hdev->cmd_cnt) && !skb_queue_empty(&hdev->cmd_q)) in hci_cmd_complete_evt()
3057 queue_work(hdev->workqueue, &hdev->cmd_work); in hci_cmd_complete_evt()
3060 static void hci_cmd_status_evt(struct hci_dev *hdev, struct sk_buff *skb, in hci_cmd_status_evt() argument
3074 hci_cs_inquiry(hdev, ev->status); in hci_cmd_status_evt()
3078 hci_cs_create_conn(hdev, ev->status); in hci_cmd_status_evt()
3082 hci_cs_disconnect(hdev, ev->status); in hci_cmd_status_evt()
3086 hci_cs_add_sco(hdev, ev->status); in hci_cmd_status_evt()
3090 hci_cs_auth_requested(hdev, ev->status); in hci_cmd_status_evt()
3094 hci_cs_set_conn_encrypt(hdev, ev->status); in hci_cmd_status_evt()
3098 hci_cs_remote_name_req(hdev, ev->status); in hci_cmd_status_evt()
3102 hci_cs_read_remote_features(hdev, ev->status); in hci_cmd_status_evt()
3106 hci_cs_read_remote_ext_features(hdev, ev->status); in hci_cmd_status_evt()
3110 hci_cs_setup_sync_conn(hdev, ev->status); in hci_cmd_status_evt()
3114 hci_cs_sniff_mode(hdev, ev->status); in hci_cmd_status_evt()
3118 hci_cs_exit_sniff_mode(hdev, ev->status); in hci_cmd_status_evt()
3122 hci_cs_switch_role(hdev, ev->status); in hci_cmd_status_evt()
3126 hci_cs_le_create_conn(hdev, ev->status); in hci_cmd_status_evt()
3130 hci_cs_le_read_remote_features(hdev, ev->status); in hci_cmd_status_evt()
3134 hci_cs_le_start_enc(hdev, ev->status); in hci_cmd_status_evt()
3138 BT_DBG("%s opcode 0x%4.4x", hdev->name, *opcode); in hci_cmd_status_evt()
3143 cancel_delayed_work(&hdev->cmd_timer); in hci_cmd_status_evt()
3145 if (ev->ncmd && !test_bit(HCI_RESET, &hdev->flags)) in hci_cmd_status_evt()
3146 atomic_set(&hdev->cmd_cnt, 1); in hci_cmd_status_evt()
3155 (hdev->sent_cmd && !bt_cb(hdev->sent_cmd)->hci.req_event)) in hci_cmd_status_evt()
3156 hci_req_cmd_complete(hdev, *opcode, ev->status, req_complete, in hci_cmd_status_evt()
3159 if (atomic_read(&hdev->cmd_cnt) && !skb_queue_empty(&hdev->cmd_q)) in hci_cmd_status_evt()
3160 queue_work(hdev->workqueue, &hdev->cmd_work); in hci_cmd_status_evt()
3163 static void hci_hardware_error_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_hardware_error_evt() argument
3167 hdev->hw_error_code = ev->code; in hci_hardware_error_evt()
3169 queue_work(hdev->req_workqueue, &hdev->error_reset); in hci_hardware_error_evt()
3172 static void hci_role_change_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_role_change_evt() argument
3177 BT_DBG("%s status 0x%2.2x", hdev->name, ev->status); in hci_role_change_evt()
3179 hci_dev_lock(hdev); in hci_role_change_evt()
3181 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &ev->bdaddr); in hci_role_change_evt()
3191 hci_dev_unlock(hdev); in hci_role_change_evt()
3194 static void hci_num_comp_pkts_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_num_comp_pkts_evt() argument
3199 if (hdev->flow_ctl_mode != HCI_FLOW_CTL_MODE_PACKET_BASED) { in hci_num_comp_pkts_evt()
3200 BT_ERR("Wrong event for mode %d", hdev->flow_ctl_mode); in hci_num_comp_pkts_evt()
3206 BT_DBG("%s bad parameters", hdev->name); in hci_num_comp_pkts_evt()
3210 BT_DBG("%s num_hndl %d", hdev->name, ev->num_hndl); in hci_num_comp_pkts_evt()
3220 conn = hci_conn_hash_lookup_handle(hdev, handle); in hci_num_comp_pkts_evt()
3228 hdev->acl_cnt += count; in hci_num_comp_pkts_evt()
3229 if (hdev->acl_cnt > hdev->acl_pkts) in hci_num_comp_pkts_evt()
3230 hdev->acl_cnt = hdev->acl_pkts; in hci_num_comp_pkts_evt()
3234 if (hdev->le_pkts) { in hci_num_comp_pkts_evt()
3235 hdev->le_cnt += count; in hci_num_comp_pkts_evt()
3236 if (hdev->le_cnt > hdev->le_pkts) in hci_num_comp_pkts_evt()
3237 hdev->le_cnt = hdev->le_pkts; in hci_num_comp_pkts_evt()
3239 hdev->acl_cnt += count; in hci_num_comp_pkts_evt()
3240 if (hdev->acl_cnt > hdev->acl_pkts) in hci_num_comp_pkts_evt()
3241 hdev->acl_cnt = hdev->acl_pkts; in hci_num_comp_pkts_evt()
3246 hdev->sco_cnt += count; in hci_num_comp_pkts_evt()
3247 if (hdev->sco_cnt > hdev->sco_pkts) in hci_num_comp_pkts_evt()
3248 hdev->sco_cnt = hdev->sco_pkts; in hci_num_comp_pkts_evt()
3257 queue_work(hdev->workqueue, &hdev->tx_work); in hci_num_comp_pkts_evt()
3260 static struct hci_conn *__hci_conn_lookup_handle(struct hci_dev *hdev, in __hci_conn_lookup_handle() argument
3265 switch (hdev->dev_type) { in __hci_conn_lookup_handle()
3267 return hci_conn_hash_lookup_handle(hdev, handle); in __hci_conn_lookup_handle()
3269 chan = hci_chan_lookup_handle(hdev, handle); in __hci_conn_lookup_handle()
3274 BT_ERR("%s unknown dev_type %d", hdev->name, hdev->dev_type); in __hci_conn_lookup_handle()
3281 static void hci_num_comp_blocks_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_num_comp_blocks_evt() argument
3286 if (hdev->flow_ctl_mode != HCI_FLOW_CTL_MODE_BLOCK_BASED) { in hci_num_comp_blocks_evt()
3287 BT_ERR("Wrong event for mode %d", hdev->flow_ctl_mode); in hci_num_comp_blocks_evt()
3293 BT_DBG("%s bad parameters", hdev->name); in hci_num_comp_blocks_evt()
3297 BT_DBG("%s num_blocks %d num_hndl %d", hdev->name, ev->num_blocks, in hci_num_comp_blocks_evt()
3308 conn = __hci_conn_lookup_handle(hdev, handle); in hci_num_comp_blocks_evt()
3317 hdev->block_cnt += block_count; in hci_num_comp_blocks_evt()
3318 if (hdev->block_cnt > hdev->num_blocks) in hci_num_comp_blocks_evt()
3319 hdev->block_cnt = hdev->num_blocks; in hci_num_comp_blocks_evt()
3328 queue_work(hdev->workqueue, &hdev->tx_work); in hci_num_comp_blocks_evt()
3331 static void hci_mode_change_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_mode_change_evt() argument
3336 BT_DBG("%s status 0x%2.2x", hdev->name, ev->status); in hci_mode_change_evt()
3338 hci_dev_lock(hdev); in hci_mode_change_evt()
3340 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(ev->handle)); in hci_mode_change_evt()
3356 hci_dev_unlock(hdev); in hci_mode_change_evt()
3359 static void hci_pin_code_request_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_pin_code_request_evt() argument
3364 BT_DBG("%s", hdev->name); in hci_pin_code_request_evt()
3366 hci_dev_lock(hdev); in hci_pin_code_request_evt()
3368 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &ev->bdaddr); in hci_pin_code_request_evt()
3378 if (!hci_dev_test_flag(hdev, HCI_BONDABLE) && in hci_pin_code_request_evt()
3380 hci_send_cmd(hdev, HCI_OP_PIN_CODE_NEG_REPLY, in hci_pin_code_request_evt()
3382 } else if (hci_dev_test_flag(hdev, HCI_MGMT)) { in hci_pin_code_request_evt()
3390 mgmt_pin_code_request(hdev, &ev->bdaddr, secure); in hci_pin_code_request_evt()
3394 hci_dev_unlock(hdev); in hci_pin_code_request_evt()
3429 static void hci_link_key_request_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_link_key_request_evt() argument
3436 BT_DBG("%s", hdev->name); in hci_link_key_request_evt()
3438 if (!hci_dev_test_flag(hdev, HCI_MGMT)) in hci_link_key_request_evt()
3441 hci_dev_lock(hdev); in hci_link_key_request_evt()
3443 key = hci_find_link_key(hdev, &ev->bdaddr); in hci_link_key_request_evt()
3445 BT_DBG("%s link key not found for %pMR", hdev->name, in hci_link_key_request_evt()
3450 BT_DBG("%s found key type %u for %pMR", hdev->name, key->type, in hci_link_key_request_evt()
3453 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &ev->bdaddr); in hci_link_key_request_evt()
3460 BT_DBG("%s ignoring unauthenticated key", hdev->name); in hci_link_key_request_evt()
3468 hdev->name); in hci_link_key_request_evt()
3478 hci_send_cmd(hdev, HCI_OP_LINK_KEY_REPLY, sizeof(cp), &cp); in hci_link_key_request_evt()
3480 hci_dev_unlock(hdev); in hci_link_key_request_evt()
3485 hci_send_cmd(hdev, HCI_OP_LINK_KEY_NEG_REPLY, 6, &ev->bdaddr); in hci_link_key_request_evt()
3486 hci_dev_unlock(hdev); in hci_link_key_request_evt()
3489 static void hci_link_key_notify_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_link_key_notify_evt() argument
3497 BT_DBG("%s", hdev->name); in hci_link_key_notify_evt()
3499 hci_dev_lock(hdev); in hci_link_key_notify_evt()
3501 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &ev->bdaddr); in hci_link_key_notify_evt()
3512 if (!hci_dev_test_flag(hdev, HCI_MGMT)) in hci_link_key_notify_evt()
3515 key = hci_add_link_key(hdev, conn, &ev->bdaddr, ev->link_key, in hci_link_key_notify_evt()
3526 mgmt_new_link_key(hdev, key, persistent); in hci_link_key_notify_evt()
3534 !hci_dev_test_flag(hdev, HCI_KEEP_DEBUG_KEYS)) { in hci_link_key_notify_evt()
3546 hci_dev_unlock(hdev); in hci_link_key_notify_evt()
3549 static void hci_clock_offset_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_clock_offset_evt() argument
3554 BT_DBG("%s status 0x%2.2x", hdev->name, ev->status); in hci_clock_offset_evt()
3556 hci_dev_lock(hdev); in hci_clock_offset_evt()
3558 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(ev->handle)); in hci_clock_offset_evt()
3562 ie = hci_inquiry_cache_lookup(hdev, &conn->dst); in hci_clock_offset_evt()
3569 hci_dev_unlock(hdev); in hci_clock_offset_evt()
3572 static void hci_pkt_type_change_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_pkt_type_change_evt() argument
3577 BT_DBG("%s status 0x%2.2x", hdev->name, ev->status); in hci_pkt_type_change_evt()
3579 hci_dev_lock(hdev); in hci_pkt_type_change_evt()
3581 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(ev->handle)); in hci_pkt_type_change_evt()
3585 hci_dev_unlock(hdev); in hci_pkt_type_change_evt()
3588 static void hci_pscan_rep_mode_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_pscan_rep_mode_evt() argument
3593 BT_DBG("%s", hdev->name); in hci_pscan_rep_mode_evt()
3595 hci_dev_lock(hdev); in hci_pscan_rep_mode_evt()
3597 ie = hci_inquiry_cache_lookup(hdev, &ev->bdaddr); in hci_pscan_rep_mode_evt()
3603 hci_dev_unlock(hdev); in hci_pscan_rep_mode_evt()
3606 static void hci_inquiry_result_with_rssi_evt(struct hci_dev *hdev, in hci_inquiry_result_with_rssi_evt() argument
3612 BT_DBG("%s num_rsp %d", hdev->name, num_rsp); in hci_inquiry_result_with_rssi_evt()
3617 if (hci_dev_test_flag(hdev, HCI_PERIODIC_INQ)) in hci_inquiry_result_with_rssi_evt()
3620 hci_dev_lock(hdev); in hci_inquiry_result_with_rssi_evt()
3638 flags = hci_inquiry_cache_update(hdev, &data, false); in hci_inquiry_result_with_rssi_evt()
3640 mgmt_device_found(hdev, &info->bdaddr, ACL_LINK, 0x00, in hci_inquiry_result_with_rssi_evt()
3659 flags = hci_inquiry_cache_update(hdev, &data, false); in hci_inquiry_result_with_rssi_evt()
3661 mgmt_device_found(hdev, &info->bdaddr, ACL_LINK, 0x00, in hci_inquiry_result_with_rssi_evt()
3667 hci_dev_unlock(hdev); in hci_inquiry_result_with_rssi_evt()
3670 static void hci_remote_ext_features_evt(struct hci_dev *hdev, in hci_remote_ext_features_evt() argument
3676 BT_DBG("%s", hdev->name); in hci_remote_ext_features_evt()
3678 hci_dev_lock(hdev); in hci_remote_ext_features_evt()
3680 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(ev->handle)); in hci_remote_ext_features_evt()
3690 ie = hci_inquiry_cache_lookup(hdev, &conn->dst); in hci_remote_ext_features_evt()
3720 hci_send_cmd(hdev, HCI_OP_REMOTE_NAME_REQ, sizeof(cp), &cp); in hci_remote_ext_features_evt()
3722 mgmt_device_connected(hdev, conn, 0, NULL, 0); in hci_remote_ext_features_evt()
3724 if (!hci_outgoing_auth_needed(hdev, conn)) { in hci_remote_ext_features_evt()
3731 hci_dev_unlock(hdev); in hci_remote_ext_features_evt()
3734 static void hci_sync_conn_complete_evt(struct hci_dev *hdev, in hci_sync_conn_complete_evt() argument
3740 BT_DBG("%s status 0x%2.2x", hdev->name, ev->status); in hci_sync_conn_complete_evt()
3742 hci_dev_lock(hdev); in hci_sync_conn_complete_evt()
3744 conn = hci_conn_hash_lookup_ba(hdev, ev->link_type, &ev->bdaddr); in hci_sync_conn_complete_evt()
3758 conn = hci_conn_hash_lookup_ba(hdev, ESCO_LINK, &ev->bdaddr); in hci_sync_conn_complete_evt()
3781 conn->pkt_type = (hdev->esco_type & SCO_ESCO_MASK) | in hci_sync_conn_complete_evt()
3782 (hdev->esco_type & EDR_ESCO_MASK); in hci_sync_conn_complete_evt()
3798 hci_dev_unlock(hdev); in hci_sync_conn_complete_evt()
3818 static void hci_extended_inquiry_result_evt(struct hci_dev *hdev, in hci_extended_inquiry_result_evt() argument
3826 BT_DBG("%s num_rsp %d", hdev->name, num_rsp); in hci_extended_inquiry_result_evt()
3831 if (hci_dev_test_flag(hdev, HCI_PERIODIC_INQ)) in hci_extended_inquiry_result_evt()
3834 hci_dev_lock(hdev); in hci_extended_inquiry_result_evt()
3849 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_extended_inquiry_result_evt()
3856 flags = hci_inquiry_cache_update(hdev, &data, name_known); in hci_extended_inquiry_result_evt()
3860 mgmt_device_found(hdev, &info->bdaddr, ACL_LINK, 0x00, in hci_extended_inquiry_result_evt()
3865 hci_dev_unlock(hdev); in hci_extended_inquiry_result_evt()
3868 static void hci_key_refresh_complete_evt(struct hci_dev *hdev, in hci_key_refresh_complete_evt() argument
3874 BT_DBG("%s status 0x%2.2x handle 0x%4.4x", hdev->name, ev->status, in hci_key_refresh_complete_evt()
3877 hci_dev_lock(hdev); in hci_key_refresh_complete_evt()
3879 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(ev->handle)); in hci_key_refresh_complete_evt()
3915 hci_dev_unlock(hdev); in hci_key_refresh_complete_evt()
3938 struct hci_dev *hdev = conn->hdev; in bredr_oob_data_present() local
3941 data = hci_find_remote_oob_data(hdev, &conn->dst, BDADDR_BREDR); in bredr_oob_data_present()
3945 if (bredr_sc_enabled(hdev)) { in bredr_oob_data_present()
3952 if (!hci_dev_test_flag(hdev, HCI_SC_ONLY)) in bredr_oob_data_present()
3978 static void hci_io_capa_request_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_io_capa_request_evt() argument
3983 BT_DBG("%s", hdev->name); in hci_io_capa_request_evt()
3985 hci_dev_lock(hdev); in hci_io_capa_request_evt()
3987 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &ev->bdaddr); in hci_io_capa_request_evt()
3993 if (!hci_dev_test_flag(hdev, HCI_MGMT)) in hci_io_capa_request_evt()
3999 if (hci_dev_test_flag(hdev, HCI_BONDABLE) || in hci_io_capa_request_evt()
4025 if (!hci_dev_test_flag(hdev, HCI_BONDABLE)) in hci_io_capa_request_evt()
4031 hci_send_cmd(hdev, HCI_OP_IO_CAPABILITY_REPLY, in hci_io_capa_request_evt()
4039 hci_send_cmd(hdev, HCI_OP_IO_CAPABILITY_NEG_REPLY, in hci_io_capa_request_evt()
4044 hci_dev_unlock(hdev); in hci_io_capa_request_evt()
4047 static void hci_io_capa_reply_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_io_capa_reply_evt() argument
4052 BT_DBG("%s", hdev->name); in hci_io_capa_reply_evt()
4054 hci_dev_lock(hdev); in hci_io_capa_reply_evt()
4056 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &ev->bdaddr); in hci_io_capa_reply_evt()
4064 hci_dev_unlock(hdev); in hci_io_capa_reply_evt()
4067 static void hci_user_confirm_request_evt(struct hci_dev *hdev, in hci_user_confirm_request_evt() argument
4074 BT_DBG("%s", hdev->name); in hci_user_confirm_request_evt()
4076 hci_dev_lock(hdev); in hci_user_confirm_request_evt()
4078 if (!hci_dev_test_flag(hdev, HCI_MGMT)) in hci_user_confirm_request_evt()
4081 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &ev->bdaddr); in hci_user_confirm_request_evt()
4096 hci_send_cmd(hdev, HCI_OP_USER_CONFIRM_NEG_REPLY, in hci_user_confirm_request_evt()
4120 hdev->auto_accept_delay); in hci_user_confirm_request_evt()
4122 if (hdev->auto_accept_delay > 0) { in hci_user_confirm_request_evt()
4123 int delay = msecs_to_jiffies(hdev->auto_accept_delay); in hci_user_confirm_request_evt()
4124 queue_delayed_work(conn->hdev->workqueue, in hci_user_confirm_request_evt()
4129 hci_send_cmd(hdev, HCI_OP_USER_CONFIRM_REPLY, in hci_user_confirm_request_evt()
4135 mgmt_user_confirm_request(hdev, &ev->bdaddr, ACL_LINK, 0, in hci_user_confirm_request_evt()
4139 hci_dev_unlock(hdev); in hci_user_confirm_request_evt()
4142 static void hci_user_passkey_request_evt(struct hci_dev *hdev, in hci_user_passkey_request_evt() argument
4147 BT_DBG("%s", hdev->name); in hci_user_passkey_request_evt()
4149 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_user_passkey_request_evt()
4150 mgmt_user_passkey_request(hdev, &ev->bdaddr, ACL_LINK, 0); in hci_user_passkey_request_evt()
4153 static void hci_user_passkey_notify_evt(struct hci_dev *hdev, in hci_user_passkey_notify_evt() argument
4159 BT_DBG("%s", hdev->name); in hci_user_passkey_notify_evt()
4161 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &ev->bdaddr); in hci_user_passkey_notify_evt()
4168 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_user_passkey_notify_evt()
4169 mgmt_user_passkey_notify(hdev, &conn->dst, conn->type, in hci_user_passkey_notify_evt()
4174 static void hci_keypress_notify_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_keypress_notify_evt() argument
4179 BT_DBG("%s", hdev->name); in hci_keypress_notify_evt()
4181 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &ev->bdaddr); in hci_keypress_notify_evt()
4206 if (hci_dev_test_flag(hdev, HCI_MGMT)) in hci_keypress_notify_evt()
4207 mgmt_user_passkey_notify(hdev, &conn->dst, conn->type, in hci_keypress_notify_evt()
4212 static void hci_simple_pair_complete_evt(struct hci_dev *hdev, in hci_simple_pair_complete_evt() argument
4218 BT_DBG("%s", hdev->name); in hci_simple_pair_complete_evt()
4220 hci_dev_lock(hdev); in hci_simple_pair_complete_evt()
4222 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &ev->bdaddr); in hci_simple_pair_complete_evt()
4240 hci_dev_unlock(hdev); in hci_simple_pair_complete_evt()
4243 static void hci_remote_host_features_evt(struct hci_dev *hdev, in hci_remote_host_features_evt() argument
4250 BT_DBG("%s", hdev->name); in hci_remote_host_features_evt()
4252 hci_dev_lock(hdev); in hci_remote_host_features_evt()
4254 conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, &ev->bdaddr); in hci_remote_host_features_evt()
4258 ie = hci_inquiry_cache_lookup(hdev, &ev->bdaddr); in hci_remote_host_features_evt()
4262 hci_dev_unlock(hdev); in hci_remote_host_features_evt()
4265 static void hci_remote_oob_data_request_evt(struct hci_dev *hdev, in hci_remote_oob_data_request_evt() argument
4271 BT_DBG("%s", hdev->name); in hci_remote_oob_data_request_evt()
4273 hci_dev_lock(hdev); in hci_remote_oob_data_request_evt()
4275 if (!hci_dev_test_flag(hdev, HCI_MGMT)) in hci_remote_oob_data_request_evt()
4278 data = hci_find_remote_oob_data(hdev, &ev->bdaddr, BDADDR_BREDR); in hci_remote_oob_data_request_evt()
4283 hci_send_cmd(hdev, HCI_OP_REMOTE_OOB_DATA_NEG_REPLY, in hci_remote_oob_data_request_evt()
4288 if (bredr_sc_enabled(hdev)) { in hci_remote_oob_data_request_evt()
4292 if (hci_dev_test_flag(hdev, HCI_SC_ONLY)) { in hci_remote_oob_data_request_evt()
4302 hci_send_cmd(hdev, HCI_OP_REMOTE_OOB_EXT_DATA_REPLY, in hci_remote_oob_data_request_evt()
4311 hci_send_cmd(hdev, HCI_OP_REMOTE_OOB_DATA_REPLY, in hci_remote_oob_data_request_evt()
4316 hci_dev_unlock(hdev); in hci_remote_oob_data_request_evt()
4320 static void hci_chan_selected_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_chan_selected_evt() argument
4325 BT_DBG("%s handle 0x%2.2x", hdev->name, ev->phy_handle); in hci_chan_selected_evt()
4329 hcon = hci_conn_hash_lookup_handle(hdev, ev->phy_handle); in hci_chan_selected_evt()
4333 amp_read_loc_assoc_final_data(hdev, hcon); in hci_chan_selected_evt()
4336 static void hci_phy_link_complete_evt(struct hci_dev *hdev, in hci_phy_link_complete_evt() argument
4342 BT_DBG("%s handle 0x%2.2x status 0x%2.2x", hdev->name, ev->phy_handle, in hci_phy_link_complete_evt()
4345 hci_dev_lock(hdev); in hci_phy_link_complete_evt()
4347 hcon = hci_conn_hash_lookup_handle(hdev, ev->phy_handle); in hci_phy_link_complete_evt()
4349 hci_dev_unlock(hdev); in hci_phy_link_complete_evt()
4355 hci_dev_unlock(hdev); in hci_phy_link_complete_evt()
4373 hci_dev_unlock(hdev); in hci_phy_link_complete_evt()
4376 static void hci_loglink_complete_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_loglink_complete_evt() argument
4384 hdev->name, le16_to_cpu(ev->handle), ev->phy_handle, in hci_loglink_complete_evt()
4387 hcon = hci_conn_hash_lookup_handle(hdev, ev->phy_handle); in hci_loglink_complete_evt()
4406 bredr_chan->conn->mtu = hdev->block_mtu; in hci_loglink_complete_evt()
4414 static void hci_disconn_loglink_complete_evt(struct hci_dev *hdev, in hci_disconn_loglink_complete_evt() argument
4420 BT_DBG("%s log handle 0x%4.4x status 0x%2.2x", hdev->name, in hci_disconn_loglink_complete_evt()
4426 hci_dev_lock(hdev); in hci_disconn_loglink_complete_evt()
4428 hchan = hci_chan_lookup_handle(hdev, le16_to_cpu(ev->handle)); in hci_disconn_loglink_complete_evt()
4435 hci_dev_unlock(hdev); in hci_disconn_loglink_complete_evt()
4438 static void hci_disconn_phylink_complete_evt(struct hci_dev *hdev, in hci_disconn_phylink_complete_evt() argument
4444 BT_DBG("%s status 0x%2.2x", hdev->name, ev->status); in hci_disconn_phylink_complete_evt()
4449 hci_dev_lock(hdev); in hci_disconn_phylink_complete_evt()
4451 hcon = hci_conn_hash_lookup_handle(hdev, ev->phy_handle); in hci_disconn_phylink_complete_evt()
4457 hci_dev_unlock(hdev); in hci_disconn_phylink_complete_evt()
4461 static void hci_le_conn_complete_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_le_conn_complete_evt() argument
4469 BT_DBG("%s status 0x%2.2x", hdev->name, ev->status); in hci_le_conn_complete_evt()
4471 hci_dev_lock(hdev); in hci_le_conn_complete_evt()
4476 hci_dev_clear_flag(hdev, HCI_LE_ADV); in hci_le_conn_complete_evt()
4478 conn = hci_lookup_le_connect(hdev); in hci_le_conn_complete_evt()
4480 conn = hci_conn_add(hdev, LE_LINK, &ev->bdaddr, ev->role); in hci_le_conn_complete_evt()
4499 if (hci_dev_test_flag(hdev, HCI_PRIVACY)) { in hci_le_conn_complete_evt()
4501 bacpy(&conn->init_addr, &hdev->rpa); in hci_le_conn_complete_evt()
4503 hci_copy_identity_address(hdev, in hci_le_conn_complete_evt()
4516 conn->resp_addr_type = hdev->adv_addr_type; in hci_le_conn_complete_evt()
4517 if (hdev->adv_addr_type == ADDR_LE_DEV_RANDOM) in hci_le_conn_complete_evt()
4518 bacpy(&conn->resp_addr, &hdev->random_addr); in hci_le_conn_complete_evt()
4520 bacpy(&conn->resp_addr, &hdev->bdaddr); in hci_le_conn_complete_evt()
4530 conn->le_conn_min_interval = hdev->le_conn_min_interval; in hci_le_conn_complete_evt()
4531 conn->le_conn_max_interval = hdev->le_conn_max_interval; in hci_le_conn_complete_evt()
4543 irk = hci_get_irk(hdev, &conn->dst, conn->dst_type); in hci_le_conn_complete_evt()
4560 if (hci_bdaddr_list_lookup(&hdev->blacklist, &conn->dst, addr_type)) { in hci_le_conn_complete_evt()
4566 mgmt_device_connected(hdev, conn, 0, NULL, 0); in hci_le_conn_complete_evt()
4590 (hdev->le_features[0] & HCI_LE_SLAVE_FEATURES)) { in hci_le_conn_complete_evt()
4595 hci_send_cmd(hdev, HCI_OP_LE_READ_REMOTE_FEATURES, in hci_le_conn_complete_evt()
4607 params = hci_pend_le_action_lookup(&hdev->pend_le_conns, &conn->dst, in hci_le_conn_complete_evt()
4619 hci_update_background_scan(hdev); in hci_le_conn_complete_evt()
4620 hci_dev_unlock(hdev); in hci_le_conn_complete_evt()
4623 static void hci_le_conn_update_complete_evt(struct hci_dev *hdev, in hci_le_conn_update_complete_evt() argument
4629 BT_DBG("%s status 0x%2.2x", hdev->name, ev->status); in hci_le_conn_update_complete_evt()
4634 hci_dev_lock(hdev); in hci_le_conn_update_complete_evt()
4636 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(ev->handle)); in hci_le_conn_update_complete_evt()
4643 hci_dev_unlock(hdev); in hci_le_conn_update_complete_evt()
4647 static struct hci_conn *check_pending_le_conn(struct hci_dev *hdev, in check_pending_le_conn() argument
4660 if (hci_bdaddr_list_lookup(&hdev->blacklist, addr, addr_type)) in check_pending_le_conn()
4666 if (hdev->conn_hash.le_num_slave > 0) in check_pending_le_conn()
4672 params = hci_pend_le_action_lookup(&hdev->pend_le_conns, addr, in check_pending_le_conn()
4700 conn = hci_connect_le(hdev, addr, addr_type, BT_SECURITY_LOW, in check_pending_le_conn()
4735 static void process_adv_report(struct hci_dev *hdev, u8 type, bdaddr_t *bdaddr, in process_adv_report() argument
4739 struct discovery_state *d = &hdev->discovery; in process_adv_report()
4775 hdev->name); in process_adv_report()
4794 if (!hci_dev_test_flag(hdev, HCI_PRIVACY)) in process_adv_report()
4801 if (!smp_irk_matches(hdev, hdev->irk, direct_addr)) in process_adv_report()
4806 irk = hci_get_irk(hdev, bdaddr, bdaddr_type); in process_adv_report()
4817 conn = check_pending_le_conn(hdev, bdaddr, bdaddr_type, type, in process_adv_report()
4831 if (hdev->le_scan_type == LE_SCAN_PASSIVE) { in process_adv_report()
4835 if (!hci_pend_le_action_lookup(&hdev->pend_le_reports, in process_adv_report()
4843 mgmt_device_found(hdev, bdaddr, LE_LINK, bdaddr_type, NULL, in process_adv_report()
4873 if (!has_pending_adv_report(hdev)) { in process_adv_report()
4878 store_pending_adv_report(hdev, bdaddr, bdaddr_type, in process_adv_report()
4883 mgmt_device_found(hdev, bdaddr, LE_LINK, bdaddr_type, NULL, in process_adv_report()
4899 mgmt_device_found(hdev, &d->last_adv_addr, LE_LINK, in process_adv_report()
4909 store_pending_adv_report(hdev, bdaddr, bdaddr_type, in process_adv_report()
4917 clear_pending_adv_report(hdev); in process_adv_report()
4918 mgmt_device_found(hdev, bdaddr, LE_LINK, bdaddr_type, NULL, in process_adv_report()
4927 mgmt_device_found(hdev, &d->last_adv_addr, LE_LINK, in process_adv_report()
4930 clear_pending_adv_report(hdev); in process_adv_report()
4933 static void hci_le_adv_report_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_le_adv_report_evt() argument
4938 hci_dev_lock(hdev); in hci_le_adv_report_evt()
4945 process_adv_report(hdev, ev->evt_type, &ev->bdaddr, in hci_le_adv_report_evt()
4952 hci_dev_unlock(hdev); in hci_le_adv_report_evt()
4955 static void hci_le_remote_feat_complete_evt(struct hci_dev *hdev, in hci_le_remote_feat_complete_evt() argument
4961 BT_DBG("%s status 0x%2.2x", hdev->name, ev->status); in hci_le_remote_feat_complete_evt()
4963 hci_dev_lock(hdev); in hci_le_remote_feat_complete_evt()
4965 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(ev->handle)); in hci_le_remote_feat_complete_evt()
4982 if ((hdev->le_features[0] & HCI_LE_SLAVE_FEATURES) && in hci_le_remote_feat_complete_evt()
4994 hci_dev_unlock(hdev); in hci_le_remote_feat_complete_evt()
4997 static void hci_le_ltk_request_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_le_ltk_request_evt() argument
5005 BT_DBG("%s handle 0x%4.4x", hdev->name, __le16_to_cpu(ev->handle)); in hci_le_ltk_request_evt()
5007 hci_dev_lock(hdev); in hci_le_ltk_request_evt()
5009 conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(ev->handle)); in hci_le_ltk_request_evt()
5013 ltk = hci_find_ltk(hdev, &conn->dst, conn->dst_type, conn->role); in hci_le_ltk_request_evt()
5035 hci_send_cmd(hdev, HCI_OP_LE_LTK_REPLY, sizeof(cp), &cp); in hci_le_ltk_request_evt()
5051 hci_dev_unlock(hdev); in hci_le_ltk_request_evt()
5057 hci_send_cmd(hdev, HCI_OP_LE_LTK_NEG_REPLY, sizeof(neg), &neg); in hci_le_ltk_request_evt()
5058 hci_dev_unlock(hdev); in hci_le_ltk_request_evt()
5061 static void send_conn_param_neg_reply(struct hci_dev *hdev, u16 handle, in send_conn_param_neg_reply() argument
5069 hci_send_cmd(hdev, HCI_OP_LE_CONN_PARAM_REQ_NEG_REPLY, sizeof(cp), in send_conn_param_neg_reply()
5073 static void hci_le_remote_conn_param_req_evt(struct hci_dev *hdev, in hci_le_remote_conn_param_req_evt() argument
5087 hcon = hci_conn_hash_lookup_handle(hdev, handle); in hci_le_remote_conn_param_req_evt()
5089 return send_conn_param_neg_reply(hdev, handle, in hci_le_remote_conn_param_req_evt()
5093 return send_conn_param_neg_reply(hdev, handle, in hci_le_remote_conn_param_req_evt()
5100 hci_dev_lock(hdev); in hci_le_remote_conn_param_req_evt()
5102 params = hci_conn_params_lookup(hdev, &hcon->dst, in hci_le_remote_conn_param_req_evt()
5114 hci_dev_unlock(hdev); in hci_le_remote_conn_param_req_evt()
5116 mgmt_new_conn_param(hdev, &hcon->dst, hcon->dst_type, in hci_le_remote_conn_param_req_evt()
5128 hci_send_cmd(hdev, HCI_OP_LE_CONN_PARAM_REQ_REPLY, sizeof(cp), &cp); in hci_le_remote_conn_param_req_evt()
5131 static void hci_le_direct_adv_report_evt(struct hci_dev *hdev, in hci_le_direct_adv_report_evt() argument
5137 hci_dev_lock(hdev); in hci_le_direct_adv_report_evt()
5142 process_adv_report(hdev, ev->evt_type, &ev->bdaddr, in hci_le_direct_adv_report_evt()
5149 hci_dev_unlock(hdev); in hci_le_direct_adv_report_evt()
5152 static void hci_le_meta_evt(struct hci_dev *hdev, struct sk_buff *skb) in hci_le_meta_evt() argument
5160 hci_le_conn_complete_evt(hdev, skb); in hci_le_meta_evt()
5164 hci_le_conn_update_complete_evt(hdev, skb); in hci_le_meta_evt()
5168 hci_le_adv_report_evt(hdev, skb); in hci_le_meta_evt()
5172 hci_le_remote_feat_complete_evt(hdev, skb); in hci_le_meta_evt()
5176 hci_le_ltk_request_evt(hdev, skb); in hci_le_meta_evt()
5180 hci_le_remote_conn_param_req_evt(hdev, skb); in hci_le_meta_evt()
5184 hci_le_direct_adv_report_evt(hdev, skb); in hci_le_meta_evt()
5192 static bool hci_get_cmd_complete(struct hci_dev *hdev, u16 opcode, in hci_get_cmd_complete() argument
5237 void hci_event_packet(struct hci_dev *hdev, struct sk_buff *skb) in hci_event_packet() argument
5246 if (hdev->sent_cmd && bt_cb(hdev->sent_cmd)->hci.req_event == event) { in hci_event_packet()
5247 struct hci_command_hdr *cmd_hdr = (void *) hdev->sent_cmd->data; in hci_event_packet()
5249 hci_req_cmd_complete(hdev, opcode, status, &req_complete, in hci_event_packet()
5267 hci_inquiry_complete_evt(hdev, skb); in hci_event_packet()
5271 hci_inquiry_result_evt(hdev, skb); in hci_event_packet()
5275 hci_conn_complete_evt(hdev, skb); in hci_event_packet()
5279 hci_conn_request_evt(hdev, skb); in hci_event_packet()
5283 hci_disconn_complete_evt(hdev, skb); in hci_event_packet()
5287 hci_auth_complete_evt(hdev, skb); in hci_event_packet()
5291 hci_remote_name_evt(hdev, skb); in hci_event_packet()
5295 hci_encrypt_change_evt(hdev, skb); in hci_event_packet()
5299 hci_change_link_key_complete_evt(hdev, skb); in hci_event_packet()
5303 hci_remote_features_evt(hdev, skb); in hci_event_packet()
5307 hci_cmd_complete_evt(hdev, skb, &opcode, &status, in hci_event_packet()
5312 hci_cmd_status_evt(hdev, skb, &opcode, &status, &req_complete, in hci_event_packet()
5317 hci_hardware_error_evt(hdev, skb); in hci_event_packet()
5321 hci_role_change_evt(hdev, skb); in hci_event_packet()
5325 hci_num_comp_pkts_evt(hdev, skb); in hci_event_packet()
5329 hci_mode_change_evt(hdev, skb); in hci_event_packet()
5333 hci_pin_code_request_evt(hdev, skb); in hci_event_packet()
5337 hci_link_key_request_evt(hdev, skb); in hci_event_packet()
5341 hci_link_key_notify_evt(hdev, skb); in hci_event_packet()
5345 hci_clock_offset_evt(hdev, skb); in hci_event_packet()
5349 hci_pkt_type_change_evt(hdev, skb); in hci_event_packet()
5353 hci_pscan_rep_mode_evt(hdev, skb); in hci_event_packet()
5357 hci_inquiry_result_with_rssi_evt(hdev, skb); in hci_event_packet()
5361 hci_remote_ext_features_evt(hdev, skb); in hci_event_packet()
5365 hci_sync_conn_complete_evt(hdev, skb); in hci_event_packet()
5369 hci_extended_inquiry_result_evt(hdev, skb); in hci_event_packet()
5373 hci_key_refresh_complete_evt(hdev, skb); in hci_event_packet()
5377 hci_io_capa_request_evt(hdev, skb); in hci_event_packet()
5381 hci_io_capa_reply_evt(hdev, skb); in hci_event_packet()
5385 hci_user_confirm_request_evt(hdev, skb); in hci_event_packet()
5389 hci_user_passkey_request_evt(hdev, skb); in hci_event_packet()
5393 hci_user_passkey_notify_evt(hdev, skb); in hci_event_packet()
5397 hci_keypress_notify_evt(hdev, skb); in hci_event_packet()
5401 hci_simple_pair_complete_evt(hdev, skb); in hci_event_packet()
5405 hci_remote_host_features_evt(hdev, skb); in hci_event_packet()
5409 hci_le_meta_evt(hdev, skb); in hci_event_packet()
5413 hci_remote_oob_data_request_evt(hdev, skb); in hci_event_packet()
5418 hci_chan_selected_evt(hdev, skb); in hci_event_packet()
5422 hci_phy_link_complete_evt(hdev, skb); in hci_event_packet()
5426 hci_loglink_complete_evt(hdev, skb); in hci_event_packet()
5430 hci_disconn_loglink_complete_evt(hdev, skb); in hci_event_packet()
5434 hci_disconn_phylink_complete_evt(hdev, skb); in hci_event_packet()
5439 hci_num_comp_blocks_evt(hdev, skb); in hci_event_packet()
5443 BT_DBG("%s event 0x%2.2x", hdev->name, event); in hci_event_packet()
5448 req_complete(hdev, status, opcode); in hci_event_packet()
5450 if (!hci_get_cmd_complete(hdev, opcode, req_evt, orig_skb)) { in hci_event_packet()
5454 req_complete_skb(hdev, status, opcode, orig_skb); in hci_event_packet()
5459 hdev->stat.evt_rx++; in hci_event_packet()