mxc_spi.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2008, Guennadi Liakhovetski <lg@denx.de>
  4. */
  5. #include <common.h>
  6. #include <dm.h>
  7. #include <malloc.h>
  8. #include <spi.h>
  9. #include <linux/errno.h>
  10. #include <asm/io.h>
  11. #include <asm/gpio.h>
  12. #include <asm/arch/imx-regs.h>
  13. #include <asm/arch/clock.h>
  14. #include <asm/mach-imx/spi.h>
  15. DECLARE_GLOBAL_DATA_PTR;
  16. #ifdef CONFIG_MX27
  17. /* i.MX27 has a completely wrong register layout and register definitions in the
  18. * datasheet, the correct one is in the Freescale's Linux driver */
  19. #error "i.MX27 CSPI not supported due to drastic differences in register definitions" \
  20. "See linux mxc_spi driver from Freescale for details."
  21. #endif
  22. __weak int board_spi_cs_gpio(unsigned bus, unsigned cs)
  23. {
  24. return -1;
  25. }
  26. #define OUT MXC_GPIO_DIRECTION_OUT
  27. #define reg_read readl
  28. #define reg_write(a, v) writel(v, a)
  29. #if !defined(CONFIG_SYS_SPI_MXC_WAIT)
  30. #define CONFIG_SYS_SPI_MXC_WAIT (CONFIG_SYS_HZ/100) /* 10 ms */
  31. #endif
  32. struct mxc_spi_slave {
  33. struct spi_slave slave;
  34. unsigned long base;
  35. u32 ctrl_reg;
  36. #if defined(MXC_ECSPI)
  37. u32 cfg_reg;
  38. #endif
  39. int gpio;
  40. int ss_pol;
  41. unsigned int max_hz;
  42. unsigned int mode;
  43. struct gpio_desc ss;
  44. };
  45. static inline struct mxc_spi_slave *to_mxc_spi_slave(struct spi_slave *slave)
  46. {
  47. return container_of(slave, struct mxc_spi_slave, slave);
  48. }
  49. static void mxc_spi_cs_activate(struct mxc_spi_slave *mxcs)
  50. {
  51. if (CONFIG_IS_ENABLED(DM_SPI)) {
  52. dm_gpio_set_value(&mxcs->ss, 1);
  53. } else {
  54. if (mxcs->gpio > 0)
  55. gpio_set_value(mxcs->gpio, mxcs->ss_pol);
  56. }
  57. }
  58. static void mxc_spi_cs_deactivate(struct mxc_spi_slave *mxcs)
  59. {
  60. if (CONFIG_IS_ENABLED(DM_SPI)) {
  61. dm_gpio_set_value(&mxcs->ss, 0);
  62. } else {
  63. if (mxcs->gpio > 0)
  64. gpio_set_value(mxcs->gpio, !(mxcs->ss_pol));
  65. }
  66. }
  67. u32 get_cspi_div(u32 div)
  68. {
  69. int i;
  70. for (i = 0; i < 8; i++) {
  71. if (div <= (4 << i))
  72. return i;
  73. }
  74. return i;
  75. }
  76. #ifdef MXC_CSPI
  77. static s32 spi_cfg_mxc(struct mxc_spi_slave *mxcs, unsigned int cs)
  78. {
  79. unsigned int ctrl_reg;
  80. u32 clk_src;
  81. u32 div;
  82. unsigned int max_hz = mxcs->max_hz;
  83. unsigned int mode = mxcs->mode;
  84. clk_src = mxc_get_clock(MXC_CSPI_CLK);
  85. div = DIV_ROUND_UP(clk_src, max_hz);
  86. div = get_cspi_div(div);
  87. debug("clk %d Hz, div %d, real clk %d Hz\n",
  88. max_hz, div, clk_src / (4 << div));
  89. ctrl_reg = MXC_CSPICTRL_CHIPSELECT(cs) |
  90. MXC_CSPICTRL_BITCOUNT(MXC_CSPICTRL_MAXBITS) |
  91. MXC_CSPICTRL_DATARATE(div) |
  92. MXC_CSPICTRL_EN |
  93. #ifdef CONFIG_MX35
  94. MXC_CSPICTRL_SSCTL |
  95. #endif
  96. MXC_CSPICTRL_MODE;
  97. if (mode & SPI_CPHA)
  98. ctrl_reg |= MXC_CSPICTRL_PHA;
  99. if (mode & SPI_CPOL)
  100. ctrl_reg |= MXC_CSPICTRL_POL;
  101. if (mode & SPI_CS_HIGH)
  102. ctrl_reg |= MXC_CSPICTRL_SSPOL;
  103. mxcs->ctrl_reg = ctrl_reg;
  104. return 0;
  105. }
  106. #endif
  107. #ifdef MXC_ECSPI
  108. static s32 spi_cfg_mxc(struct mxc_spi_slave *mxcs, unsigned int cs)
  109. {
  110. u32 clk_src = mxc_get_clock(MXC_CSPI_CLK);
  111. s32 reg_ctrl, reg_config;
  112. u32 ss_pol = 0, sclkpol = 0, sclkpha = 0, sclkctl = 0;
  113. u32 pre_div = 0, post_div = 0;
  114. struct cspi_regs *regs = (struct cspi_regs *)mxcs->base;
  115. unsigned int max_hz = mxcs->max_hz;
  116. unsigned int mode = mxcs->mode;
  117. /*
  118. * Reset SPI and set all CSs to master mode, if toggling
  119. * between slave and master mode we might see a glitch
  120. * on the clock line
  121. */
  122. reg_ctrl = MXC_CSPICTRL_MODE_MASK;
  123. reg_write(&regs->ctrl, reg_ctrl);
  124. reg_ctrl |= MXC_CSPICTRL_EN;
  125. reg_write(&regs->ctrl, reg_ctrl);
  126. if (clk_src > max_hz) {
  127. pre_div = (clk_src - 1) / max_hz;
  128. /* fls(1) = 1, fls(0x80000000) = 32, fls(16) = 5 */
  129. post_div = fls(pre_div);
  130. if (post_div > 4) {
  131. post_div -= 4;
  132. if (post_div >= 16) {
  133. printf("Error: no divider for the freq: %d\n",
  134. max_hz);
  135. return -1;
  136. }
  137. pre_div >>= post_div;
  138. } else {
  139. post_div = 0;
  140. }
  141. }
  142. debug("pre_div = %d, post_div=%d\n", pre_div, post_div);
  143. reg_ctrl = (reg_ctrl & ~MXC_CSPICTRL_SELCHAN(3)) |
  144. MXC_CSPICTRL_SELCHAN(cs);
  145. reg_ctrl = (reg_ctrl & ~MXC_CSPICTRL_PREDIV(0x0F)) |
  146. MXC_CSPICTRL_PREDIV(pre_div);
  147. reg_ctrl = (reg_ctrl & ~MXC_CSPICTRL_POSTDIV(0x0F)) |
  148. MXC_CSPICTRL_POSTDIV(post_div);
  149. if (mode & SPI_CS_HIGH)
  150. ss_pol = 1;
  151. if (mode & SPI_CPOL) {
  152. sclkpol = 1;
  153. sclkctl = 1;
  154. }
  155. if (mode & SPI_CPHA)
  156. sclkpha = 1;
  157. reg_config = reg_read(&regs->cfg);
  158. /*
  159. * Configuration register setup
  160. * The MX51 supports different setup for each SS
  161. */
  162. reg_config = (reg_config & ~(1 << (cs + MXC_CSPICON_SSPOL))) |
  163. (ss_pol << (cs + MXC_CSPICON_SSPOL));
  164. reg_config = (reg_config & ~(1 << (cs + MXC_CSPICON_POL))) |
  165. (sclkpol << (cs + MXC_CSPICON_POL));
  166. reg_config = (reg_config & ~(1 << (cs + MXC_CSPICON_CTL))) |
  167. (sclkctl << (cs + MXC_CSPICON_CTL));
  168. reg_config = (reg_config & ~(1 << (cs + MXC_CSPICON_PHA))) |
  169. (sclkpha << (cs + MXC_CSPICON_PHA));
  170. debug("reg_ctrl = 0x%x\n", reg_ctrl);
  171. reg_write(&regs->ctrl, reg_ctrl);
  172. debug("reg_config = 0x%x\n", reg_config);
  173. reg_write(&regs->cfg, reg_config);
  174. /* save config register and control register */
  175. mxcs->ctrl_reg = reg_ctrl;
  176. mxcs->cfg_reg = reg_config;
  177. /* clear interrupt reg */
  178. reg_write(&regs->intr, 0);
  179. reg_write(&regs->stat, MXC_CSPICTRL_TC | MXC_CSPICTRL_RXOVF);
  180. return 0;
  181. }
  182. #endif
  183. int spi_xchg_single(struct mxc_spi_slave *mxcs, unsigned int bitlen,
  184. const u8 *dout, u8 *din, unsigned long flags)
  185. {
  186. int nbytes = DIV_ROUND_UP(bitlen, 8);
  187. u32 data, cnt, i;
  188. struct cspi_regs *regs = (struct cspi_regs *)mxcs->base;
  189. u32 ts;
  190. int status;
  191. debug("%s: bitlen %d dout 0x%x din 0x%x\n",
  192. __func__, bitlen, (u32)dout, (u32)din);
  193. mxcs->ctrl_reg = (mxcs->ctrl_reg &
  194. ~MXC_CSPICTRL_BITCOUNT(MXC_CSPICTRL_MAXBITS)) |
  195. MXC_CSPICTRL_BITCOUNT(bitlen - 1);
  196. reg_write(&regs->ctrl, mxcs->ctrl_reg | MXC_CSPICTRL_EN);
  197. #ifdef MXC_ECSPI
  198. reg_write(&regs->cfg, mxcs->cfg_reg);
  199. #endif
  200. /* Clear interrupt register */
  201. reg_write(&regs->stat, MXC_CSPICTRL_TC | MXC_CSPICTRL_RXOVF);
  202. /*
  203. * The SPI controller works only with words,
  204. * check if less than a word is sent.
  205. * Access to the FIFO is only 32 bit
  206. */
  207. if (bitlen % 32) {
  208. data = 0;
  209. cnt = (bitlen % 32) / 8;
  210. if (dout) {
  211. for (i = 0; i < cnt; i++) {
  212. data = (data << 8) | (*dout++ & 0xFF);
  213. }
  214. }
  215. debug("Sending SPI 0x%x\n", data);
  216. reg_write(&regs->txdata, data);
  217. nbytes -= cnt;
  218. }
  219. data = 0;
  220. while (nbytes > 0) {
  221. data = 0;
  222. if (dout) {
  223. /* Buffer is not 32-bit aligned */
  224. if ((unsigned long)dout & 0x03) {
  225. data = 0;
  226. for (i = 0; i < 4; i++)
  227. data = (data << 8) | (*dout++ & 0xFF);
  228. } else {
  229. data = *(u32 *)dout;
  230. data = cpu_to_be32(data);
  231. dout += 4;
  232. }
  233. }
  234. debug("Sending SPI 0x%x\n", data);
  235. reg_write(&regs->txdata, data);
  236. nbytes -= 4;
  237. }
  238. /* FIFO is written, now starts the transfer setting the XCH bit */
  239. reg_write(&regs->ctrl, mxcs->ctrl_reg |
  240. MXC_CSPICTRL_EN | MXC_CSPICTRL_XCH);
  241. ts = get_timer(0);
  242. status = reg_read(&regs->stat);
  243. /* Wait until the TC (Transfer completed) bit is set */
  244. while ((status & MXC_CSPICTRL_TC) == 0) {
  245. if (get_timer(ts) > CONFIG_SYS_SPI_MXC_WAIT) {
  246. printf("spi_xchg_single: Timeout!\n");
  247. return -1;
  248. }
  249. status = reg_read(&regs->stat);
  250. }
  251. /* Transfer completed, clear any pending request */
  252. reg_write(&regs->stat, MXC_CSPICTRL_TC | MXC_CSPICTRL_RXOVF);
  253. nbytes = DIV_ROUND_UP(bitlen, 8);
  254. cnt = nbytes % 32;
  255. if (bitlen % 32) {
  256. data = reg_read(&regs->rxdata);
  257. cnt = (bitlen % 32) / 8;
  258. data = cpu_to_be32(data) >> ((sizeof(data) - cnt) * 8);
  259. debug("SPI Rx unaligned: 0x%x\n", data);
  260. if (din) {
  261. memcpy(din, &data, cnt);
  262. din += cnt;
  263. }
  264. nbytes -= cnt;
  265. }
  266. while (nbytes > 0) {
  267. u32 tmp;
  268. tmp = reg_read(&regs->rxdata);
  269. data = cpu_to_be32(tmp);
  270. debug("SPI Rx: 0x%x 0x%x\n", tmp, data);
  271. cnt = min_t(u32, nbytes, sizeof(data));
  272. if (din) {
  273. memcpy(din, &data, cnt);
  274. din += cnt;
  275. }
  276. nbytes -= cnt;
  277. }
  278. return 0;
  279. }
  280. static int mxc_spi_xfer_internal(struct mxc_spi_slave *mxcs,
  281. unsigned int bitlen, const void *dout,
  282. void *din, unsigned long flags)
  283. {
  284. int n_bytes = DIV_ROUND_UP(bitlen, 8);
  285. int n_bits;
  286. int ret;
  287. u32 blk_size;
  288. u8 *p_outbuf = (u8 *)dout;
  289. u8 *p_inbuf = (u8 *)din;
  290. if (!mxcs)
  291. return -EINVAL;
  292. if (flags & SPI_XFER_BEGIN)
  293. mxc_spi_cs_activate(mxcs);
  294. while (n_bytes > 0) {
  295. if (n_bytes < MAX_SPI_BYTES)
  296. blk_size = n_bytes;
  297. else
  298. blk_size = MAX_SPI_BYTES;
  299. n_bits = blk_size * 8;
  300. ret = spi_xchg_single(mxcs, n_bits, p_outbuf, p_inbuf, 0);
  301. if (ret)
  302. return ret;
  303. if (dout)
  304. p_outbuf += blk_size;
  305. if (din)
  306. p_inbuf += blk_size;
  307. n_bytes -= blk_size;
  308. }
  309. if (flags & SPI_XFER_END) {
  310. mxc_spi_cs_deactivate(mxcs);
  311. }
  312. return 0;
  313. }
  314. static int mxc_spi_claim_bus_internal(struct mxc_spi_slave *mxcs, int cs)
  315. {
  316. struct cspi_regs *regs = (struct cspi_regs *)mxcs->base;
  317. int ret;
  318. reg_write(&regs->rxdata, 1);
  319. udelay(1);
  320. ret = spi_cfg_mxc(mxcs, cs);
  321. if (ret) {
  322. printf("mxc_spi: cannot setup SPI controller\n");
  323. return ret;
  324. }
  325. reg_write(&regs->period, MXC_CSPIPERIOD_32KHZ);
  326. reg_write(&regs->intr, 0);
  327. return 0;
  328. }
  329. #ifndef CONFIG_DM_SPI
  330. int spi_xfer(struct spi_slave *slave, unsigned int bitlen, const void *dout,
  331. void *din, unsigned long flags)
  332. {
  333. struct mxc_spi_slave *mxcs = to_mxc_spi_slave(slave);
  334. return mxc_spi_xfer_internal(mxcs, bitlen, dout, din, flags);
  335. }
  336. /*
  337. * Some SPI devices require active chip-select over multiple
  338. * transactions, we achieve this using a GPIO. Still, the SPI
  339. * controller has to be configured to use one of its own chipselects.
  340. * To use this feature you have to implement board_spi_cs_gpio() to assign
  341. * a gpio value for each cs (-1 if cs doesn't need to use gpio).
  342. * You must use some unused on this SPI controller cs between 0 and 3.
  343. */
  344. static int setup_cs_gpio(struct mxc_spi_slave *mxcs,
  345. unsigned int bus, unsigned int cs)
  346. {
  347. int ret;
  348. mxcs->gpio = board_spi_cs_gpio(bus, cs);
  349. if (mxcs->gpio == -1)
  350. return 0;
  351. gpio_request(mxcs->gpio, "spi-cs");
  352. ret = gpio_direction_output(mxcs->gpio, !(mxcs->ss_pol));
  353. if (ret) {
  354. printf("mxc_spi: cannot setup gpio %d\n", mxcs->gpio);
  355. return -EINVAL;
  356. }
  357. return 0;
  358. }
  359. static unsigned long spi_bases[] = {
  360. MXC_SPI_BASE_ADDRESSES
  361. };
  362. struct spi_slave *spi_setup_slave(unsigned int bus, unsigned int cs,
  363. unsigned int max_hz, unsigned int mode)
  364. {
  365. struct mxc_spi_slave *mxcs;
  366. int ret;
  367. if (bus >= ARRAY_SIZE(spi_bases))
  368. return NULL;
  369. if (max_hz == 0) {
  370. printf("Error: desired clock is 0\n");
  371. return NULL;
  372. }
  373. mxcs = spi_alloc_slave(struct mxc_spi_slave, bus, cs);
  374. if (!mxcs) {
  375. puts("mxc_spi: SPI Slave not allocated !\n");
  376. return NULL;
  377. }
  378. mxcs->ss_pol = (mode & SPI_CS_HIGH) ? 1 : 0;
  379. ret = setup_cs_gpio(mxcs, bus, cs);
  380. if (ret < 0) {
  381. free(mxcs);
  382. return NULL;
  383. }
  384. mxcs->base = spi_bases[bus];
  385. mxcs->max_hz = max_hz;
  386. mxcs->mode = mode;
  387. return &mxcs->slave;
  388. }
  389. void spi_free_slave(struct spi_slave *slave)
  390. {
  391. struct mxc_spi_slave *mxcs = to_mxc_spi_slave(slave);
  392. free(mxcs);
  393. }
  394. int spi_claim_bus(struct spi_slave *slave)
  395. {
  396. struct mxc_spi_slave *mxcs = to_mxc_spi_slave(slave);
  397. return mxc_spi_claim_bus_internal(mxcs, slave->cs);
  398. }
  399. void spi_release_bus(struct spi_slave *slave)
  400. {
  401. /* TODO: Shut the controller down */
  402. }
  403. #else
  404. static int mxc_spi_probe(struct udevice *bus)
  405. {
  406. struct mxc_spi_slave *plat = bus->platdata;
  407. struct mxc_spi_slave *mxcs = dev_get_platdata(bus);
  408. int node = dev_of_offset(bus);
  409. const void *blob = gd->fdt_blob;
  410. int ret;
  411. if (gpio_request_by_name(bus, "cs-gpios", 0, &plat->ss,
  412. GPIOD_IS_OUT)) {
  413. dev_err(bus, "No cs-gpios property\n");
  414. return -EINVAL;
  415. }
  416. plat->base = devfdt_get_addr(bus);
  417. if (plat->base == FDT_ADDR_T_NONE)
  418. return -ENODEV;
  419. ret = dm_gpio_set_value(&plat->ss, 0);
  420. if (ret) {
  421. dev_err(bus, "Setting cs error\n");
  422. return ret;
  423. }
  424. mxcs->max_hz = fdtdec_get_int(blob, node, "spi-max-frequency",
  425. 20000000);
  426. return 0;
  427. }
  428. static int mxc_spi_xfer(struct udevice *dev, unsigned int bitlen,
  429. const void *dout, void *din, unsigned long flags)
  430. {
  431. struct mxc_spi_slave *mxcs = dev_get_platdata(dev->parent);
  432. return mxc_spi_xfer_internal(mxcs, bitlen, dout, din, flags);
  433. }
  434. static int mxc_spi_claim_bus(struct udevice *dev)
  435. {
  436. struct mxc_spi_slave *mxcs = dev_get_platdata(dev->parent);
  437. struct dm_spi_slave_platdata *slave_plat = dev_get_parent_platdata(dev);
  438. return mxc_spi_claim_bus_internal(mxcs, slave_plat->cs);
  439. }
  440. static int mxc_spi_release_bus(struct udevice *dev)
  441. {
  442. return 0;
  443. }
  444. static int mxc_spi_set_speed(struct udevice *bus, uint speed)
  445. {
  446. /* Nothing to do */
  447. return 0;
  448. }
  449. static int mxc_spi_set_mode(struct udevice *bus, uint mode)
  450. {
  451. struct mxc_spi_slave *mxcs = dev_get_platdata(bus);
  452. mxcs->mode = mode;
  453. mxcs->ss_pol = (mode & SPI_CS_HIGH) ? 1 : 0;
  454. return 0;
  455. }
  456. static const struct dm_spi_ops mxc_spi_ops = {
  457. .claim_bus = mxc_spi_claim_bus,
  458. .release_bus = mxc_spi_release_bus,
  459. .xfer = mxc_spi_xfer,
  460. .set_speed = mxc_spi_set_speed,
  461. .set_mode = mxc_spi_set_mode,
  462. };
  463. static const struct udevice_id mxc_spi_ids[] = {
  464. { .compatible = "fsl,imx51-ecspi" },
  465. { }
  466. };
  467. U_BOOT_DRIVER(mxc_spi) = {
  468. .name = "mxc_spi",
  469. .id = UCLASS_SPI,
  470. .of_match = mxc_spi_ids,
  471. .ops = &mxc_spi_ops,
  472. .platdata_auto_alloc_size = sizeof(struct mxc_spi_slave),
  473. .probe = mxc_spi_probe,
  474. };
  475. #endif