mctp-serial.c 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Management Component Transport Protocol (MCTP) - serial transport
  4. * binding. This driver is an implementation of the DMTF specificiation
  5. * "DSP0253 - Management Component Transport Protocol (MCTP) Serial Transport
  6. * Binding", available at:
  7. *
  8. * https://www.dmtf.org/sites/default/files/standards/documents/DSP0253_1.0.0.pdf
  9. *
  10. * This driver provides DSP0253-type MCTP-over-serial transport using a Linux
  11. * tty device, by setting the N_MCTP line discipline on the tty.
  12. *
  13. * Copyright (c) 2021 Code Construct
  14. */
  15. #include <linux/idr.h>
  16. #include <linux/if_arp.h>
  17. #include <linux/module.h>
  18. #include <linux/skbuff.h>
  19. #include <linux/tty.h>
  20. #include <linux/workqueue.h>
  21. #include <linux/crc-ccitt.h>
  22. #include <linux/mctp.h>
  23. #include <net/mctp.h>
  24. #include <net/pkt_sched.h>
  25. #define MCTP_SERIAL_MTU 68 /* base mtu (64) + mctp header */
  26. #define MCTP_SERIAL_FRAME_MTU (MCTP_SERIAL_MTU + 6) /* + serial framing */
  27. #define MCTP_SERIAL_VERSION 0x1 /* DSP0253 defines a single version: 1 */
  28. #define BUFSIZE MCTP_SERIAL_FRAME_MTU
  29. #define BYTE_FRAME 0x7e
  30. #define BYTE_ESC 0x7d
  31. #define FCS_INIT 0xffff
  32. static DEFINE_IDA(mctp_serial_ida);
  33. enum mctp_serial_state {
  34. STATE_IDLE,
  35. STATE_START,
  36. STATE_HEADER,
  37. STATE_DATA,
  38. STATE_ESCAPE,
  39. STATE_TRAILER,
  40. STATE_DONE,
  41. STATE_ERR,
  42. };
  43. struct mctp_serial {
  44. struct net_device *netdev;
  45. struct tty_struct *tty;
  46. int idx;
  47. /* protects our rx & tx state machines; held during both paths */
  48. spinlock_t lock;
  49. struct work_struct tx_work;
  50. enum mctp_serial_state txstate, rxstate;
  51. u16 txfcs, rxfcs, rxfcs_rcvd;
  52. unsigned int txlen, rxlen;
  53. unsigned int txpos, rxpos;
  54. unsigned char txbuf[BUFSIZE],
  55. rxbuf[BUFSIZE];
  56. };
  57. static bool needs_escape(unsigned char c)
  58. {
  59. return c == BYTE_ESC || c == BYTE_FRAME;
  60. }
  61. static int next_chunk_len(struct mctp_serial *dev)
  62. {
  63. int i;
  64. /* either we have no bytes to send ... */
  65. if (dev->txpos == dev->txlen)
  66. return 0;
  67. /* ... or the next byte to send is an escaped byte; requiring a
  68. * single-byte chunk...
  69. */
  70. if (needs_escape(dev->txbuf[dev->txpos]))
  71. return 1;
  72. /* ... or we have one or more bytes up to the next escape - this chunk
  73. * will be those non-escaped bytes, and does not include the escaped
  74. * byte.
  75. */
  76. for (i = 1; i + dev->txpos + 1 < dev->txlen; i++) {
  77. if (needs_escape(dev->txbuf[dev->txpos + i + 1]))
  78. break;
  79. }
  80. return i;
  81. }
  82. static int write_chunk(struct mctp_serial *dev, unsigned char *buf, int len)
  83. {
  84. return dev->tty->ops->write(dev->tty, buf, len);
  85. }
  86. static void mctp_serial_tx_work(struct work_struct *work)
  87. {
  88. struct mctp_serial *dev = container_of(work, struct mctp_serial,
  89. tx_work);
  90. unsigned char c, buf[3];
  91. unsigned long flags;
  92. int len, txlen;
  93. spin_lock_irqsave(&dev->lock, flags);
  94. /* txstate represents the next thing to send */
  95. switch (dev->txstate) {
  96. case STATE_START:
  97. dev->txpos = 0;
  98. fallthrough;
  99. case STATE_HEADER:
  100. buf[0] = BYTE_FRAME;
  101. buf[1] = MCTP_SERIAL_VERSION;
  102. buf[2] = dev->txlen;
  103. if (!dev->txpos)
  104. dev->txfcs = crc_ccitt(FCS_INIT, buf + 1, 2);
  105. txlen = write_chunk(dev, buf + dev->txpos, 3 - dev->txpos);
  106. if (txlen <= 0) {
  107. dev->txstate = STATE_ERR;
  108. } else {
  109. dev->txpos += txlen;
  110. if (dev->txpos == 3) {
  111. dev->txstate = STATE_DATA;
  112. dev->txpos = 0;
  113. }
  114. }
  115. break;
  116. case STATE_ESCAPE:
  117. buf[0] = dev->txbuf[dev->txpos] & ~0x20;
  118. txlen = write_chunk(dev, buf, 1);
  119. if (txlen <= 0) {
  120. dev->txstate = STATE_ERR;
  121. } else {
  122. dev->txpos += txlen;
  123. if (dev->txpos == dev->txlen) {
  124. dev->txstate = STATE_TRAILER;
  125. dev->txpos = 0;
  126. }
  127. }
  128. break;
  129. case STATE_DATA:
  130. len = next_chunk_len(dev);
  131. if (len) {
  132. c = dev->txbuf[dev->txpos];
  133. if (len == 1 && needs_escape(c)) {
  134. buf[0] = BYTE_ESC;
  135. buf[1] = c & ~0x20;
  136. dev->txfcs = crc_ccitt_byte(dev->txfcs, c);
  137. txlen = write_chunk(dev, buf, 2);
  138. if (txlen == 2)
  139. dev->txpos++;
  140. else if (txlen == 1)
  141. dev->txstate = STATE_ESCAPE;
  142. else
  143. dev->txstate = STATE_ERR;
  144. } else {
  145. txlen = write_chunk(dev,
  146. dev->txbuf + dev->txpos,
  147. len);
  148. if (txlen <= 0) {
  149. dev->txstate = STATE_ERR;
  150. } else {
  151. dev->txfcs = crc_ccitt(dev->txfcs,
  152. dev->txbuf +
  153. dev->txpos,
  154. txlen);
  155. dev->txpos += txlen;
  156. }
  157. }
  158. if (dev->txstate == STATE_DATA &&
  159. dev->txpos == dev->txlen) {
  160. dev->txstate = STATE_TRAILER;
  161. dev->txpos = 0;
  162. }
  163. break;
  164. }
  165. dev->txstate = STATE_TRAILER;
  166. dev->txpos = 0;
  167. fallthrough;
  168. case STATE_TRAILER:
  169. buf[0] = dev->txfcs >> 8;
  170. buf[1] = dev->txfcs & 0xff;
  171. buf[2] = BYTE_FRAME;
  172. txlen = write_chunk(dev, buf + dev->txpos, 3 - dev->txpos);
  173. if (txlen <= 0) {
  174. dev->txstate = STATE_ERR;
  175. } else {
  176. dev->txpos += txlen;
  177. if (dev->txpos == 3) {
  178. dev->txstate = STATE_DONE;
  179. dev->txpos = 0;
  180. }
  181. }
  182. break;
  183. default:
  184. netdev_err_once(dev->netdev, "invalid tx state %d\n",
  185. dev->txstate);
  186. }
  187. if (dev->txstate == STATE_DONE) {
  188. dev->netdev->stats.tx_packets++;
  189. dev->netdev->stats.tx_bytes += dev->txlen;
  190. dev->txlen = 0;
  191. dev->txpos = 0;
  192. clear_bit(TTY_DO_WRITE_WAKEUP, &dev->tty->flags);
  193. dev->txstate = STATE_IDLE;
  194. spin_unlock_irqrestore(&dev->lock, flags);
  195. netif_wake_queue(dev->netdev);
  196. } else {
  197. spin_unlock_irqrestore(&dev->lock, flags);
  198. }
  199. }
  200. static netdev_tx_t mctp_serial_tx(struct sk_buff *skb, struct net_device *ndev)
  201. {
  202. struct mctp_serial *dev = netdev_priv(ndev);
  203. unsigned long flags;
  204. WARN_ON(dev->txstate != STATE_IDLE);
  205. if (skb->len > MCTP_SERIAL_MTU) {
  206. dev->netdev->stats.tx_dropped++;
  207. goto out;
  208. }
  209. spin_lock_irqsave(&dev->lock, flags);
  210. netif_stop_queue(dev->netdev);
  211. skb_copy_bits(skb, 0, dev->txbuf, skb->len);
  212. dev->txpos = 0;
  213. dev->txlen = skb->len;
  214. dev->txstate = STATE_START;
  215. spin_unlock_irqrestore(&dev->lock, flags);
  216. set_bit(TTY_DO_WRITE_WAKEUP, &dev->tty->flags);
  217. schedule_work(&dev->tx_work);
  218. out:
  219. kfree_skb(skb);
  220. return NETDEV_TX_OK;
  221. }
  222. static void mctp_serial_tty_write_wakeup(struct tty_struct *tty)
  223. {
  224. struct mctp_serial *dev = tty->disc_data;
  225. schedule_work(&dev->tx_work);
  226. }
  227. static void mctp_serial_rx(struct mctp_serial *dev)
  228. {
  229. struct mctp_skb_cb *cb;
  230. struct sk_buff *skb;
  231. if (dev->rxfcs != dev->rxfcs_rcvd) {
  232. dev->netdev->stats.rx_dropped++;
  233. dev->netdev->stats.rx_crc_errors++;
  234. return;
  235. }
  236. skb = netdev_alloc_skb(dev->netdev, dev->rxlen);
  237. if (!skb) {
  238. dev->netdev->stats.rx_dropped++;
  239. return;
  240. }
  241. skb->protocol = htons(ETH_P_MCTP);
  242. skb_put_data(skb, dev->rxbuf, dev->rxlen);
  243. skb_reset_network_header(skb);
  244. cb = __mctp_cb(skb);
  245. cb->halen = 0;
  246. netif_rx(skb);
  247. dev->netdev->stats.rx_packets++;
  248. dev->netdev->stats.rx_bytes += dev->rxlen;
  249. }
  250. static void mctp_serial_push_header(struct mctp_serial *dev, unsigned char c)
  251. {
  252. switch (dev->rxpos) {
  253. case 0:
  254. if (c == BYTE_FRAME)
  255. dev->rxpos++;
  256. else
  257. dev->rxstate = STATE_ERR;
  258. break;
  259. case 1:
  260. if (c == MCTP_SERIAL_VERSION) {
  261. dev->rxpos++;
  262. dev->rxfcs = crc_ccitt_byte(FCS_INIT, c);
  263. } else {
  264. dev->rxstate = STATE_ERR;
  265. }
  266. break;
  267. case 2:
  268. if (c > MCTP_SERIAL_FRAME_MTU) {
  269. dev->rxstate = STATE_ERR;
  270. } else {
  271. dev->rxlen = c;
  272. dev->rxpos = 0;
  273. dev->rxstate = STATE_DATA;
  274. dev->rxfcs = crc_ccitt_byte(dev->rxfcs, c);
  275. }
  276. break;
  277. }
  278. }
  279. static void mctp_serial_push_trailer(struct mctp_serial *dev, unsigned char c)
  280. {
  281. switch (dev->rxpos) {
  282. case 0:
  283. dev->rxfcs_rcvd = c << 8;
  284. dev->rxpos++;
  285. break;
  286. case 1:
  287. dev->rxfcs_rcvd |= c;
  288. dev->rxpos++;
  289. break;
  290. case 2:
  291. if (c != BYTE_FRAME) {
  292. dev->rxstate = STATE_ERR;
  293. } else {
  294. mctp_serial_rx(dev);
  295. dev->rxlen = 0;
  296. dev->rxpos = 0;
  297. dev->rxstate = STATE_IDLE;
  298. }
  299. break;
  300. }
  301. }
  302. static void mctp_serial_push(struct mctp_serial *dev, unsigned char c)
  303. {
  304. switch (dev->rxstate) {
  305. case STATE_IDLE:
  306. dev->rxstate = STATE_HEADER;
  307. fallthrough;
  308. case STATE_HEADER:
  309. mctp_serial_push_header(dev, c);
  310. break;
  311. case STATE_ESCAPE:
  312. c |= 0x20;
  313. fallthrough;
  314. case STATE_DATA:
  315. if (dev->rxstate != STATE_ESCAPE && c == BYTE_ESC) {
  316. dev->rxstate = STATE_ESCAPE;
  317. } else {
  318. dev->rxfcs = crc_ccitt_byte(dev->rxfcs, c);
  319. dev->rxbuf[dev->rxpos] = c;
  320. dev->rxpos++;
  321. dev->rxstate = STATE_DATA;
  322. if (dev->rxpos == dev->rxlen) {
  323. dev->rxpos = 0;
  324. dev->rxstate = STATE_TRAILER;
  325. }
  326. }
  327. break;
  328. case STATE_TRAILER:
  329. mctp_serial_push_trailer(dev, c);
  330. break;
  331. case STATE_ERR:
  332. if (c == BYTE_FRAME)
  333. dev->rxstate = STATE_IDLE;
  334. break;
  335. default:
  336. netdev_err_once(dev->netdev, "invalid rx state %d\n",
  337. dev->rxstate);
  338. }
  339. }
  340. static void mctp_serial_tty_receive_buf(struct tty_struct *tty,
  341. const unsigned char *c,
  342. const char *f, int len)
  343. {
  344. struct mctp_serial *dev = tty->disc_data;
  345. int i;
  346. if (!netif_running(dev->netdev))
  347. return;
  348. /* we don't (currently) use the flag bytes, just data. */
  349. for (i = 0; i < len; i++)
  350. mctp_serial_push(dev, c[i]);
  351. }
  352. static void mctp_serial_uninit(struct net_device *ndev)
  353. {
  354. struct mctp_serial *dev = netdev_priv(ndev);
  355. cancel_work_sync(&dev->tx_work);
  356. }
  357. static const struct net_device_ops mctp_serial_netdev_ops = {
  358. .ndo_start_xmit = mctp_serial_tx,
  359. .ndo_uninit = mctp_serial_uninit,
  360. };
  361. static void mctp_serial_setup(struct net_device *ndev)
  362. {
  363. ndev->type = ARPHRD_MCTP;
  364. /* we limit at the fixed MTU, which is also the MCTP-standard
  365. * baseline MTU, so is also our minimum
  366. */
  367. ndev->mtu = MCTP_SERIAL_MTU;
  368. ndev->max_mtu = MCTP_SERIAL_MTU;
  369. ndev->min_mtu = MCTP_SERIAL_MTU;
  370. ndev->hard_header_len = 0;
  371. ndev->addr_len = 0;
  372. ndev->tx_queue_len = DEFAULT_TX_QUEUE_LEN;
  373. ndev->flags = IFF_NOARP;
  374. ndev->netdev_ops = &mctp_serial_netdev_ops;
  375. ndev->needs_free_netdev = true;
  376. }
  377. static int mctp_serial_open(struct tty_struct *tty)
  378. {
  379. struct mctp_serial *dev;
  380. struct net_device *ndev;
  381. char name[32];
  382. int idx, rc;
  383. if (!capable(CAP_NET_ADMIN))
  384. return -EPERM;
  385. if (!tty->ops->write)
  386. return -EOPNOTSUPP;
  387. idx = ida_alloc(&mctp_serial_ida, GFP_KERNEL);
  388. if (idx < 0)
  389. return idx;
  390. snprintf(name, sizeof(name), "mctpserial%d", idx);
  391. ndev = alloc_netdev(sizeof(*dev), name, NET_NAME_ENUM,
  392. mctp_serial_setup);
  393. if (!ndev) {
  394. rc = -ENOMEM;
  395. goto free_ida;
  396. }
  397. dev = netdev_priv(ndev);
  398. dev->idx = idx;
  399. dev->tty = tty;
  400. dev->netdev = ndev;
  401. dev->txstate = STATE_IDLE;
  402. dev->rxstate = STATE_IDLE;
  403. spin_lock_init(&dev->lock);
  404. INIT_WORK(&dev->tx_work, mctp_serial_tx_work);
  405. rc = register_netdev(ndev);
  406. if (rc)
  407. goto free_netdev;
  408. tty->receive_room = 64 * 1024;
  409. tty->disc_data = dev;
  410. return 0;
  411. free_netdev:
  412. free_netdev(ndev);
  413. free_ida:
  414. ida_free(&mctp_serial_ida, idx);
  415. return rc;
  416. }
  417. static void mctp_serial_close(struct tty_struct *tty)
  418. {
  419. struct mctp_serial *dev = tty->disc_data;
  420. int idx = dev->idx;
  421. unregister_netdev(dev->netdev);
  422. ida_free(&mctp_serial_ida, idx);
  423. }
  424. static struct tty_ldisc_ops mctp_ldisc = {
  425. .owner = THIS_MODULE,
  426. .num = N_MCTP,
  427. .name = "mctp",
  428. .open = mctp_serial_open,
  429. .close = mctp_serial_close,
  430. .receive_buf = mctp_serial_tty_receive_buf,
  431. .write_wakeup = mctp_serial_tty_write_wakeup,
  432. };
  433. static int __init mctp_serial_init(void)
  434. {
  435. return tty_register_ldisc(&mctp_ldisc);
  436. }
  437. static void __exit mctp_serial_exit(void)
  438. {
  439. tty_unregister_ldisc(&mctp_ldisc);
  440. }
  441. module_init(mctp_serial_init);
  442. module_exit(mctp_serial_exit);
  443. MODULE_LICENSE("GPL v2");
  444. MODULE_AUTHOR("Jeremy Kerr <[email protected]>");
  445. MODULE_DESCRIPTION("MCTP Serial transport");