|
@@ -3580,6 +3580,25 @@ void *hci_sent_cmd_data(struct hci_dev *hdev, __u16 opcode)
|
|
return hdev->sent_cmd->data + HCI_COMMAND_HDR_SIZE;
|
|
return hdev->sent_cmd->data + HCI_COMMAND_HDR_SIZE;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+/* Send HCI command and wait for command commplete event */
|
|
|
|
+struct sk_buff *hci_cmd_sync(struct hci_dev *hdev, u16 opcode, u32 plen,
|
|
|
|
+ const void *param, u32 timeout)
|
|
|
|
+{
|
|
|
|
+ struct sk_buff *skb;
|
|
|
|
+
|
|
|
|
+ if (!test_bit(HCI_UP, &hdev->flags))
|
|
|
|
+ return ERR_PTR(-ENETDOWN);
|
|
|
|
+
|
|
|
|
+ bt_dev_dbg(hdev, "opcode 0x%4.4x plen %d", opcode, plen);
|
|
|
|
+
|
|
|
|
+ hci_req_lock(hdev);
|
|
|
|
+ skb = __hci_cmd_sync(hdev, opcode, plen, param, timeout);
|
|
|
|
+ hci_req_unlock(hdev);
|
|
|
|
+
|
|
|
|
+ return skb;
|
|
|
|
+}
|
|
|
|
+EXPORT_SYMBOL(hci_cmd_sync);
|
|
|
|
+
|
|
/* Send ACL data */
|
|
/* Send ACL data */
|
|
static void hci_add_acl_hdr(struct sk_buff *skb, __u16 handle, __u16 flags)
|
|
static void hci_add_acl_hdr(struct sk_buff *skb, __u16 handle, __u16 flags)
|
|
{
|
|
{
|