spi-coldfire-qspi.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603
  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 == 8)
  291. mcfqspi_transfer_msg8(mcfqspi, t->len, t->tx_buf,
  292. t->rx_buf);
  293. else
  294. mcfqspi_transfer_msg16(mcfqspi, t->len / 2, t->tx_buf,
  295. t->rx_buf);
  296. mcfqspi_wr_qir(mcfqspi, 0);
  297. if (t->delay_usecs)
  298. udelay(t->delay_usecs);
  299. if (t->cs_change) {
  300. if (!list_is_last(&t->transfer_list, &msg->transfers))
  301. mcfqspi_cs_deselect(mcfqspi, spi->chip_select,
  302. cs_high);
  303. } else {
  304. if (list_is_last(&t->transfer_list, &msg->transfers))
  305. mcfqspi_cs_deselect(mcfqspi, spi->chip_select,
  306. cs_high);
  307. }
  308. msg->actual_length += t->len;
  309. }
  310. msg->status = status;
  311. spi_finalize_current_message(master);
  312. return status;
  313. }
  314. static int mcfqspi_prepare_transfer_hw(struct spi_master *master)
  315. {
  316. struct mcfqspi *mcfqspi = spi_master_get_devdata(master);
  317. pm_runtime_get_sync(mcfqspi->dev);
  318. return 0;
  319. }
  320. static int mcfqspi_unprepare_transfer_hw(struct spi_master *master)
  321. {
  322. struct mcfqspi *mcfqspi = spi_master_get_devdata(master);
  323. pm_runtime_put_sync(mcfqspi->dev);
  324. return 0;
  325. }
  326. static int mcfqspi_setup(struct spi_device *spi)
  327. {
  328. if ((spi->bits_per_word < 8) || (spi->bits_per_word > 16)) {
  329. dev_dbg(&spi->dev, "%d bits per word is not supported\n",
  330. spi->bits_per_word);
  331. return -EINVAL;
  332. }
  333. if (spi->chip_select >= spi->master->num_chipselect) {
  334. dev_dbg(&spi->dev, "%d chip select is out of range\n",
  335. spi->chip_select);
  336. return -EINVAL;
  337. }
  338. mcfqspi_cs_deselect(spi_master_get_devdata(spi->master),
  339. spi->chip_select, spi->mode & SPI_CS_HIGH);
  340. dev_dbg(&spi->dev,
  341. "bits per word %d, chip select %d, speed %d KHz\n",
  342. spi->bits_per_word, spi->chip_select,
  343. (MCFQSPI_BUSCLK / mcfqspi_qmr_baud(spi->max_speed_hz))
  344. / 1000);
  345. return 0;
  346. }
  347. static int mcfqspi_probe(struct platform_device *pdev)
  348. {
  349. struct spi_master *master;
  350. struct mcfqspi *mcfqspi;
  351. struct resource *res;
  352. struct mcfqspi_platform_data *pdata;
  353. int status;
  354. master = spi_alloc_master(&pdev->dev, sizeof(*mcfqspi));
  355. if (master == NULL) {
  356. dev_dbg(&pdev->dev, "spi_alloc_master failed\n");
  357. return -ENOMEM;
  358. }
  359. mcfqspi = spi_master_get_devdata(master);
  360. res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  361. if (!res) {
  362. dev_dbg(&pdev->dev, "platform_get_resource failed\n");
  363. status = -ENXIO;
  364. goto fail0;
  365. }
  366. if (!request_mem_region(res->start, resource_size(res), pdev->name)) {
  367. dev_dbg(&pdev->dev, "request_mem_region failed\n");
  368. status = -EBUSY;
  369. goto fail0;
  370. }
  371. mcfqspi->iobase = ioremap(res->start, resource_size(res));
  372. if (!mcfqspi->iobase) {
  373. dev_dbg(&pdev->dev, "ioremap failed\n");
  374. status = -ENOMEM;
  375. goto fail1;
  376. }
  377. mcfqspi->irq = platform_get_irq(pdev, 0);
  378. if (mcfqspi->irq < 0) {
  379. dev_dbg(&pdev->dev, "platform_get_irq failed\n");
  380. status = -ENXIO;
  381. goto fail2;
  382. }
  383. status = request_irq(mcfqspi->irq, mcfqspi_irq_handler, 0,
  384. pdev->name, mcfqspi);
  385. if (status) {
  386. dev_dbg(&pdev->dev, "request_irq failed\n");
  387. goto fail2;
  388. }
  389. mcfqspi->clk = clk_get(&pdev->dev, "qspi_clk");
  390. if (IS_ERR(mcfqspi->clk)) {
  391. dev_dbg(&pdev->dev, "clk_get failed\n");
  392. status = PTR_ERR(mcfqspi->clk);
  393. goto fail3;
  394. }
  395. clk_enable(mcfqspi->clk);
  396. pdata = pdev->dev.platform_data;
  397. if (!pdata) {
  398. dev_dbg(&pdev->dev, "platform data is missing\n");
  399. goto fail4;
  400. }
  401. master->bus_num = pdata->bus_num;
  402. master->num_chipselect = pdata->num_chipselect;
  403. mcfqspi->cs_control = pdata->cs_control;
  404. status = mcfqspi_cs_setup(mcfqspi);
  405. if (status) {
  406. dev_dbg(&pdev->dev, "error initializing cs_control\n");
  407. goto fail4;
  408. }
  409. init_waitqueue_head(&mcfqspi->waitq);
  410. mcfqspi->dev = &pdev->dev;
  411. master->mode_bits = SPI_CS_HIGH | SPI_CPOL | SPI_CPHA;
  412. master->setup = mcfqspi_setup;
  413. master->transfer_one_message = mcfqspi_transfer_one_message;
  414. master->prepare_transfer_hardware = mcfqspi_prepare_transfer_hw;
  415. master->unprepare_transfer_hardware = mcfqspi_unprepare_transfer_hw;
  416. platform_set_drvdata(pdev, master);
  417. status = spi_register_master(master);
  418. if (status) {
  419. dev_dbg(&pdev->dev, "spi_register_master failed\n");
  420. goto fail5;
  421. }
  422. pm_runtime_enable(mcfqspi->dev);
  423. dev_info(&pdev->dev, "Coldfire QSPI bus driver\n");
  424. return 0;
  425. fail5:
  426. mcfqspi_cs_teardown(mcfqspi);
  427. fail4:
  428. clk_disable(mcfqspi->clk);
  429. clk_put(mcfqspi->clk);
  430. fail3:
  431. free_irq(mcfqspi->irq, mcfqspi);
  432. fail2:
  433. iounmap(mcfqspi->iobase);
  434. fail1:
  435. release_mem_region(res->start, resource_size(res));
  436. fail0:
  437. spi_master_put(master);
  438. dev_dbg(&pdev->dev, "Coldfire QSPI probe failed\n");
  439. return status;
  440. }
  441. static int mcfqspi_remove(struct platform_device *pdev)
  442. {
  443. struct spi_master *master = platform_get_drvdata(pdev);
  444. struct mcfqspi *mcfqspi = spi_master_get_devdata(master);
  445. struct resource *res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  446. pm_runtime_disable(mcfqspi->dev);
  447. /* disable the hardware (set the baud rate to 0) */
  448. mcfqspi_wr_qmr(mcfqspi, MCFQSPI_QMR_MSTR);
  449. platform_set_drvdata(pdev, NULL);
  450. mcfqspi_cs_teardown(mcfqspi);
  451. clk_disable(mcfqspi->clk);
  452. clk_put(mcfqspi->clk);
  453. free_irq(mcfqspi->irq, mcfqspi);
  454. iounmap(mcfqspi->iobase);
  455. release_mem_region(res->start, resource_size(res));
  456. spi_unregister_master(master);
  457. return 0;
  458. }
  459. #ifdef CONFIG_PM_SLEEP
  460. static int mcfqspi_suspend(struct device *dev)
  461. {
  462. struct spi_master *master = dev_get_drvdata(dev);
  463. struct mcfqspi *mcfqspi = spi_master_get_devdata(master);
  464. spi_master_suspend(master);
  465. clk_disable(mcfqspi->clk);
  466. return 0;
  467. }
  468. static int mcfqspi_resume(struct device *dev)
  469. {
  470. struct spi_master *master = dev_get_drvdata(dev);
  471. struct mcfqspi *mcfqspi = spi_master_get_devdata(master);
  472. spi_master_resume(master);
  473. clk_enable(mcfqspi->clk);
  474. return 0;
  475. }
  476. #endif
  477. #ifdef CONFIG_PM_RUNTIME
  478. static int mcfqspi_runtime_suspend(struct device *dev)
  479. {
  480. struct mcfqspi *mcfqspi = platform_get_drvdata(to_platform_device(dev));
  481. clk_disable(mcfqspi->clk);
  482. return 0;
  483. }
  484. static int mcfqspi_runtime_resume(struct device *dev)
  485. {
  486. struct mcfqspi *mcfqspi = platform_get_drvdata(to_platform_device(dev));
  487. clk_enable(mcfqspi->clk);
  488. return 0;
  489. }
  490. #endif
  491. static const struct dev_pm_ops mcfqspi_pm = {
  492. SET_SYSTEM_SLEEP_PM_OPS(mcfqspi_suspend, mcfqspi_resume)
  493. SET_RUNTIME_PM_OPS(mcfqspi_runtime_suspend, mcfqspi_runtime_resume,
  494. NULL)
  495. };
  496. static struct platform_driver mcfqspi_driver = {
  497. .driver.name = DRIVER_NAME,
  498. .driver.owner = THIS_MODULE,
  499. .driver.pm = &mcfqspi_pm,
  500. .probe = mcfqspi_probe,
  501. .remove = mcfqspi_remove,
  502. };
  503. module_platform_driver(mcfqspi_driver);
  504. MODULE_AUTHOR("Steven King <sfking@fdwdc.com>");
  505. MODULE_DESCRIPTION("Coldfire QSPI Controller Driver");
  506. MODULE_LICENSE("GPL");
  507. MODULE_ALIAS("platform:" DRIVER_NAME);