bpa10x.c 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. *
  4. * Digianswer Bluetooth USB driver
  5. *
  6. * Copyright (C) 2004-2007 Marcel Holtmann <marcel@holtmann.org>
  7. */
  8. #include <linux/kernel.h>
  9. #include <linux/module.h>
  10. #include <linux/init.h>
  11. #include <linux/slab.h>
  12. #include <linux/types.h>
  13. #include <linux/sched.h>
  14. #include <linux/errno.h>
  15. #include <linux/skbuff.h>
  16. #include <linux/usb.h>
  17. #include <net/bluetooth/bluetooth.h>
  18. #include <net/bluetooth/hci_core.h>
  19. #include "hci_uart.h"
  20. #define VERSION "0.11"
  21. static const struct usb_device_id bpa10x_table[] = {
  22. /* Tektronix BPA 100/105 (Digianswer) */
  23. { USB_DEVICE(0x08fd, 0x0002) },
  24. { } /* Terminating entry */
  25. };
  26. MODULE_DEVICE_TABLE(usb, bpa10x_table);
  27. struct bpa10x_data {
  28. struct hci_dev *hdev;
  29. struct usb_device *udev;
  30. struct usb_anchor tx_anchor;
  31. struct usb_anchor rx_anchor;
  32. struct sk_buff *rx_skb[2];
  33. struct hci_uart hu;
  34. };
  35. static void bpa10x_tx_complete(struct urb *urb)
  36. {
  37. struct sk_buff *skb = urb->context;
  38. struct hci_dev *hdev = (struct hci_dev *) skb->dev;
  39. BT_DBG("%s urb %p status %d count %d", hdev->name,
  40. urb, urb->status, urb->actual_length);
  41. if (!test_bit(HCI_RUNNING, &hdev->flags))
  42. goto done;
  43. if (!urb->status)
  44. hdev->stat.byte_tx += urb->transfer_buffer_length;
  45. else
  46. hdev->stat.err_tx++;
  47. done:
  48. kfree(urb->setup_packet);
  49. kfree_skb(skb);
  50. }
  51. #define HCI_VENDOR_HDR_SIZE 5
  52. #define HCI_RECV_VENDOR \
  53. .type = HCI_VENDOR_PKT, \
  54. .hlen = HCI_VENDOR_HDR_SIZE, \
  55. .loff = 3, \
  56. .lsize = 2, \
  57. .maxlen = HCI_MAX_FRAME_SIZE
  58. static const struct h4_recv_pkt bpa10x_recv_pkts[] = {
  59. { H4_RECV_ACL, .recv = hci_recv_frame },
  60. { H4_RECV_SCO, .recv = hci_recv_frame },
  61. { H4_RECV_EVENT, .recv = hci_recv_frame },
  62. { HCI_RECV_VENDOR, .recv = hci_recv_diag },
  63. };
  64. static void bpa10x_rx_complete(struct urb *urb)
  65. {
  66. struct hci_dev *hdev = urb->context;
  67. struct bpa10x_data *data = hci_get_drvdata(hdev);
  68. int err;
  69. BT_DBG("%s urb %p status %d count %d", hdev->name,
  70. urb, urb->status, urb->actual_length);
  71. if (!test_bit(HCI_RUNNING, &hdev->flags))
  72. return;
  73. if (urb->status == 0) {
  74. bool idx = usb_pipebulk(urb->pipe);
  75. data->rx_skb[idx] = h4_recv_buf(&data->hu, data->rx_skb[idx],
  76. urb->transfer_buffer,
  77. urb->actual_length,
  78. bpa10x_recv_pkts,
  79. ARRAY_SIZE(bpa10x_recv_pkts));
  80. if (IS_ERR(data->rx_skb[idx])) {
  81. bt_dev_err(hdev, "corrupted event packet");
  82. hdev->stat.err_rx++;
  83. data->rx_skb[idx] = NULL;
  84. }
  85. }
  86. usb_anchor_urb(urb, &data->rx_anchor);
  87. err = usb_submit_urb(urb, GFP_ATOMIC);
  88. if (err < 0) {
  89. bt_dev_err(hdev, "urb %p failed to resubmit (%d)", urb, -err);
  90. usb_unanchor_urb(urb);
  91. }
  92. }
  93. static inline int bpa10x_submit_intr_urb(struct hci_dev *hdev)
  94. {
  95. struct bpa10x_data *data = hci_get_drvdata(hdev);
  96. struct urb *urb;
  97. unsigned char *buf;
  98. unsigned int pipe;
  99. int err, size = 16;
  100. BT_DBG("%s", hdev->name);
  101. urb = usb_alloc_urb(0, GFP_KERNEL);
  102. if (!urb)
  103. return -ENOMEM;
  104. buf = kmalloc(size, GFP_KERNEL);
  105. if (!buf) {
  106. usb_free_urb(urb);
  107. return -ENOMEM;
  108. }
  109. pipe = usb_rcvintpipe(data->udev, 0x81);
  110. usb_fill_int_urb(urb, data->udev, pipe, buf, size,
  111. bpa10x_rx_complete, hdev, 1);
  112. urb->transfer_flags |= URB_FREE_BUFFER;
  113. usb_anchor_urb(urb, &data->rx_anchor);
  114. err = usb_submit_urb(urb, GFP_KERNEL);
  115. if (err < 0) {
  116. bt_dev_err(hdev, "urb %p submission failed (%d)", urb, -err);
  117. usb_unanchor_urb(urb);
  118. }
  119. usb_free_urb(urb);
  120. return err;
  121. }
  122. static inline int bpa10x_submit_bulk_urb(struct hci_dev *hdev)
  123. {
  124. struct bpa10x_data *data = hci_get_drvdata(hdev);
  125. struct urb *urb;
  126. unsigned char *buf;
  127. unsigned int pipe;
  128. int err, size = 64;
  129. BT_DBG("%s", hdev->name);
  130. urb = usb_alloc_urb(0, GFP_KERNEL);
  131. if (!urb)
  132. return -ENOMEM;
  133. buf = kmalloc(size, GFP_KERNEL);
  134. if (!buf) {
  135. usb_free_urb(urb);
  136. return -ENOMEM;
  137. }
  138. pipe = usb_rcvbulkpipe(data->udev, 0x82);
  139. usb_fill_bulk_urb(urb, data->udev, pipe,
  140. buf, size, bpa10x_rx_complete, hdev);
  141. urb->transfer_flags |= URB_FREE_BUFFER;
  142. usb_anchor_urb(urb, &data->rx_anchor);
  143. err = usb_submit_urb(urb, GFP_KERNEL);
  144. if (err < 0) {
  145. bt_dev_err(hdev, "urb %p submission failed (%d)", urb, -err);
  146. usb_unanchor_urb(urb);
  147. }
  148. usb_free_urb(urb);
  149. return err;
  150. }
  151. static int bpa10x_open(struct hci_dev *hdev)
  152. {
  153. struct bpa10x_data *data = hci_get_drvdata(hdev);
  154. int err;
  155. BT_DBG("%s", hdev->name);
  156. err = bpa10x_submit_intr_urb(hdev);
  157. if (err < 0)
  158. goto error;
  159. err = bpa10x_submit_bulk_urb(hdev);
  160. if (err < 0)
  161. goto error;
  162. return 0;
  163. error:
  164. usb_kill_anchored_urbs(&data->rx_anchor);
  165. return err;
  166. }
  167. static int bpa10x_close(struct hci_dev *hdev)
  168. {
  169. struct bpa10x_data *data = hci_get_drvdata(hdev);
  170. BT_DBG("%s", hdev->name);
  171. usb_kill_anchored_urbs(&data->rx_anchor);
  172. return 0;
  173. }
  174. static int bpa10x_flush(struct hci_dev *hdev)
  175. {
  176. struct bpa10x_data *data = hci_get_drvdata(hdev);
  177. BT_DBG("%s", hdev->name);
  178. usb_kill_anchored_urbs(&data->tx_anchor);
  179. return 0;
  180. }
  181. static int bpa10x_setup(struct hci_dev *hdev)
  182. {
  183. static const u8 req[] = { 0x07 };
  184. struct sk_buff *skb;
  185. BT_DBG("%s", hdev->name);
  186. /* Read revision string */
  187. skb = __hci_cmd_sync(hdev, 0xfc0e, sizeof(req), req, HCI_INIT_TIMEOUT);
  188. if (IS_ERR(skb))
  189. return PTR_ERR(skb);
  190. bt_dev_info(hdev, "%s", (char *)(skb->data + 1));
  191. hci_set_fw_info(hdev, "%s", skb->data + 1);
  192. kfree_skb(skb);
  193. return 0;
  194. }
  195. static int bpa10x_send_frame(struct hci_dev *hdev, struct sk_buff *skb)
  196. {
  197. struct bpa10x_data *data = hci_get_drvdata(hdev);
  198. struct usb_ctrlrequest *dr;
  199. struct urb *urb;
  200. unsigned int pipe;
  201. int err;
  202. BT_DBG("%s", hdev->name);
  203. skb->dev = (void *) hdev;
  204. urb = usb_alloc_urb(0, GFP_KERNEL);
  205. if (!urb)
  206. return -ENOMEM;
  207. /* Prepend skb with frame type */
  208. *(u8 *)skb_push(skb, 1) = hci_skb_pkt_type(skb);
  209. switch (hci_skb_pkt_type(skb)) {
  210. case HCI_COMMAND_PKT:
  211. dr = kmalloc_obj(*dr);
  212. if (!dr) {
  213. usb_free_urb(urb);
  214. return -ENOMEM;
  215. }
  216. dr->bRequestType = USB_TYPE_VENDOR;
  217. dr->bRequest = 0;
  218. dr->wIndex = 0;
  219. dr->wValue = 0;
  220. dr->wLength = __cpu_to_le16(skb->len);
  221. pipe = usb_sndctrlpipe(data->udev, 0x00);
  222. usb_fill_control_urb(urb, data->udev, pipe, (void *) dr,
  223. skb->data, skb->len, bpa10x_tx_complete, skb);
  224. hdev->stat.cmd_tx++;
  225. break;
  226. case HCI_ACLDATA_PKT:
  227. pipe = usb_sndbulkpipe(data->udev, 0x02);
  228. usb_fill_bulk_urb(urb, data->udev, pipe,
  229. skb->data, skb->len, bpa10x_tx_complete, skb);
  230. hdev->stat.acl_tx++;
  231. break;
  232. case HCI_SCODATA_PKT:
  233. pipe = usb_sndbulkpipe(data->udev, 0x02);
  234. usb_fill_bulk_urb(urb, data->udev, pipe,
  235. skb->data, skb->len, bpa10x_tx_complete, skb);
  236. hdev->stat.sco_tx++;
  237. break;
  238. default:
  239. usb_free_urb(urb);
  240. return -EILSEQ;
  241. }
  242. usb_anchor_urb(urb, &data->tx_anchor);
  243. err = usb_submit_urb(urb, GFP_KERNEL);
  244. if (err < 0) {
  245. bt_dev_err(hdev, "urb %p submission failed", urb);
  246. kfree(urb->setup_packet);
  247. usb_unanchor_urb(urb);
  248. }
  249. usb_free_urb(urb);
  250. return err;
  251. }
  252. static int bpa10x_set_diag(struct hci_dev *hdev, bool enable)
  253. {
  254. const u8 req[] = { 0x00, enable };
  255. struct sk_buff *skb;
  256. BT_DBG("%s", hdev->name);
  257. if (!test_bit(HCI_RUNNING, &hdev->flags))
  258. return -ENETDOWN;
  259. /* Enable sniffer operation */
  260. skb = __hci_cmd_sync(hdev, 0xfc0e, sizeof(req), req, HCI_INIT_TIMEOUT);
  261. if (IS_ERR(skb))
  262. return PTR_ERR(skb);
  263. kfree_skb(skb);
  264. return 0;
  265. }
  266. static int bpa10x_probe(struct usb_interface *intf,
  267. const struct usb_device_id *id)
  268. {
  269. struct bpa10x_data *data;
  270. struct hci_dev *hdev;
  271. int err;
  272. BT_DBG("intf %p id %p", intf, id);
  273. if (intf->cur_altsetting->desc.bInterfaceNumber != 0)
  274. return -ENODEV;
  275. data = devm_kzalloc(&intf->dev, sizeof(*data), GFP_KERNEL);
  276. if (!data)
  277. return -ENOMEM;
  278. data->udev = interface_to_usbdev(intf);
  279. init_usb_anchor(&data->tx_anchor);
  280. init_usb_anchor(&data->rx_anchor);
  281. hdev = hci_alloc_dev();
  282. if (!hdev)
  283. return -ENOMEM;
  284. hdev->bus = HCI_USB;
  285. hci_set_drvdata(hdev, data);
  286. data->hdev = hdev;
  287. data->hu.hdev = hdev;
  288. SET_HCIDEV_DEV(hdev, &intf->dev);
  289. hdev->open = bpa10x_open;
  290. hdev->close = bpa10x_close;
  291. hdev->flush = bpa10x_flush;
  292. hdev->setup = bpa10x_setup;
  293. hdev->send = bpa10x_send_frame;
  294. hdev->set_diag = bpa10x_set_diag;
  295. hci_set_quirk(hdev, HCI_QUIRK_RESET_ON_CLOSE);
  296. err = hci_register_dev(hdev);
  297. if (err < 0) {
  298. hci_free_dev(hdev);
  299. return err;
  300. }
  301. usb_set_intfdata(intf, data);
  302. return 0;
  303. }
  304. static void bpa10x_disconnect(struct usb_interface *intf)
  305. {
  306. struct bpa10x_data *data = usb_get_intfdata(intf);
  307. BT_DBG("intf %p", intf);
  308. if (!data)
  309. return;
  310. usb_set_intfdata(intf, NULL);
  311. hci_unregister_dev(data->hdev);
  312. hci_free_dev(data->hdev);
  313. kfree_skb(data->rx_skb[0]);
  314. kfree_skb(data->rx_skb[1]);
  315. }
  316. static struct usb_driver bpa10x_driver = {
  317. .name = "bpa10x",
  318. .probe = bpa10x_probe,
  319. .disconnect = bpa10x_disconnect,
  320. .id_table = bpa10x_table,
  321. .disable_hub_initiated_lpm = 1,
  322. };
  323. module_usb_driver(bpa10x_driver);
  324. MODULE_AUTHOR("Marcel Holtmann <marcel@holtmann.org>");
  325. MODULE_DESCRIPTION("Digianswer Bluetooth USB driver ver " VERSION);
  326. MODULE_VERSION(VERSION);
  327. MODULE_LICENSE("GPL");