mxc_spi.c 13 KB

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