spi-pic32.c 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878
  1. /*
  2. * Microchip PIC32 SPI controller driver.
  3. *
  4. * Purna Chandra Mandal <purna.mandal@microchip.com>
  5. * Copyright (c) 2016, Microchip Technology Inc.
  6. *
  7. * This program is free software; you can distribute it and/or modify it
  8. * under the terms of the GNU General Public License (Version 2) as
  9. * published by the Free Software Foundation.
  10. *
  11. * This program is distributed in the hope it will be useful, but WITHOUT
  12. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  13. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
  14. * for more details.
  15. */
  16. #include <linux/clk.h>
  17. #include <linux/clkdev.h>
  18. #include <linux/delay.h>
  19. #include <linux/dmaengine.h>
  20. #include <linux/dma-mapping.h>
  21. #include <linux/highmem.h>
  22. #include <linux/module.h>
  23. #include <linux/io.h>
  24. #include <linux/interrupt.h>
  25. #include <linux/of.h>
  26. #include <linux/of_irq.h>
  27. #include <linux/of_gpio.h>
  28. #include <linux/of_address.h>
  29. #include <linux/platform_device.h>
  30. #include <linux/spi/spi.h>
  31. /* SPI controller registers */
  32. struct pic32_spi_regs {
  33. u32 ctrl;
  34. u32 ctrl_clr;
  35. u32 ctrl_set;
  36. u32 ctrl_inv;
  37. u32 status;
  38. u32 status_clr;
  39. u32 status_set;
  40. u32 status_inv;
  41. u32 buf;
  42. u32 dontuse[3];
  43. u32 baud;
  44. u32 dontuse2[3];
  45. u32 ctrl2;
  46. u32 ctrl2_clr;
  47. u32 ctrl2_set;
  48. u32 ctrl2_inv;
  49. };
  50. /* Bit fields of SPI Control Register */
  51. #define CTRL_RX_INT_SHIFT 0 /* Rx interrupt generation */
  52. #define RX_FIFO_EMTPY 0
  53. #define RX_FIFO_NOT_EMPTY 1 /* not empty */
  54. #define RX_FIFO_HALF_FULL 2 /* full by half or more */
  55. #define RX_FIFO_FULL 3 /* completely full */
  56. #define CTRL_TX_INT_SHIFT 2 /* TX interrupt generation */
  57. #define TX_FIFO_ALL_EMPTY 0 /* completely empty */
  58. #define TX_FIFO_EMTPY 1 /* empty */
  59. #define TX_FIFO_HALF_EMPTY 2 /* empty by half or more */
  60. #define TX_FIFO_NOT_FULL 3 /* atleast one empty */
  61. #define CTRL_MSTEN BIT(5) /* enable master mode */
  62. #define CTRL_CKP BIT(6) /* active low */
  63. #define CTRL_CKE BIT(8) /* Tx on falling edge */
  64. #define CTRL_SMP BIT(9) /* Rx at middle or end of tx */
  65. #define CTRL_BPW_MASK 0x03 /* bits per word/sample */
  66. #define CTRL_BPW_SHIFT 10
  67. #define PIC32_BPW_8 0
  68. #define PIC32_BPW_16 1
  69. #define PIC32_BPW_32 2
  70. #define CTRL_SIDL BIT(13) /* sleep when idle */
  71. #define CTRL_ON BIT(15) /* enable macro */
  72. #define CTRL_ENHBUF BIT(16) /* enable enhanced buffering */
  73. #define CTRL_MCLKSEL BIT(23) /* select clock source */
  74. #define CTRL_MSSEN BIT(28) /* macro driven /SS */
  75. #define CTRL_FRMEN BIT(31) /* enable framing mode */
  76. /* Bit fields of SPI Status Register */
  77. #define STAT_RF_EMPTY BIT(5) /* RX Fifo empty */
  78. #define STAT_RX_OV BIT(6) /* err, s/w needs to clear */
  79. #define STAT_TX_UR BIT(8) /* UR in Framed SPI modes */
  80. #define STAT_FRM_ERR BIT(12) /* Multiple Frame Sync pulse */
  81. #define STAT_TF_LVL_MASK 0x1F
  82. #define STAT_TF_LVL_SHIFT 16
  83. #define STAT_RF_LVL_MASK 0x1F
  84. #define STAT_RF_LVL_SHIFT 24
  85. /* Bit fields of SPI Baud Register */
  86. #define BAUD_MASK 0x1ff
  87. /* Bit fields of SPI Control2 Register */
  88. #define CTRL2_TX_UR_EN BIT(10) /* Enable int on Tx under-run */
  89. #define CTRL2_RX_OV_EN BIT(11) /* Enable int on Rx over-run */
  90. #define CTRL2_FRM_ERR_EN BIT(12) /* Enable frame err int */
  91. /* Minimum DMA transfer size */
  92. #define PIC32_DMA_LEN_MIN 64
  93. struct pic32_spi {
  94. dma_addr_t dma_base;
  95. struct pic32_spi_regs __iomem *regs;
  96. int fault_irq;
  97. int rx_irq;
  98. int tx_irq;
  99. u32 fifo_n_byte; /* FIFO depth in bytes */
  100. struct clk *clk;
  101. struct spi_master *master;
  102. /* Current controller setting */
  103. u32 speed_hz; /* spi-clk rate */
  104. u32 mode;
  105. u32 bits_per_word;
  106. u32 fifo_n_elm; /* FIFO depth in words */
  107. #define PIC32F_DMA_PREP 0 /* DMA chnls configured */
  108. unsigned long flags;
  109. /* Current transfer state */
  110. struct completion xfer_done;
  111. /* PIO transfer specific */
  112. const void *tx;
  113. const void *tx_end;
  114. const void *rx;
  115. const void *rx_end;
  116. int len;
  117. void (*rx_fifo)(struct pic32_spi *);
  118. void (*tx_fifo)(struct pic32_spi *);
  119. };
  120. static inline void pic32_spi_enable(struct pic32_spi *pic32s)
  121. {
  122. writel(CTRL_ON | CTRL_SIDL, &pic32s->regs->ctrl_set);
  123. }
  124. static inline void pic32_spi_disable(struct pic32_spi *pic32s)
  125. {
  126. writel(CTRL_ON | CTRL_SIDL, &pic32s->regs->ctrl_clr);
  127. /* avoid SPI registers read/write at immediate next CPU clock */
  128. ndelay(20);
  129. }
  130. static void pic32_spi_set_clk_rate(struct pic32_spi *pic32s, u32 spi_ck)
  131. {
  132. u32 div;
  133. /* div = (clk_in / 2 * spi_ck) - 1 */
  134. div = DIV_ROUND_CLOSEST(clk_get_rate(pic32s->clk), 2 * spi_ck) - 1;
  135. writel(div & BAUD_MASK, &pic32s->regs->baud);
  136. }
  137. static inline u32 pic32_rx_fifo_level(struct pic32_spi *pic32s)
  138. {
  139. u32 sr = readl(&pic32s->regs->status);
  140. return (sr >> STAT_RF_LVL_SHIFT) & STAT_RF_LVL_MASK;
  141. }
  142. static inline u32 pic32_tx_fifo_level(struct pic32_spi *pic32s)
  143. {
  144. u32 sr = readl(&pic32s->regs->status);
  145. return (sr >> STAT_TF_LVL_SHIFT) & STAT_TF_LVL_MASK;
  146. }
  147. /* Return the max entries we can fill into tx fifo */
  148. static u32 pic32_tx_max(struct pic32_spi *pic32s, int n_bytes)
  149. {
  150. u32 tx_left, tx_room, rxtx_gap;
  151. tx_left = (pic32s->tx_end - pic32s->tx) / n_bytes;
  152. tx_room = pic32s->fifo_n_elm - pic32_tx_fifo_level(pic32s);
  153. /*
  154. * Another concern is about the tx/rx mismatch, we
  155. * though to use (pic32s->fifo_n_byte - rxfl - txfl) as
  156. * one maximum value for tx, but it doesn't cover the
  157. * data which is out of tx/rx fifo and inside the
  158. * shift registers. So a ctrl from sw point of
  159. * view is taken.
  160. */
  161. rxtx_gap = ((pic32s->rx_end - pic32s->rx) -
  162. (pic32s->tx_end - pic32s->tx)) / n_bytes;
  163. return min3(tx_left, tx_room, (u32)(pic32s->fifo_n_elm - rxtx_gap));
  164. }
  165. /* Return the max entries we should read out of rx fifo */
  166. static u32 pic32_rx_max(struct pic32_spi *pic32s, int n_bytes)
  167. {
  168. u32 rx_left = (pic32s->rx_end - pic32s->rx) / n_bytes;
  169. return min_t(u32, rx_left, pic32_rx_fifo_level(pic32s));
  170. }
  171. #define BUILD_SPI_FIFO_RW(__name, __type, __bwl) \
  172. static void pic32_spi_rx_##__name(struct pic32_spi *pic32s) \
  173. { \
  174. __type v; \
  175. u32 mx = pic32_rx_max(pic32s, sizeof(__type)); \
  176. for (; mx; mx--) { \
  177. v = read##__bwl(&pic32s->regs->buf); \
  178. if (pic32s->rx_end - pic32s->len) \
  179. *(__type *)(pic32s->rx) = v; \
  180. pic32s->rx += sizeof(__type); \
  181. } \
  182. } \
  183. \
  184. static void pic32_spi_tx_##__name(struct pic32_spi *pic32s) \
  185. { \
  186. __type v; \
  187. u32 mx = pic32_tx_max(pic32s, sizeof(__type)); \
  188. for (; mx ; mx--) { \
  189. v = (__type)~0U; \
  190. if (pic32s->tx_end - pic32s->len) \
  191. v = *(__type *)(pic32s->tx); \
  192. write##__bwl(v, &pic32s->regs->buf); \
  193. pic32s->tx += sizeof(__type); \
  194. } \
  195. }
  196. BUILD_SPI_FIFO_RW(byte, u8, b);
  197. BUILD_SPI_FIFO_RW(word, u16, w);
  198. BUILD_SPI_FIFO_RW(dword, u32, l);
  199. static void pic32_err_stop(struct pic32_spi *pic32s, const char *msg)
  200. {
  201. /* disable all interrupts */
  202. disable_irq_nosync(pic32s->fault_irq);
  203. disable_irq_nosync(pic32s->rx_irq);
  204. disable_irq_nosync(pic32s->tx_irq);
  205. /* Show err message and abort xfer with err */
  206. dev_err(&pic32s->master->dev, "%s\n", msg);
  207. if (pic32s->master->cur_msg)
  208. pic32s->master->cur_msg->status = -EIO;
  209. complete(&pic32s->xfer_done);
  210. }
  211. static irqreturn_t pic32_spi_fault_irq(int irq, void *dev_id)
  212. {
  213. struct pic32_spi *pic32s = dev_id;
  214. u32 status;
  215. status = readl(&pic32s->regs->status);
  216. /* Error handling */
  217. if (status & (STAT_RX_OV | STAT_TX_UR)) {
  218. writel(STAT_RX_OV, &pic32s->regs->status_clr);
  219. writel(STAT_TX_UR, &pic32s->regs->status_clr);
  220. pic32_err_stop(pic32s, "err_irq: fifo ov/ur-run\n");
  221. return IRQ_HANDLED;
  222. }
  223. if (status & STAT_FRM_ERR) {
  224. pic32_err_stop(pic32s, "err_irq: frame error");
  225. return IRQ_HANDLED;
  226. }
  227. if (!pic32s->master->cur_msg) {
  228. pic32_err_stop(pic32s, "err_irq: no mesg");
  229. return IRQ_NONE;
  230. }
  231. return IRQ_NONE;
  232. }
  233. static irqreturn_t pic32_spi_rx_irq(int irq, void *dev_id)
  234. {
  235. struct pic32_spi *pic32s = dev_id;
  236. pic32s->rx_fifo(pic32s);
  237. /* rx complete ? */
  238. if (pic32s->rx_end == pic32s->rx) {
  239. /* disable all interrupts */
  240. disable_irq_nosync(pic32s->fault_irq);
  241. disable_irq_nosync(pic32s->rx_irq);
  242. /* complete current xfer */
  243. complete(&pic32s->xfer_done);
  244. }
  245. return IRQ_HANDLED;
  246. }
  247. static irqreturn_t pic32_spi_tx_irq(int irq, void *dev_id)
  248. {
  249. struct pic32_spi *pic32s = dev_id;
  250. pic32s->tx_fifo(pic32s);
  251. /* tx complete? disable tx interrupt */
  252. if (pic32s->tx_end == pic32s->tx)
  253. disable_irq_nosync(pic32s->tx_irq);
  254. return IRQ_HANDLED;
  255. }
  256. static void pic32_spi_dma_rx_notify(void *data)
  257. {
  258. struct pic32_spi *pic32s = data;
  259. complete(&pic32s->xfer_done);
  260. }
  261. static int pic32_spi_dma_transfer(struct pic32_spi *pic32s,
  262. struct spi_transfer *xfer)
  263. {
  264. struct spi_master *master = pic32s->master;
  265. struct dma_async_tx_descriptor *desc_rx;
  266. struct dma_async_tx_descriptor *desc_tx;
  267. dma_cookie_t cookie;
  268. int ret;
  269. if (!master->dma_rx || !master->dma_tx)
  270. return -ENODEV;
  271. desc_rx = dmaengine_prep_slave_sg(master->dma_rx,
  272. xfer->rx_sg.sgl,
  273. xfer->rx_sg.nents,
  274. DMA_FROM_DEVICE,
  275. DMA_PREP_INTERRUPT | DMA_CTRL_ACK);
  276. if (!desc_rx) {
  277. ret = -EINVAL;
  278. goto err_dma;
  279. }
  280. desc_tx = dmaengine_prep_slave_sg(master->dma_tx,
  281. xfer->tx_sg.sgl,
  282. xfer->tx_sg.nents,
  283. DMA_TO_DEVICE,
  284. DMA_PREP_INTERRUPT | DMA_CTRL_ACK);
  285. if (!desc_tx) {
  286. ret = -EINVAL;
  287. goto err_dma;
  288. }
  289. /* Put callback on the RX transfer, that should finish last */
  290. desc_rx->callback = pic32_spi_dma_rx_notify;
  291. desc_rx->callback_param = pic32s;
  292. cookie = dmaengine_submit(desc_rx);
  293. ret = dma_submit_error(cookie);
  294. if (ret)
  295. goto err_dma;
  296. cookie = dmaengine_submit(desc_tx);
  297. ret = dma_submit_error(cookie);
  298. if (ret)
  299. goto err_dma_tx;
  300. dma_async_issue_pending(master->dma_rx);
  301. dma_async_issue_pending(master->dma_tx);
  302. return 0;
  303. err_dma_tx:
  304. dmaengine_terminate_all(master->dma_rx);
  305. err_dma:
  306. return ret;
  307. }
  308. static int pic32_spi_dma_config(struct pic32_spi *pic32s, u32 dma_width)
  309. {
  310. int buf_offset = offsetof(struct pic32_spi_regs, buf);
  311. struct spi_master *master = pic32s->master;
  312. struct dma_slave_config cfg;
  313. int ret;
  314. cfg.device_fc = true;
  315. cfg.src_addr = pic32s->dma_base + buf_offset;
  316. cfg.dst_addr = pic32s->dma_base + buf_offset;
  317. cfg.src_maxburst = pic32s->fifo_n_elm / 2; /* fill one-half */
  318. cfg.dst_maxburst = pic32s->fifo_n_elm / 2; /* drain one-half */
  319. cfg.src_addr_width = dma_width;
  320. cfg.dst_addr_width = dma_width;
  321. /* tx channel */
  322. cfg.slave_id = pic32s->tx_irq;
  323. cfg.direction = DMA_MEM_TO_DEV;
  324. ret = dmaengine_slave_config(master->dma_tx, &cfg);
  325. if (ret) {
  326. dev_err(&master->dev, "tx channel setup failed\n");
  327. return ret;
  328. }
  329. /* rx channel */
  330. cfg.slave_id = pic32s->rx_irq;
  331. cfg.direction = DMA_DEV_TO_MEM;
  332. ret = dmaengine_slave_config(master->dma_rx, &cfg);
  333. if (ret)
  334. dev_err(&master->dev, "rx channel setup failed\n");
  335. return ret;
  336. }
  337. static int pic32_spi_set_word_size(struct pic32_spi *pic32s, u8 bits_per_word)
  338. {
  339. enum dma_slave_buswidth dmawidth;
  340. u32 buswidth, v;
  341. switch (bits_per_word) {
  342. case 8:
  343. pic32s->rx_fifo = pic32_spi_rx_byte;
  344. pic32s->tx_fifo = pic32_spi_tx_byte;
  345. buswidth = PIC32_BPW_8;
  346. dmawidth = DMA_SLAVE_BUSWIDTH_1_BYTE;
  347. break;
  348. case 16:
  349. pic32s->rx_fifo = pic32_spi_rx_word;
  350. pic32s->tx_fifo = pic32_spi_tx_word;
  351. buswidth = PIC32_BPW_16;
  352. dmawidth = DMA_SLAVE_BUSWIDTH_2_BYTES;
  353. break;
  354. case 32:
  355. pic32s->rx_fifo = pic32_spi_rx_dword;
  356. pic32s->tx_fifo = pic32_spi_tx_dword;
  357. buswidth = PIC32_BPW_32;
  358. dmawidth = DMA_SLAVE_BUSWIDTH_4_BYTES;
  359. break;
  360. default:
  361. /* not supported */
  362. return -EINVAL;
  363. }
  364. /* calculate maximum number of words fifos can hold */
  365. pic32s->fifo_n_elm = DIV_ROUND_UP(pic32s->fifo_n_byte,
  366. bits_per_word / 8);
  367. /* set word size */
  368. v = readl(&pic32s->regs->ctrl);
  369. v &= ~(CTRL_BPW_MASK << CTRL_BPW_SHIFT);
  370. v |= buswidth << CTRL_BPW_SHIFT;
  371. writel(v, &pic32s->regs->ctrl);
  372. /* re-configure dma width, if required */
  373. if (test_bit(PIC32F_DMA_PREP, &pic32s->flags))
  374. pic32_spi_dma_config(pic32s, dmawidth);
  375. return 0;
  376. }
  377. static int pic32_spi_prepare_hardware(struct spi_master *master)
  378. {
  379. struct pic32_spi *pic32s = spi_master_get_devdata(master);
  380. pic32_spi_enable(pic32s);
  381. return 0;
  382. }
  383. static int pic32_spi_prepare_message(struct spi_master *master,
  384. struct spi_message *msg)
  385. {
  386. struct pic32_spi *pic32s = spi_master_get_devdata(master);
  387. struct spi_device *spi = msg->spi;
  388. u32 val;
  389. /* set device specific bits_per_word */
  390. if (pic32s->bits_per_word != spi->bits_per_word) {
  391. pic32_spi_set_word_size(pic32s, spi->bits_per_word);
  392. pic32s->bits_per_word = spi->bits_per_word;
  393. }
  394. /* device specific speed change */
  395. if (pic32s->speed_hz != spi->max_speed_hz) {
  396. pic32_spi_set_clk_rate(pic32s, spi->max_speed_hz);
  397. pic32s->speed_hz = spi->max_speed_hz;
  398. }
  399. /* device specific mode change */
  400. if (pic32s->mode != spi->mode) {
  401. val = readl(&pic32s->regs->ctrl);
  402. /* active low */
  403. if (spi->mode & SPI_CPOL)
  404. val |= CTRL_CKP;
  405. else
  406. val &= ~CTRL_CKP;
  407. /* tx on rising edge */
  408. if (spi->mode & SPI_CPHA)
  409. val &= ~CTRL_CKE;
  410. else
  411. val |= CTRL_CKE;
  412. /* rx at end of tx */
  413. val |= CTRL_SMP;
  414. writel(val, &pic32s->regs->ctrl);
  415. pic32s->mode = spi->mode;
  416. }
  417. return 0;
  418. }
  419. static bool pic32_spi_can_dma(struct spi_master *master,
  420. struct spi_device *spi,
  421. struct spi_transfer *xfer)
  422. {
  423. struct pic32_spi *pic32s = spi_master_get_devdata(master);
  424. /* skip using DMA on small size transfer to avoid overhead.*/
  425. return (xfer->len >= PIC32_DMA_LEN_MIN) &&
  426. test_bit(PIC32F_DMA_PREP, &pic32s->flags);
  427. }
  428. static int pic32_spi_one_transfer(struct spi_master *master,
  429. struct spi_device *spi,
  430. struct spi_transfer *transfer)
  431. {
  432. struct pic32_spi *pic32s;
  433. bool dma_issued = false;
  434. int ret;
  435. pic32s = spi_master_get_devdata(master);
  436. /* handle transfer specific word size change */
  437. if (transfer->bits_per_word &&
  438. (transfer->bits_per_word != pic32s->bits_per_word)) {
  439. ret = pic32_spi_set_word_size(pic32s, transfer->bits_per_word);
  440. if (ret)
  441. return ret;
  442. pic32s->bits_per_word = transfer->bits_per_word;
  443. }
  444. /* handle transfer specific speed change */
  445. if (transfer->speed_hz && (transfer->speed_hz != pic32s->speed_hz)) {
  446. pic32_spi_set_clk_rate(pic32s, transfer->speed_hz);
  447. pic32s->speed_hz = transfer->speed_hz;
  448. }
  449. reinit_completion(&pic32s->xfer_done);
  450. /* transact by DMA mode */
  451. if (transfer->rx_sg.nents && transfer->tx_sg.nents) {
  452. ret = pic32_spi_dma_transfer(pic32s, transfer);
  453. if (ret) {
  454. dev_err(&spi->dev, "dma submit error\n");
  455. return ret;
  456. }
  457. /* DMA issued */
  458. dma_issued = true;
  459. } else {
  460. /* set current transfer information */
  461. pic32s->tx = (const void *)transfer->tx_buf;
  462. pic32s->rx = (const void *)transfer->rx_buf;
  463. pic32s->tx_end = pic32s->tx + transfer->len;
  464. pic32s->rx_end = pic32s->rx + transfer->len;
  465. pic32s->len = transfer->len;
  466. /* transact by interrupt driven PIO */
  467. enable_irq(pic32s->fault_irq);
  468. enable_irq(pic32s->rx_irq);
  469. enable_irq(pic32s->tx_irq);
  470. }
  471. /* wait for completion */
  472. ret = wait_for_completion_timeout(&pic32s->xfer_done, 2 * HZ);
  473. if (ret <= 0) {
  474. dev_err(&spi->dev, "wait error/timedout\n");
  475. if (dma_issued) {
  476. dmaengine_terminate_all(master->dma_rx);
  477. dmaengine_terminate_all(master->dma_rx);
  478. }
  479. ret = -ETIMEDOUT;
  480. } else {
  481. ret = 0;
  482. }
  483. return ret;
  484. }
  485. static int pic32_spi_unprepare_message(struct spi_master *master,
  486. struct spi_message *msg)
  487. {
  488. /* nothing to do */
  489. return 0;
  490. }
  491. static int pic32_spi_unprepare_hardware(struct spi_master *master)
  492. {
  493. struct pic32_spi *pic32s = spi_master_get_devdata(master);
  494. pic32_spi_disable(pic32s);
  495. return 0;
  496. }
  497. /* This may be called multiple times by same spi dev */
  498. static int pic32_spi_setup(struct spi_device *spi)
  499. {
  500. if (!spi->max_speed_hz) {
  501. dev_err(&spi->dev, "No max speed HZ parameter\n");
  502. return -EINVAL;
  503. }
  504. /* PIC32 spi controller can drive /CS during transfer depending
  505. * on tx fifo fill-level. /CS will stay asserted as long as TX
  506. * fifo is non-empty, else will be deasserted indicating
  507. * completion of the ongoing transfer. This might result into
  508. * unreliable/erroneous SPI transactions.
  509. * To avoid that we will always handle /CS by toggling GPIO.
  510. */
  511. if (!gpio_is_valid(spi->cs_gpio))
  512. return -EINVAL;
  513. gpio_direction_output(spi->cs_gpio, !(spi->mode & SPI_CS_HIGH));
  514. return 0;
  515. }
  516. static void pic32_spi_cleanup(struct spi_device *spi)
  517. {
  518. /* de-activate cs-gpio */
  519. gpio_direction_output(spi->cs_gpio, !(spi->mode & SPI_CS_HIGH));
  520. }
  521. static void pic32_spi_dma_prep(struct pic32_spi *pic32s, struct device *dev)
  522. {
  523. struct spi_master *master = pic32s->master;
  524. dma_cap_mask_t mask;
  525. dma_cap_zero(mask);
  526. dma_cap_set(DMA_SLAVE, mask);
  527. master->dma_rx = dma_request_slave_channel_compat(mask, NULL, NULL,
  528. dev, "spi-rx");
  529. if (!master->dma_rx) {
  530. dev_warn(dev, "RX channel not found.\n");
  531. goto out_err;
  532. }
  533. master->dma_tx = dma_request_slave_channel_compat(mask, NULL, NULL,
  534. dev, "spi-tx");
  535. if (!master->dma_tx) {
  536. dev_warn(dev, "TX channel not found.\n");
  537. goto out_err;
  538. }
  539. if (pic32_spi_dma_config(pic32s, DMA_SLAVE_BUSWIDTH_1_BYTE))
  540. goto out_err;
  541. /* DMA chnls allocated and prepared */
  542. set_bit(PIC32F_DMA_PREP, &pic32s->flags);
  543. return;
  544. out_err:
  545. if (master->dma_rx)
  546. dma_release_channel(master->dma_rx);
  547. if (master->dma_tx)
  548. dma_release_channel(master->dma_tx);
  549. }
  550. static void pic32_spi_dma_unprep(struct pic32_spi *pic32s)
  551. {
  552. if (!test_bit(PIC32F_DMA_PREP, &pic32s->flags))
  553. return;
  554. clear_bit(PIC32F_DMA_PREP, &pic32s->flags);
  555. if (pic32s->master->dma_rx)
  556. dma_release_channel(pic32s->master->dma_rx);
  557. if (pic32s->master->dma_tx)
  558. dma_release_channel(pic32s->master->dma_tx);
  559. }
  560. static void pic32_spi_hw_init(struct pic32_spi *pic32s)
  561. {
  562. u32 ctrl;
  563. /* disable hardware */
  564. pic32_spi_disable(pic32s);
  565. ctrl = readl(&pic32s->regs->ctrl);
  566. /* enable enhanced fifo of 128bit deep */
  567. ctrl |= CTRL_ENHBUF;
  568. pic32s->fifo_n_byte = 16;
  569. /* disable framing mode */
  570. ctrl &= ~CTRL_FRMEN;
  571. /* enable master mode while disabled */
  572. ctrl |= CTRL_MSTEN;
  573. /* set tx fifo threshold interrupt */
  574. ctrl &= ~(0x3 << CTRL_TX_INT_SHIFT);
  575. ctrl |= (TX_FIFO_HALF_EMPTY << CTRL_TX_INT_SHIFT);
  576. /* set rx fifo threshold interrupt */
  577. ctrl &= ~(0x3 << CTRL_RX_INT_SHIFT);
  578. ctrl |= (RX_FIFO_NOT_EMPTY << CTRL_RX_INT_SHIFT);
  579. /* select clk source */
  580. ctrl &= ~CTRL_MCLKSEL;
  581. /* set manual /CS mode */
  582. ctrl &= ~CTRL_MSSEN;
  583. writel(ctrl, &pic32s->regs->ctrl);
  584. /* enable error reporting */
  585. ctrl = CTRL2_TX_UR_EN | CTRL2_RX_OV_EN | CTRL2_FRM_ERR_EN;
  586. writel(ctrl, &pic32s->regs->ctrl2_set);
  587. }
  588. static int pic32_spi_hw_probe(struct platform_device *pdev,
  589. struct pic32_spi *pic32s)
  590. {
  591. struct resource *mem;
  592. int ret;
  593. mem = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  594. pic32s->regs = devm_ioremap_resource(&pdev->dev, mem);
  595. if (IS_ERR(pic32s->regs))
  596. return PTR_ERR(pic32s->regs);
  597. pic32s->dma_base = mem->start;
  598. /* get irq resources: err-irq, rx-irq, tx-irq */
  599. pic32s->fault_irq = platform_get_irq_byname(pdev, "fault");
  600. if (pic32s->fault_irq < 0) {
  601. dev_err(&pdev->dev, "fault-irq not found\n");
  602. return pic32s->fault_irq;
  603. }
  604. pic32s->rx_irq = platform_get_irq_byname(pdev, "rx");
  605. if (pic32s->rx_irq < 0) {
  606. dev_err(&pdev->dev, "rx-irq not found\n");
  607. return pic32s->rx_irq;
  608. }
  609. pic32s->tx_irq = platform_get_irq_byname(pdev, "tx");
  610. if (pic32s->tx_irq < 0) {
  611. dev_err(&pdev->dev, "tx-irq not found\n");
  612. return pic32s->tx_irq;
  613. }
  614. /* get clock */
  615. pic32s->clk = devm_clk_get(&pdev->dev, "mck0");
  616. if (IS_ERR(pic32s->clk)) {
  617. dev_err(&pdev->dev, "clk not found\n");
  618. ret = PTR_ERR(pic32s->clk);
  619. goto err_unmap_mem;
  620. }
  621. ret = clk_prepare_enable(pic32s->clk);
  622. if (ret)
  623. goto err_unmap_mem;
  624. pic32_spi_hw_init(pic32s);
  625. return 0;
  626. err_unmap_mem:
  627. dev_err(&pdev->dev, "%s failed, err %d\n", __func__, ret);
  628. return ret;
  629. }
  630. static int pic32_spi_probe(struct platform_device *pdev)
  631. {
  632. struct spi_master *master;
  633. struct pic32_spi *pic32s;
  634. int ret;
  635. master = spi_alloc_master(&pdev->dev, sizeof(*pic32s));
  636. if (!master)
  637. return -ENOMEM;
  638. pic32s = spi_master_get_devdata(master);
  639. pic32s->master = master;
  640. ret = pic32_spi_hw_probe(pdev, pic32s);
  641. if (ret)
  642. goto err_master;
  643. master->dev.of_node = of_node_get(pdev->dev.of_node);
  644. master->mode_bits = SPI_MODE_3 | SPI_MODE_0 | SPI_CS_HIGH;
  645. master->num_chipselect = 1; /* single chip-select */
  646. master->max_speed_hz = clk_get_rate(pic32s->clk);
  647. master->setup = pic32_spi_setup;
  648. master->cleanup = pic32_spi_cleanup;
  649. master->flags = SPI_MASTER_MUST_TX | SPI_MASTER_MUST_RX;
  650. master->bits_per_word_mask = SPI_BPW_MASK(8) | SPI_BPW_MASK(16) |
  651. SPI_BPW_MASK(32);
  652. master->transfer_one = pic32_spi_one_transfer;
  653. master->prepare_message = pic32_spi_prepare_message;
  654. master->unprepare_message = pic32_spi_unprepare_message;
  655. master->prepare_transfer_hardware = pic32_spi_prepare_hardware;
  656. master->unprepare_transfer_hardware = pic32_spi_unprepare_hardware;
  657. /* optional DMA support */
  658. pic32_spi_dma_prep(pic32s, &pdev->dev);
  659. if (test_bit(PIC32F_DMA_PREP, &pic32s->flags))
  660. master->can_dma = pic32_spi_can_dma;
  661. init_completion(&pic32s->xfer_done);
  662. pic32s->mode = -1;
  663. /* install irq handlers (with irq-disabled) */
  664. irq_set_status_flags(pic32s->fault_irq, IRQ_NOAUTOEN);
  665. ret = devm_request_irq(&pdev->dev, pic32s->fault_irq,
  666. pic32_spi_fault_irq, IRQF_NO_THREAD,
  667. dev_name(&pdev->dev), pic32s);
  668. if (ret < 0) {
  669. dev_err(&pdev->dev, "request fault-irq %d\n", pic32s->rx_irq);
  670. goto err_bailout;
  671. }
  672. /* receive interrupt handler */
  673. irq_set_status_flags(pic32s->rx_irq, IRQ_NOAUTOEN);
  674. ret = devm_request_irq(&pdev->dev, pic32s->rx_irq,
  675. pic32_spi_rx_irq, IRQF_NO_THREAD,
  676. dev_name(&pdev->dev), pic32s);
  677. if (ret < 0) {
  678. dev_err(&pdev->dev, "request rx-irq %d\n", pic32s->rx_irq);
  679. goto err_bailout;
  680. }
  681. /* transmit interrupt handler */
  682. irq_set_status_flags(pic32s->tx_irq, IRQ_NOAUTOEN);
  683. ret = devm_request_irq(&pdev->dev, pic32s->tx_irq,
  684. pic32_spi_tx_irq, IRQF_NO_THREAD,
  685. dev_name(&pdev->dev), pic32s);
  686. if (ret < 0) {
  687. dev_err(&pdev->dev, "request tx-irq %d\n", pic32s->tx_irq);
  688. goto err_bailout;
  689. }
  690. /* register master */
  691. ret = devm_spi_register_master(&pdev->dev, master);
  692. if (ret) {
  693. dev_err(&master->dev, "failed registering spi master\n");
  694. goto err_bailout;
  695. }
  696. platform_set_drvdata(pdev, pic32s);
  697. return 0;
  698. err_bailout:
  699. clk_disable_unprepare(pic32s->clk);
  700. err_master:
  701. spi_master_put(master);
  702. return ret;
  703. }
  704. static int pic32_spi_remove(struct platform_device *pdev)
  705. {
  706. struct pic32_spi *pic32s;
  707. pic32s = platform_get_drvdata(pdev);
  708. pic32_spi_disable(pic32s);
  709. clk_disable_unprepare(pic32s->clk);
  710. pic32_spi_dma_unprep(pic32s);
  711. return 0;
  712. }
  713. static const struct of_device_id pic32_spi_of_match[] = {
  714. {.compatible = "microchip,pic32mzda-spi",},
  715. {},
  716. };
  717. MODULE_DEVICE_TABLE(of, pic32_spi_of_match);
  718. static struct platform_driver pic32_spi_driver = {
  719. .driver = {
  720. .name = "spi-pic32",
  721. .of_match_table = of_match_ptr(pic32_spi_of_match),
  722. },
  723. .probe = pic32_spi_probe,
  724. .remove = pic32_spi_remove,
  725. };
  726. module_platform_driver(pic32_spi_driver);
  727. MODULE_AUTHOR("Purna Chandra Mandal <purna.mandal@microchip.com>");
  728. MODULE_DESCRIPTION("Microchip SPI driver for PIC32 SPI controller.");
  729. MODULE_LICENSE("GPL v2");