| /* |
| BlueZ - Bluetooth protocol stack for Linux |
| Copyright (C) 2014 Intel Corporation |
| |
| This program is free software; you can redistribute it and/or modify |
| it under the terms of the GNU General Public License version 2 as |
| published by the Free Software Foundation; |
| |
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS. |
| IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) AND AUTHOR(S) BE LIABLE FOR ANY |
| CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES |
| WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
| ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
| OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
| |
| ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS, |
| COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS, RELATING TO USE OF THIS |
| SOFTWARE IS DISCLAIMED. |
| */ |
| |
| #include <asm/unaligned.h> |
| |
| #define HCI_REQ_DONE 0 |
| #define HCI_REQ_PEND 1 |
| #define HCI_REQ_CANCELED 2 |
| |
| #define hci_req_sync_lock(hdev) mutex_lock(&hdev->req_lock) |
| #define hci_req_sync_unlock(hdev) mutex_unlock(&hdev->req_lock) |
| |
| struct hci_request { |
| struct hci_dev *hdev; |
| struct sk_buff_head cmd_q; |
| |
| /* If something goes wrong when building the HCI request, the error |
| * value is stored in this field. |
| */ |
| int err; |
| }; |
| |
| void hci_req_init(struct hci_request *req, struct hci_dev *hdev); |
| void hci_req_purge(struct hci_request *req); |
| bool hci_req_status_pend(struct hci_dev *hdev); |
| int hci_req_run(struct hci_request *req, hci_req_complete_t complete); |
| int hci_req_run_skb(struct hci_request *req, hci_req_complete_skb_t complete); |
| void hci_req_sync_complete(struct hci_dev *hdev, u8 result, u16 opcode, |
| struct sk_buff *skb); |
| void hci_req_add(struct hci_request *req, u16 opcode, u32 plen, |
| const void *param); |
| void hci_req_add_ev(struct hci_request *req, u16 opcode, u32 plen, |
| const void *param, u8 event); |
| void hci_req_cmd_complete(struct hci_dev *hdev, u16 opcode, u8 status, |
| hci_req_complete_t *req_complete, |
| hci_req_complete_skb_t *req_complete_skb); |
| |
| int hci_req_sync(struct hci_dev *hdev, int (*req)(struct hci_request *req, |
| unsigned long opt), |
| unsigned long opt, u32 timeout, u8 *hci_status); |
| int __hci_req_sync(struct hci_dev *hdev, int (*func)(struct hci_request *req, |
| unsigned long opt), |
| unsigned long opt, u32 timeout, u8 *hci_status); |
| |
| struct sk_buff *hci_prepare_cmd(struct hci_dev *hdev, u16 opcode, u32 plen, |
| const void *param); |
| |
| void hci_req_add_le_scan_disable(struct hci_request *req, bool rpa_le_conn); |
| void hci_req_add_le_passive_scan(struct hci_request *req); |
| |
| void hci_request_setup(struct hci_dev *hdev); |
| void hci_request_cancel_all(struct hci_dev *hdev); |