kirkwood_spi.c 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * (C) Copyright 2009
  4. * Marvell Semiconductor <www.marvell.com>
  5. * Written-by: Prafulla Wadaskar <prafulla@marvell.com>
  6. *
  7. * Derived from drivers/spi/mpc8xxx_spi.c
  8. */
  9. #include <common.h>
  10. #include <dm.h>
  11. #include <log.h>
  12. #include <malloc.h>
  13. #include <spi.h>
  14. #include <asm/io.h>
  15. #include <asm/arch/soc.h>
  16. #ifdef CONFIG_ARCH_KIRKWOOD
  17. #include <asm/arch/mpp.h>
  18. #endif
  19. #include <asm/arch-mvebu/spi.h>
  20. struct mvebu_spi_dev {
  21. bool is_errata_50mhz_ac;
  22. };
  23. struct mvebu_spi_plat {
  24. struct kwspi_registers *spireg;
  25. bool is_errata_50mhz_ac;
  26. };
  27. struct mvebu_spi_priv {
  28. struct kwspi_registers *spireg;
  29. };
  30. static void _spi_cs_activate(struct kwspi_registers *reg)
  31. {
  32. setbits_le32(&reg->ctrl, KWSPI_CSN_ACT);
  33. }
  34. static void _spi_cs_deactivate(struct kwspi_registers *reg)
  35. {
  36. clrbits_le32(&reg->ctrl, KWSPI_CSN_ACT);
  37. }
  38. static int _spi_xfer(struct kwspi_registers *reg, unsigned int bitlen,
  39. const void *dout, void *din, unsigned long flags)
  40. {
  41. unsigned int tmpdout, tmpdin;
  42. int tm, isread = 0;
  43. debug("spi_xfer: dout %p din %p bitlen %u\n", dout, din, bitlen);
  44. if (flags & SPI_XFER_BEGIN)
  45. _spi_cs_activate(reg);
  46. /*
  47. * handle data in 8-bit chunks
  48. * TBD: 2byte xfer mode to be enabled
  49. */
  50. clrsetbits_le32(&reg->cfg, KWSPI_XFERLEN_MASK, KWSPI_XFERLEN_1BYTE);
  51. while (bitlen > 4) {
  52. debug("loopstart bitlen %d\n", bitlen);
  53. tmpdout = 0;
  54. /* Shift data so it's msb-justified */
  55. if (dout)
  56. tmpdout = *(u32 *)dout & 0xff;
  57. clrbits_le32(&reg->irq_cause, KWSPI_SMEMRDIRQ);
  58. writel(tmpdout, &reg->dout); /* Write the data out */
  59. debug("*** spi_xfer: ... %08x written, bitlen %d\n",
  60. tmpdout, bitlen);
  61. /*
  62. * Wait for SPI transmit to get out
  63. * or time out (1 second = 1000 ms)
  64. * The NE event must be read and cleared first
  65. */
  66. for (tm = 0, isread = 0; tm < KWSPI_TIMEOUT; ++tm) {
  67. if (readl(&reg->irq_cause) & KWSPI_SMEMRDIRQ) {
  68. isread = 1;
  69. tmpdin = readl(&reg->din);
  70. debug("spi_xfer: din %p..%08x read\n",
  71. din, tmpdin);
  72. if (din) {
  73. *((u8 *)din) = (u8)tmpdin;
  74. din += 1;
  75. }
  76. if (dout)
  77. dout += 1;
  78. bitlen -= 8;
  79. }
  80. if (isread)
  81. break;
  82. }
  83. if (tm >= KWSPI_TIMEOUT)
  84. printf("*** spi_xfer: Time out during SPI transfer\n");
  85. debug("loopend bitlen %d\n", bitlen);
  86. }
  87. if (flags & SPI_XFER_END)
  88. _spi_cs_deactivate(reg);
  89. return 0;
  90. }
  91. static int mvebu_spi_set_speed(struct udevice *bus, uint hz)
  92. {
  93. struct mvebu_spi_plat *plat = dev_get_plat(bus);
  94. struct dm_spi_bus *spi = dev_get_uclass_priv(bus);
  95. struct kwspi_registers *reg = plat->spireg;
  96. u32 data, divider;
  97. unsigned int spr, sppr;
  98. if (spi->max_hz && (hz > spi->max_hz)) {
  99. debug("%s: limit speed to the max_hz of the bus %d\n",
  100. __func__, spi->max_hz);
  101. hz = spi->max_hz;
  102. }
  103. /*
  104. * Calculate spi clock prescaller using max_hz.
  105. * SPPR is SPI Baud Rate Pre-selection, it holds bits 5 and 7:6 in
  106. * SPI Interface Configuration Register;
  107. * SPR is SPI Baud Rate Selection, it holds bits 3:0 in SPI Interface
  108. * Configuration Register.
  109. * The SPR together with the SPPR define the SPI CLK frequency as
  110. * follows:
  111. * SPI actual frequency = core_clk / (SPR * (2 ^ SPPR))
  112. */
  113. divider = DIV_ROUND_UP(CFG_SYS_TCLK, hz);
  114. if (divider < 16) {
  115. /* This is the easy case, divider is less than 16 */
  116. spr = divider;
  117. sppr = 0;
  118. } else {
  119. unsigned int two_pow_sppr;
  120. /*
  121. * Find the highest bit set in divider. This and the
  122. * three next bits define SPR (apart from rounding).
  123. * SPPR is then the number of zero bits that must be
  124. * appended:
  125. */
  126. sppr = fls(divider) - 4;
  127. /*
  128. * As SPR only has 4 bits, we have to round divider up
  129. * to the next multiple of 2 ** sppr.
  130. */
  131. two_pow_sppr = 1 << sppr;
  132. divider = (divider + two_pow_sppr - 1) & -two_pow_sppr;
  133. /*
  134. * recalculate sppr as rounding up divider might have
  135. * increased it enough to change the position of the
  136. * highest set bit. In this case the bit that now
  137. * doesn't make it into SPR is 0, so there is no need to
  138. * round again.
  139. */
  140. sppr = fls(divider) - 4;
  141. spr = divider >> sppr;
  142. /*
  143. * Now do range checking. SPR is constructed to have a
  144. * width of 4 bits, so this is fine for sure. So we
  145. * still need to check for sppr to fit into 3 bits:
  146. */
  147. if (sppr > 7)
  148. return -EINVAL;
  149. }
  150. data = ((sppr & 0x6) << 5) | ((sppr & 0x1) << 4) | spr;
  151. /* program spi clock prescaler using max_hz */
  152. writel(KWSPI_ADRLEN_3BYTE | data, &reg->cfg);
  153. debug("data = 0x%08x\n", data);
  154. return 0;
  155. }
  156. static void mvebu_spi_50mhz_ac_timing_erratum(struct udevice *bus, uint mode)
  157. {
  158. struct mvebu_spi_plat *plat = dev_get_plat(bus);
  159. struct kwspi_registers *reg = plat->spireg;
  160. u32 data;
  161. /*
  162. * Erratum description: (Erratum NO. FE-9144572) The device
  163. * SPI interface supports frequencies of up to 50 MHz.
  164. * However, due to this erratum, when the device core clock is
  165. * 250 MHz and the SPI interfaces is configured for 50MHz SPI
  166. * clock and CPOL=CPHA=1 there might occur data corruption on
  167. * reads from the SPI device.
  168. * Erratum Workaround:
  169. * Work in one of the following configurations:
  170. * 1. Set CPOL=CPHA=0 in "SPI Interface Configuration
  171. * Register".
  172. * 2. Set TMISO_SAMPLE value to 0x2 in "SPI Timing Parameters 1
  173. * Register" before setting the interface.
  174. */
  175. data = readl(&reg->timing1);
  176. data &= ~KW_SPI_TMISO_SAMPLE_MASK;
  177. if (CFG_SYS_TCLK == 250000000 &&
  178. mode & SPI_CPOL &&
  179. mode & SPI_CPHA)
  180. data |= KW_SPI_TMISO_SAMPLE_2;
  181. else
  182. data |= KW_SPI_TMISO_SAMPLE_1;
  183. writel(data, &reg->timing1);
  184. }
  185. static int mvebu_spi_set_mode(struct udevice *bus, uint mode)
  186. {
  187. struct mvebu_spi_plat *plat = dev_get_plat(bus);
  188. struct kwspi_registers *reg = plat->spireg;
  189. u32 data = readl(&reg->cfg);
  190. data &= ~(KWSPI_CPHA | KWSPI_CPOL | KWSPI_RXLSBF | KWSPI_TXLSBF);
  191. if (mode & SPI_CPHA)
  192. data |= KWSPI_CPHA;
  193. if (mode & SPI_CPOL)
  194. data |= KWSPI_CPOL;
  195. if (mode & SPI_LSB_FIRST)
  196. data |= (KWSPI_RXLSBF | KWSPI_TXLSBF);
  197. writel(data, &reg->cfg);
  198. if (plat->is_errata_50mhz_ac)
  199. mvebu_spi_50mhz_ac_timing_erratum(bus, mode);
  200. return 0;
  201. }
  202. static int mvebu_spi_xfer(struct udevice *dev, unsigned int bitlen,
  203. const void *dout, void *din, unsigned long flags)
  204. {
  205. struct udevice *bus = dev->parent;
  206. struct mvebu_spi_plat *plat = dev_get_plat(bus);
  207. return _spi_xfer(plat->spireg, bitlen, dout, din, flags);
  208. }
  209. __attribute__((weak)) int mvebu_board_spi_claim_bus(struct udevice *dev)
  210. {
  211. return 0;
  212. }
  213. static int mvebu_spi_claim_bus(struct udevice *dev)
  214. {
  215. struct udevice *bus = dev->parent;
  216. struct mvebu_spi_plat *plat = dev_get_plat(bus);
  217. /* Configure the chip-select in the CTRL register */
  218. clrsetbits_le32(&plat->spireg->ctrl,
  219. KWSPI_CS_MASK << KWSPI_CS_SHIFT,
  220. spi_chip_select(dev) << KWSPI_CS_SHIFT);
  221. return mvebu_board_spi_claim_bus(dev);
  222. }
  223. __attribute__((weak)) int mvebu_board_spi_release_bus(struct udevice *dev)
  224. {
  225. return 0;
  226. }
  227. static int mvebu_spi_release_bus(struct udevice *dev)
  228. {
  229. return mvebu_board_spi_release_bus(dev);
  230. }
  231. static int mvebu_spi_probe(struct udevice *bus)
  232. {
  233. struct mvebu_spi_plat *plat = dev_get_plat(bus);
  234. struct kwspi_registers *reg = plat->spireg;
  235. writel(KWSPI_SMEMRDY, &reg->ctrl);
  236. writel(KWSPI_SMEMRDIRQ, &reg->irq_cause);
  237. writel(KWSPI_IRQMASK, &reg->irq_mask);
  238. return 0;
  239. }
  240. static int mvebu_spi_of_to_plat(struct udevice *bus)
  241. {
  242. struct mvebu_spi_plat *plat = dev_get_plat(bus);
  243. const struct mvebu_spi_dev *drvdata =
  244. (struct mvebu_spi_dev *)dev_get_driver_data(bus);
  245. plat->spireg = dev_read_addr_ptr(bus);
  246. plat->is_errata_50mhz_ac = drvdata->is_errata_50mhz_ac;
  247. return 0;
  248. }
  249. static const struct dm_spi_ops mvebu_spi_ops = {
  250. .claim_bus = mvebu_spi_claim_bus,
  251. .release_bus = mvebu_spi_release_bus,
  252. .xfer = mvebu_spi_xfer,
  253. .set_speed = mvebu_spi_set_speed,
  254. .set_mode = mvebu_spi_set_mode,
  255. /*
  256. * cs_info is not needed, since we require all chip selects to be
  257. * in the device tree explicitly
  258. */
  259. };
  260. static const struct mvebu_spi_dev armada_spi_dev_data = {
  261. .is_errata_50mhz_ac = false,
  262. };
  263. static const struct mvebu_spi_dev armada_xp_spi_dev_data = {
  264. .is_errata_50mhz_ac = false,
  265. };
  266. static const struct mvebu_spi_dev armada_375_spi_dev_data = {
  267. .is_errata_50mhz_ac = false,
  268. };
  269. static const struct mvebu_spi_dev armada_380_spi_dev_data = {
  270. .is_errata_50mhz_ac = true,
  271. };
  272. static const struct udevice_id mvebu_spi_ids[] = {
  273. {
  274. .compatible = "marvell,orion-spi",
  275. .data = (ulong)&armada_spi_dev_data,
  276. },
  277. {
  278. .compatible = "marvell,armada-375-spi",
  279. .data = (ulong)&armada_375_spi_dev_data
  280. },
  281. {
  282. .compatible = "marvell,armada-380-spi",
  283. .data = (ulong)&armada_380_spi_dev_data
  284. },
  285. {
  286. .compatible = "marvell,armada-xp-spi",
  287. .data = (ulong)&armada_xp_spi_dev_data
  288. },
  289. { }
  290. };
  291. U_BOOT_DRIVER(mvebu_spi) = {
  292. .name = "mvebu_spi",
  293. .id = UCLASS_SPI,
  294. .of_match = mvebu_spi_ids,
  295. .ops = &mvebu_spi_ops,
  296. .of_to_plat = mvebu_spi_of_to_plat,
  297. .plat_auto = sizeof(struct mvebu_spi_plat),
  298. .priv_auto = sizeof(struct mvebu_spi_priv),
  299. .probe = mvebu_spi_probe,
  300. };