spi-qcom-qspi.c 14 KB

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