spi-qcom-qspi.c 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663
  1. // SPDX-License-Identifier: GPL-2.0
  2. // Copyright (c) 2017-2018, The Linux foundation. All rights reserved.
  3. #include <linux/clk.h>
  4. #include <linux/interconnect.h>
  5. #include <linux/interrupt.h>
  6. #include <linux/io.h>
  7. #include <linux/module.h>
  8. #include <linux/of.h>
  9. #include <linux/of_platform.h>
  10. #include <linux/pm_runtime.h>
  11. #include <linux/pm_opp.h>
  12. #include <linux/spi/spi.h>
  13. #include <linux/spi/spi-mem.h>
  14. #define QSPI_NUM_CS 2
  15. #define QSPI_BYTES_PER_WORD 4
  16. #define MSTR_CONFIG 0x0000
  17. #define FULL_CYCLE_MODE BIT(3)
  18. #define FB_CLK_EN BIT(4)
  19. #define PIN_HOLDN BIT(6)
  20. #define PIN_WPN BIT(7)
  21. #define DMA_ENABLE BIT(8)
  22. #define BIG_ENDIAN_MODE BIT(9)
  23. #define SPI_MODE_MSK 0xc00
  24. #define SPI_MODE_SHFT 10
  25. #define CHIP_SELECT_NUM BIT(12)
  26. #define SBL_EN BIT(13)
  27. #define LPA_BASE_MSK 0x3c000
  28. #define LPA_BASE_SHFT 14
  29. #define TX_DATA_DELAY_MSK 0xc0000
  30. #define TX_DATA_DELAY_SHFT 18
  31. #define TX_CLK_DELAY_MSK 0x300000
  32. #define TX_CLK_DELAY_SHFT 20
  33. #define TX_CS_N_DELAY_MSK 0xc00000
  34. #define TX_CS_N_DELAY_SHFT 22
  35. #define TX_DATA_OE_DELAY_MSK 0x3000000
  36. #define TX_DATA_OE_DELAY_SHFT 24
  37. #define AHB_MASTER_CFG 0x0004
  38. #define HMEM_TYPE_START_MID_TRANS_MSK 0x7
  39. #define HMEM_TYPE_START_MID_TRANS_SHFT 0
  40. #define HMEM_TYPE_LAST_TRANS_MSK 0x38
  41. #define HMEM_TYPE_LAST_TRANS_SHFT 3
  42. #define USE_HMEMTYPE_LAST_ON_DESC_OR_CHAIN_MSK 0xc0
  43. #define USE_HMEMTYPE_LAST_ON_DESC_OR_CHAIN_SHFT 6
  44. #define HMEMTYPE_READ_TRANS_MSK 0x700
  45. #define HMEMTYPE_READ_TRANS_SHFT 8
  46. #define HSHARED BIT(11)
  47. #define HINNERSHARED BIT(12)
  48. #define MSTR_INT_EN 0x000C
  49. #define MSTR_INT_STATUS 0x0010
  50. #define RESP_FIFO_UNDERRUN BIT(0)
  51. #define RESP_FIFO_NOT_EMPTY BIT(1)
  52. #define RESP_FIFO_RDY BIT(2)
  53. #define HRESP_FROM_NOC_ERR BIT(3)
  54. #define WR_FIFO_EMPTY BIT(9)
  55. #define WR_FIFO_FULL BIT(10)
  56. #define WR_FIFO_OVERRUN BIT(11)
  57. #define TRANSACTION_DONE BIT(16)
  58. #define QSPI_ERR_IRQS (RESP_FIFO_UNDERRUN | HRESP_FROM_NOC_ERR | \
  59. WR_FIFO_OVERRUN)
  60. #define QSPI_ALL_IRQS (QSPI_ERR_IRQS | RESP_FIFO_RDY | \
  61. WR_FIFO_EMPTY | WR_FIFO_FULL | \
  62. TRANSACTION_DONE)
  63. #define PIO_XFER_CTRL 0x0014
  64. #define REQUEST_COUNT_MSK 0xffff
  65. #define PIO_XFER_CFG 0x0018
  66. #define TRANSFER_DIRECTION BIT(0)
  67. #define MULTI_IO_MODE_MSK 0xe
  68. #define MULTI_IO_MODE_SHFT 1
  69. #define TRANSFER_FRAGMENT BIT(8)
  70. #define SDR_1BIT 1
  71. #define SDR_2BIT 2
  72. #define SDR_4BIT 3
  73. #define DDR_1BIT 5
  74. #define DDR_2BIT 6
  75. #define DDR_4BIT 7
  76. #define DMA_DESC_SINGLE_SPI 1
  77. #define DMA_DESC_DUAL_SPI 2
  78. #define DMA_DESC_QUAD_SPI 3
  79. #define PIO_XFER_STATUS 0x001c
  80. #define WR_FIFO_BYTES_MSK 0xffff0000
  81. #define WR_FIFO_BYTES_SHFT 16
  82. #define PIO_DATAOUT_1B 0x0020
  83. #define PIO_DATAOUT_4B 0x0024
  84. #define RD_FIFO_CFG 0x0028
  85. #define CONTINUOUS_MODE BIT(0)
  86. #define RD_FIFO_STATUS 0x002c
  87. #define FIFO_EMPTY BIT(11)
  88. #define WR_CNTS_MSK 0x7f0
  89. #define WR_CNTS_SHFT 4
  90. #define RDY_64BYTE BIT(3)
  91. #define RDY_32BYTE BIT(2)
  92. #define RDY_16BYTE BIT(1)
  93. #define FIFO_RDY BIT(0)
  94. #define RD_FIFO_RESET 0x0030
  95. #define RESET_FIFO BIT(0)
  96. #define CUR_MEM_ADDR 0x0048
  97. #define HW_VERSION 0x004c
  98. #define RD_FIFO 0x0050
  99. #define SAMPLING_CLK_CFG 0x0090
  100. #define SAMPLING_CLK_STATUS 0x0094
  101. enum qspi_dir {
  102. QSPI_READ,
  103. QSPI_WRITE,
  104. };
  105. struct qspi_xfer {
  106. union {
  107. const void *tx_buf;
  108. void *rx_buf;
  109. };
  110. unsigned int rem_bytes;
  111. unsigned int buswidth;
  112. enum qspi_dir dir;
  113. bool is_last;
  114. };
  115. enum qspi_clocks {
  116. QSPI_CLK_CORE,
  117. QSPI_CLK_IFACE,
  118. QSPI_NUM_CLKS
  119. };
  120. struct qcom_qspi {
  121. void __iomem *base;
  122. struct device *dev;
  123. struct clk_bulk_data *clks;
  124. struct qspi_xfer xfer;
  125. struct icc_path *icc_path_cpu_to_qspi;
  126. unsigned long last_speed;
  127. /* Lock to protect data accessed by IRQs */
  128. spinlock_t lock;
  129. };
  130. static u32 qspi_buswidth_to_iomode(struct qcom_qspi *ctrl,
  131. unsigned int buswidth)
  132. {
  133. switch (buswidth) {
  134. case 1:
  135. return SDR_1BIT << MULTI_IO_MODE_SHFT;
  136. case 2:
  137. return SDR_2BIT << MULTI_IO_MODE_SHFT;
  138. case 4:
  139. return SDR_4BIT << MULTI_IO_MODE_SHFT;
  140. default:
  141. dev_warn_once(ctrl->dev,
  142. "Unexpected bus width: %u\n", buswidth);
  143. return SDR_1BIT << MULTI_IO_MODE_SHFT;
  144. }
  145. }
  146. static void qcom_qspi_pio_xfer_cfg(struct qcom_qspi *ctrl)
  147. {
  148. u32 pio_xfer_cfg;
  149. const struct qspi_xfer *xfer;
  150. xfer = &ctrl->xfer;
  151. pio_xfer_cfg = readl(ctrl->base + PIO_XFER_CFG);
  152. pio_xfer_cfg &= ~TRANSFER_DIRECTION;
  153. pio_xfer_cfg |= xfer->dir;
  154. if (xfer->is_last)
  155. pio_xfer_cfg &= ~TRANSFER_FRAGMENT;
  156. else
  157. pio_xfer_cfg |= TRANSFER_FRAGMENT;
  158. pio_xfer_cfg &= ~MULTI_IO_MODE_MSK;
  159. pio_xfer_cfg |= qspi_buswidth_to_iomode(ctrl, xfer->buswidth);
  160. writel(pio_xfer_cfg, ctrl->base + PIO_XFER_CFG);
  161. }
  162. static void qcom_qspi_pio_xfer_ctrl(struct qcom_qspi *ctrl)
  163. {
  164. u32 pio_xfer_ctrl;
  165. pio_xfer_ctrl = readl(ctrl->base + PIO_XFER_CTRL);
  166. pio_xfer_ctrl &= ~REQUEST_COUNT_MSK;
  167. pio_xfer_ctrl |= ctrl->xfer.rem_bytes;
  168. writel(pio_xfer_ctrl, ctrl->base + PIO_XFER_CTRL);
  169. }
  170. static void qcom_qspi_pio_xfer(struct qcom_qspi *ctrl)
  171. {
  172. u32 ints;
  173. qcom_qspi_pio_xfer_cfg(ctrl);
  174. /* Ack any previous interrupts that might be hanging around */
  175. writel(QSPI_ALL_IRQS, ctrl->base + MSTR_INT_STATUS);
  176. /* Setup new interrupts */
  177. if (ctrl->xfer.dir == QSPI_WRITE)
  178. ints = QSPI_ERR_IRQS | WR_FIFO_EMPTY;
  179. else
  180. ints = QSPI_ERR_IRQS | RESP_FIFO_RDY;
  181. writel(ints, ctrl->base + MSTR_INT_EN);
  182. /* Kick off the transfer */
  183. qcom_qspi_pio_xfer_ctrl(ctrl);
  184. }
  185. static void qcom_qspi_handle_err(struct spi_master *master,
  186. struct spi_message *msg)
  187. {
  188. struct qcom_qspi *ctrl = spi_master_get_devdata(master);
  189. unsigned long flags;
  190. spin_lock_irqsave(&ctrl->lock, flags);
  191. writel(0, ctrl->base + MSTR_INT_EN);
  192. ctrl->xfer.rem_bytes = 0;
  193. spin_unlock_irqrestore(&ctrl->lock, flags);
  194. }
  195. static int qcom_qspi_set_speed(struct qcom_qspi *ctrl, unsigned long speed_hz)
  196. {
  197. int ret;
  198. unsigned int avg_bw_cpu;
  199. if (speed_hz == ctrl->last_speed)
  200. return 0;
  201. /* In regular operation (SBL_EN=1) core must be 4x transfer clock */
  202. ret = dev_pm_opp_set_rate(ctrl->dev, speed_hz * 4);
  203. if (ret) {
  204. dev_err(ctrl->dev, "Failed to set core clk %d\n", ret);
  205. return ret;
  206. }
  207. /*
  208. * Set BW quota for CPU as driver supports FIFO mode only.
  209. * We don't have explicit peak requirement so keep it equal to avg_bw.
  210. */
  211. avg_bw_cpu = Bps_to_icc(speed_hz);
  212. ret = icc_set_bw(ctrl->icc_path_cpu_to_qspi, avg_bw_cpu, avg_bw_cpu);
  213. if (ret) {
  214. dev_err(ctrl->dev, "%s: ICC BW voting failed for cpu: %d\n",
  215. __func__, ret);
  216. return ret;
  217. }
  218. ctrl->last_speed = speed_hz;
  219. return 0;
  220. }
  221. static int qcom_qspi_transfer_one(struct spi_master *master,
  222. struct spi_device *slv,
  223. struct spi_transfer *xfer)
  224. {
  225. struct qcom_qspi *ctrl = spi_master_get_devdata(master);
  226. int ret;
  227. unsigned long speed_hz;
  228. unsigned long flags;
  229. speed_hz = slv->max_speed_hz;
  230. if (xfer->speed_hz)
  231. speed_hz = xfer->speed_hz;
  232. ret = qcom_qspi_set_speed(ctrl, speed_hz);
  233. if (ret)
  234. return ret;
  235. spin_lock_irqsave(&ctrl->lock, flags);
  236. /* We are half duplex, so either rx or tx will be set */
  237. if (xfer->rx_buf) {
  238. ctrl->xfer.dir = QSPI_READ;
  239. ctrl->xfer.buswidth = xfer->rx_nbits;
  240. ctrl->xfer.rx_buf = xfer->rx_buf;
  241. } else {
  242. ctrl->xfer.dir = QSPI_WRITE;
  243. ctrl->xfer.buswidth = xfer->tx_nbits;
  244. ctrl->xfer.tx_buf = xfer->tx_buf;
  245. }
  246. ctrl->xfer.is_last = list_is_last(&xfer->transfer_list,
  247. &master->cur_msg->transfers);
  248. ctrl->xfer.rem_bytes = xfer->len;
  249. qcom_qspi_pio_xfer(ctrl);
  250. spin_unlock_irqrestore(&ctrl->lock, flags);
  251. /* We'll call spi_finalize_current_transfer() when done */
  252. return 1;
  253. }
  254. static int qcom_qspi_prepare_message(struct spi_master *master,
  255. struct spi_message *message)
  256. {
  257. u32 mstr_cfg;
  258. struct qcom_qspi *ctrl;
  259. int tx_data_oe_delay = 1;
  260. int tx_data_delay = 1;
  261. unsigned long flags;
  262. ctrl = spi_master_get_devdata(master);
  263. spin_lock_irqsave(&ctrl->lock, flags);
  264. mstr_cfg = readl(ctrl->base + MSTR_CONFIG);
  265. mstr_cfg &= ~CHIP_SELECT_NUM;
  266. if (message->spi->chip_select)
  267. mstr_cfg |= CHIP_SELECT_NUM;
  268. mstr_cfg |= FB_CLK_EN | PIN_WPN | PIN_HOLDN | SBL_EN | FULL_CYCLE_MODE;
  269. mstr_cfg &= ~(SPI_MODE_MSK | TX_DATA_OE_DELAY_MSK | TX_DATA_DELAY_MSK);
  270. mstr_cfg |= message->spi->mode << SPI_MODE_SHFT;
  271. mstr_cfg |= tx_data_oe_delay << TX_DATA_OE_DELAY_SHFT;
  272. mstr_cfg |= tx_data_delay << TX_DATA_DELAY_SHFT;
  273. mstr_cfg &= ~DMA_ENABLE;
  274. writel(mstr_cfg, ctrl->base + MSTR_CONFIG);
  275. spin_unlock_irqrestore(&ctrl->lock, flags);
  276. return 0;
  277. }
  278. static irqreturn_t pio_read(struct qcom_qspi *ctrl)
  279. {
  280. u32 rd_fifo_status;
  281. u32 rd_fifo;
  282. unsigned int wr_cnts;
  283. unsigned int bytes_to_read;
  284. unsigned int words_to_read;
  285. u32 *word_buf;
  286. u8 *byte_buf;
  287. int i;
  288. rd_fifo_status = readl(ctrl->base + RD_FIFO_STATUS);
  289. if (!(rd_fifo_status & FIFO_RDY)) {
  290. dev_dbg(ctrl->dev, "Spurious IRQ %#x\n", rd_fifo_status);
  291. return IRQ_NONE;
  292. }
  293. wr_cnts = (rd_fifo_status & WR_CNTS_MSK) >> WR_CNTS_SHFT;
  294. wr_cnts = min(wr_cnts, ctrl->xfer.rem_bytes);
  295. words_to_read = wr_cnts / QSPI_BYTES_PER_WORD;
  296. bytes_to_read = wr_cnts % QSPI_BYTES_PER_WORD;
  297. if (words_to_read) {
  298. word_buf = ctrl->xfer.rx_buf;
  299. ctrl->xfer.rem_bytes -= words_to_read * QSPI_BYTES_PER_WORD;
  300. ioread32_rep(ctrl->base + RD_FIFO, word_buf, words_to_read);
  301. ctrl->xfer.rx_buf = word_buf + words_to_read;
  302. }
  303. if (bytes_to_read) {
  304. byte_buf = ctrl->xfer.rx_buf;
  305. rd_fifo = readl(ctrl->base + RD_FIFO);
  306. ctrl->xfer.rem_bytes -= bytes_to_read;
  307. for (i = 0; i < bytes_to_read; i++)
  308. *byte_buf++ = rd_fifo >> (i * BITS_PER_BYTE);
  309. ctrl->xfer.rx_buf = byte_buf;
  310. }
  311. return IRQ_HANDLED;
  312. }
  313. static irqreturn_t pio_write(struct qcom_qspi *ctrl)
  314. {
  315. const void *xfer_buf = ctrl->xfer.tx_buf;
  316. const int *word_buf;
  317. const char *byte_buf;
  318. unsigned int wr_fifo_bytes;
  319. unsigned int wr_fifo_words;
  320. unsigned int wr_size;
  321. unsigned int rem_words;
  322. wr_fifo_bytes = readl(ctrl->base + PIO_XFER_STATUS);
  323. wr_fifo_bytes >>= WR_FIFO_BYTES_SHFT;
  324. if (ctrl->xfer.rem_bytes < QSPI_BYTES_PER_WORD) {
  325. /* Process the last 1-3 bytes */
  326. wr_size = min(wr_fifo_bytes, ctrl->xfer.rem_bytes);
  327. ctrl->xfer.rem_bytes -= wr_size;
  328. byte_buf = xfer_buf;
  329. while (wr_size--)
  330. writel(*byte_buf++,
  331. ctrl->base + PIO_DATAOUT_1B);
  332. ctrl->xfer.tx_buf = byte_buf;
  333. } else {
  334. /*
  335. * Process all the whole words; to keep things simple we'll
  336. * just wait for the next interrupt to handle the last 1-3
  337. * bytes if we don't have an even number of words.
  338. */
  339. rem_words = ctrl->xfer.rem_bytes / QSPI_BYTES_PER_WORD;
  340. wr_fifo_words = wr_fifo_bytes / QSPI_BYTES_PER_WORD;
  341. wr_size = min(rem_words, wr_fifo_words);
  342. ctrl->xfer.rem_bytes -= wr_size * QSPI_BYTES_PER_WORD;
  343. word_buf = xfer_buf;
  344. iowrite32_rep(ctrl->base + PIO_DATAOUT_4B, word_buf, wr_size);
  345. ctrl->xfer.tx_buf = word_buf + wr_size;
  346. }
  347. return IRQ_HANDLED;
  348. }
  349. static irqreturn_t qcom_qspi_irq(int irq, void *dev_id)
  350. {
  351. u32 int_status;
  352. struct qcom_qspi *ctrl = dev_id;
  353. irqreturn_t ret = IRQ_NONE;
  354. spin_lock(&ctrl->lock);
  355. int_status = readl(ctrl->base + MSTR_INT_STATUS);
  356. writel(int_status, ctrl->base + MSTR_INT_STATUS);
  357. if (ctrl->xfer.dir == QSPI_WRITE) {
  358. if (int_status & WR_FIFO_EMPTY)
  359. ret = pio_write(ctrl);
  360. } else {
  361. if (int_status & RESP_FIFO_RDY)
  362. ret = pio_read(ctrl);
  363. }
  364. if (int_status & QSPI_ERR_IRQS) {
  365. if (int_status & RESP_FIFO_UNDERRUN)
  366. dev_err(ctrl->dev, "IRQ error: FIFO underrun\n");
  367. if (int_status & WR_FIFO_OVERRUN)
  368. dev_err(ctrl->dev, "IRQ error: FIFO overrun\n");
  369. if (int_status & HRESP_FROM_NOC_ERR)
  370. dev_err(ctrl->dev, "IRQ error: NOC response error\n");
  371. ret = IRQ_HANDLED;
  372. }
  373. if (!ctrl->xfer.rem_bytes) {
  374. writel(0, ctrl->base + MSTR_INT_EN);
  375. spi_finalize_current_transfer(dev_get_drvdata(ctrl->dev));
  376. }
  377. spin_unlock(&ctrl->lock);
  378. return ret;
  379. }
  380. static int qcom_qspi_probe(struct platform_device *pdev)
  381. {
  382. int ret;
  383. struct device *dev;
  384. struct spi_master *master;
  385. struct qcom_qspi *ctrl;
  386. dev = &pdev->dev;
  387. master = devm_spi_alloc_master(dev, sizeof(*ctrl));
  388. if (!master)
  389. return -ENOMEM;
  390. platform_set_drvdata(pdev, master);
  391. ctrl = spi_master_get_devdata(master);
  392. spin_lock_init(&ctrl->lock);
  393. ctrl->dev = dev;
  394. ctrl->base = devm_platform_ioremap_resource(pdev, 0);
  395. if (IS_ERR(ctrl->base))
  396. return PTR_ERR(ctrl->base);
  397. ctrl->clks = devm_kcalloc(dev, QSPI_NUM_CLKS,
  398. sizeof(*ctrl->clks), GFP_KERNEL);
  399. if (!ctrl->clks)
  400. return -ENOMEM;
  401. ctrl->clks[QSPI_CLK_CORE].id = "core";
  402. ctrl->clks[QSPI_CLK_IFACE].id = "iface";
  403. ret = devm_clk_bulk_get(dev, QSPI_NUM_CLKS, ctrl->clks);
  404. if (ret)
  405. return ret;
  406. ctrl->icc_path_cpu_to_qspi = devm_of_icc_get(dev, "qspi-config");
  407. if (IS_ERR(ctrl->icc_path_cpu_to_qspi))
  408. return dev_err_probe(dev, PTR_ERR(ctrl->icc_path_cpu_to_qspi),
  409. "Failed to get cpu path\n");
  410. /* Set BW vote for register access */
  411. ret = icc_set_bw(ctrl->icc_path_cpu_to_qspi, Bps_to_icc(1000),
  412. Bps_to_icc(1000));
  413. if (ret) {
  414. dev_err(ctrl->dev, "%s: ICC BW voting failed for cpu: %d\n",
  415. __func__, ret);
  416. return ret;
  417. }
  418. ret = icc_disable(ctrl->icc_path_cpu_to_qspi);
  419. if (ret) {
  420. dev_err(ctrl->dev, "%s: ICC disable failed for cpu: %d\n",
  421. __func__, ret);
  422. return ret;
  423. }
  424. ret = platform_get_irq(pdev, 0);
  425. if (ret < 0)
  426. return ret;
  427. ret = devm_request_irq(dev, ret, qcom_qspi_irq, 0, dev_name(dev), ctrl);
  428. if (ret) {
  429. dev_err(dev, "Failed to request irq %d\n", ret);
  430. return ret;
  431. }
  432. master->max_speed_hz = 300000000;
  433. master->num_chipselect = QSPI_NUM_CS;
  434. master->bus_num = -1;
  435. master->dev.of_node = pdev->dev.of_node;
  436. master->mode_bits = SPI_MODE_0 |
  437. SPI_TX_DUAL | SPI_RX_DUAL |
  438. SPI_TX_QUAD | SPI_RX_QUAD;
  439. master->flags = SPI_MASTER_HALF_DUPLEX;
  440. master->prepare_message = qcom_qspi_prepare_message;
  441. master->transfer_one = qcom_qspi_transfer_one;
  442. master->handle_err = qcom_qspi_handle_err;
  443. master->auto_runtime_pm = true;
  444. ret = devm_pm_opp_set_clkname(&pdev->dev, "core");
  445. if (ret)
  446. return ret;
  447. /* OPP table is optional */
  448. ret = devm_pm_opp_of_add_table(&pdev->dev);
  449. if (ret && ret != -ENODEV) {
  450. dev_err(&pdev->dev, "invalid OPP table in device tree\n");
  451. return ret;
  452. }
  453. pm_runtime_use_autosuspend(dev);
  454. pm_runtime_set_autosuspend_delay(dev, 250);
  455. pm_runtime_enable(dev);
  456. ret = spi_register_master(master);
  457. if (!ret)
  458. return 0;
  459. pm_runtime_disable(dev);
  460. return ret;
  461. }
  462. static int qcom_qspi_remove(struct platform_device *pdev)
  463. {
  464. struct spi_master *master = platform_get_drvdata(pdev);
  465. /* Unregister _before_ disabling pm_runtime() so we stop transfers */
  466. spi_unregister_master(master);
  467. pm_runtime_disable(&pdev->dev);
  468. return 0;
  469. }
  470. static int __maybe_unused qcom_qspi_runtime_suspend(struct device *dev)
  471. {
  472. struct spi_master *master = dev_get_drvdata(dev);
  473. struct qcom_qspi *ctrl = spi_master_get_devdata(master);
  474. int ret;
  475. /* Drop the performance state vote */
  476. dev_pm_opp_set_rate(dev, 0);
  477. clk_bulk_disable_unprepare(QSPI_NUM_CLKS, ctrl->clks);
  478. ret = icc_disable(ctrl->icc_path_cpu_to_qspi);
  479. if (ret) {
  480. dev_err_ratelimited(ctrl->dev, "%s: ICC disable failed for cpu: %d\n",
  481. __func__, ret);
  482. return ret;
  483. }
  484. return 0;
  485. }
  486. static int __maybe_unused qcom_qspi_runtime_resume(struct device *dev)
  487. {
  488. struct spi_master *master = dev_get_drvdata(dev);
  489. struct qcom_qspi *ctrl = spi_master_get_devdata(master);
  490. int ret;
  491. ret = icc_enable(ctrl->icc_path_cpu_to_qspi);
  492. if (ret) {
  493. dev_err_ratelimited(ctrl->dev, "%s: ICC enable failed for cpu: %d\n",
  494. __func__, ret);
  495. return ret;
  496. }
  497. ret = clk_bulk_prepare_enable(QSPI_NUM_CLKS, ctrl->clks);
  498. if (ret)
  499. return ret;
  500. return dev_pm_opp_set_rate(dev, ctrl->last_speed * 4);
  501. }
  502. static int __maybe_unused qcom_qspi_suspend(struct device *dev)
  503. {
  504. struct spi_master *master = dev_get_drvdata(dev);
  505. int ret;
  506. ret = spi_master_suspend(master);
  507. if (ret)
  508. return ret;
  509. ret = pm_runtime_force_suspend(dev);
  510. if (ret)
  511. spi_master_resume(master);
  512. return ret;
  513. }
  514. static int __maybe_unused qcom_qspi_resume(struct device *dev)
  515. {
  516. struct spi_master *master = dev_get_drvdata(dev);
  517. int ret;
  518. ret = pm_runtime_force_resume(dev);
  519. if (ret)
  520. return ret;
  521. ret = spi_master_resume(master);
  522. if (ret)
  523. pm_runtime_force_suspend(dev);
  524. return ret;
  525. }
  526. static const struct dev_pm_ops qcom_qspi_dev_pm_ops = {
  527. SET_RUNTIME_PM_OPS(qcom_qspi_runtime_suspend,
  528. qcom_qspi_runtime_resume, NULL)
  529. SET_SYSTEM_SLEEP_PM_OPS(qcom_qspi_suspend, qcom_qspi_resume)
  530. };
  531. static const struct of_device_id qcom_qspi_dt_match[] = {
  532. { .compatible = "qcom,qspi-v1", },
  533. { }
  534. };
  535. MODULE_DEVICE_TABLE(of, qcom_qspi_dt_match);
  536. static struct platform_driver qcom_qspi_driver = {
  537. .driver = {
  538. .name = "qcom_qspi",
  539. .pm = &qcom_qspi_dev_pm_ops,
  540. .of_match_table = qcom_qspi_dt_match,
  541. },
  542. .probe = qcom_qspi_probe,
  543. .remove = qcom_qspi_remove,
  544. };
  545. module_platform_driver(qcom_qspi_driver);
  546. MODULE_DESCRIPTION("SPI driver for QSPI cores");
  547. MODULE_LICENSE("GPL v2");