spi-coldfire-qspi.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604
  1. /*
  2. * Freescale/Motorola Coldfire Queued SPI driver
  3. *
  4. * Copyright 2010 Steven King <sfking@fdwdc.com>
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation; either version 2 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program; if not, write to the Free Software
  18. * Foundation, Inc., 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA
  19. *
  20. */
  21. #include <linux/kernel.h>
  22. #include <linux/module.h>
  23. #include <linux/interrupt.h>
  24. #include <linux/errno.h>
  25. #include <linux/platform_device.h>
  26. #include <linux/sched.h>
  27. #include <linux/delay.h>
  28. #include <linux/io.h>
  29. #include <linux/clk.h>
  30. #include <linux/err.h>
  31. #include <linux/spi/spi.h>
  32. #include <linux/pm_runtime.h>
  33. #include <asm/coldfire.h>
  34. #include <asm/mcfsim.h>
  35. #include <asm/mcfqspi.h>
  36. #define DRIVER_NAME "mcfqspi"
  37. #define MCFQSPI_BUSCLK (MCF_BUSCLK / 2)
  38. #define MCFQSPI_QMR 0x00
  39. #define MCFQSPI_QMR_MSTR 0x8000
  40. #define MCFQSPI_QMR_CPOL 0x0200
  41. #define MCFQSPI_QMR_CPHA 0x0100
  42. #define MCFQSPI_QDLYR 0x04
  43. #define MCFQSPI_QDLYR_SPE 0x8000
  44. #define MCFQSPI_QWR 0x08
  45. #define MCFQSPI_QWR_HALT 0x8000
  46. #define MCFQSPI_QWR_WREN 0x4000
  47. #define MCFQSPI_QWR_CSIV 0x1000
  48. #define MCFQSPI_QIR 0x0C
  49. #define MCFQSPI_QIR_WCEFB 0x8000
  50. #define MCFQSPI_QIR_ABRTB 0x4000
  51. #define MCFQSPI_QIR_ABRTL 0x1000
  52. #define MCFQSPI_QIR_WCEFE 0x0800
  53. #define MCFQSPI_QIR_ABRTE 0x0400
  54. #define MCFQSPI_QIR_SPIFE 0x0100
  55. #define MCFQSPI_QIR_WCEF 0x0008
  56. #define MCFQSPI_QIR_ABRT 0x0004
  57. #define MCFQSPI_QIR_SPIF 0x0001
  58. #define MCFQSPI_QAR 0x010
  59. #define MCFQSPI_QAR_TXBUF 0x00
  60. #define MCFQSPI_QAR_RXBUF 0x10
  61. #define MCFQSPI_QAR_CMDBUF 0x20
  62. #define MCFQSPI_QDR 0x014
  63. #define MCFQSPI_QCR 0x014
  64. #define MCFQSPI_QCR_CONT 0x8000
  65. #define MCFQSPI_QCR_BITSE 0x4000
  66. #define MCFQSPI_QCR_DT 0x2000
  67. struct mcfqspi {
  68. void __iomem *iobase;
  69. int irq;
  70. struct clk *clk;
  71. struct mcfqspi_cs_control *cs_control;
  72. wait_queue_head_t waitq;
  73. struct device *dev;
  74. };
  75. static void mcfqspi_wr_qmr(struct mcfqspi *mcfqspi, u16 val)
  76. {
  77. writew(val, mcfqspi->iobase + MCFQSPI_QMR);
  78. }
  79. static void mcfqspi_wr_qdlyr(struct mcfqspi *mcfqspi, u16 val)
  80. {
  81. writew(val, mcfqspi->iobase + MCFQSPI_QDLYR);
  82. }
  83. static u16 mcfqspi_rd_qdlyr(struct mcfqspi *mcfqspi)
  84. {
  85. return readw(mcfqspi->iobase + MCFQSPI_QDLYR);
  86. }
  87. static void mcfqspi_wr_qwr(struct mcfqspi *mcfqspi, u16 val)
  88. {
  89. writew(val, mcfqspi->iobase + MCFQSPI_QWR);
  90. }
  91. static void mcfqspi_wr_qir(struct mcfqspi *mcfqspi, u16 val)
  92. {
  93. writew(val, mcfqspi->iobase + MCFQSPI_QIR);
  94. }
  95. static void mcfqspi_wr_qar(struct mcfqspi *mcfqspi, u16 val)
  96. {
  97. writew(val, mcfqspi->iobase + MCFQSPI_QAR);
  98. }
  99. static void mcfqspi_wr_qdr(struct mcfqspi *mcfqspi, u16 val)
  100. {
  101. writew(val, mcfqspi->iobase + MCFQSPI_QDR);
  102. }
  103. static u16 mcfqspi_rd_qdr(struct mcfqspi *mcfqspi)
  104. {
  105. return readw(mcfqspi->iobase + MCFQSPI_QDR);
  106. }
  107. static void mcfqspi_cs_select(struct mcfqspi *mcfqspi, u8 chip_select,
  108. bool cs_high)
  109. {
  110. mcfqspi->cs_control->select(mcfqspi->cs_control, chip_select, cs_high);
  111. }
  112. static void mcfqspi_cs_deselect(struct mcfqspi *mcfqspi, u8 chip_select,
  113. bool cs_high)
  114. {
  115. mcfqspi->cs_control->deselect(mcfqspi->cs_control, chip_select, cs_high);
  116. }
  117. static int mcfqspi_cs_setup(struct mcfqspi *mcfqspi)
  118. {
  119. return (mcfqspi->cs_control && mcfqspi->cs_control->setup) ?
  120. mcfqspi->cs_control->setup(mcfqspi->cs_control) : 0;
  121. }
  122. static void mcfqspi_cs_teardown(struct mcfqspi *mcfqspi)
  123. {
  124. if (mcfqspi->cs_control && mcfqspi->cs_control->teardown)
  125. mcfqspi->cs_control->teardown(mcfqspi->cs_control);
  126. }
  127. static u8 mcfqspi_qmr_baud(u32 speed_hz)
  128. {
  129. return clamp((MCFQSPI_BUSCLK + speed_hz - 1) / speed_hz, 2u, 255u);
  130. }
  131. static bool mcfqspi_qdlyr_spe(struct mcfqspi *mcfqspi)
  132. {
  133. return mcfqspi_rd_qdlyr(mcfqspi) & MCFQSPI_QDLYR_SPE;
  134. }
  135. static irqreturn_t mcfqspi_irq_handler(int this_irq, void *dev_id)
  136. {
  137. struct mcfqspi *mcfqspi = dev_id;
  138. /* clear interrupt */
  139. mcfqspi_wr_qir(mcfqspi, MCFQSPI_QIR_SPIFE | MCFQSPI_QIR_SPIF);
  140. wake_up(&mcfqspi->waitq);
  141. return IRQ_HANDLED;
  142. }
  143. static void mcfqspi_transfer_msg8(struct mcfqspi *mcfqspi, unsigned count,
  144. const u8 *txbuf, u8 *rxbuf)
  145. {
  146. unsigned i, n, offset = 0;
  147. n = min(count, 16u);
  148. mcfqspi_wr_qar(mcfqspi, MCFQSPI_QAR_CMDBUF);
  149. for (i = 0; i < n; ++i)
  150. mcfqspi_wr_qdr(mcfqspi, MCFQSPI_QCR_BITSE);
  151. mcfqspi_wr_qar(mcfqspi, MCFQSPI_QAR_TXBUF);
  152. if (txbuf)
  153. for (i = 0; i < n; ++i)
  154. mcfqspi_wr_qdr(mcfqspi, *txbuf++);
  155. else
  156. for (i = 0; i < count; ++i)
  157. mcfqspi_wr_qdr(mcfqspi, 0);
  158. count -= n;
  159. if (count) {
  160. u16 qwr = 0xf08;
  161. mcfqspi_wr_qwr(mcfqspi, 0x700);
  162. mcfqspi_wr_qdlyr(mcfqspi, MCFQSPI_QDLYR_SPE);
  163. do {
  164. wait_event(mcfqspi->waitq, !mcfqspi_qdlyr_spe(mcfqspi));
  165. mcfqspi_wr_qwr(mcfqspi, qwr);
  166. mcfqspi_wr_qdlyr(mcfqspi, MCFQSPI_QDLYR_SPE);
  167. if (rxbuf) {
  168. mcfqspi_wr_qar(mcfqspi,
  169. MCFQSPI_QAR_RXBUF + offset);
  170. for (i = 0; i < 8; ++i)
  171. *rxbuf++ = mcfqspi_rd_qdr(mcfqspi);
  172. }
  173. n = min(count, 8u);
  174. if (txbuf) {
  175. mcfqspi_wr_qar(mcfqspi,
  176. MCFQSPI_QAR_TXBUF + offset);
  177. for (i = 0; i < n; ++i)
  178. mcfqspi_wr_qdr(mcfqspi, *txbuf++);
  179. }
  180. qwr = (offset ? 0x808 : 0) + ((n - 1) << 8);
  181. offset ^= 8;
  182. count -= n;
  183. } while (count);
  184. wait_event(mcfqspi->waitq, !mcfqspi_qdlyr_spe(mcfqspi));
  185. mcfqspi_wr_qwr(mcfqspi, qwr);
  186. mcfqspi_wr_qdlyr(mcfqspi, MCFQSPI_QDLYR_SPE);
  187. if (rxbuf) {
  188. mcfqspi_wr_qar(mcfqspi, MCFQSPI_QAR_RXBUF + offset);
  189. for (i = 0; i < 8; ++i)
  190. *rxbuf++ = mcfqspi_rd_qdr(mcfqspi);
  191. offset ^= 8;
  192. }
  193. } else {
  194. mcfqspi_wr_qwr(mcfqspi, (n - 1) << 8);
  195. mcfqspi_wr_qdlyr(mcfqspi, MCFQSPI_QDLYR_SPE);
  196. }
  197. wait_event(mcfqspi->waitq, !mcfqspi_qdlyr_spe(mcfqspi));
  198. if (rxbuf) {
  199. mcfqspi_wr_qar(mcfqspi, MCFQSPI_QAR_RXBUF + offset);
  200. for (i = 0; i < n; ++i)
  201. *rxbuf++ = mcfqspi_rd_qdr(mcfqspi);
  202. }
  203. }
  204. static void mcfqspi_transfer_msg16(struct mcfqspi *mcfqspi, unsigned count,
  205. const u16 *txbuf, u16 *rxbuf)
  206. {
  207. unsigned i, n, offset = 0;
  208. n = min(count, 16u);
  209. mcfqspi_wr_qar(mcfqspi, MCFQSPI_QAR_CMDBUF);
  210. for (i = 0; i < n; ++i)
  211. mcfqspi_wr_qdr(mcfqspi, MCFQSPI_QCR_BITSE);
  212. mcfqspi_wr_qar(mcfqspi, MCFQSPI_QAR_TXBUF);
  213. if (txbuf)
  214. for (i = 0; i < n; ++i)
  215. mcfqspi_wr_qdr(mcfqspi, *txbuf++);
  216. else
  217. for (i = 0; i < count; ++i)
  218. mcfqspi_wr_qdr(mcfqspi, 0);
  219. count -= n;
  220. if (count) {
  221. u16 qwr = 0xf08;
  222. mcfqspi_wr_qwr(mcfqspi, 0x700);
  223. mcfqspi_wr_qdlyr(mcfqspi, MCFQSPI_QDLYR_SPE);
  224. do {
  225. wait_event(mcfqspi->waitq, !mcfqspi_qdlyr_spe(mcfqspi));
  226. mcfqspi_wr_qwr(mcfqspi, qwr);
  227. mcfqspi_wr_qdlyr(mcfqspi, MCFQSPI_QDLYR_SPE);
  228. if (rxbuf) {
  229. mcfqspi_wr_qar(mcfqspi,
  230. MCFQSPI_QAR_RXBUF + offset);
  231. for (i = 0; i < 8; ++i)
  232. *rxbuf++ = mcfqspi_rd_qdr(mcfqspi);
  233. }
  234. n = min(count, 8u);
  235. if (txbuf) {
  236. mcfqspi_wr_qar(mcfqspi,
  237. MCFQSPI_QAR_TXBUF + offset);
  238. for (i = 0; i < n; ++i)
  239. mcfqspi_wr_qdr(mcfqspi, *txbuf++);
  240. }
  241. qwr = (offset ? 0x808 : 0x000) + ((n - 1) << 8);
  242. offset ^= 8;
  243. count -= n;
  244. } while (count);
  245. wait_event(mcfqspi->waitq, !mcfqspi_qdlyr_spe(mcfqspi));
  246. mcfqspi_wr_qwr(mcfqspi, qwr);
  247. mcfqspi_wr_qdlyr(mcfqspi, MCFQSPI_QDLYR_SPE);
  248. if (rxbuf) {
  249. mcfqspi_wr_qar(mcfqspi, MCFQSPI_QAR_RXBUF + offset);
  250. for (i = 0; i < 8; ++i)
  251. *rxbuf++ = mcfqspi_rd_qdr(mcfqspi);
  252. offset ^= 8;
  253. }
  254. } else {
  255. mcfqspi_wr_qwr(mcfqspi, (n - 1) << 8);
  256. mcfqspi_wr_qdlyr(mcfqspi, MCFQSPI_QDLYR_SPE);
  257. }
  258. wait_event(mcfqspi->waitq, !mcfqspi_qdlyr_spe(mcfqspi));
  259. if (rxbuf) {
  260. mcfqspi_wr_qar(mcfqspi, MCFQSPI_QAR_RXBUF + offset);
  261. for (i = 0; i < n; ++i)
  262. *rxbuf++ = mcfqspi_rd_qdr(mcfqspi);
  263. }
  264. }
  265. static int mcfqspi_transfer_one_message(struct spi_master *master,
  266. struct spi_message *msg)
  267. {
  268. struct mcfqspi *mcfqspi = spi_master_get_devdata(master);
  269. struct spi_device *spi = msg->spi;
  270. struct spi_transfer *t;
  271. int status = 0;
  272. list_for_each_entry(t, &msg->transfers, transfer_list) {
  273. bool cs_high = spi->mode & SPI_CS_HIGH;
  274. u16 qmr = MCFQSPI_QMR_MSTR;
  275. if (t->bits_per_word)
  276. qmr |= t->bits_per_word << 10;
  277. else
  278. qmr |= spi->bits_per_word << 10;
  279. if (spi->mode & SPI_CPHA)
  280. qmr |= MCFQSPI_QMR_CPHA;
  281. if (spi->mode & SPI_CPOL)
  282. qmr |= MCFQSPI_QMR_CPOL;
  283. if (t->speed_hz)
  284. qmr |= mcfqspi_qmr_baud(t->speed_hz);
  285. else
  286. qmr |= mcfqspi_qmr_baud(spi->max_speed_hz);
  287. mcfqspi_wr_qmr(mcfqspi, qmr);
  288. mcfqspi_cs_select(mcfqspi, spi->chip_select, cs_high);
  289. mcfqspi_wr_qir(mcfqspi, MCFQSPI_QIR_SPIFE);
  290. if ((t->bits_per_word ? t->bits_per_word :
  291. spi->bits_per_word) == 8)
  292. mcfqspi_transfer_msg8(mcfqspi, t->len, t->tx_buf,
  293. t->rx_buf);
  294. else
  295. mcfqspi_transfer_msg16(mcfqspi, t->len / 2, t->tx_buf,
  296. t->rx_buf);
  297. mcfqspi_wr_qir(mcfqspi, 0);
  298. if (t->delay_usecs)
  299. udelay(t->delay_usecs);
  300. if (t->cs_change) {
  301. if (!list_is_last(&t->transfer_list, &msg->transfers))
  302. mcfqspi_cs_deselect(mcfqspi, spi->chip_select,
  303. cs_high);
  304. } else {
  305. if (list_is_last(&t->transfer_list, &msg->transfers))
  306. mcfqspi_cs_deselect(mcfqspi, spi->chip_select,
  307. cs_high);
  308. }
  309. msg->actual_length += t->len;
  310. }
  311. msg->status = status;
  312. spi_finalize_current_message(master);
  313. return status;
  314. }
  315. static int mcfqspi_prepare_transfer_hw(struct spi_master *master)
  316. {
  317. struct mcfqspi *mcfqspi = spi_master_get_devdata(master);
  318. pm_runtime_get_sync(mcfqspi->dev);
  319. return 0;
  320. }
  321. static int mcfqspi_unprepare_transfer_hw(struct spi_master *master)
  322. {
  323. struct mcfqspi *mcfqspi = spi_master_get_devdata(master);
  324. pm_runtime_put_sync(mcfqspi->dev);
  325. return 0;
  326. }
  327. static int mcfqspi_setup(struct spi_device *spi)
  328. {
  329. if ((spi->bits_per_word < 8) || (spi->bits_per_word > 16)) {
  330. dev_dbg(&spi->dev, "%d bits per word is not supported\n",
  331. spi->bits_per_word);
  332. return -EINVAL;
  333. }
  334. if (spi->chip_select >= spi->master->num_chipselect) {
  335. dev_dbg(&spi->dev, "%d chip select is out of range\n",
  336. spi->chip_select);
  337. return -EINVAL;
  338. }
  339. mcfqspi_cs_deselect(spi_master_get_devdata(spi->master),
  340. spi->chip_select, spi->mode & SPI_CS_HIGH);
  341. dev_dbg(&spi->dev,
  342. "bits per word %d, chip select %d, speed %d KHz\n",
  343. spi->bits_per_word, spi->chip_select,
  344. (MCFQSPI_BUSCLK / mcfqspi_qmr_baud(spi->max_speed_hz))
  345. / 1000);
  346. return 0;
  347. }
  348. static int mcfqspi_probe(struct platform_device *pdev)
  349. {
  350. struct spi_master *master;
  351. struct mcfqspi *mcfqspi;
  352. struct resource *res;
  353. struct mcfqspi_platform_data *pdata;
  354. int status;
  355. master = spi_alloc_master(&pdev->dev, sizeof(*mcfqspi));
  356. if (master == NULL) {
  357. dev_dbg(&pdev->dev, "spi_alloc_master failed\n");
  358. return -ENOMEM;
  359. }
  360. mcfqspi = spi_master_get_devdata(master);
  361. res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  362. if (!res) {
  363. dev_dbg(&pdev->dev, "platform_get_resource failed\n");
  364. status = -ENXIO;
  365. goto fail0;
  366. }
  367. if (!request_mem_region(res->start, resource_size(res), pdev->name)) {
  368. dev_dbg(&pdev->dev, "request_mem_region failed\n");
  369. status = -EBUSY;
  370. goto fail0;
  371. }
  372. mcfqspi->iobase = ioremap(res->start, resource_size(res));
  373. if (!mcfqspi->iobase) {
  374. dev_dbg(&pdev->dev, "ioremap failed\n");
  375. status = -ENOMEM;
  376. goto fail1;
  377. }
  378. mcfqspi->irq = platform_get_irq(pdev, 0);
  379. if (mcfqspi->irq < 0) {
  380. dev_dbg(&pdev->dev, "platform_get_irq failed\n");
  381. status = -ENXIO;
  382. goto fail2;
  383. }
  384. status = request_irq(mcfqspi->irq, mcfqspi_irq_handler, 0,
  385. pdev->name, mcfqspi);
  386. if (status) {
  387. dev_dbg(&pdev->dev, "request_irq failed\n");
  388. goto fail2;
  389. }
  390. mcfqspi->clk = clk_get(&pdev->dev, "qspi_clk");
  391. if (IS_ERR(mcfqspi->clk)) {
  392. dev_dbg(&pdev->dev, "clk_get failed\n");
  393. status = PTR_ERR(mcfqspi->clk);
  394. goto fail3;
  395. }
  396. clk_enable(mcfqspi->clk);
  397. pdata = pdev->dev.platform_data;
  398. if (!pdata) {
  399. dev_dbg(&pdev->dev, "platform data is missing\n");
  400. goto fail4;
  401. }
  402. master->bus_num = pdata->bus_num;
  403. master->num_chipselect = pdata->num_chipselect;
  404. mcfqspi->cs_control = pdata->cs_control;
  405. status = mcfqspi_cs_setup(mcfqspi);
  406. if (status) {
  407. dev_dbg(&pdev->dev, "error initializing cs_control\n");
  408. goto fail4;
  409. }
  410. init_waitqueue_head(&mcfqspi->waitq);
  411. mcfqspi->dev = &pdev->dev;
  412. master->mode_bits = SPI_CS_HIGH | SPI_CPOL | SPI_CPHA;
  413. master->setup = mcfqspi_setup;
  414. master->transfer_one_message = mcfqspi_transfer_one_message;
  415. master->prepare_transfer_hardware = mcfqspi_prepare_transfer_hw;
  416. master->unprepare_transfer_hardware = mcfqspi_unprepare_transfer_hw;
  417. platform_set_drvdata(pdev, master);
  418. status = spi_register_master(master);
  419. if (status) {
  420. dev_dbg(&pdev->dev, "spi_register_master failed\n");
  421. goto fail5;
  422. }
  423. pm_runtime_enable(mcfqspi->dev);
  424. dev_info(&pdev->dev, "Coldfire QSPI bus driver\n");
  425. return 0;
  426. fail5:
  427. mcfqspi_cs_teardown(mcfqspi);
  428. fail4:
  429. clk_disable(mcfqspi->clk);
  430. clk_put(mcfqspi->clk);
  431. fail3:
  432. free_irq(mcfqspi->irq, mcfqspi);
  433. fail2:
  434. iounmap(mcfqspi->iobase);
  435. fail1:
  436. release_mem_region(res->start, resource_size(res));
  437. fail0:
  438. spi_master_put(master);
  439. dev_dbg(&pdev->dev, "Coldfire QSPI probe failed\n");
  440. return status;
  441. }
  442. static int mcfqspi_remove(struct platform_device *pdev)
  443. {
  444. struct spi_master *master = platform_get_drvdata(pdev);
  445. struct mcfqspi *mcfqspi = spi_master_get_devdata(master);
  446. struct resource *res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  447. pm_runtime_disable(mcfqspi->dev);
  448. /* disable the hardware (set the baud rate to 0) */
  449. mcfqspi_wr_qmr(mcfqspi, MCFQSPI_QMR_MSTR);
  450. platform_set_drvdata(pdev, NULL);
  451. mcfqspi_cs_teardown(mcfqspi);
  452. clk_disable(mcfqspi->clk);
  453. clk_put(mcfqspi->clk);
  454. free_irq(mcfqspi->irq, mcfqspi);
  455. iounmap(mcfqspi->iobase);
  456. release_mem_region(res->start, resource_size(res));
  457. spi_unregister_master(master);
  458. return 0;
  459. }
  460. #ifdef CONFIG_PM_SLEEP
  461. static int mcfqspi_suspend(struct device *dev)
  462. {
  463. struct spi_master *master = dev_get_drvdata(dev);
  464. struct mcfqspi *mcfqspi = spi_master_get_devdata(master);
  465. spi_master_suspend(master);
  466. clk_disable(mcfqspi->clk);
  467. return 0;
  468. }
  469. static int mcfqspi_resume(struct device *dev)
  470. {
  471. struct spi_master *master = dev_get_drvdata(dev);
  472. struct mcfqspi *mcfqspi = spi_master_get_devdata(master);
  473. spi_master_resume(master);
  474. clk_enable(mcfqspi->clk);
  475. return 0;
  476. }
  477. #endif
  478. #ifdef CONFIG_PM_RUNTIME
  479. static int mcfqspi_runtime_suspend(struct device *dev)
  480. {
  481. struct mcfqspi *mcfqspi = platform_get_drvdata(to_platform_device(dev));
  482. clk_disable(mcfqspi->clk);
  483. return 0;
  484. }
  485. static int mcfqspi_runtime_resume(struct device *dev)
  486. {
  487. struct mcfqspi *mcfqspi = platform_get_drvdata(to_platform_device(dev));
  488. clk_enable(mcfqspi->clk);
  489. return 0;
  490. }
  491. #endif
  492. static const struct dev_pm_ops mcfqspi_pm = {
  493. SET_SYSTEM_SLEEP_PM_OPS(mcfqspi_suspend, mcfqspi_resume)
  494. SET_RUNTIME_PM_OPS(mcfqspi_runtime_suspend, mcfqspi_runtime_resume,
  495. NULL)
  496. };
  497. static struct platform_driver mcfqspi_driver = {
  498. .driver.name = DRIVER_NAME,
  499. .driver.owner = THIS_MODULE,
  500. .driver.pm = &mcfqspi_pm,
  501. .probe = mcfqspi_probe,
  502. .remove = mcfqspi_remove,
  503. };
  504. module_platform_driver(mcfqspi_driver);
  505. MODULE_AUTHOR("Steven King <sfking@fdwdc.com>");
  506. MODULE_DESCRIPTION("Coldfire QSPI Controller Driver");
  507. MODULE_LICENSE("GPL");
  508. MODULE_ALIAS("platform:" DRIVER_NAME);