hci_mrvl.c 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. *
  4. * Bluetooth HCI UART driver for marvell devices
  5. *
  6. * Copyright (C) 2016 Marvell International Ltd.
  7. * Copyright (C) 2016 Intel Corporation
  8. */
  9. #include <linux/kernel.h>
  10. #include <linux/errno.h>
  11. #include <linux/skbuff.h>
  12. #include <linux/firmware.h>
  13. #include <linux/module.h>
  14. #include <linux/tty.h>
  15. #include <linux/of.h>
  16. #include <linux/serdev.h>
  17. #include <net/bluetooth/bluetooth.h>
  18. #include <net/bluetooth/hci_core.h>
  19. #include "hci_uart.h"
  20. #define HCI_FW_REQ_PKT 0xA5
  21. #define HCI_CHIP_VER_PKT 0xAA
  22. #define MRVL_ACK 0x5A
  23. #define MRVL_NAK 0xBF
  24. #define MRVL_RAW_DATA 0x1F
  25. enum {
  26. STATE_CHIP_VER_PENDING,
  27. STATE_FW_REQ_PENDING,
  28. };
  29. struct mrvl_data {
  30. struct sk_buff *rx_skb;
  31. struct sk_buff_head txq;
  32. struct sk_buff_head rawq;
  33. unsigned long flags;
  34. unsigned int tx_len;
  35. u8 id, rev;
  36. };
  37. struct mrvl_serdev {
  38. struct hci_uart hu;
  39. };
  40. struct hci_mrvl_pkt {
  41. __le16 lhs;
  42. __le16 rhs;
  43. } __packed;
  44. #define HCI_MRVL_PKT_SIZE 4
  45. static int mrvl_open(struct hci_uart *hu)
  46. {
  47. struct mrvl_data *mrvl;
  48. int ret;
  49. BT_DBG("hu %p", hu);
  50. if (!hci_uart_has_flow_control(hu))
  51. return -EOPNOTSUPP;
  52. mrvl = kzalloc(sizeof(*mrvl), GFP_KERNEL);
  53. if (!mrvl)
  54. return -ENOMEM;
  55. skb_queue_head_init(&mrvl->txq);
  56. skb_queue_head_init(&mrvl->rawq);
  57. set_bit(STATE_CHIP_VER_PENDING, &mrvl->flags);
  58. hu->priv = mrvl;
  59. if (hu->serdev) {
  60. ret = serdev_device_open(hu->serdev);
  61. if (ret)
  62. goto err;
  63. }
  64. return 0;
  65. err:
  66. kfree(mrvl);
  67. return ret;
  68. }
  69. static int mrvl_close(struct hci_uart *hu)
  70. {
  71. struct mrvl_data *mrvl = hu->priv;
  72. BT_DBG("hu %p", hu);
  73. if (hu->serdev)
  74. serdev_device_close(hu->serdev);
  75. skb_queue_purge(&mrvl->txq);
  76. skb_queue_purge(&mrvl->rawq);
  77. kfree_skb(mrvl->rx_skb);
  78. kfree(mrvl);
  79. hu->priv = NULL;
  80. return 0;
  81. }
  82. static int mrvl_flush(struct hci_uart *hu)
  83. {
  84. struct mrvl_data *mrvl = hu->priv;
  85. BT_DBG("hu %p", hu);
  86. skb_queue_purge(&mrvl->txq);
  87. skb_queue_purge(&mrvl->rawq);
  88. return 0;
  89. }
  90. static struct sk_buff *mrvl_dequeue(struct hci_uart *hu)
  91. {
  92. struct mrvl_data *mrvl = hu->priv;
  93. struct sk_buff *skb;
  94. skb = skb_dequeue(&mrvl->txq);
  95. if (!skb) {
  96. /* Any raw data ? */
  97. skb = skb_dequeue(&mrvl->rawq);
  98. } else {
  99. /* Prepend skb with frame type */
  100. memcpy(skb_push(skb, 1), &bt_cb(skb)->pkt_type, 1);
  101. }
  102. return skb;
  103. }
  104. static int mrvl_enqueue(struct hci_uart *hu, struct sk_buff *skb)
  105. {
  106. struct mrvl_data *mrvl = hu->priv;
  107. skb_queue_tail(&mrvl->txq, skb);
  108. return 0;
  109. }
  110. static void mrvl_send_ack(struct hci_uart *hu, unsigned char type)
  111. {
  112. struct mrvl_data *mrvl = hu->priv;
  113. struct sk_buff *skb;
  114. /* No H4 payload, only 1 byte header */
  115. skb = bt_skb_alloc(0, GFP_ATOMIC);
  116. if (!skb) {
  117. bt_dev_err(hu->hdev, "Unable to alloc ack/nak packet");
  118. return;
  119. }
  120. hci_skb_pkt_type(skb) = type;
  121. skb_queue_tail(&mrvl->txq, skb);
  122. hci_uart_tx_wakeup(hu);
  123. }
  124. static int mrvl_recv_fw_req(struct hci_dev *hdev, struct sk_buff *skb)
  125. {
  126. struct hci_mrvl_pkt *pkt = (void *)skb->data;
  127. struct hci_uart *hu = hci_get_drvdata(hdev);
  128. struct mrvl_data *mrvl = hu->priv;
  129. int ret = 0;
  130. if ((pkt->lhs ^ pkt->rhs) != 0xffff) {
  131. bt_dev_err(hdev, "Corrupted mrvl header");
  132. mrvl_send_ack(hu, MRVL_NAK);
  133. ret = -EINVAL;
  134. goto done;
  135. }
  136. mrvl_send_ack(hu, MRVL_ACK);
  137. if (!test_bit(STATE_FW_REQ_PENDING, &mrvl->flags)) {
  138. bt_dev_err(hdev, "Received unexpected firmware request");
  139. ret = -EINVAL;
  140. goto done;
  141. }
  142. mrvl->tx_len = le16_to_cpu(pkt->lhs);
  143. clear_bit(STATE_FW_REQ_PENDING, &mrvl->flags);
  144. smp_mb__after_atomic();
  145. wake_up_bit(&mrvl->flags, STATE_FW_REQ_PENDING);
  146. done:
  147. kfree_skb(skb);
  148. return ret;
  149. }
  150. static int mrvl_recv_chip_ver(struct hci_dev *hdev, struct sk_buff *skb)
  151. {
  152. struct hci_mrvl_pkt *pkt = (void *)skb->data;
  153. struct hci_uart *hu = hci_get_drvdata(hdev);
  154. struct mrvl_data *mrvl = hu->priv;
  155. u16 version = le16_to_cpu(pkt->lhs);
  156. int ret = 0;
  157. if ((pkt->lhs ^ pkt->rhs) != 0xffff) {
  158. bt_dev_err(hdev, "Corrupted mrvl header");
  159. mrvl_send_ack(hu, MRVL_NAK);
  160. ret = -EINVAL;
  161. goto done;
  162. }
  163. mrvl_send_ack(hu, MRVL_ACK);
  164. if (!test_bit(STATE_CHIP_VER_PENDING, &mrvl->flags)) {
  165. bt_dev_err(hdev, "Received unexpected chip version");
  166. goto done;
  167. }
  168. mrvl->id = version;
  169. mrvl->rev = version >> 8;
  170. bt_dev_info(hdev, "Controller id = %x, rev = %x", mrvl->id, mrvl->rev);
  171. clear_bit(STATE_CHIP_VER_PENDING, &mrvl->flags);
  172. smp_mb__after_atomic();
  173. wake_up_bit(&mrvl->flags, STATE_CHIP_VER_PENDING);
  174. done:
  175. kfree_skb(skb);
  176. return ret;
  177. }
  178. #define HCI_RECV_CHIP_VER \
  179. .type = HCI_CHIP_VER_PKT, \
  180. .hlen = HCI_MRVL_PKT_SIZE, \
  181. .loff = 0, \
  182. .lsize = 0, \
  183. .maxlen = HCI_MRVL_PKT_SIZE
  184. #define HCI_RECV_FW_REQ \
  185. .type = HCI_FW_REQ_PKT, \
  186. .hlen = HCI_MRVL_PKT_SIZE, \
  187. .loff = 0, \
  188. .lsize = 0, \
  189. .maxlen = HCI_MRVL_PKT_SIZE
  190. static const struct h4_recv_pkt mrvl_recv_pkts[] = {
  191. { H4_RECV_ACL, .recv = hci_recv_frame },
  192. { H4_RECV_SCO, .recv = hci_recv_frame },
  193. { H4_RECV_EVENT, .recv = hci_recv_frame },
  194. { HCI_RECV_FW_REQ, .recv = mrvl_recv_fw_req },
  195. { HCI_RECV_CHIP_VER, .recv = mrvl_recv_chip_ver },
  196. };
  197. static int mrvl_recv(struct hci_uart *hu, const void *data, int count)
  198. {
  199. struct mrvl_data *mrvl = hu->priv;
  200. if (!test_bit(HCI_UART_REGISTERED, &hu->flags))
  201. return -EUNATCH;
  202. mrvl->rx_skb = h4_recv_buf(hu->hdev, mrvl->rx_skb, data, count,
  203. mrvl_recv_pkts,
  204. ARRAY_SIZE(mrvl_recv_pkts));
  205. if (IS_ERR(mrvl->rx_skb)) {
  206. int err = PTR_ERR(mrvl->rx_skb);
  207. bt_dev_err(hu->hdev, "Frame reassembly failed (%d)", err);
  208. mrvl->rx_skb = NULL;
  209. return err;
  210. }
  211. return count;
  212. }
  213. static int mrvl_load_firmware(struct hci_dev *hdev, const char *name)
  214. {
  215. struct hci_uart *hu = hci_get_drvdata(hdev);
  216. struct mrvl_data *mrvl = hu->priv;
  217. const struct firmware *fw = NULL;
  218. const u8 *fw_ptr, *fw_max;
  219. int err;
  220. err = request_firmware(&fw, name, &hdev->dev);
  221. if (err < 0) {
  222. bt_dev_err(hdev, "Failed to load firmware file %s", name);
  223. return err;
  224. }
  225. fw_ptr = fw->data;
  226. fw_max = fw->data + fw->size;
  227. bt_dev_info(hdev, "Loading %s", name);
  228. set_bit(STATE_FW_REQ_PENDING, &mrvl->flags);
  229. while (fw_ptr <= fw_max) {
  230. struct sk_buff *skb;
  231. /* Controller drives the firmware load by sending firmware
  232. * request packets containing the expected fragment size.
  233. */
  234. err = wait_on_bit_timeout(&mrvl->flags, STATE_FW_REQ_PENDING,
  235. TASK_INTERRUPTIBLE,
  236. msecs_to_jiffies(2000));
  237. if (err == 1) {
  238. bt_dev_err(hdev, "Firmware load interrupted");
  239. err = -EINTR;
  240. break;
  241. } else if (err) {
  242. bt_dev_err(hdev, "Firmware request timeout");
  243. err = -ETIMEDOUT;
  244. break;
  245. }
  246. bt_dev_dbg(hdev, "Firmware request, expecting %d bytes",
  247. mrvl->tx_len);
  248. if (fw_ptr == fw_max) {
  249. /* Controller requests a null size once firmware is
  250. * fully loaded. If controller expects more data, there
  251. * is an issue.
  252. */
  253. if (!mrvl->tx_len) {
  254. bt_dev_info(hdev, "Firmware loading complete");
  255. } else {
  256. bt_dev_err(hdev, "Firmware loading failure");
  257. err = -EINVAL;
  258. }
  259. break;
  260. }
  261. if (fw_ptr + mrvl->tx_len > fw_max) {
  262. mrvl->tx_len = fw_max - fw_ptr;
  263. bt_dev_dbg(hdev, "Adjusting tx_len to %d",
  264. mrvl->tx_len);
  265. }
  266. skb = bt_skb_alloc(mrvl->tx_len, GFP_KERNEL);
  267. if (!skb) {
  268. bt_dev_err(hdev, "Failed to alloc mem for FW packet");
  269. err = -ENOMEM;
  270. break;
  271. }
  272. bt_cb(skb)->pkt_type = MRVL_RAW_DATA;
  273. skb_put_data(skb, fw_ptr, mrvl->tx_len);
  274. fw_ptr += mrvl->tx_len;
  275. set_bit(STATE_FW_REQ_PENDING, &mrvl->flags);
  276. skb_queue_tail(&mrvl->rawq, skb);
  277. hci_uart_tx_wakeup(hu);
  278. }
  279. release_firmware(fw);
  280. return err;
  281. }
  282. static int mrvl_setup(struct hci_uart *hu)
  283. {
  284. int err;
  285. hci_uart_set_flow_control(hu, true);
  286. err = mrvl_load_firmware(hu->hdev, "mrvl/helper_uart_3000000.bin");
  287. if (err) {
  288. bt_dev_err(hu->hdev, "Unable to download firmware helper");
  289. return -EINVAL;
  290. }
  291. /* Let the final ack go out before switching the baudrate */
  292. hci_uart_wait_until_sent(hu);
  293. if (hu->serdev)
  294. serdev_device_set_baudrate(hu->serdev, 3000000);
  295. else
  296. hci_uart_set_baudrate(hu, 3000000);
  297. hci_uart_set_flow_control(hu, false);
  298. err = mrvl_load_firmware(hu->hdev, "mrvl/uart8897_bt.bin");
  299. if (err)
  300. return err;
  301. return 0;
  302. }
  303. static const struct hci_uart_proto mrvl_proto = {
  304. .id = HCI_UART_MRVL,
  305. .name = "Marvell",
  306. .init_speed = 115200,
  307. .open = mrvl_open,
  308. .close = mrvl_close,
  309. .flush = mrvl_flush,
  310. .setup = mrvl_setup,
  311. .recv = mrvl_recv,
  312. .enqueue = mrvl_enqueue,
  313. .dequeue = mrvl_dequeue,
  314. };
  315. static int mrvl_serdev_probe(struct serdev_device *serdev)
  316. {
  317. struct mrvl_serdev *mrvldev;
  318. mrvldev = devm_kzalloc(&serdev->dev, sizeof(*mrvldev), GFP_KERNEL);
  319. if (!mrvldev)
  320. return -ENOMEM;
  321. mrvldev->hu.serdev = serdev;
  322. serdev_device_set_drvdata(serdev, mrvldev);
  323. return hci_uart_register_device(&mrvldev->hu, &mrvl_proto);
  324. }
  325. static void mrvl_serdev_remove(struct serdev_device *serdev)
  326. {
  327. struct mrvl_serdev *mrvldev = serdev_device_get_drvdata(serdev);
  328. hci_uart_unregister_device(&mrvldev->hu);
  329. }
  330. #ifdef CONFIG_OF
  331. static const struct of_device_id mrvl_bluetooth_of_match[] = {
  332. { .compatible = "mrvl,88w8897" },
  333. { },
  334. };
  335. MODULE_DEVICE_TABLE(of, mrvl_bluetooth_of_match);
  336. #endif
  337. static struct serdev_device_driver mrvl_serdev_driver = {
  338. .probe = mrvl_serdev_probe,
  339. .remove = mrvl_serdev_remove,
  340. .driver = {
  341. .name = "hci_uart_mrvl",
  342. .of_match_table = of_match_ptr(mrvl_bluetooth_of_match),
  343. },
  344. };
  345. int __init mrvl_init(void)
  346. {
  347. serdev_device_driver_register(&mrvl_serdev_driver);
  348. return hci_uart_register_proto(&mrvl_proto);
  349. }
  350. int __exit mrvl_deinit(void)
  351. {
  352. serdev_device_driver_unregister(&mrvl_serdev_driver);
  353. return hci_uart_unregister_proto(&mrvl_proto);
  354. }