spi-qup.c 27 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066
  1. /*
  2. * Copyright (c) 2008-2014, The Linux foundation. All rights reserved.
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License rev 2 and
  6. * only rev 2 as published by the free Software foundation.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or fITNESS fOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. */
  13. #include <linux/clk.h>
  14. #include <linux/delay.h>
  15. #include <linux/err.h>
  16. #include <linux/interrupt.h>
  17. #include <linux/io.h>
  18. #include <linux/list.h>
  19. #include <linux/module.h>
  20. #include <linux/of.h>
  21. #include <linux/platform_device.h>
  22. #include <linux/pm_runtime.h>
  23. #include <linux/spi/spi.h>
  24. #include <linux/dmaengine.h>
  25. #include <linux/dma-mapping.h>
  26. #define QUP_CONFIG 0x0000
  27. #define QUP_STATE 0x0004
  28. #define QUP_IO_M_MODES 0x0008
  29. #define QUP_SW_RESET 0x000c
  30. #define QUP_OPERATIONAL 0x0018
  31. #define QUP_ERROR_FLAGS 0x001c
  32. #define QUP_ERROR_FLAGS_EN 0x0020
  33. #define QUP_OPERATIONAL_MASK 0x0028
  34. #define QUP_HW_VERSION 0x0030
  35. #define QUP_MX_OUTPUT_CNT 0x0100
  36. #define QUP_OUTPUT_FIFO 0x0110
  37. #define QUP_MX_WRITE_CNT 0x0150
  38. #define QUP_MX_INPUT_CNT 0x0200
  39. #define QUP_MX_READ_CNT 0x0208
  40. #define QUP_INPUT_FIFO 0x0218
  41. #define SPI_CONFIG 0x0300
  42. #define SPI_IO_CONTROL 0x0304
  43. #define SPI_ERROR_FLAGS 0x0308
  44. #define SPI_ERROR_FLAGS_EN 0x030c
  45. /* QUP_CONFIG fields */
  46. #define QUP_CONFIG_SPI_MODE (1 << 8)
  47. #define QUP_CONFIG_CLOCK_AUTO_GATE BIT(13)
  48. #define QUP_CONFIG_NO_INPUT BIT(7)
  49. #define QUP_CONFIG_NO_OUTPUT BIT(6)
  50. #define QUP_CONFIG_N 0x001f
  51. /* QUP_STATE fields */
  52. #define QUP_STATE_VALID BIT(2)
  53. #define QUP_STATE_RESET 0
  54. #define QUP_STATE_RUN 1
  55. #define QUP_STATE_PAUSE 3
  56. #define QUP_STATE_MASK 3
  57. #define QUP_STATE_CLEAR 2
  58. #define QUP_HW_VERSION_2_1_1 0x20010001
  59. /* QUP_IO_M_MODES fields */
  60. #define QUP_IO_M_PACK_EN BIT(15)
  61. #define QUP_IO_M_UNPACK_EN BIT(14)
  62. #define QUP_IO_M_INPUT_MODE_MASK_SHIFT 12
  63. #define QUP_IO_M_OUTPUT_MODE_MASK_SHIFT 10
  64. #define QUP_IO_M_INPUT_MODE_MASK (3 << QUP_IO_M_INPUT_MODE_MASK_SHIFT)
  65. #define QUP_IO_M_OUTPUT_MODE_MASK (3 << QUP_IO_M_OUTPUT_MODE_MASK_SHIFT)
  66. #define QUP_IO_M_OUTPUT_BLOCK_SIZE(x) (((x) & (0x03 << 0)) >> 0)
  67. #define QUP_IO_M_OUTPUT_FIFO_SIZE(x) (((x) & (0x07 << 2)) >> 2)
  68. #define QUP_IO_M_INPUT_BLOCK_SIZE(x) (((x) & (0x03 << 5)) >> 5)
  69. #define QUP_IO_M_INPUT_FIFO_SIZE(x) (((x) & (0x07 << 7)) >> 7)
  70. #define QUP_IO_M_MODE_FIFO 0
  71. #define QUP_IO_M_MODE_BLOCK 1
  72. #define QUP_IO_M_MODE_DMOV 2
  73. #define QUP_IO_M_MODE_BAM 3
  74. /* QUP_OPERATIONAL fields */
  75. #define QUP_OP_MAX_INPUT_DONE_FLAG BIT(11)
  76. #define QUP_OP_MAX_OUTPUT_DONE_FLAG BIT(10)
  77. #define QUP_OP_IN_SERVICE_FLAG BIT(9)
  78. #define QUP_OP_OUT_SERVICE_FLAG BIT(8)
  79. #define QUP_OP_IN_FIFO_FULL BIT(7)
  80. #define QUP_OP_OUT_FIFO_FULL BIT(6)
  81. #define QUP_OP_IN_FIFO_NOT_EMPTY BIT(5)
  82. #define QUP_OP_OUT_FIFO_NOT_EMPTY BIT(4)
  83. /* QUP_ERROR_FLAGS and QUP_ERROR_FLAGS_EN fields */
  84. #define QUP_ERROR_OUTPUT_OVER_RUN BIT(5)
  85. #define QUP_ERROR_INPUT_UNDER_RUN BIT(4)
  86. #define QUP_ERROR_OUTPUT_UNDER_RUN BIT(3)
  87. #define QUP_ERROR_INPUT_OVER_RUN BIT(2)
  88. /* SPI_CONFIG fields */
  89. #define SPI_CONFIG_HS_MODE BIT(10)
  90. #define SPI_CONFIG_INPUT_FIRST BIT(9)
  91. #define SPI_CONFIG_LOOPBACK BIT(8)
  92. /* SPI_IO_CONTROL fields */
  93. #define SPI_IO_C_FORCE_CS BIT(11)
  94. #define SPI_IO_C_CLK_IDLE_HIGH BIT(10)
  95. #define SPI_IO_C_MX_CS_MODE BIT(8)
  96. #define SPI_IO_C_CS_N_POLARITY_0 BIT(4)
  97. #define SPI_IO_C_CS_SELECT(x) (((x) & 3) << 2)
  98. #define SPI_IO_C_CS_SELECT_MASK 0x000c
  99. #define SPI_IO_C_TRISTATE_CS BIT(1)
  100. #define SPI_IO_C_NO_TRI_STATE BIT(0)
  101. /* SPI_ERROR_FLAGS and SPI_ERROR_FLAGS_EN fields */
  102. #define SPI_ERROR_CLK_OVER_RUN BIT(1)
  103. #define SPI_ERROR_CLK_UNDER_RUN BIT(0)
  104. #define SPI_NUM_CHIPSELECTS 4
  105. #define SPI_MAX_DMA_XFER (SZ_64K - 64)
  106. /* high speed mode is when bus rate is greater then 26MHz */
  107. #define SPI_HS_MIN_RATE 26000000
  108. #define SPI_MAX_RATE 50000000
  109. #define SPI_DELAY_THRESHOLD 1
  110. #define SPI_DELAY_RETRY 10
  111. struct spi_qup {
  112. void __iomem *base;
  113. struct device *dev;
  114. struct clk *cclk; /* core clock */
  115. struct clk *iclk; /* interface clock */
  116. int irq;
  117. spinlock_t lock;
  118. int in_fifo_sz;
  119. int out_fifo_sz;
  120. int in_blk_sz;
  121. int out_blk_sz;
  122. struct spi_transfer *xfer;
  123. struct completion done;
  124. int error;
  125. int w_size; /* bytes per SPI word */
  126. int n_words;
  127. int tx_bytes;
  128. int rx_bytes;
  129. int qup_v1;
  130. int use_dma;
  131. struct dma_slave_config rx_conf;
  132. struct dma_slave_config tx_conf;
  133. };
  134. static inline bool spi_qup_is_valid_state(struct spi_qup *controller)
  135. {
  136. u32 opstate = readl_relaxed(controller->base + QUP_STATE);
  137. return opstate & QUP_STATE_VALID;
  138. }
  139. static int spi_qup_set_state(struct spi_qup *controller, u32 state)
  140. {
  141. unsigned long loop;
  142. u32 cur_state;
  143. loop = 0;
  144. while (!spi_qup_is_valid_state(controller)) {
  145. usleep_range(SPI_DELAY_THRESHOLD, SPI_DELAY_THRESHOLD * 2);
  146. if (++loop > SPI_DELAY_RETRY)
  147. return -EIO;
  148. }
  149. if (loop)
  150. dev_dbg(controller->dev, "invalid state for %ld,us %d\n",
  151. loop, state);
  152. cur_state = readl_relaxed(controller->base + QUP_STATE);
  153. /*
  154. * Per spec: for PAUSE_STATE to RESET_STATE, two writes
  155. * of (b10) are required
  156. */
  157. if (((cur_state & QUP_STATE_MASK) == QUP_STATE_PAUSE) &&
  158. (state == QUP_STATE_RESET)) {
  159. writel_relaxed(QUP_STATE_CLEAR, controller->base + QUP_STATE);
  160. writel_relaxed(QUP_STATE_CLEAR, controller->base + QUP_STATE);
  161. } else {
  162. cur_state &= ~QUP_STATE_MASK;
  163. cur_state |= state;
  164. writel_relaxed(cur_state, controller->base + QUP_STATE);
  165. }
  166. loop = 0;
  167. while (!spi_qup_is_valid_state(controller)) {
  168. usleep_range(SPI_DELAY_THRESHOLD, SPI_DELAY_THRESHOLD * 2);
  169. if (++loop > SPI_DELAY_RETRY)
  170. return -EIO;
  171. }
  172. return 0;
  173. }
  174. static void spi_qup_fifo_read(struct spi_qup *controller,
  175. struct spi_transfer *xfer)
  176. {
  177. u8 *rx_buf = xfer->rx_buf;
  178. u32 word, state;
  179. int idx, shift, w_size;
  180. w_size = controller->w_size;
  181. while (controller->rx_bytes < xfer->len) {
  182. state = readl_relaxed(controller->base + QUP_OPERATIONAL);
  183. if (0 == (state & QUP_OP_IN_FIFO_NOT_EMPTY))
  184. break;
  185. word = readl_relaxed(controller->base + QUP_INPUT_FIFO);
  186. if (!rx_buf) {
  187. controller->rx_bytes += w_size;
  188. continue;
  189. }
  190. for (idx = 0; idx < w_size; idx++, controller->rx_bytes++) {
  191. /*
  192. * The data format depends on bytes per SPI word:
  193. * 4 bytes: 0x12345678
  194. * 2 bytes: 0x00001234
  195. * 1 byte : 0x00000012
  196. */
  197. shift = BITS_PER_BYTE;
  198. shift *= (w_size - idx - 1);
  199. rx_buf[controller->rx_bytes] = word >> shift;
  200. }
  201. }
  202. }
  203. static void spi_qup_fifo_write(struct spi_qup *controller,
  204. struct spi_transfer *xfer)
  205. {
  206. const u8 *tx_buf = xfer->tx_buf;
  207. u32 word, state, data;
  208. int idx, w_size;
  209. w_size = controller->w_size;
  210. while (controller->tx_bytes < xfer->len) {
  211. state = readl_relaxed(controller->base + QUP_OPERATIONAL);
  212. if (state & QUP_OP_OUT_FIFO_FULL)
  213. break;
  214. word = 0;
  215. for (idx = 0; idx < w_size; idx++, controller->tx_bytes++) {
  216. if (!tx_buf) {
  217. controller->tx_bytes += w_size;
  218. break;
  219. }
  220. data = tx_buf[controller->tx_bytes];
  221. word |= data << (BITS_PER_BYTE * (3 - idx));
  222. }
  223. writel_relaxed(word, controller->base + QUP_OUTPUT_FIFO);
  224. }
  225. }
  226. static void spi_qup_dma_done(void *data)
  227. {
  228. struct spi_qup *qup = data;
  229. complete(&qup->done);
  230. }
  231. static int spi_qup_prep_sg(struct spi_master *master, struct spi_transfer *xfer,
  232. enum dma_transfer_direction dir,
  233. dma_async_tx_callback callback)
  234. {
  235. struct spi_qup *qup = spi_master_get_devdata(master);
  236. unsigned long flags = DMA_PREP_INTERRUPT | DMA_PREP_FENCE;
  237. struct dma_async_tx_descriptor *desc;
  238. struct scatterlist *sgl;
  239. struct dma_chan *chan;
  240. dma_cookie_t cookie;
  241. unsigned int nents;
  242. if (dir == DMA_MEM_TO_DEV) {
  243. chan = master->dma_tx;
  244. nents = xfer->tx_sg.nents;
  245. sgl = xfer->tx_sg.sgl;
  246. } else {
  247. chan = master->dma_rx;
  248. nents = xfer->rx_sg.nents;
  249. sgl = xfer->rx_sg.sgl;
  250. }
  251. desc = dmaengine_prep_slave_sg(chan, sgl, nents, dir, flags);
  252. if (!desc)
  253. return -EINVAL;
  254. desc->callback = callback;
  255. desc->callback_param = qup;
  256. cookie = dmaengine_submit(desc);
  257. return dma_submit_error(cookie);
  258. }
  259. static void spi_qup_dma_terminate(struct spi_master *master,
  260. struct spi_transfer *xfer)
  261. {
  262. if (xfer->tx_buf)
  263. dmaengine_terminate_all(master->dma_tx);
  264. if (xfer->rx_buf)
  265. dmaengine_terminate_all(master->dma_rx);
  266. }
  267. static int spi_qup_do_dma(struct spi_master *master, struct spi_transfer *xfer)
  268. {
  269. dma_async_tx_callback rx_done = NULL, tx_done = NULL;
  270. int ret;
  271. if (xfer->rx_buf)
  272. rx_done = spi_qup_dma_done;
  273. else if (xfer->tx_buf)
  274. tx_done = spi_qup_dma_done;
  275. if (xfer->rx_buf) {
  276. ret = spi_qup_prep_sg(master, xfer, DMA_DEV_TO_MEM, rx_done);
  277. if (ret)
  278. return ret;
  279. dma_async_issue_pending(master->dma_rx);
  280. }
  281. if (xfer->tx_buf) {
  282. ret = spi_qup_prep_sg(master, xfer, DMA_MEM_TO_DEV, tx_done);
  283. if (ret)
  284. return ret;
  285. dma_async_issue_pending(master->dma_tx);
  286. }
  287. return 0;
  288. }
  289. static int spi_qup_do_pio(struct spi_master *master, struct spi_transfer *xfer)
  290. {
  291. struct spi_qup *qup = spi_master_get_devdata(master);
  292. int ret;
  293. ret = spi_qup_set_state(qup, QUP_STATE_RUN);
  294. if (ret) {
  295. dev_warn(qup->dev, "cannot set RUN state\n");
  296. return ret;
  297. }
  298. ret = spi_qup_set_state(qup, QUP_STATE_PAUSE);
  299. if (ret) {
  300. dev_warn(qup->dev, "cannot set PAUSE state\n");
  301. return ret;
  302. }
  303. spi_qup_fifo_write(qup, xfer);
  304. return 0;
  305. }
  306. static irqreturn_t spi_qup_qup_irq(int irq, void *dev_id)
  307. {
  308. struct spi_qup *controller = dev_id;
  309. struct spi_transfer *xfer;
  310. u32 opflags, qup_err, spi_err;
  311. unsigned long flags;
  312. int error = 0;
  313. spin_lock_irqsave(&controller->lock, flags);
  314. xfer = controller->xfer;
  315. controller->xfer = NULL;
  316. spin_unlock_irqrestore(&controller->lock, flags);
  317. qup_err = readl_relaxed(controller->base + QUP_ERROR_FLAGS);
  318. spi_err = readl_relaxed(controller->base + SPI_ERROR_FLAGS);
  319. opflags = readl_relaxed(controller->base + QUP_OPERATIONAL);
  320. writel_relaxed(qup_err, controller->base + QUP_ERROR_FLAGS);
  321. writel_relaxed(spi_err, controller->base + SPI_ERROR_FLAGS);
  322. writel_relaxed(opflags, controller->base + QUP_OPERATIONAL);
  323. if (!xfer) {
  324. dev_err_ratelimited(controller->dev, "unexpected irq %08x %08x %08x\n",
  325. qup_err, spi_err, opflags);
  326. return IRQ_HANDLED;
  327. }
  328. if (qup_err) {
  329. if (qup_err & QUP_ERROR_OUTPUT_OVER_RUN)
  330. dev_warn(controller->dev, "OUTPUT_OVER_RUN\n");
  331. if (qup_err & QUP_ERROR_INPUT_UNDER_RUN)
  332. dev_warn(controller->dev, "INPUT_UNDER_RUN\n");
  333. if (qup_err & QUP_ERROR_OUTPUT_UNDER_RUN)
  334. dev_warn(controller->dev, "OUTPUT_UNDER_RUN\n");
  335. if (qup_err & QUP_ERROR_INPUT_OVER_RUN)
  336. dev_warn(controller->dev, "INPUT_OVER_RUN\n");
  337. error = -EIO;
  338. }
  339. if (spi_err) {
  340. if (spi_err & SPI_ERROR_CLK_OVER_RUN)
  341. dev_warn(controller->dev, "CLK_OVER_RUN\n");
  342. if (spi_err & SPI_ERROR_CLK_UNDER_RUN)
  343. dev_warn(controller->dev, "CLK_UNDER_RUN\n");
  344. error = -EIO;
  345. }
  346. if (!controller->use_dma) {
  347. if (opflags & QUP_OP_IN_SERVICE_FLAG)
  348. spi_qup_fifo_read(controller, xfer);
  349. if (opflags & QUP_OP_OUT_SERVICE_FLAG)
  350. spi_qup_fifo_write(controller, xfer);
  351. }
  352. spin_lock_irqsave(&controller->lock, flags);
  353. controller->error = error;
  354. controller->xfer = xfer;
  355. spin_unlock_irqrestore(&controller->lock, flags);
  356. if (controller->rx_bytes == xfer->len || error)
  357. complete(&controller->done);
  358. return IRQ_HANDLED;
  359. }
  360. static u32
  361. spi_qup_get_mode(struct spi_master *master, struct spi_transfer *xfer)
  362. {
  363. struct spi_qup *qup = spi_master_get_devdata(master);
  364. u32 mode;
  365. qup->w_size = 4;
  366. if (xfer->bits_per_word <= 8)
  367. qup->w_size = 1;
  368. else if (xfer->bits_per_word <= 16)
  369. qup->w_size = 2;
  370. qup->n_words = xfer->len / qup->w_size;
  371. if (qup->n_words <= (qup->in_fifo_sz / sizeof(u32)))
  372. mode = QUP_IO_M_MODE_FIFO;
  373. else
  374. mode = QUP_IO_M_MODE_BLOCK;
  375. return mode;
  376. }
  377. /* set clock freq ... bits per word */
  378. static int spi_qup_io_config(struct spi_device *spi, struct spi_transfer *xfer)
  379. {
  380. struct spi_qup *controller = spi_master_get_devdata(spi->master);
  381. u32 config, iomode, mode, control;
  382. int ret, n_words;
  383. if (spi->mode & SPI_LOOP && xfer->len > controller->in_fifo_sz) {
  384. dev_err(controller->dev, "too big size for loopback %d > %d\n",
  385. xfer->len, controller->in_fifo_sz);
  386. return -EIO;
  387. }
  388. ret = clk_set_rate(controller->cclk, xfer->speed_hz);
  389. if (ret) {
  390. dev_err(controller->dev, "fail to set frequency %d",
  391. xfer->speed_hz);
  392. return -EIO;
  393. }
  394. if (spi_qup_set_state(controller, QUP_STATE_RESET)) {
  395. dev_err(controller->dev, "cannot set RESET state\n");
  396. return -EIO;
  397. }
  398. mode = spi_qup_get_mode(spi->master, xfer);
  399. n_words = controller->n_words;
  400. if (mode == QUP_IO_M_MODE_FIFO) {
  401. writel_relaxed(n_words, controller->base + QUP_MX_READ_CNT);
  402. writel_relaxed(n_words, controller->base + QUP_MX_WRITE_CNT);
  403. /* must be zero for FIFO */
  404. writel_relaxed(0, controller->base + QUP_MX_INPUT_CNT);
  405. writel_relaxed(0, controller->base + QUP_MX_OUTPUT_CNT);
  406. } else if (!controller->use_dma) {
  407. writel_relaxed(n_words, controller->base + QUP_MX_INPUT_CNT);
  408. writel_relaxed(n_words, controller->base + QUP_MX_OUTPUT_CNT);
  409. /* must be zero for BLOCK and BAM */
  410. writel_relaxed(0, controller->base + QUP_MX_READ_CNT);
  411. writel_relaxed(0, controller->base + QUP_MX_WRITE_CNT);
  412. } else {
  413. mode = QUP_IO_M_MODE_BAM;
  414. writel_relaxed(0, controller->base + QUP_MX_READ_CNT);
  415. writel_relaxed(0, controller->base + QUP_MX_WRITE_CNT);
  416. if (!controller->qup_v1) {
  417. void __iomem *input_cnt;
  418. input_cnt = controller->base + QUP_MX_INPUT_CNT;
  419. /*
  420. * for DMA transfers, both QUP_MX_INPUT_CNT and
  421. * QUP_MX_OUTPUT_CNT must be zero to all cases but one.
  422. * That case is a non-balanced transfer when there is
  423. * only a rx_buf.
  424. */
  425. if (xfer->tx_buf)
  426. writel_relaxed(0, input_cnt);
  427. else
  428. writel_relaxed(n_words, input_cnt);
  429. writel_relaxed(0, controller->base + QUP_MX_OUTPUT_CNT);
  430. }
  431. }
  432. iomode = readl_relaxed(controller->base + QUP_IO_M_MODES);
  433. /* Set input and output transfer mode */
  434. iomode &= ~(QUP_IO_M_INPUT_MODE_MASK | QUP_IO_M_OUTPUT_MODE_MASK);
  435. if (!controller->use_dma)
  436. iomode &= ~(QUP_IO_M_PACK_EN | QUP_IO_M_UNPACK_EN);
  437. else
  438. iomode |= QUP_IO_M_PACK_EN | QUP_IO_M_UNPACK_EN;
  439. iomode |= (mode << QUP_IO_M_OUTPUT_MODE_MASK_SHIFT);
  440. iomode |= (mode << QUP_IO_M_INPUT_MODE_MASK_SHIFT);
  441. writel_relaxed(iomode, controller->base + QUP_IO_M_MODES);
  442. control = readl_relaxed(controller->base + SPI_IO_CONTROL);
  443. if (spi->mode & SPI_CPOL)
  444. control |= SPI_IO_C_CLK_IDLE_HIGH;
  445. else
  446. control &= ~SPI_IO_C_CLK_IDLE_HIGH;
  447. writel_relaxed(control, controller->base + SPI_IO_CONTROL);
  448. config = readl_relaxed(controller->base + SPI_CONFIG);
  449. if (spi->mode & SPI_LOOP)
  450. config |= SPI_CONFIG_LOOPBACK;
  451. else
  452. config &= ~SPI_CONFIG_LOOPBACK;
  453. if (spi->mode & SPI_CPHA)
  454. config &= ~SPI_CONFIG_INPUT_FIRST;
  455. else
  456. config |= SPI_CONFIG_INPUT_FIRST;
  457. /*
  458. * HS_MODE improves signal stability for spi-clk high rates,
  459. * but is invalid in loop back mode.
  460. */
  461. if ((xfer->speed_hz >= SPI_HS_MIN_RATE) && !(spi->mode & SPI_LOOP))
  462. config |= SPI_CONFIG_HS_MODE;
  463. else
  464. config &= ~SPI_CONFIG_HS_MODE;
  465. writel_relaxed(config, controller->base + SPI_CONFIG);
  466. config = readl_relaxed(controller->base + QUP_CONFIG);
  467. config &= ~(QUP_CONFIG_NO_INPUT | QUP_CONFIG_NO_OUTPUT | QUP_CONFIG_N);
  468. config |= xfer->bits_per_word - 1;
  469. config |= QUP_CONFIG_SPI_MODE;
  470. if (controller->use_dma) {
  471. if (!xfer->tx_buf)
  472. config |= QUP_CONFIG_NO_OUTPUT;
  473. if (!xfer->rx_buf)
  474. config |= QUP_CONFIG_NO_INPUT;
  475. }
  476. writel_relaxed(config, controller->base + QUP_CONFIG);
  477. /* only write to OPERATIONAL_MASK when register is present */
  478. if (!controller->qup_v1) {
  479. u32 mask = 0;
  480. /*
  481. * mask INPUT and OUTPUT service flags to prevent IRQs on FIFO
  482. * status change in BAM mode
  483. */
  484. if (mode == QUP_IO_M_MODE_BAM)
  485. mask = QUP_OP_IN_SERVICE_FLAG | QUP_OP_OUT_SERVICE_FLAG;
  486. writel_relaxed(mask, controller->base + QUP_OPERATIONAL_MASK);
  487. }
  488. return 0;
  489. }
  490. static int spi_qup_transfer_one(struct spi_master *master,
  491. struct spi_device *spi,
  492. struct spi_transfer *xfer)
  493. {
  494. struct spi_qup *controller = spi_master_get_devdata(master);
  495. unsigned long timeout, flags;
  496. int ret = -EIO;
  497. ret = spi_qup_io_config(spi, xfer);
  498. if (ret)
  499. return ret;
  500. timeout = DIV_ROUND_UP(xfer->speed_hz, MSEC_PER_SEC);
  501. timeout = DIV_ROUND_UP(xfer->len * 8, timeout);
  502. timeout = 100 * msecs_to_jiffies(timeout);
  503. reinit_completion(&controller->done);
  504. spin_lock_irqsave(&controller->lock, flags);
  505. controller->xfer = xfer;
  506. controller->error = 0;
  507. controller->rx_bytes = 0;
  508. controller->tx_bytes = 0;
  509. spin_unlock_irqrestore(&controller->lock, flags);
  510. if (controller->use_dma)
  511. ret = spi_qup_do_dma(master, xfer);
  512. else
  513. ret = spi_qup_do_pio(master, xfer);
  514. if (ret)
  515. goto exit;
  516. if (spi_qup_set_state(controller, QUP_STATE_RUN)) {
  517. dev_warn(controller->dev, "cannot set EXECUTE state\n");
  518. goto exit;
  519. }
  520. if (!wait_for_completion_timeout(&controller->done, timeout))
  521. ret = -ETIMEDOUT;
  522. exit:
  523. spi_qup_set_state(controller, QUP_STATE_RESET);
  524. spin_lock_irqsave(&controller->lock, flags);
  525. controller->xfer = NULL;
  526. if (!ret)
  527. ret = controller->error;
  528. spin_unlock_irqrestore(&controller->lock, flags);
  529. if (ret && controller->use_dma)
  530. spi_qup_dma_terminate(master, xfer);
  531. return ret;
  532. }
  533. static bool spi_qup_can_dma(struct spi_master *master, struct spi_device *spi,
  534. struct spi_transfer *xfer)
  535. {
  536. struct spi_qup *qup = spi_master_get_devdata(master);
  537. size_t dma_align = dma_get_cache_alignment();
  538. u32 mode;
  539. qup->use_dma = 0;
  540. if (xfer->rx_buf && (xfer->len % qup->in_blk_sz ||
  541. IS_ERR_OR_NULL(master->dma_rx) ||
  542. !IS_ALIGNED((size_t)xfer->rx_buf, dma_align)))
  543. return false;
  544. if (xfer->tx_buf && (xfer->len % qup->out_blk_sz ||
  545. IS_ERR_OR_NULL(master->dma_tx) ||
  546. !IS_ALIGNED((size_t)xfer->tx_buf, dma_align)))
  547. return false;
  548. mode = spi_qup_get_mode(master, xfer);
  549. if (mode == QUP_IO_M_MODE_FIFO)
  550. return false;
  551. qup->use_dma = 1;
  552. return true;
  553. }
  554. static void spi_qup_release_dma(struct spi_master *master)
  555. {
  556. if (!IS_ERR_OR_NULL(master->dma_rx))
  557. dma_release_channel(master->dma_rx);
  558. if (!IS_ERR_OR_NULL(master->dma_tx))
  559. dma_release_channel(master->dma_tx);
  560. }
  561. static int spi_qup_init_dma(struct spi_master *master, resource_size_t base)
  562. {
  563. struct spi_qup *spi = spi_master_get_devdata(master);
  564. struct dma_slave_config *rx_conf = &spi->rx_conf,
  565. *tx_conf = &spi->tx_conf;
  566. struct device *dev = spi->dev;
  567. int ret;
  568. /* allocate dma resources, if available */
  569. master->dma_rx = dma_request_slave_channel_reason(dev, "rx");
  570. if (IS_ERR(master->dma_rx))
  571. return PTR_ERR(master->dma_rx);
  572. master->dma_tx = dma_request_slave_channel_reason(dev, "tx");
  573. if (IS_ERR(master->dma_tx)) {
  574. ret = PTR_ERR(master->dma_tx);
  575. goto err_tx;
  576. }
  577. /* set DMA parameters */
  578. rx_conf->direction = DMA_DEV_TO_MEM;
  579. rx_conf->device_fc = 1;
  580. rx_conf->src_addr = base + QUP_INPUT_FIFO;
  581. rx_conf->src_maxburst = spi->in_blk_sz;
  582. tx_conf->direction = DMA_MEM_TO_DEV;
  583. tx_conf->device_fc = 1;
  584. tx_conf->dst_addr = base + QUP_OUTPUT_FIFO;
  585. tx_conf->dst_maxburst = spi->out_blk_sz;
  586. ret = dmaengine_slave_config(master->dma_rx, rx_conf);
  587. if (ret) {
  588. dev_err(dev, "failed to configure RX channel\n");
  589. goto err;
  590. }
  591. ret = dmaengine_slave_config(master->dma_tx, tx_conf);
  592. if (ret) {
  593. dev_err(dev, "failed to configure TX channel\n");
  594. goto err;
  595. }
  596. return 0;
  597. err:
  598. dma_release_channel(master->dma_tx);
  599. err_tx:
  600. dma_release_channel(master->dma_rx);
  601. return ret;
  602. }
  603. static int spi_qup_probe(struct platform_device *pdev)
  604. {
  605. struct spi_master *master;
  606. struct clk *iclk, *cclk;
  607. struct spi_qup *controller;
  608. struct resource *res;
  609. struct device *dev;
  610. void __iomem *base;
  611. u32 max_freq, iomode, num_cs;
  612. int ret, irq, size;
  613. dev = &pdev->dev;
  614. res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  615. base = devm_ioremap_resource(dev, res);
  616. if (IS_ERR(base))
  617. return PTR_ERR(base);
  618. irq = platform_get_irq(pdev, 0);
  619. if (irq < 0)
  620. return irq;
  621. cclk = devm_clk_get(dev, "core");
  622. if (IS_ERR(cclk))
  623. return PTR_ERR(cclk);
  624. iclk = devm_clk_get(dev, "iface");
  625. if (IS_ERR(iclk))
  626. return PTR_ERR(iclk);
  627. /* This is optional parameter */
  628. if (of_property_read_u32(dev->of_node, "spi-max-frequency", &max_freq))
  629. max_freq = SPI_MAX_RATE;
  630. if (!max_freq || max_freq > SPI_MAX_RATE) {
  631. dev_err(dev, "invalid clock frequency %d\n", max_freq);
  632. return -ENXIO;
  633. }
  634. ret = clk_prepare_enable(cclk);
  635. if (ret) {
  636. dev_err(dev, "cannot enable core clock\n");
  637. return ret;
  638. }
  639. ret = clk_prepare_enable(iclk);
  640. if (ret) {
  641. clk_disable_unprepare(cclk);
  642. dev_err(dev, "cannot enable iface clock\n");
  643. return ret;
  644. }
  645. master = spi_alloc_master(dev, sizeof(struct spi_qup));
  646. if (!master) {
  647. clk_disable_unprepare(cclk);
  648. clk_disable_unprepare(iclk);
  649. dev_err(dev, "cannot allocate master\n");
  650. return -ENOMEM;
  651. }
  652. /* use num-cs unless not present or out of range */
  653. if (of_property_read_u32(dev->of_node, "num-cs", &num_cs) ||
  654. num_cs > SPI_NUM_CHIPSELECTS)
  655. master->num_chipselect = SPI_NUM_CHIPSELECTS;
  656. else
  657. master->num_chipselect = num_cs;
  658. master->bus_num = pdev->id;
  659. master->mode_bits = SPI_CPOL | SPI_CPHA | SPI_CS_HIGH | SPI_LOOP;
  660. master->bits_per_word_mask = SPI_BPW_RANGE_MASK(4, 32);
  661. master->max_speed_hz = max_freq;
  662. master->transfer_one = spi_qup_transfer_one;
  663. master->dev.of_node = pdev->dev.of_node;
  664. master->auto_runtime_pm = true;
  665. master->dma_alignment = dma_get_cache_alignment();
  666. master->max_dma_len = SPI_MAX_DMA_XFER;
  667. platform_set_drvdata(pdev, master);
  668. controller = spi_master_get_devdata(master);
  669. controller->dev = dev;
  670. controller->base = base;
  671. controller->iclk = iclk;
  672. controller->cclk = cclk;
  673. controller->irq = irq;
  674. ret = spi_qup_init_dma(master, res->start);
  675. if (ret == -EPROBE_DEFER)
  676. goto error;
  677. else if (!ret)
  678. master->can_dma = spi_qup_can_dma;
  679. /* set v1 flag if device is version 1 */
  680. if (of_device_is_compatible(dev->of_node, "qcom,spi-qup-v1.1.1"))
  681. controller->qup_v1 = 1;
  682. spin_lock_init(&controller->lock);
  683. init_completion(&controller->done);
  684. iomode = readl_relaxed(base + QUP_IO_M_MODES);
  685. size = QUP_IO_M_OUTPUT_BLOCK_SIZE(iomode);
  686. if (size)
  687. controller->out_blk_sz = size * 16;
  688. else
  689. controller->out_blk_sz = 4;
  690. size = QUP_IO_M_INPUT_BLOCK_SIZE(iomode);
  691. if (size)
  692. controller->in_blk_sz = size * 16;
  693. else
  694. controller->in_blk_sz = 4;
  695. size = QUP_IO_M_OUTPUT_FIFO_SIZE(iomode);
  696. controller->out_fifo_sz = controller->out_blk_sz * (2 << size);
  697. size = QUP_IO_M_INPUT_FIFO_SIZE(iomode);
  698. controller->in_fifo_sz = controller->in_blk_sz * (2 << size);
  699. dev_info(dev, "IN:block:%d, fifo:%d, OUT:block:%d, fifo:%d\n",
  700. controller->in_blk_sz, controller->in_fifo_sz,
  701. controller->out_blk_sz, controller->out_fifo_sz);
  702. writel_relaxed(1, base + QUP_SW_RESET);
  703. ret = spi_qup_set_state(controller, QUP_STATE_RESET);
  704. if (ret) {
  705. dev_err(dev, "cannot set RESET state\n");
  706. goto error_dma;
  707. }
  708. writel_relaxed(0, base + QUP_OPERATIONAL);
  709. writel_relaxed(0, base + QUP_IO_M_MODES);
  710. if (!controller->qup_v1)
  711. writel_relaxed(0, base + QUP_OPERATIONAL_MASK);
  712. writel_relaxed(SPI_ERROR_CLK_UNDER_RUN | SPI_ERROR_CLK_OVER_RUN,
  713. base + SPI_ERROR_FLAGS_EN);
  714. /* if earlier version of the QUP, disable INPUT_OVERRUN */
  715. if (controller->qup_v1)
  716. writel_relaxed(QUP_ERROR_OUTPUT_OVER_RUN |
  717. QUP_ERROR_INPUT_UNDER_RUN | QUP_ERROR_OUTPUT_UNDER_RUN,
  718. base + QUP_ERROR_FLAGS_EN);
  719. writel_relaxed(0, base + SPI_CONFIG);
  720. writel_relaxed(SPI_IO_C_NO_TRI_STATE, base + SPI_IO_CONTROL);
  721. ret = devm_request_irq(dev, irq, spi_qup_qup_irq,
  722. IRQF_TRIGGER_HIGH, pdev->name, controller);
  723. if (ret)
  724. goto error_dma;
  725. pm_runtime_set_autosuspend_delay(dev, MSEC_PER_SEC);
  726. pm_runtime_use_autosuspend(dev);
  727. pm_runtime_set_active(dev);
  728. pm_runtime_enable(dev);
  729. ret = devm_spi_register_master(dev, master);
  730. if (ret)
  731. goto disable_pm;
  732. return 0;
  733. disable_pm:
  734. pm_runtime_disable(&pdev->dev);
  735. error_dma:
  736. spi_qup_release_dma(master);
  737. error:
  738. clk_disable_unprepare(cclk);
  739. clk_disable_unprepare(iclk);
  740. spi_master_put(master);
  741. return ret;
  742. }
  743. #ifdef CONFIG_PM
  744. static int spi_qup_pm_suspend_runtime(struct device *device)
  745. {
  746. struct spi_master *master = dev_get_drvdata(device);
  747. struct spi_qup *controller = spi_master_get_devdata(master);
  748. u32 config;
  749. /* Enable clocks auto gaiting */
  750. config = readl(controller->base + QUP_CONFIG);
  751. config |= QUP_CONFIG_CLOCK_AUTO_GATE;
  752. writel_relaxed(config, controller->base + QUP_CONFIG);
  753. clk_disable_unprepare(controller->cclk);
  754. clk_disable_unprepare(controller->iclk);
  755. return 0;
  756. }
  757. static int spi_qup_pm_resume_runtime(struct device *device)
  758. {
  759. struct spi_master *master = dev_get_drvdata(device);
  760. struct spi_qup *controller = spi_master_get_devdata(master);
  761. u32 config;
  762. int ret;
  763. ret = clk_prepare_enable(controller->iclk);
  764. if (ret)
  765. return ret;
  766. ret = clk_prepare_enable(controller->cclk);
  767. if (ret)
  768. return ret;
  769. /* Disable clocks auto gaiting */
  770. config = readl_relaxed(controller->base + QUP_CONFIG);
  771. config &= ~QUP_CONFIG_CLOCK_AUTO_GATE;
  772. writel_relaxed(config, controller->base + QUP_CONFIG);
  773. return 0;
  774. }
  775. #endif /* CONFIG_PM */
  776. #ifdef CONFIG_PM_SLEEP
  777. static int spi_qup_suspend(struct device *device)
  778. {
  779. struct spi_master *master = dev_get_drvdata(device);
  780. struct spi_qup *controller = spi_master_get_devdata(master);
  781. int ret;
  782. ret = spi_master_suspend(master);
  783. if (ret)
  784. return ret;
  785. ret = spi_qup_set_state(controller, QUP_STATE_RESET);
  786. if (ret)
  787. return ret;
  788. if (!pm_runtime_suspended(device)) {
  789. clk_disable_unprepare(controller->cclk);
  790. clk_disable_unprepare(controller->iclk);
  791. }
  792. return 0;
  793. }
  794. static int spi_qup_resume(struct device *device)
  795. {
  796. struct spi_master *master = dev_get_drvdata(device);
  797. struct spi_qup *controller = spi_master_get_devdata(master);
  798. int ret;
  799. ret = clk_prepare_enable(controller->iclk);
  800. if (ret)
  801. return ret;
  802. ret = clk_prepare_enable(controller->cclk);
  803. if (ret)
  804. return ret;
  805. ret = spi_qup_set_state(controller, QUP_STATE_RESET);
  806. if (ret)
  807. return ret;
  808. return spi_master_resume(master);
  809. }
  810. #endif /* CONFIG_PM_SLEEP */
  811. static int spi_qup_remove(struct platform_device *pdev)
  812. {
  813. struct spi_master *master = dev_get_drvdata(&pdev->dev);
  814. struct spi_qup *controller = spi_master_get_devdata(master);
  815. int ret;
  816. ret = pm_runtime_get_sync(&pdev->dev);
  817. if (ret < 0)
  818. return ret;
  819. ret = spi_qup_set_state(controller, QUP_STATE_RESET);
  820. if (ret)
  821. return ret;
  822. spi_qup_release_dma(master);
  823. clk_disable_unprepare(controller->cclk);
  824. clk_disable_unprepare(controller->iclk);
  825. pm_runtime_put_noidle(&pdev->dev);
  826. pm_runtime_disable(&pdev->dev);
  827. return 0;
  828. }
  829. static const struct of_device_id spi_qup_dt_match[] = {
  830. { .compatible = "qcom,spi-qup-v1.1.1", },
  831. { .compatible = "qcom,spi-qup-v2.1.1", },
  832. { .compatible = "qcom,spi-qup-v2.2.1", },
  833. { }
  834. };
  835. MODULE_DEVICE_TABLE(of, spi_qup_dt_match);
  836. static const struct dev_pm_ops spi_qup_dev_pm_ops = {
  837. SET_SYSTEM_SLEEP_PM_OPS(spi_qup_suspend, spi_qup_resume)
  838. SET_RUNTIME_PM_OPS(spi_qup_pm_suspend_runtime,
  839. spi_qup_pm_resume_runtime,
  840. NULL)
  841. };
  842. static struct platform_driver spi_qup_driver = {
  843. .driver = {
  844. .name = "spi_qup",
  845. .pm = &spi_qup_dev_pm_ops,
  846. .of_match_table = spi_qup_dt_match,
  847. },
  848. .probe = spi_qup_probe,
  849. .remove = spi_qup_remove,
  850. };
  851. module_platform_driver(spi_qup_driver);
  852. MODULE_LICENSE("GPL v2");
  853. MODULE_ALIAS("platform:spi_qup");