blob: 03ffe95415fcfe0ab08f4f478c6f72c1df3dcaf3 [file] [log] [blame]
Marcel Holtmann6a98e382021-10-27 16:58:38 -07001/* SPDX-License-Identifier: GPL-2.0 */
2/*
3 * BlueZ - Bluetooth protocol stack for Linux
4 *
5 * Copyright (C) 2021 Intel Corporation
6 */
7
8typedef int (*hci_cmd_sync_work_func_t)(struct hci_dev *hdev, void *data);
9typedef void (*hci_cmd_sync_work_destroy_t)(struct hci_dev *hdev, void *data,
10 int err);
11
12struct hci_cmd_sync_work_entry {
13 struct list_head list;
14 hci_cmd_sync_work_func_t func;
15 void *data;
16 hci_cmd_sync_work_destroy_t destroy;
17};
18
19/* Function with sync suffix shall not be called with hdev->lock held as they
20 * wait the command to complete and in the meantime an event could be received
21 * which could attempt to acquire hdev->lock causing a deadlock.
22 */
23struct sk_buff *__hci_cmd_sync(struct hci_dev *hdev, u16 opcode, u32 plen,
24 const void *param, u32 timeout);
25struct sk_buff *hci_cmd_sync(struct hci_dev *hdev, u16 opcode, u32 plen,
26 const void *param, u32 timeout);
27struct sk_buff *__hci_cmd_sync_ev(struct hci_dev *hdev, u16 opcode, u32 plen,
28 const void *param, u8 event, u32 timeout);
29struct sk_buff *__hci_cmd_sync_sk(struct hci_dev *hdev, u16 opcode, u32 plen,
30 const void *param, u8 event, u32 timeout,
31 struct sock *sk);
32int __hci_cmd_sync_status(struct hci_dev *hdev, u16 opcode, u32 plen,
33 const void *param, u32 timeout);
34int __hci_cmd_sync_status_sk(struct hci_dev *hdev, u16 opcode, u32 plen,
35 const void *param, u8 event, u32 timeout,
36 struct sock *sk);
37
38void hci_cmd_sync_init(struct hci_dev *hdev);
39void hci_cmd_sync_clear(struct hci_dev *hdev);
40
41int hci_cmd_sync_queue(struct hci_dev *hdev, hci_cmd_sync_work_func_t func,
42 void *data, hci_cmd_sync_work_destroy_t destroy);
Luiz Augusto von Dentz161510c2021-10-27 16:58:39 -070043
44int hci_update_eir_sync(struct hci_dev *hdev);
45int hci_update_class_sync(struct hci_dev *hdev);
Luiz Augusto von Dentzcba6b752021-10-27 16:58:40 -070046
47int hci_update_eir_sync(struct hci_dev *hdev);
48int hci_update_class_sync(struct hci_dev *hdev);
49
50int hci_update_random_address_sync(struct hci_dev *hdev, bool require_privacy,
51 bool rpa, u8 *own_addr_type);
52
53int hci_update_scan_rsp_data_sync(struct hci_dev *hdev, u8 instance);
54int hci_update_adv_data_sync(struct hci_dev *hdev, u8 instance);
55int hci_schedule_adv_instance_sync(struct hci_dev *hdev, u8 instance,
56 bool force);
57
58int hci_setup_ext_adv_instance_sync(struct hci_dev *hdev, u8 instance);
59int hci_start_ext_adv_sync(struct hci_dev *hdev, u8 instance);
60int hci_enable_ext_advertising_sync(struct hci_dev *hdev, u8 instance);
61int hci_enable_advertising_sync(struct hci_dev *hdev);
Luiz Augusto von Dentzabfeea42021-10-27 16:58:45 -070062int hci_enable_advertising(struct hci_dev *hdev);
Luiz Augusto von Dentzcba6b752021-10-27 16:58:40 -070063
64int hci_remove_advertising_sync(struct hci_dev *hdev, struct sock *sk,
65 u8 instance, bool force);
66int hci_disable_advertising_sync(struct hci_dev *hdev);
Luiz Augusto von Dentze8907f72021-10-27 16:58:41 -070067
68int hci_update_passive_scan_sync(struct hci_dev *hdev);
Luiz Augusto von Dentzad383c22021-10-27 16:58:42 -070069int hci_update_passive_scan(struct hci_dev *hdev);
Luiz Augusto von Dentzcf75ad82021-10-27 16:58:44 -070070
Brian Gix353a0242021-10-27 16:58:46 -070071int hci_write_fast_connectable_sync(struct hci_dev *hdev, bool enable);
Brian Gix451d95a2021-10-27 16:58:47 -070072int hci_update_scan_sync(struct hci_dev *hdev);
Brian Gix353a0242021-10-27 16:58:46 -070073
Luiz Augusto von Dentzcf75ad82021-10-27 16:58:44 -070074int hci_dev_open_sync(struct hci_dev *hdev);
75int hci_dev_close_sync(struct hci_dev *hdev);
76
77int hci_powered_update_sync(struct hci_dev *hdev);
78int hci_set_powered_sync(struct hci_dev *hdev, u8 val);
Luiz Augusto von Dentzabfeea42021-10-27 16:58:45 -070079
80int hci_start_discovery_sync(struct hci_dev *hdev);
81int hci_stop_discovery_sync(struct hci_dev *hdev);