| /* | 
 |    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) | 
 |  | 
 | #define HCI_REQ_DONE	  0 | 
 | #define HCI_REQ_PEND	  1 | 
 | #define HCI_REQ_CANCELED  2 | 
 |  | 
 | 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); |