sdhci.c 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright 2011, Marvell Semiconductor Inc.
  4. * Lei Wen <leiwen@marvell.com>
  5. *
  6. * Back ported to the 8xx platform (from the 8260 platform) by
  7. * Murray.Jensen@cmst.csiro.au, 27-Jan-01.
  8. */
  9. #include <common.h>
  10. #include <errno.h>
  11. #include <malloc.h>
  12. #include <mmc.h>
  13. #include <sdhci.h>
  14. #if defined(CONFIG_FIXED_SDHCI_ALIGNED_BUFFER)
  15. void *aligned_buffer = (void *)CONFIG_FIXED_SDHCI_ALIGNED_BUFFER;
  16. #else
  17. void *aligned_buffer;
  18. #endif
  19. static void sdhci_reset(struct sdhci_host *host, u8 mask)
  20. {
  21. unsigned long timeout;
  22. /* Wait max 100 ms */
  23. timeout = 100;
  24. sdhci_writeb(host, mask, SDHCI_SOFTWARE_RESET);
  25. while (sdhci_readb(host, SDHCI_SOFTWARE_RESET) & mask) {
  26. if (timeout == 0) {
  27. printf("%s: Reset 0x%x never completed.\n",
  28. __func__, (int)mask);
  29. return;
  30. }
  31. timeout--;
  32. udelay(1000);
  33. }
  34. }
  35. static void sdhci_cmd_done(struct sdhci_host *host, struct mmc_cmd *cmd)
  36. {
  37. int i;
  38. if (cmd->resp_type & MMC_RSP_136) {
  39. /* CRC is stripped so we need to do some shifting. */
  40. for (i = 0; i < 4; i++) {
  41. cmd->response[i] = sdhci_readl(host,
  42. SDHCI_RESPONSE + (3-i)*4) << 8;
  43. if (i != 3)
  44. cmd->response[i] |= sdhci_readb(host,
  45. SDHCI_RESPONSE + (3-i)*4-1);
  46. }
  47. } else {
  48. cmd->response[0] = sdhci_readl(host, SDHCI_RESPONSE);
  49. }
  50. }
  51. static void sdhci_transfer_pio(struct sdhci_host *host, struct mmc_data *data)
  52. {
  53. int i;
  54. char *offs;
  55. for (i = 0; i < data->blocksize; i += 4) {
  56. offs = data->dest + i;
  57. if (data->flags == MMC_DATA_READ)
  58. *(u32 *)offs = sdhci_readl(host, SDHCI_BUFFER);
  59. else
  60. sdhci_writel(host, *(u32 *)offs, SDHCI_BUFFER);
  61. }
  62. }
  63. static int sdhci_transfer_data(struct sdhci_host *host, struct mmc_data *data,
  64. unsigned int start_addr)
  65. {
  66. unsigned int stat, rdy, mask, timeout, block = 0;
  67. bool transfer_done = false;
  68. #ifdef CONFIG_MMC_SDHCI_SDMA
  69. unsigned char ctrl;
  70. ctrl = sdhci_readb(host, SDHCI_HOST_CONTROL);
  71. ctrl &= ~SDHCI_CTRL_DMA_MASK;
  72. sdhci_writeb(host, ctrl, SDHCI_HOST_CONTROL);
  73. #endif
  74. timeout = 1000000;
  75. rdy = SDHCI_INT_SPACE_AVAIL | SDHCI_INT_DATA_AVAIL;
  76. mask = SDHCI_DATA_AVAILABLE | SDHCI_SPACE_AVAILABLE;
  77. do {
  78. stat = sdhci_readl(host, SDHCI_INT_STATUS);
  79. if (stat & SDHCI_INT_ERROR) {
  80. pr_debug("%s: Error detected in status(0x%X)!\n",
  81. __func__, stat);
  82. return -EIO;
  83. }
  84. if (!transfer_done && (stat & rdy)) {
  85. if (!(sdhci_readl(host, SDHCI_PRESENT_STATE) & mask))
  86. continue;
  87. sdhci_writel(host, rdy, SDHCI_INT_STATUS);
  88. sdhci_transfer_pio(host, data);
  89. data->dest += data->blocksize;
  90. if (++block >= data->blocks) {
  91. /* Keep looping until the SDHCI_INT_DATA_END is
  92. * cleared, even if we finished sending all the
  93. * blocks.
  94. */
  95. transfer_done = true;
  96. continue;
  97. }
  98. }
  99. #ifdef CONFIG_MMC_SDHCI_SDMA
  100. if (!transfer_done && (stat & SDHCI_INT_DMA_END)) {
  101. sdhci_writel(host, SDHCI_INT_DMA_END, SDHCI_INT_STATUS);
  102. start_addr &= ~(SDHCI_DEFAULT_BOUNDARY_SIZE - 1);
  103. start_addr += SDHCI_DEFAULT_BOUNDARY_SIZE;
  104. sdhci_writel(host, start_addr, SDHCI_DMA_ADDRESS);
  105. }
  106. #endif
  107. if (timeout-- > 0)
  108. udelay(10);
  109. else {
  110. printf("%s: Transfer data timeout\n", __func__);
  111. return -ETIMEDOUT;
  112. }
  113. } while (!(stat & SDHCI_INT_DATA_END));
  114. return 0;
  115. }
  116. /*
  117. * No command will be sent by driver if card is busy, so driver must wait
  118. * for card ready state.
  119. * Every time when card is busy after timeout then (last) timeout value will be
  120. * increased twice but only if it doesn't exceed global defined maximum.
  121. * Each function call will use last timeout value.
  122. */
  123. #define SDHCI_CMD_MAX_TIMEOUT 3200
  124. #define SDHCI_CMD_DEFAULT_TIMEOUT 100
  125. #define SDHCI_READ_STATUS_TIMEOUT 1000
  126. #ifdef CONFIG_DM_MMC
  127. static int sdhci_send_command(struct udevice *dev, struct mmc_cmd *cmd,
  128. struct mmc_data *data)
  129. {
  130. struct mmc *mmc = mmc_get_mmc_dev(dev);
  131. #else
  132. static int sdhci_send_command(struct mmc *mmc, struct mmc_cmd *cmd,
  133. struct mmc_data *data)
  134. {
  135. #endif
  136. struct sdhci_host *host = mmc->priv;
  137. unsigned int stat = 0;
  138. int ret = 0;
  139. int trans_bytes = 0, is_aligned = 1;
  140. u32 mask, flags, mode;
  141. unsigned int time = 0, start_addr = 0;
  142. int mmc_dev = mmc_get_blk_desc(mmc)->devnum;
  143. ulong start = get_timer(0);
  144. /* Timeout unit - ms */
  145. static unsigned int cmd_timeout = SDHCI_CMD_DEFAULT_TIMEOUT;
  146. mask = SDHCI_CMD_INHIBIT | SDHCI_DATA_INHIBIT;
  147. /* We shouldn't wait for data inihibit for stop commands, even
  148. though they might use busy signaling */
  149. if (cmd->cmdidx == MMC_CMD_STOP_TRANSMISSION ||
  150. ((cmd->cmdidx == MMC_CMD_SEND_TUNING_BLOCK ||
  151. cmd->cmdidx == MMC_CMD_SEND_TUNING_BLOCK_HS200) && !data))
  152. mask &= ~SDHCI_DATA_INHIBIT;
  153. while (sdhci_readl(host, SDHCI_PRESENT_STATE) & mask) {
  154. if (time >= cmd_timeout) {
  155. printf("%s: MMC: %d busy ", __func__, mmc_dev);
  156. if (2 * cmd_timeout <= SDHCI_CMD_MAX_TIMEOUT) {
  157. cmd_timeout += cmd_timeout;
  158. printf("timeout increasing to: %u ms.\n",
  159. cmd_timeout);
  160. } else {
  161. puts("timeout.\n");
  162. return -ECOMM;
  163. }
  164. }
  165. time++;
  166. udelay(1000);
  167. }
  168. sdhci_writel(host, SDHCI_INT_ALL_MASK, SDHCI_INT_STATUS);
  169. mask = SDHCI_INT_RESPONSE;
  170. if ((cmd->cmdidx == MMC_CMD_SEND_TUNING_BLOCK ||
  171. cmd->cmdidx == MMC_CMD_SEND_TUNING_BLOCK_HS200) && !data)
  172. mask = SDHCI_INT_DATA_AVAIL;
  173. if (!(cmd->resp_type & MMC_RSP_PRESENT))
  174. flags = SDHCI_CMD_RESP_NONE;
  175. else if (cmd->resp_type & MMC_RSP_136)
  176. flags = SDHCI_CMD_RESP_LONG;
  177. else if (cmd->resp_type & MMC_RSP_BUSY) {
  178. flags = SDHCI_CMD_RESP_SHORT_BUSY;
  179. if (data)
  180. mask |= SDHCI_INT_DATA_END;
  181. } else
  182. flags = SDHCI_CMD_RESP_SHORT;
  183. if (cmd->resp_type & MMC_RSP_CRC)
  184. flags |= SDHCI_CMD_CRC;
  185. if (cmd->resp_type & MMC_RSP_OPCODE)
  186. flags |= SDHCI_CMD_INDEX;
  187. if (data || cmd->cmdidx == MMC_CMD_SEND_TUNING_BLOCK ||
  188. cmd->cmdidx == MMC_CMD_SEND_TUNING_BLOCK_HS200)
  189. flags |= SDHCI_CMD_DATA;
  190. /* Set Transfer mode regarding to data flag */
  191. if (data) {
  192. sdhci_writeb(host, 0xe, SDHCI_TIMEOUT_CONTROL);
  193. mode = SDHCI_TRNS_BLK_CNT_EN;
  194. trans_bytes = data->blocks * data->blocksize;
  195. if (data->blocks > 1)
  196. mode |= SDHCI_TRNS_MULTI;
  197. if (data->flags == MMC_DATA_READ)
  198. mode |= SDHCI_TRNS_READ;
  199. #ifdef CONFIG_MMC_SDHCI_SDMA
  200. if (data->flags == MMC_DATA_READ)
  201. start_addr = (unsigned long)data->dest;
  202. else
  203. start_addr = (unsigned long)data->src;
  204. if ((host->quirks & SDHCI_QUIRK_32BIT_DMA_ADDR) &&
  205. (start_addr & 0x7) != 0x0) {
  206. is_aligned = 0;
  207. start_addr = (unsigned long)aligned_buffer;
  208. if (data->flags != MMC_DATA_READ)
  209. memcpy(aligned_buffer, data->src, trans_bytes);
  210. }
  211. #if defined(CONFIG_FIXED_SDHCI_ALIGNED_BUFFER)
  212. /*
  213. * Always use this bounce-buffer when
  214. * CONFIG_FIXED_SDHCI_ALIGNED_BUFFER is defined
  215. */
  216. is_aligned = 0;
  217. start_addr = (unsigned long)aligned_buffer;
  218. if (data->flags != MMC_DATA_READ)
  219. memcpy(aligned_buffer, data->src, trans_bytes);
  220. #endif
  221. sdhci_writel(host, start_addr, SDHCI_DMA_ADDRESS);
  222. mode |= SDHCI_TRNS_DMA;
  223. #endif
  224. sdhci_writew(host, SDHCI_MAKE_BLKSZ(SDHCI_DEFAULT_BOUNDARY_ARG,
  225. data->blocksize),
  226. SDHCI_BLOCK_SIZE);
  227. sdhci_writew(host, data->blocks, SDHCI_BLOCK_COUNT);
  228. sdhci_writew(host, mode, SDHCI_TRANSFER_MODE);
  229. } else if (cmd->resp_type & MMC_RSP_BUSY) {
  230. sdhci_writeb(host, 0xe, SDHCI_TIMEOUT_CONTROL);
  231. }
  232. sdhci_writel(host, cmd->cmdarg, SDHCI_ARGUMENT);
  233. #ifdef CONFIG_MMC_SDHCI_SDMA
  234. if (data) {
  235. trans_bytes = ALIGN(trans_bytes, CONFIG_SYS_CACHELINE_SIZE);
  236. flush_cache(start_addr, trans_bytes);
  237. }
  238. #endif
  239. sdhci_writew(host, SDHCI_MAKE_CMD(cmd->cmdidx, flags), SDHCI_COMMAND);
  240. start = get_timer(0);
  241. do {
  242. stat = sdhci_readl(host, SDHCI_INT_STATUS);
  243. if (stat & SDHCI_INT_ERROR)
  244. break;
  245. if (get_timer(start) >= SDHCI_READ_STATUS_TIMEOUT) {
  246. if (host->quirks & SDHCI_QUIRK_BROKEN_R1B) {
  247. return 0;
  248. } else {
  249. printf("%s: Timeout for status update!\n",
  250. __func__);
  251. return -ETIMEDOUT;
  252. }
  253. }
  254. } while ((stat & mask) != mask);
  255. if ((stat & (SDHCI_INT_ERROR | mask)) == mask) {
  256. sdhci_cmd_done(host, cmd);
  257. sdhci_writel(host, mask, SDHCI_INT_STATUS);
  258. } else
  259. ret = -1;
  260. if (!ret && data)
  261. ret = sdhci_transfer_data(host, data, start_addr);
  262. if (host->quirks & SDHCI_QUIRK_WAIT_SEND_CMD)
  263. udelay(1000);
  264. stat = sdhci_readl(host, SDHCI_INT_STATUS);
  265. sdhci_writel(host, SDHCI_INT_ALL_MASK, SDHCI_INT_STATUS);
  266. if (!ret) {
  267. if ((host->quirks & SDHCI_QUIRK_32BIT_DMA_ADDR) &&
  268. !is_aligned && (data->flags == MMC_DATA_READ))
  269. memcpy(data->dest, aligned_buffer, trans_bytes);
  270. return 0;
  271. }
  272. sdhci_reset(host, SDHCI_RESET_CMD);
  273. sdhci_reset(host, SDHCI_RESET_DATA);
  274. if (stat & SDHCI_INT_TIMEOUT)
  275. return -ETIMEDOUT;
  276. else
  277. return -ECOMM;
  278. }
  279. #if defined(CONFIG_DM_MMC) && defined(MMC_SUPPORTS_TUNING)
  280. static int sdhci_execute_tuning(struct udevice *dev, uint opcode)
  281. {
  282. int err;
  283. struct mmc *mmc = mmc_get_mmc_dev(dev);
  284. struct sdhci_host *host = mmc->priv;
  285. debug("%s\n", __func__);
  286. if (host->ops && host->ops->platform_execute_tuning) {
  287. err = host->ops->platform_execute_tuning(mmc, opcode);
  288. if (err)
  289. return err;
  290. return 0;
  291. }
  292. return 0;
  293. }
  294. #endif
  295. static int sdhci_set_clock(struct mmc *mmc, unsigned int clock)
  296. {
  297. struct sdhci_host *host = mmc->priv;
  298. unsigned int div, clk = 0, timeout;
  299. /* Wait max 20 ms */
  300. timeout = 200;
  301. while (sdhci_readl(host, SDHCI_PRESENT_STATE) &
  302. (SDHCI_CMD_INHIBIT | SDHCI_DATA_INHIBIT)) {
  303. if (timeout == 0) {
  304. printf("%s: Timeout to wait cmd & data inhibit\n",
  305. __func__);
  306. return -EBUSY;
  307. }
  308. timeout--;
  309. udelay(100);
  310. }
  311. sdhci_writew(host, 0, SDHCI_CLOCK_CONTROL);
  312. if (clock == 0)
  313. return 0;
  314. if (host->ops && host->ops->set_delay)
  315. host->ops->set_delay(host);
  316. if (SDHCI_GET_VERSION(host) >= SDHCI_SPEC_300) {
  317. /*
  318. * Check if the Host Controller supports Programmable Clock
  319. * Mode.
  320. */
  321. if (host->clk_mul) {
  322. for (div = 1; div <= 1024; div++) {
  323. if ((host->max_clk / div) <= clock)
  324. break;
  325. }
  326. /*
  327. * Set Programmable Clock Mode in the Clock
  328. * Control register.
  329. */
  330. clk = SDHCI_PROG_CLOCK_MODE;
  331. div--;
  332. } else {
  333. /* Version 3.00 divisors must be a multiple of 2. */
  334. if (host->max_clk <= clock) {
  335. div = 1;
  336. } else {
  337. for (div = 2;
  338. div < SDHCI_MAX_DIV_SPEC_300;
  339. div += 2) {
  340. if ((host->max_clk / div) <= clock)
  341. break;
  342. }
  343. }
  344. div >>= 1;
  345. }
  346. } else {
  347. /* Version 2.00 divisors must be a power of 2. */
  348. for (div = 1; div < SDHCI_MAX_DIV_SPEC_200; div *= 2) {
  349. if ((host->max_clk / div) <= clock)
  350. break;
  351. }
  352. div >>= 1;
  353. }
  354. if (host->ops && host->ops->set_clock)
  355. host->ops->set_clock(host, div);
  356. clk |= (div & SDHCI_DIV_MASK) << SDHCI_DIVIDER_SHIFT;
  357. clk |= ((div & SDHCI_DIV_HI_MASK) >> SDHCI_DIV_MASK_LEN)
  358. << SDHCI_DIVIDER_HI_SHIFT;
  359. clk |= SDHCI_CLOCK_INT_EN;
  360. sdhci_writew(host, clk, SDHCI_CLOCK_CONTROL);
  361. /* Wait max 20 ms */
  362. timeout = 20;
  363. while (!((clk = sdhci_readw(host, SDHCI_CLOCK_CONTROL))
  364. & SDHCI_CLOCK_INT_STABLE)) {
  365. if (timeout == 0) {
  366. printf("%s: Internal clock never stabilised.\n",
  367. __func__);
  368. return -EBUSY;
  369. }
  370. timeout--;
  371. udelay(1000);
  372. }
  373. clk |= SDHCI_CLOCK_CARD_EN;
  374. sdhci_writew(host, clk, SDHCI_CLOCK_CONTROL);
  375. return 0;
  376. }
  377. static void sdhci_set_power(struct sdhci_host *host, unsigned short power)
  378. {
  379. u8 pwr = 0;
  380. if (power != (unsigned short)-1) {
  381. switch (1 << power) {
  382. case MMC_VDD_165_195:
  383. pwr = SDHCI_POWER_180;
  384. break;
  385. case MMC_VDD_29_30:
  386. case MMC_VDD_30_31:
  387. pwr = SDHCI_POWER_300;
  388. break;
  389. case MMC_VDD_32_33:
  390. case MMC_VDD_33_34:
  391. pwr = SDHCI_POWER_330;
  392. break;
  393. }
  394. }
  395. if (pwr == 0) {
  396. sdhci_writeb(host, 0, SDHCI_POWER_CONTROL);
  397. return;
  398. }
  399. pwr |= SDHCI_POWER_ON;
  400. sdhci_writeb(host, pwr, SDHCI_POWER_CONTROL);
  401. }
  402. #ifdef CONFIG_DM_MMC
  403. static int sdhci_set_ios(struct udevice *dev)
  404. {
  405. struct mmc *mmc = mmc_get_mmc_dev(dev);
  406. #else
  407. static int sdhci_set_ios(struct mmc *mmc)
  408. {
  409. #endif
  410. u32 ctrl;
  411. struct sdhci_host *host = mmc->priv;
  412. if (host->ops && host->ops->set_control_reg)
  413. host->ops->set_control_reg(host);
  414. if (mmc->clock != host->clock)
  415. sdhci_set_clock(mmc, mmc->clock);
  416. if (mmc->clk_disable)
  417. sdhci_set_clock(mmc, 0);
  418. /* Set bus width */
  419. ctrl = sdhci_readb(host, SDHCI_HOST_CONTROL);
  420. if (mmc->bus_width == 8) {
  421. ctrl &= ~SDHCI_CTRL_4BITBUS;
  422. if ((SDHCI_GET_VERSION(host) >= SDHCI_SPEC_300) ||
  423. (host->quirks & SDHCI_QUIRK_USE_WIDE8))
  424. ctrl |= SDHCI_CTRL_8BITBUS;
  425. } else {
  426. if ((SDHCI_GET_VERSION(host) >= SDHCI_SPEC_300) ||
  427. (host->quirks & SDHCI_QUIRK_USE_WIDE8))
  428. ctrl &= ~SDHCI_CTRL_8BITBUS;
  429. if (mmc->bus_width == 4)
  430. ctrl |= SDHCI_CTRL_4BITBUS;
  431. else
  432. ctrl &= ~SDHCI_CTRL_4BITBUS;
  433. }
  434. if (mmc->clock > 26000000)
  435. ctrl |= SDHCI_CTRL_HISPD;
  436. else
  437. ctrl &= ~SDHCI_CTRL_HISPD;
  438. if ((host->quirks & SDHCI_QUIRK_NO_HISPD_BIT) ||
  439. (host->quirks & SDHCI_QUIRK_BROKEN_HISPD_MODE))
  440. ctrl &= ~SDHCI_CTRL_HISPD;
  441. sdhci_writeb(host, ctrl, SDHCI_HOST_CONTROL);
  442. /* If available, call the driver specific "post" set_ios() function */
  443. if (host->ops && host->ops->set_ios_post)
  444. host->ops->set_ios_post(host);
  445. return 0;
  446. }
  447. static int sdhci_init(struct mmc *mmc)
  448. {
  449. struct sdhci_host *host = mmc->priv;
  450. sdhci_reset(host, SDHCI_RESET_ALL);
  451. if ((host->quirks & SDHCI_QUIRK_32BIT_DMA_ADDR) && !aligned_buffer) {
  452. aligned_buffer = memalign(8, 512*1024);
  453. if (!aligned_buffer) {
  454. printf("%s: Aligned buffer alloc failed!!!\n",
  455. __func__);
  456. return -ENOMEM;
  457. }
  458. }
  459. sdhci_set_power(host, fls(mmc->cfg->voltages) - 1);
  460. if (host->ops && host->ops->get_cd)
  461. host->ops->get_cd(host);
  462. /* Enable only interrupts served by the SD controller */
  463. sdhci_writel(host, SDHCI_INT_DATA_MASK | SDHCI_INT_CMD_MASK,
  464. SDHCI_INT_ENABLE);
  465. /* Mask all sdhci interrupt sources */
  466. sdhci_writel(host, 0x0, SDHCI_SIGNAL_ENABLE);
  467. return 0;
  468. }
  469. #ifdef CONFIG_DM_MMC
  470. int sdhci_probe(struct udevice *dev)
  471. {
  472. struct mmc *mmc = mmc_get_mmc_dev(dev);
  473. return sdhci_init(mmc);
  474. }
  475. const struct dm_mmc_ops sdhci_ops = {
  476. .send_cmd = sdhci_send_command,
  477. .set_ios = sdhci_set_ios,
  478. #ifdef MMC_SUPPORTS_TUNING
  479. .execute_tuning = sdhci_execute_tuning,
  480. #endif
  481. };
  482. #else
  483. static const struct mmc_ops sdhci_ops = {
  484. .send_cmd = sdhci_send_command,
  485. .set_ios = sdhci_set_ios,
  486. .init = sdhci_init,
  487. };
  488. #endif
  489. int sdhci_setup_cfg(struct mmc_config *cfg, struct sdhci_host *host,
  490. u32 f_max, u32 f_min)
  491. {
  492. u32 caps, caps_1 = 0;
  493. caps = sdhci_readl(host, SDHCI_CAPABILITIES);
  494. #ifdef CONFIG_MMC_SDHCI_SDMA
  495. if (!(caps & SDHCI_CAN_DO_SDMA)) {
  496. printf("%s: Your controller doesn't support SDMA!!\n",
  497. __func__);
  498. return -EINVAL;
  499. }
  500. #endif
  501. if (host->quirks & SDHCI_QUIRK_REG32_RW)
  502. host->version =
  503. sdhci_readl(host, SDHCI_HOST_VERSION - 2) >> 16;
  504. else
  505. host->version = sdhci_readw(host, SDHCI_HOST_VERSION);
  506. cfg->name = host->name;
  507. #ifndef CONFIG_DM_MMC
  508. cfg->ops = &sdhci_ops;
  509. #endif
  510. /* Check whether the clock multiplier is supported or not */
  511. if (SDHCI_GET_VERSION(host) >= SDHCI_SPEC_300) {
  512. caps_1 = sdhci_readl(host, SDHCI_CAPABILITIES_1);
  513. host->clk_mul = (caps_1 & SDHCI_CLOCK_MUL_MASK) >>
  514. SDHCI_CLOCK_MUL_SHIFT;
  515. }
  516. if (host->max_clk == 0) {
  517. if (SDHCI_GET_VERSION(host) >= SDHCI_SPEC_300)
  518. host->max_clk = (caps & SDHCI_CLOCK_V3_BASE_MASK) >>
  519. SDHCI_CLOCK_BASE_SHIFT;
  520. else
  521. host->max_clk = (caps & SDHCI_CLOCK_BASE_MASK) >>
  522. SDHCI_CLOCK_BASE_SHIFT;
  523. host->max_clk *= 1000000;
  524. if (host->clk_mul)
  525. host->max_clk *= host->clk_mul;
  526. }
  527. if (host->max_clk == 0) {
  528. printf("%s: Hardware doesn't specify base clock frequency\n",
  529. __func__);
  530. return -EINVAL;
  531. }
  532. if (f_max && (f_max < host->max_clk))
  533. cfg->f_max = f_max;
  534. else
  535. cfg->f_max = host->max_clk;
  536. if (f_min)
  537. cfg->f_min = f_min;
  538. else {
  539. if (SDHCI_GET_VERSION(host) >= SDHCI_SPEC_300)
  540. cfg->f_min = cfg->f_max / SDHCI_MAX_DIV_SPEC_300;
  541. else
  542. cfg->f_min = cfg->f_max / SDHCI_MAX_DIV_SPEC_200;
  543. }
  544. cfg->voltages = 0;
  545. if (caps & SDHCI_CAN_VDD_330)
  546. cfg->voltages |= MMC_VDD_32_33 | MMC_VDD_33_34;
  547. if (caps & SDHCI_CAN_VDD_300)
  548. cfg->voltages |= MMC_VDD_29_30 | MMC_VDD_30_31;
  549. if (caps & SDHCI_CAN_VDD_180)
  550. cfg->voltages |= MMC_VDD_165_195;
  551. if (host->quirks & SDHCI_QUIRK_BROKEN_VOLTAGE)
  552. cfg->voltages |= host->voltages;
  553. cfg->host_caps |= MMC_MODE_HS | MMC_MODE_HS_52MHz | MMC_MODE_4BIT;
  554. /* Since Host Controller Version3.0 */
  555. if (SDHCI_GET_VERSION(host) >= SDHCI_SPEC_300) {
  556. if (!(caps & SDHCI_CAN_DO_8BIT))
  557. cfg->host_caps &= ~MMC_MODE_8BIT;
  558. }
  559. if (host->quirks & SDHCI_QUIRK_BROKEN_HISPD_MODE) {
  560. cfg->host_caps &= ~MMC_MODE_HS;
  561. cfg->host_caps &= ~MMC_MODE_HS_52MHz;
  562. }
  563. if (SDHCI_GET_VERSION(host) >= SDHCI_SPEC_300)
  564. caps_1 = sdhci_readl(host, SDHCI_CAPABILITIES_1);
  565. if (!(cfg->voltages & MMC_VDD_165_195) ||
  566. (host->quirks & SDHCI_QUIRK_NO_1_8_V))
  567. caps_1 &= ~(SDHCI_SUPPORT_SDR104 | SDHCI_SUPPORT_SDR50 |
  568. SDHCI_SUPPORT_DDR50);
  569. if (caps_1 & (SDHCI_SUPPORT_SDR104 | SDHCI_SUPPORT_SDR50 |
  570. SDHCI_SUPPORT_DDR50))
  571. cfg->host_caps |= MMC_CAP(UHS_SDR12) | MMC_CAP(UHS_SDR25);
  572. if (caps_1 & SDHCI_SUPPORT_SDR104) {
  573. cfg->host_caps |= MMC_CAP(UHS_SDR104) | MMC_CAP(UHS_SDR50);
  574. /*
  575. * SD3.0: SDR104 is supported so (for eMMC) the caps2
  576. * field can be promoted to support HS200.
  577. */
  578. cfg->host_caps |= MMC_CAP(MMC_HS_200);
  579. } else if (caps_1 & SDHCI_SUPPORT_SDR50) {
  580. cfg->host_caps |= MMC_CAP(UHS_SDR50);
  581. }
  582. if (caps_1 & SDHCI_SUPPORT_DDR50)
  583. cfg->host_caps |= MMC_CAP(UHS_DDR50);
  584. if (host->host_caps)
  585. cfg->host_caps |= host->host_caps;
  586. cfg->b_max = CONFIG_SYS_MMC_MAX_BLK_COUNT;
  587. return 0;
  588. }
  589. #ifdef CONFIG_BLK
  590. int sdhci_bind(struct udevice *dev, struct mmc *mmc, struct mmc_config *cfg)
  591. {
  592. return mmc_bind(dev, mmc, cfg);
  593. }
  594. #else
  595. int add_sdhci(struct sdhci_host *host, u32 f_max, u32 f_min)
  596. {
  597. int ret;
  598. ret = sdhci_setup_cfg(&host->cfg, host, f_max, f_min);
  599. if (ret)
  600. return ret;
  601. host->mmc = mmc_create(&host->cfg, host);
  602. if (host->mmc == NULL) {
  603. printf("%s: mmc create fail!\n", __func__);
  604. return -ENOMEM;
  605. }
  606. return 0;
  607. }
  608. #endif