mxc_spi.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582
  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. void spi_init(void)
  337. {
  338. }
  339. /*
  340. * Some SPI devices require active chip-select over multiple
  341. * transactions, we achieve this using a GPIO. Still, the SPI
  342. * controller has to be configured to use one of its own chipselects.
  343. * To use this feature you have to implement board_spi_cs_gpio() to assign
  344. * a gpio value for each cs (-1 if cs doesn't need to use gpio).
  345. * You must use some unused on this SPI controller cs between 0 and 3.
  346. */
  347. static int setup_cs_gpio(struct mxc_spi_slave *mxcs,
  348. unsigned int bus, unsigned int cs)
  349. {
  350. int ret;
  351. mxcs->gpio = board_spi_cs_gpio(bus, cs);
  352. if (mxcs->gpio == -1)
  353. return 0;
  354. gpio_request(mxcs->gpio, "spi-cs");
  355. ret = gpio_direction_output(mxcs->gpio, !(mxcs->ss_pol));
  356. if (ret) {
  357. printf("mxc_spi: cannot setup gpio %d\n", mxcs->gpio);
  358. return -EINVAL;
  359. }
  360. return 0;
  361. }
  362. static unsigned long spi_bases[] = {
  363. MXC_SPI_BASE_ADDRESSES
  364. };
  365. struct spi_slave *spi_setup_slave(unsigned int bus, unsigned int cs,
  366. unsigned int max_hz, unsigned int mode)
  367. {
  368. struct mxc_spi_slave *mxcs;
  369. int ret;
  370. if (bus >= ARRAY_SIZE(spi_bases))
  371. return NULL;
  372. if (max_hz == 0) {
  373. printf("Error: desired clock is 0\n");
  374. return NULL;
  375. }
  376. mxcs = spi_alloc_slave(struct mxc_spi_slave, bus, cs);
  377. if (!mxcs) {
  378. puts("mxc_spi: SPI Slave not allocated !\n");
  379. return NULL;
  380. }
  381. mxcs->ss_pol = (mode & SPI_CS_HIGH) ? 1 : 0;
  382. ret = setup_cs_gpio(mxcs, bus, cs);
  383. if (ret < 0) {
  384. free(mxcs);
  385. return NULL;
  386. }
  387. mxcs->base = spi_bases[bus];
  388. mxcs->max_hz = max_hz;
  389. mxcs->mode = mode;
  390. return &mxcs->slave;
  391. }
  392. void spi_free_slave(struct spi_slave *slave)
  393. {
  394. struct mxc_spi_slave *mxcs = to_mxc_spi_slave(slave);
  395. free(mxcs);
  396. }
  397. int spi_claim_bus(struct spi_slave *slave)
  398. {
  399. struct mxc_spi_slave *mxcs = to_mxc_spi_slave(slave);
  400. return mxc_spi_claim_bus_internal(mxcs, slave->cs);
  401. }
  402. void spi_release_bus(struct spi_slave *slave)
  403. {
  404. /* TODO: Shut the controller down */
  405. }
  406. #else
  407. static int mxc_spi_probe(struct udevice *bus)
  408. {
  409. struct mxc_spi_slave *plat = bus->platdata;
  410. struct mxc_spi_slave *mxcs = dev_get_platdata(bus);
  411. int node = dev_of_offset(bus);
  412. const void *blob = gd->fdt_blob;
  413. int ret;
  414. if (gpio_request_by_name(bus, "cs-gpios", 0, &plat->ss,
  415. GPIOD_IS_OUT)) {
  416. dev_err(bus, "No cs-gpios property\n");
  417. return -EINVAL;
  418. }
  419. plat->base = devfdt_get_addr(bus);
  420. if (plat->base == FDT_ADDR_T_NONE)
  421. return -ENODEV;
  422. ret = dm_gpio_set_value(&plat->ss, 0);
  423. if (ret) {
  424. dev_err(bus, "Setting cs error\n");
  425. return ret;
  426. }
  427. mxcs->max_hz = fdtdec_get_int(blob, node, "spi-max-frequency",
  428. 20000000);
  429. return 0;
  430. }
  431. static int mxc_spi_xfer(struct udevice *dev, unsigned int bitlen,
  432. const void *dout, void *din, unsigned long flags)
  433. {
  434. struct mxc_spi_slave *mxcs = dev_get_platdata(dev->parent);
  435. return mxc_spi_xfer_internal(mxcs, bitlen, dout, din, flags);
  436. }
  437. static int mxc_spi_claim_bus(struct udevice *dev)
  438. {
  439. struct mxc_spi_slave *mxcs = dev_get_platdata(dev->parent);
  440. struct dm_spi_slave_platdata *slave_plat = dev_get_parent_platdata(dev);
  441. return mxc_spi_claim_bus_internal(mxcs, slave_plat->cs);
  442. }
  443. static int mxc_spi_release_bus(struct udevice *dev)
  444. {
  445. return 0;
  446. }
  447. static int mxc_spi_set_speed(struct udevice *bus, uint speed)
  448. {
  449. /* Nothing to do */
  450. return 0;
  451. }
  452. static int mxc_spi_set_mode(struct udevice *bus, uint mode)
  453. {
  454. struct mxc_spi_slave *mxcs = dev_get_platdata(bus);
  455. mxcs->mode = mode;
  456. mxcs->ss_pol = (mode & SPI_CS_HIGH) ? 1 : 0;
  457. return 0;
  458. }
  459. static const struct dm_spi_ops mxc_spi_ops = {
  460. .claim_bus = mxc_spi_claim_bus,
  461. .release_bus = mxc_spi_release_bus,
  462. .xfer = mxc_spi_xfer,
  463. .set_speed = mxc_spi_set_speed,
  464. .set_mode = mxc_spi_set_mode,
  465. };
  466. static const struct udevice_id mxc_spi_ids[] = {
  467. { .compatible = "fsl,imx51-ecspi" },
  468. { }
  469. };
  470. U_BOOT_DRIVER(mxc_spi) = {
  471. .name = "mxc_spi",
  472. .id = UCLASS_SPI,
  473. .of_match = mxc_spi_ids,
  474. .ops = &mxc_spi_ops,
  475. .platdata_auto_alloc_size = sizeof(struct mxc_spi_slave),
  476. .probe = mxc_spi_probe,
  477. };
  478. #endif