sd.c 45 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * linux/drivers/mmc/core/sd.c
  4. *
  5. * Copyright (C) 2003-2004 Russell King, All Rights Reserved.
  6. * SD support Copyright (C) 2004 Ian Molton, All Rights Reserved.
  7. * Copyright (C) 2005-2007 Pierre Ossman, All Rights Reserved.
  8. */
  9. #include <linux/err.h>
  10. #include <linux/sizes.h>
  11. #include <linux/slab.h>
  12. #include <linux/stat.h>
  13. #include <linux/string.h>
  14. #include <linux/pm_runtime.h>
  15. #include <linux/random.h>
  16. #include <linux/scatterlist.h>
  17. #include <linux/sysfs.h>
  18. #include <linux/mmc/host.h>
  19. #include <linux/mmc/card.h>
  20. #include <linux/mmc/mmc.h>
  21. #include <linux/mmc/sd.h>
  22. #include "core.h"
  23. #include "card.h"
  24. #include "host.h"
  25. #include "bus.h"
  26. #include "mmc_ops.h"
  27. #include "quirks.h"
  28. #include "sd.h"
  29. #include "sd_ops.h"
  30. static const unsigned int tran_exp[] = {
  31. 10000, 100000, 1000000, 10000000,
  32. 0, 0, 0, 0
  33. };
  34. static const unsigned char tran_mant[] = {
  35. 0, 10, 12, 13, 15, 20, 25, 30,
  36. 35, 40, 45, 50, 55, 60, 70, 80,
  37. };
  38. static const unsigned int taac_exp[] = {
  39. 1, 10, 100, 1000, 10000, 100000, 1000000, 10000000,
  40. };
  41. static const unsigned int taac_mant[] = {
  42. 0, 10, 12, 13, 15, 20, 25, 30,
  43. 35, 40, 45, 50, 55, 60, 70, 80,
  44. };
  45. static const unsigned int sd_au_size[] = {
  46. 0, SZ_16K / 512, SZ_32K / 512, SZ_64K / 512,
  47. SZ_128K / 512, SZ_256K / 512, SZ_512K / 512, SZ_1M / 512,
  48. SZ_2M / 512, SZ_4M / 512, SZ_8M / 512, (SZ_8M + SZ_4M) / 512,
  49. SZ_16M / 512, (SZ_16M + SZ_8M) / 512, SZ_32M / 512, SZ_64M / 512,
  50. };
  51. #define SD_POWEROFF_NOTIFY_TIMEOUT_MS 1000
  52. #define SD_WRITE_EXTR_SINGLE_TIMEOUT_MS 1000
  53. struct sd_busy_data {
  54. struct mmc_card *card;
  55. u8 *reg_buf;
  56. };
  57. /*
  58. * Given the decoded CSD structure, decode the raw CID to our CID structure.
  59. */
  60. void mmc_decode_cid(struct mmc_card *card)
  61. {
  62. u32 *resp = card->raw_cid;
  63. /*
  64. * Add the raw card ID (cid) data to the entropy pool. It doesn't
  65. * matter that not all of it is unique, it's just bonus entropy.
  66. */
  67. add_device_randomness(&card->raw_cid, sizeof(card->raw_cid));
  68. /*
  69. * SD doesn't currently have a version field so we will
  70. * have to assume we can parse this.
  71. */
  72. card->cid.manfid = unstuff_bits(resp, 120, 8);
  73. card->cid.oemid = unstuff_bits(resp, 104, 16);
  74. card->cid.prod_name[0] = unstuff_bits(resp, 96, 8);
  75. card->cid.prod_name[1] = unstuff_bits(resp, 88, 8);
  76. card->cid.prod_name[2] = unstuff_bits(resp, 80, 8);
  77. card->cid.prod_name[3] = unstuff_bits(resp, 72, 8);
  78. card->cid.prod_name[4] = unstuff_bits(resp, 64, 8);
  79. card->cid.hwrev = unstuff_bits(resp, 60, 4);
  80. card->cid.fwrev = unstuff_bits(resp, 56, 4);
  81. card->cid.serial = unstuff_bits(resp, 24, 32);
  82. card->cid.year = unstuff_bits(resp, 12, 8);
  83. card->cid.month = unstuff_bits(resp, 8, 4);
  84. card->cid.year += 2000; /* SD cards year offset */
  85. /* some product names may include trailing whitespace */
  86. strim(card->cid.prod_name);
  87. }
  88. /*
  89. * Given a 128-bit response, decode to our card CSD structure.
  90. */
  91. static int mmc_decode_csd(struct mmc_card *card, bool is_sduc)
  92. {
  93. struct mmc_csd *csd = &card->csd;
  94. unsigned int e, m, csd_struct;
  95. u32 *resp = card->raw_csd;
  96. csd_struct = unstuff_bits(resp, 126, 2);
  97. switch (csd_struct) {
  98. case 0:
  99. m = unstuff_bits(resp, 115, 4);
  100. e = unstuff_bits(resp, 112, 3);
  101. csd->taac_ns = (taac_exp[e] * taac_mant[m] + 9) / 10;
  102. csd->taac_clks = unstuff_bits(resp, 104, 8) * 100;
  103. m = unstuff_bits(resp, 99, 4);
  104. e = unstuff_bits(resp, 96, 3);
  105. csd->max_dtr = tran_exp[e] * tran_mant[m];
  106. csd->cmdclass = unstuff_bits(resp, 84, 12);
  107. e = unstuff_bits(resp, 47, 3);
  108. m = unstuff_bits(resp, 62, 12);
  109. csd->capacity = (1 + m) << (e + 2);
  110. csd->read_blkbits = unstuff_bits(resp, 80, 4);
  111. csd->read_partial = unstuff_bits(resp, 79, 1);
  112. csd->write_misalign = unstuff_bits(resp, 78, 1);
  113. csd->read_misalign = unstuff_bits(resp, 77, 1);
  114. csd->dsr_imp = unstuff_bits(resp, 76, 1);
  115. csd->r2w_factor = unstuff_bits(resp, 26, 3);
  116. csd->write_blkbits = unstuff_bits(resp, 22, 4);
  117. csd->write_partial = unstuff_bits(resp, 21, 1);
  118. if (unstuff_bits(resp, 46, 1)) {
  119. csd->erase_size = 1;
  120. } else if (csd->write_blkbits >= 9) {
  121. csd->erase_size = unstuff_bits(resp, 39, 7) + 1;
  122. csd->erase_size <<= csd->write_blkbits - 9;
  123. }
  124. if (unstuff_bits(resp, 13, 1))
  125. mmc_card_set_readonly(card);
  126. break;
  127. case 1:
  128. case 2:
  129. /*
  130. * This is a block-addressed SDHC, SDXC or SDUC card.
  131. * Most interesting fields are unused and have fixed
  132. * values. To avoid getting tripped by buggy cards,
  133. * we assume those fixed values ourselves.
  134. */
  135. mmc_card_set_blockaddr(card);
  136. csd->taac_ns = 0; /* Unused */
  137. csd->taac_clks = 0; /* Unused */
  138. m = unstuff_bits(resp, 99, 4);
  139. e = unstuff_bits(resp, 96, 3);
  140. csd->max_dtr = tran_exp[e] * tran_mant[m];
  141. csd->cmdclass = unstuff_bits(resp, 84, 12);
  142. if (csd_struct == 1)
  143. m = unstuff_bits(resp, 48, 22);
  144. else
  145. m = unstuff_bits(resp, 48, 28);
  146. csd->c_size = m;
  147. if (csd->c_size >= 0x400000 && is_sduc)
  148. mmc_card_set_ult_capacity(card);
  149. else if (csd->c_size >= 0xFFFF)
  150. mmc_card_set_ext_capacity(card);
  151. csd->capacity = (1 + (typeof(sector_t))m) << 10;
  152. csd->read_blkbits = 9;
  153. csd->read_partial = 0;
  154. csd->write_misalign = 0;
  155. csd->read_misalign = 0;
  156. csd->r2w_factor = 4; /* Unused */
  157. csd->write_blkbits = 9;
  158. csd->write_partial = 0;
  159. csd->erase_size = 1;
  160. if (unstuff_bits(resp, 13, 1))
  161. mmc_card_set_readonly(card);
  162. break;
  163. default:
  164. pr_err("%s: unrecognised CSD structure version %d\n",
  165. mmc_hostname(card->host), csd_struct);
  166. return -EINVAL;
  167. }
  168. card->erase_size = csd->erase_size;
  169. return 0;
  170. }
  171. /*
  172. * Given a 64-bit response, decode to our card SCR structure.
  173. */
  174. int mmc_decode_scr(struct mmc_card *card)
  175. {
  176. struct sd_scr *scr = &card->scr;
  177. unsigned int scr_struct;
  178. u32 resp[4];
  179. resp[3] = card->raw_scr[1];
  180. resp[2] = card->raw_scr[0];
  181. scr_struct = unstuff_bits(resp, 60, 4);
  182. if (scr_struct != 0) {
  183. pr_err("%s: unrecognised SCR structure version %d\n",
  184. mmc_hostname(card->host), scr_struct);
  185. return -EINVAL;
  186. }
  187. scr->sda_vsn = unstuff_bits(resp, 56, 4);
  188. scr->bus_widths = unstuff_bits(resp, 48, 4);
  189. if (scr->sda_vsn == SCR_SPEC_VER_2)
  190. /* Check if Physical Layer Spec v3.0 is supported */
  191. scr->sda_spec3 = unstuff_bits(resp, 47, 1);
  192. if (scr->sda_spec3) {
  193. scr->sda_spec4 = unstuff_bits(resp, 42, 1);
  194. scr->sda_specx = unstuff_bits(resp, 38, 4);
  195. }
  196. if (unstuff_bits(resp, 55, 1))
  197. card->erased_byte = 0xFF;
  198. else
  199. card->erased_byte = 0x0;
  200. if (scr->sda_spec4)
  201. scr->cmds = unstuff_bits(resp, 32, 4);
  202. else if (scr->sda_spec3)
  203. scr->cmds = unstuff_bits(resp, 32, 2);
  204. /* SD Spec says: any SD Card shall set at least bits 0 and 2 */
  205. if (!(scr->bus_widths & SD_SCR_BUS_WIDTH_1) ||
  206. !(scr->bus_widths & SD_SCR_BUS_WIDTH_4)) {
  207. pr_err("%s: invalid bus width\n", mmc_hostname(card->host));
  208. return -EINVAL;
  209. }
  210. return 0;
  211. }
  212. /*
  213. * Fetch and process SD Status register.
  214. */
  215. static int mmc_read_ssr(struct mmc_card *card)
  216. {
  217. unsigned int au, es, et, eo;
  218. __be32 *raw_ssr;
  219. u32 resp[4] = {};
  220. u8 discard_support;
  221. int i;
  222. if (!(card->csd.cmdclass & CCC_APP_SPEC)) {
  223. pr_warn("%s: card lacks mandatory SD Status function\n",
  224. mmc_hostname(card->host));
  225. return 0;
  226. }
  227. raw_ssr = kmalloc(sizeof(card->raw_ssr), GFP_KERNEL);
  228. if (!raw_ssr)
  229. return -ENOMEM;
  230. if (mmc_app_sd_status(card, raw_ssr)) {
  231. pr_warn("%s: problem reading SD Status register\n",
  232. mmc_hostname(card->host));
  233. kfree(raw_ssr);
  234. return 0;
  235. }
  236. for (i = 0; i < 16; i++)
  237. card->raw_ssr[i] = be32_to_cpu(raw_ssr[i]);
  238. kfree(raw_ssr);
  239. /*
  240. * unstuff_bits only works with four u32s so we have to offset the
  241. * bitfield positions accordingly.
  242. */
  243. au = unstuff_bits(card->raw_ssr, 428 - 384, 4);
  244. if (au) {
  245. if (au <= 9 || card->scr.sda_spec3) {
  246. card->ssr.au = sd_au_size[au];
  247. es = unstuff_bits(card->raw_ssr, 408 - 384, 16);
  248. et = unstuff_bits(card->raw_ssr, 402 - 384, 6);
  249. if (es && et) {
  250. eo = unstuff_bits(card->raw_ssr, 400 - 384, 2);
  251. card->ssr.erase_timeout = (et * 1000) / es;
  252. card->ssr.erase_offset = eo * 1000;
  253. }
  254. } else {
  255. pr_warn("%s: SD Status: Invalid Allocation Unit size\n",
  256. mmc_hostname(card->host));
  257. }
  258. }
  259. /*
  260. * starting SD5.1 discard is supported if DISCARD_SUPPORT (b313) is set
  261. */
  262. resp[3] = card->raw_ssr[6];
  263. discard_support = unstuff_bits(resp, 313 - 288, 1);
  264. card->erase_arg = (card->scr.sda_specx && discard_support) ?
  265. SD_DISCARD_ARG : SD_ERASE_ARG;
  266. return 0;
  267. }
  268. /*
  269. * Fetches and decodes switch information
  270. */
  271. static int mmc_read_switch(struct mmc_card *card)
  272. {
  273. int err;
  274. u8 *status;
  275. if (card->scr.sda_vsn < SCR_SPEC_VER_1)
  276. return 0;
  277. if (!(card->csd.cmdclass & CCC_SWITCH)) {
  278. pr_warn("%s: card lacks mandatory switch function, performance might suffer\n",
  279. mmc_hostname(card->host));
  280. return 0;
  281. }
  282. status = kmalloc(64, GFP_KERNEL);
  283. if (!status)
  284. return -ENOMEM;
  285. /*
  286. * Find out the card's support bits with a mode 0 operation.
  287. * The argument does not matter, as the support bits do not
  288. * change with the arguments.
  289. */
  290. err = mmc_sd_switch(card, SD_SWITCH_CHECK, 0, 0, status);
  291. if (err) {
  292. /*
  293. * If the host or the card can't do the switch,
  294. * fail more gracefully.
  295. */
  296. if (err != -EINVAL && err != -ENOSYS && err != -EFAULT)
  297. goto out;
  298. pr_warn("%s: problem reading Bus Speed modes\n",
  299. mmc_hostname(card->host));
  300. err = 0;
  301. goto out;
  302. }
  303. if (status[13] & SD_MODE_HIGH_SPEED)
  304. card->sw_caps.hs_max_dtr = card->host->max_sd_hs_hz ?: HIGH_SPEED_MAX_DTR;
  305. if (card->scr.sda_spec3) {
  306. card->sw_caps.sd3_bus_mode = status[13];
  307. /* Driver Strengths supported by the card */
  308. card->sw_caps.sd3_drv_type = status[9];
  309. card->sw_caps.sd3_curr_limit = status[7] | status[6] << 8;
  310. }
  311. out:
  312. kfree(status);
  313. return err;
  314. }
  315. /*
  316. * Test if the card supports high-speed mode and, if so, switch to it.
  317. */
  318. int mmc_sd_switch_hs(struct mmc_card *card)
  319. {
  320. int err;
  321. u8 *status;
  322. if (card->scr.sda_vsn < SCR_SPEC_VER_1)
  323. return 0;
  324. if (!(card->csd.cmdclass & CCC_SWITCH))
  325. return 0;
  326. if (!(card->host->caps & MMC_CAP_SD_HIGHSPEED))
  327. return 0;
  328. if (card->sw_caps.hs_max_dtr == 0)
  329. return 0;
  330. status = kmalloc(64, GFP_KERNEL);
  331. if (!status)
  332. return -ENOMEM;
  333. err = mmc_sd_switch(card, SD_SWITCH_SET, 0,
  334. HIGH_SPEED_BUS_SPEED, status);
  335. if (err)
  336. goto out;
  337. if ((status[16] & 0xF) != HIGH_SPEED_BUS_SPEED) {
  338. pr_warn("%s: Problem switching card into high-speed mode!\n",
  339. mmc_hostname(card->host));
  340. err = 0;
  341. } else {
  342. err = 1;
  343. }
  344. out:
  345. kfree(status);
  346. return err;
  347. }
  348. static int sd_select_driver_type(struct mmc_card *card, u8 *status)
  349. {
  350. int card_drv_type, drive_strength, drv_type;
  351. int err;
  352. card->drive_strength = 0;
  353. card_drv_type = card->sw_caps.sd3_drv_type | SD_DRIVER_TYPE_B;
  354. drive_strength = mmc_select_drive_strength(card,
  355. card->sw_caps.uhs_max_dtr,
  356. card_drv_type, &drv_type);
  357. if (drive_strength) {
  358. err = mmc_sd_switch(card, SD_SWITCH_SET, 2,
  359. drive_strength, status);
  360. if (err)
  361. return err;
  362. if ((status[15] & 0xF) != drive_strength) {
  363. pr_warn("%s: Problem setting drive strength!\n",
  364. mmc_hostname(card->host));
  365. return 0;
  366. }
  367. card->drive_strength = drive_strength;
  368. }
  369. if (drv_type)
  370. mmc_set_driver_type(card->host, drv_type);
  371. return 0;
  372. }
  373. static void sd_update_bus_speed_mode(struct mmc_card *card)
  374. {
  375. /*
  376. * If the host doesn't support any of the UHS-I modes, fallback on
  377. * default speed.
  378. */
  379. if (!mmc_host_can_uhs(card->host)) {
  380. card->sd_bus_speed = 0;
  381. return;
  382. }
  383. if ((card->host->caps & MMC_CAP_UHS_SDR104) &&
  384. (card->sw_caps.sd3_bus_mode & SD_MODE_UHS_SDR104)) {
  385. card->sd_bus_speed = UHS_SDR104_BUS_SPEED;
  386. } else if ((card->host->caps & MMC_CAP_UHS_DDR50) &&
  387. (card->sw_caps.sd3_bus_mode & SD_MODE_UHS_DDR50)) {
  388. card->sd_bus_speed = UHS_DDR50_BUS_SPEED;
  389. } else if ((card->host->caps & (MMC_CAP_UHS_SDR104 |
  390. MMC_CAP_UHS_SDR50)) && (card->sw_caps.sd3_bus_mode &
  391. SD_MODE_UHS_SDR50)) {
  392. card->sd_bus_speed = UHS_SDR50_BUS_SPEED;
  393. } else if ((card->host->caps & (MMC_CAP_UHS_SDR104 |
  394. MMC_CAP_UHS_SDR50 | MMC_CAP_UHS_SDR25)) &&
  395. (card->sw_caps.sd3_bus_mode & SD_MODE_UHS_SDR25)) {
  396. card->sd_bus_speed = UHS_SDR25_BUS_SPEED;
  397. } else if ((card->host->caps & (MMC_CAP_UHS_SDR104 |
  398. MMC_CAP_UHS_SDR50 | MMC_CAP_UHS_SDR25 |
  399. MMC_CAP_UHS_SDR12)) && (card->sw_caps.sd3_bus_mode &
  400. SD_MODE_UHS_SDR12)) {
  401. card->sd_bus_speed = UHS_SDR12_BUS_SPEED;
  402. }
  403. }
  404. static int sd_set_bus_speed_mode(struct mmc_card *card, u8 *status)
  405. {
  406. int err;
  407. unsigned int timing = 0;
  408. switch (card->sd_bus_speed) {
  409. case UHS_SDR104_BUS_SPEED:
  410. timing = MMC_TIMING_UHS_SDR104;
  411. card->sw_caps.uhs_max_dtr = UHS_SDR104_MAX_DTR;
  412. break;
  413. case UHS_DDR50_BUS_SPEED:
  414. timing = MMC_TIMING_UHS_DDR50;
  415. card->sw_caps.uhs_max_dtr = UHS_DDR50_MAX_DTR;
  416. break;
  417. case UHS_SDR50_BUS_SPEED:
  418. timing = MMC_TIMING_UHS_SDR50;
  419. card->sw_caps.uhs_max_dtr = UHS_SDR50_MAX_DTR;
  420. break;
  421. case UHS_SDR25_BUS_SPEED:
  422. timing = MMC_TIMING_UHS_SDR25;
  423. card->sw_caps.uhs_max_dtr = UHS_SDR25_MAX_DTR;
  424. break;
  425. case UHS_SDR12_BUS_SPEED:
  426. timing = MMC_TIMING_UHS_SDR12;
  427. card->sw_caps.uhs_max_dtr = UHS_SDR12_MAX_DTR;
  428. break;
  429. default:
  430. return 0;
  431. }
  432. err = mmc_sd_switch(card, SD_SWITCH_SET, 0, card->sd_bus_speed, status);
  433. if (err)
  434. return err;
  435. if ((status[16] & 0xF) != card->sd_bus_speed)
  436. pr_warn("%s: Problem setting bus speed mode!\n",
  437. mmc_hostname(card->host));
  438. else {
  439. mmc_set_timing(card->host, timing);
  440. mmc_set_clock(card->host, card->sw_caps.uhs_max_dtr);
  441. }
  442. return 0;
  443. }
  444. /* Get host's max current setting at its current voltage */
  445. static u32 sd_get_host_max_current(struct mmc_host *host)
  446. {
  447. u32 voltage, max_current;
  448. voltage = 1 << host->ios.vdd;
  449. switch (voltage) {
  450. case MMC_VDD_165_195:
  451. max_current = host->max_current_180;
  452. break;
  453. case MMC_VDD_29_30:
  454. case MMC_VDD_30_31:
  455. max_current = host->max_current_300;
  456. break;
  457. case MMC_VDD_32_33:
  458. case MMC_VDD_33_34:
  459. max_current = host->max_current_330;
  460. break;
  461. default:
  462. max_current = 0;
  463. }
  464. return max_current;
  465. }
  466. static int sd_set_current_limit(struct mmc_card *card, u8 *status)
  467. {
  468. int current_limit = SD_SET_CURRENT_LIMIT_200;
  469. int err;
  470. u32 max_current;
  471. /*
  472. * Current limit switch is only defined for SDR50, SDR104, and DDR50
  473. * bus speed modes. For other bus speed modes, we do not change the
  474. * current limit.
  475. */
  476. if ((card->sd_bus_speed != UHS_SDR50_BUS_SPEED) &&
  477. (card->sd_bus_speed != UHS_SDR104_BUS_SPEED) &&
  478. (card->sd_bus_speed != UHS_DDR50_BUS_SPEED))
  479. return 0;
  480. /*
  481. * Host has different current capabilities when operating at
  482. * different voltages, so find out its max current first.
  483. */
  484. max_current = sd_get_host_max_current(card->host);
  485. /*
  486. * We only check host's capability here, if we set a limit that is
  487. * higher than the card's maximum current, the card will be using its
  488. * maximum current, e.g. if the card's maximum current is 300ma, and
  489. * when we set current limit to 200ma, the card will draw 200ma, and
  490. * when we set current limit to 400/600/800ma, the card will draw its
  491. * maximum 300ma from the host.
  492. *
  493. * The above is incorrect: if we try to set a current limit that is
  494. * not supported by the card, the card can rightfully error out the
  495. * attempt, and remain at the default current limit. This results
  496. * in a 300mA card being limited to 200mA even though the host
  497. * supports 800mA. Failures seen with SanDisk 8GB UHS cards with
  498. * an iMX6 host. --rmk
  499. */
  500. if (max_current >= 800 &&
  501. card->sw_caps.sd3_curr_limit & SD_MAX_CURRENT_800)
  502. current_limit = SD_SET_CURRENT_LIMIT_800;
  503. else if (max_current >= 600 &&
  504. card->sw_caps.sd3_curr_limit & SD_MAX_CURRENT_600)
  505. current_limit = SD_SET_CURRENT_LIMIT_600;
  506. else if (max_current >= 400 &&
  507. card->sw_caps.sd3_curr_limit & SD_MAX_CURRENT_400)
  508. current_limit = SD_SET_CURRENT_LIMIT_400;
  509. if (current_limit != SD_SET_CURRENT_LIMIT_200) {
  510. err = mmc_sd_switch(card, SD_SWITCH_SET, 3,
  511. current_limit, status);
  512. if (err)
  513. return err;
  514. if (((status[15] >> 4) & 0x0F) != current_limit)
  515. pr_warn("%s: Problem setting current limit!\n",
  516. mmc_hostname(card->host));
  517. }
  518. return 0;
  519. }
  520. /*
  521. * Determine if the card should tune or not.
  522. */
  523. static bool mmc_sd_use_tuning(struct mmc_card *card)
  524. {
  525. /*
  526. * SPI mode doesn't define CMD19 and tuning is only valid for SDR50 and
  527. * SDR104 mode SD-cards. Note that tuning is mandatory for SDR104.
  528. */
  529. if (mmc_host_is_spi(card->host))
  530. return false;
  531. switch (card->host->ios.timing) {
  532. case MMC_TIMING_UHS_SDR50:
  533. case MMC_TIMING_UHS_SDR104:
  534. return true;
  535. case MMC_TIMING_UHS_DDR50:
  536. return !mmc_card_no_uhs_ddr50_tuning(card);
  537. }
  538. return false;
  539. }
  540. /*
  541. * UHS-I specific initialization procedure
  542. */
  543. static int mmc_sd_init_uhs_card(struct mmc_card *card)
  544. {
  545. int err;
  546. u8 *status;
  547. if (!(card->csd.cmdclass & CCC_SWITCH))
  548. return 0;
  549. status = kmalloc(64, GFP_KERNEL);
  550. if (!status)
  551. return -ENOMEM;
  552. /* Set 4-bit bus width */
  553. err = mmc_app_set_bus_width(card, MMC_BUS_WIDTH_4);
  554. if (err)
  555. goto out;
  556. mmc_set_bus_width(card->host, MMC_BUS_WIDTH_4);
  557. /*
  558. * Select the bus speed mode depending on host
  559. * and card capability.
  560. */
  561. sd_update_bus_speed_mode(card);
  562. /* Set the driver strength for the card */
  563. err = sd_select_driver_type(card, status);
  564. if (err)
  565. goto out;
  566. /* Set current limit for the card */
  567. err = sd_set_current_limit(card, status);
  568. if (err)
  569. goto out;
  570. /* Set bus speed mode of the card */
  571. err = sd_set_bus_speed_mode(card, status);
  572. if (err)
  573. goto out;
  574. if (mmc_sd_use_tuning(card)) {
  575. err = mmc_execute_tuning(card);
  576. /*
  577. * As SD Specifications Part1 Physical Layer Specification
  578. * Version 3.01 says, CMD19 tuning is available for unlocked
  579. * cards in transfer state of 1.8V signaling mode. The small
  580. * difference between v3.00 and 3.01 spec means that CMD19
  581. * tuning is also available for DDR50 mode.
  582. */
  583. if (err && card->host->ios.timing == MMC_TIMING_UHS_DDR50) {
  584. pr_warn("%s: ddr50 tuning failed\n",
  585. mmc_hostname(card->host));
  586. err = 0;
  587. }
  588. }
  589. out:
  590. kfree(status);
  591. return err;
  592. }
  593. MMC_DEV_ATTR(cid, "%08x%08x%08x%08x\n", card->raw_cid[0], card->raw_cid[1],
  594. card->raw_cid[2], card->raw_cid[3]);
  595. MMC_DEV_ATTR(csd, "%08x%08x%08x%08x\n", card->raw_csd[0], card->raw_csd[1],
  596. card->raw_csd[2], card->raw_csd[3]);
  597. MMC_DEV_ATTR(scr, "%08x%08x\n", card->raw_scr[0], card->raw_scr[1]);
  598. MMC_DEV_ATTR(ssr,
  599. "%08x%08x%08x%08x%08x%08x%08x%08x%08x%08x%08x%08x%08x%08x%08x%08x\n",
  600. card->raw_ssr[0], card->raw_ssr[1], card->raw_ssr[2],
  601. card->raw_ssr[3], card->raw_ssr[4], card->raw_ssr[5],
  602. card->raw_ssr[6], card->raw_ssr[7], card->raw_ssr[8],
  603. card->raw_ssr[9], card->raw_ssr[10], card->raw_ssr[11],
  604. card->raw_ssr[12], card->raw_ssr[13], card->raw_ssr[14],
  605. card->raw_ssr[15]);
  606. MMC_DEV_ATTR(date, "%02d/%04d\n", card->cid.month, card->cid.year);
  607. MMC_DEV_ATTR(erase_size, "%u\n", card->erase_size << 9);
  608. MMC_DEV_ATTR(preferred_erase_size, "%u\n", card->pref_erase << 9);
  609. MMC_DEV_ATTR(fwrev, "0x%x\n", card->cid.fwrev);
  610. MMC_DEV_ATTR(hwrev, "0x%x\n", card->cid.hwrev);
  611. MMC_DEV_ATTR(manfid, "0x%06x\n", card->cid.manfid);
  612. MMC_DEV_ATTR(name, "%s\n", card->cid.prod_name);
  613. MMC_DEV_ATTR(oemid, "0x%04x\n", card->cid.oemid);
  614. MMC_DEV_ATTR(serial, "0x%08x\n", card->cid.serial);
  615. MMC_DEV_ATTR(ocr, "0x%08x\n", card->ocr);
  616. MMC_DEV_ATTR(rca, "0x%04x\n", card->rca);
  617. static ssize_t mmc_dsr_show(struct device *dev, struct device_attribute *attr,
  618. char *buf)
  619. {
  620. struct mmc_card *card = mmc_dev_to_card(dev);
  621. struct mmc_host *host = card->host;
  622. if (card->csd.dsr_imp && host->dsr_req)
  623. return sysfs_emit(buf, "0x%x\n", host->dsr);
  624. /* return default DSR value */
  625. return sysfs_emit(buf, "0x%x\n", 0x404);
  626. }
  627. static DEVICE_ATTR(dsr, 0444, mmc_dsr_show, NULL);
  628. MMC_DEV_ATTR(vendor, "0x%04x\n", card->cis.vendor);
  629. MMC_DEV_ATTR(device, "0x%04x\n", card->cis.device);
  630. MMC_DEV_ATTR(revision, "%u.%u\n", card->major_rev, card->minor_rev);
  631. #define sdio_info_attr(num) \
  632. static ssize_t info##num##_show(struct device *dev, struct device_attribute *attr, char *buf) \
  633. { \
  634. struct mmc_card *card = mmc_dev_to_card(dev); \
  635. \
  636. if (num > card->num_info) \
  637. return -ENODATA; \
  638. if (!card->info[num - 1][0]) \
  639. return 0; \
  640. return sysfs_emit(buf, "%s\n", card->info[num - 1]); \
  641. } \
  642. static DEVICE_ATTR_RO(info##num)
  643. sdio_info_attr(1);
  644. sdio_info_attr(2);
  645. sdio_info_attr(3);
  646. sdio_info_attr(4);
  647. static struct attribute *sd_std_attrs[] = {
  648. &dev_attr_vendor.attr,
  649. &dev_attr_device.attr,
  650. &dev_attr_revision.attr,
  651. &dev_attr_info1.attr,
  652. &dev_attr_info2.attr,
  653. &dev_attr_info3.attr,
  654. &dev_attr_info4.attr,
  655. &dev_attr_cid.attr,
  656. &dev_attr_csd.attr,
  657. &dev_attr_scr.attr,
  658. &dev_attr_ssr.attr,
  659. &dev_attr_date.attr,
  660. &dev_attr_erase_size.attr,
  661. &dev_attr_preferred_erase_size.attr,
  662. &dev_attr_fwrev.attr,
  663. &dev_attr_hwrev.attr,
  664. &dev_attr_manfid.attr,
  665. &dev_attr_name.attr,
  666. &dev_attr_oemid.attr,
  667. &dev_attr_serial.attr,
  668. &dev_attr_ocr.attr,
  669. &dev_attr_rca.attr,
  670. &dev_attr_dsr.attr,
  671. NULL,
  672. };
  673. static umode_t sd_std_is_visible(struct kobject *kobj, struct attribute *attr,
  674. int index)
  675. {
  676. struct device *dev = kobj_to_dev(kobj);
  677. struct mmc_card *card = mmc_dev_to_card(dev);
  678. /* CIS vendor and device ids, revision and info string are available only for Combo cards */
  679. if ((attr == &dev_attr_vendor.attr ||
  680. attr == &dev_attr_device.attr ||
  681. attr == &dev_attr_revision.attr ||
  682. attr == &dev_attr_info1.attr ||
  683. attr == &dev_attr_info2.attr ||
  684. attr == &dev_attr_info3.attr ||
  685. attr == &dev_attr_info4.attr
  686. ) &&!mmc_card_sd_combo(card))
  687. return 0;
  688. return attr->mode;
  689. }
  690. static const struct attribute_group sd_std_group = {
  691. .attrs = sd_std_attrs,
  692. .is_visible = sd_std_is_visible,
  693. };
  694. __ATTRIBUTE_GROUPS(sd_std);
  695. const struct device_type sd_type = {
  696. .groups = sd_std_groups,
  697. };
  698. /*
  699. * Fetch CID from card.
  700. */
  701. int mmc_sd_get_cid(struct mmc_host *host, u32 ocr, u32 *cid, u32 *rocr)
  702. {
  703. int err;
  704. u32 max_current;
  705. int retries = 10;
  706. u32 pocr = ocr;
  707. try_again:
  708. if (!retries) {
  709. ocr &= ~SD_OCR_S18R;
  710. pr_warn("%s: Skipping voltage switch\n", mmc_hostname(host));
  711. }
  712. /*
  713. * Since we're changing the OCR value, we seem to
  714. * need to tell some cards to go back to the idle
  715. * state. We wait 1ms to give cards time to
  716. * respond.
  717. */
  718. mmc_go_idle(host);
  719. /*
  720. * If SD_SEND_IF_COND indicates an SD 2.0
  721. * compliant card and we should set bit 30
  722. * of the ocr to indicate that we can handle
  723. * block-addressed SDHC cards.
  724. */
  725. err = mmc_send_if_cond(host, ocr);
  726. if (!err) {
  727. ocr |= SD_OCR_CCS;
  728. /* Set HO2T as well - SDUC card won't respond otherwise */
  729. ocr |= SD_OCR_2T;
  730. }
  731. /*
  732. * If the host supports one of UHS-I modes, request the card
  733. * to switch to 1.8V signaling level. If the card has failed
  734. * repeatedly to switch however, skip this.
  735. */
  736. if (retries && mmc_host_can_uhs(host))
  737. ocr |= SD_OCR_S18R;
  738. /*
  739. * If the host can supply more than 150mA at current voltage,
  740. * XPC should be set to 1.
  741. */
  742. max_current = sd_get_host_max_current(host);
  743. if (max_current > 150)
  744. ocr |= SD_OCR_XPC;
  745. err = mmc_send_app_op_cond(host, ocr, rocr);
  746. if (err)
  747. return err;
  748. /*
  749. * In case the S18A bit is set in the response, let's start the signal
  750. * voltage switch procedure. SPI mode doesn't support CMD11.
  751. * Note that, according to the spec, the S18A bit is not valid unless
  752. * the CCS bit is set as well. We deliberately deviate from the spec in
  753. * regards to this, which allows UHS-I to be supported for SDSC cards.
  754. */
  755. if (!mmc_host_is_spi(host) && (ocr & SD_OCR_S18R) &&
  756. rocr && (*rocr & SD_ROCR_S18A)) {
  757. err = mmc_set_uhs_voltage(host, pocr);
  758. if (err == -EAGAIN) {
  759. retries--;
  760. goto try_again;
  761. } else if (err) {
  762. retries = 0;
  763. goto try_again;
  764. }
  765. }
  766. err = mmc_send_cid(host, cid);
  767. return err;
  768. }
  769. int mmc_sd_get_csd(struct mmc_card *card, bool is_sduc)
  770. {
  771. int err;
  772. /*
  773. * Fetch CSD from card.
  774. */
  775. err = mmc_send_csd(card, card->raw_csd);
  776. if (err)
  777. return err;
  778. err = mmc_decode_csd(card, is_sduc);
  779. if (err)
  780. return err;
  781. return 0;
  782. }
  783. int mmc_sd_get_ro(struct mmc_host *host)
  784. {
  785. int ro;
  786. /*
  787. * Some systems don't feature a write-protect pin and don't need one.
  788. * E.g. because they only have micro-SD card slot. For those systems
  789. * assume that the SD card is always read-write.
  790. */
  791. if (host->caps2 & MMC_CAP2_NO_WRITE_PROTECT)
  792. return 0;
  793. if (!host->ops->get_ro)
  794. return -1;
  795. ro = host->ops->get_ro(host);
  796. return ro;
  797. }
  798. int mmc_sd_setup_card(struct mmc_host *host, struct mmc_card *card,
  799. bool reinit)
  800. {
  801. int err;
  802. if (!reinit) {
  803. /*
  804. * Fetch SCR from card.
  805. */
  806. err = mmc_app_send_scr(card);
  807. if (err)
  808. return err;
  809. err = mmc_decode_scr(card);
  810. if (err)
  811. return err;
  812. /*
  813. * Fetch and process SD Status register.
  814. */
  815. err = mmc_read_ssr(card);
  816. if (err)
  817. return err;
  818. /* Erase init depends on CSD and SSR */
  819. mmc_init_erase(card);
  820. }
  821. /*
  822. * Fetch switch information from card. Note, sd3_bus_mode can change if
  823. * voltage switch outcome changes, so do this always.
  824. */
  825. err = mmc_read_switch(card);
  826. if (err)
  827. return err;
  828. /*
  829. * For SPI, enable CRC as appropriate.
  830. * This CRC enable is located AFTER the reading of the
  831. * card registers because some SDHC cards are not able
  832. * to provide valid CRCs for non-512-byte blocks.
  833. */
  834. if (mmc_host_is_spi(host)) {
  835. err = mmc_spi_set_crc(host, use_spi_crc);
  836. if (err)
  837. return err;
  838. }
  839. /*
  840. * Check if read-only switch is active.
  841. */
  842. if (!reinit) {
  843. int ro = mmc_sd_get_ro(host);
  844. if (ro < 0) {
  845. pr_warn("%s: host does not support reading read-only switch, assuming write-enable\n",
  846. mmc_hostname(host));
  847. } else if (ro > 0) {
  848. mmc_card_set_readonly(card);
  849. }
  850. }
  851. return 0;
  852. }
  853. unsigned mmc_sd_get_max_clock(struct mmc_card *card)
  854. {
  855. unsigned max_dtr = (unsigned int)-1;
  856. if (mmc_card_hs(card)) {
  857. if (max_dtr > card->sw_caps.hs_max_dtr)
  858. max_dtr = card->sw_caps.hs_max_dtr;
  859. } else if (max_dtr > card->csd.max_dtr) {
  860. max_dtr = card->csd.max_dtr;
  861. }
  862. return max_dtr;
  863. }
  864. static bool mmc_sd_card_using_v18(struct mmc_card *card)
  865. {
  866. /*
  867. * According to the SD spec., the Bus Speed Mode (function group 1) bits
  868. * 2 to 4 are zero if the card is initialized at 3.3V signal level. Thus
  869. * they can be used to determine if the card has already switched to
  870. * 1.8V signaling.
  871. */
  872. return card->sw_caps.sd3_bus_mode &
  873. (SD_MODE_UHS_SDR50 | SD_MODE_UHS_SDR104 | SD_MODE_UHS_DDR50);
  874. }
  875. static int sd_write_ext_reg(struct mmc_card *card, u8 fno, u8 page, u16 offset,
  876. u8 reg_data)
  877. {
  878. struct mmc_host *host = card->host;
  879. struct mmc_request mrq = {};
  880. struct mmc_command cmd = {};
  881. struct mmc_data data = {};
  882. struct scatterlist sg;
  883. u8 *reg_buf;
  884. reg_buf = kzalloc(512, GFP_KERNEL);
  885. if (!reg_buf)
  886. return -ENOMEM;
  887. mrq.cmd = &cmd;
  888. mrq.data = &data;
  889. /*
  890. * Arguments of CMD49:
  891. * [31:31] MIO (0 = memory).
  892. * [30:27] FNO (function number).
  893. * [26:26] MW - mask write mode (0 = disable).
  894. * [25:18] page number.
  895. * [17:9] offset address.
  896. * [8:0] length (0 = 1 byte).
  897. */
  898. cmd.arg = fno << 27 | page << 18 | offset << 9;
  899. /* The first byte in the buffer is the data to be written. */
  900. reg_buf[0] = reg_data;
  901. data.flags = MMC_DATA_WRITE;
  902. data.blksz = 512;
  903. data.blocks = 1;
  904. data.sg = &sg;
  905. data.sg_len = 1;
  906. sg_init_one(&sg, reg_buf, 512);
  907. cmd.opcode = SD_WRITE_EXTR_SINGLE;
  908. cmd.flags = MMC_RSP_R1 | MMC_CMD_ADTC;
  909. mmc_set_data_timeout(&data, card);
  910. mmc_wait_for_req(host, &mrq);
  911. kfree(reg_buf);
  912. /*
  913. * Note that, the SD card is allowed to signal busy on DAT0 up to 1s
  914. * after the CMD49. Although, let's leave this to be managed by the
  915. * caller.
  916. */
  917. if (cmd.error)
  918. return cmd.error;
  919. if (data.error)
  920. return data.error;
  921. return 0;
  922. }
  923. static int sd_read_ext_reg(struct mmc_card *card, u8 fno, u8 page,
  924. u16 offset, u16 len, u8 *reg_buf)
  925. {
  926. u32 cmd_args;
  927. /*
  928. * Command arguments of CMD48:
  929. * [31:31] MIO (0 = memory).
  930. * [30:27] FNO (function number).
  931. * [26:26] reserved (0).
  932. * [25:18] page number.
  933. * [17:9] offset address.
  934. * [8:0] length (0 = 1 byte, 1ff = 512 bytes).
  935. */
  936. cmd_args = fno << 27 | page << 18 | offset << 9 | (len -1);
  937. return mmc_send_adtc_data(card, card->host, SD_READ_EXTR_SINGLE,
  938. cmd_args, reg_buf, 512);
  939. }
  940. static int sd_parse_ext_reg_power(struct mmc_card *card, u8 fno, u8 page,
  941. u16 offset)
  942. {
  943. int err;
  944. u8 *reg_buf;
  945. reg_buf = kzalloc(512, GFP_KERNEL);
  946. if (!reg_buf)
  947. return -ENOMEM;
  948. /* Read the extension register for power management function. */
  949. err = sd_read_ext_reg(card, fno, page, offset, 512, reg_buf);
  950. if (err) {
  951. pr_warn("%s: error %d reading PM func of ext reg\n",
  952. mmc_hostname(card->host), err);
  953. goto out;
  954. }
  955. /* PM revision consists of 4 bits. */
  956. card->ext_power.rev = reg_buf[0] & 0xf;
  957. /* Power Off Notification support at bit 4. */
  958. if ((reg_buf[1] & BIT(4)) && !mmc_card_broken_sd_poweroff_notify(card))
  959. card->ext_power.feature_support |= SD_EXT_POWER_OFF_NOTIFY;
  960. /* Power Sustenance support at bit 5. */
  961. if (reg_buf[1] & BIT(5))
  962. card->ext_power.feature_support |= SD_EXT_POWER_SUSTENANCE;
  963. /* Power Down Mode support at bit 6. */
  964. if (reg_buf[1] & BIT(6))
  965. card->ext_power.feature_support |= SD_EXT_POWER_DOWN_MODE;
  966. card->ext_power.fno = fno;
  967. card->ext_power.page = page;
  968. card->ext_power.offset = offset;
  969. out:
  970. kfree(reg_buf);
  971. return err;
  972. }
  973. static int sd_parse_ext_reg_perf(struct mmc_card *card, u8 fno, u8 page,
  974. u16 offset)
  975. {
  976. int err;
  977. u8 *reg_buf;
  978. reg_buf = kzalloc(512, GFP_KERNEL);
  979. if (!reg_buf)
  980. return -ENOMEM;
  981. err = sd_read_ext_reg(card, fno, page, offset, 512, reg_buf);
  982. if (err) {
  983. pr_warn("%s: error %d reading PERF func of ext reg\n",
  984. mmc_hostname(card->host), err);
  985. goto out;
  986. }
  987. /* PERF revision. */
  988. card->ext_perf.rev = reg_buf[0];
  989. /* FX_EVENT support at bit 0. */
  990. if (reg_buf[1] & BIT(0))
  991. card->ext_perf.feature_support |= SD_EXT_PERF_FX_EVENT;
  992. /* Card initiated self-maintenance support at bit 0. */
  993. if (reg_buf[2] & BIT(0))
  994. card->ext_perf.feature_support |= SD_EXT_PERF_CARD_MAINT;
  995. /* Host initiated self-maintenance support at bit 1. */
  996. if (reg_buf[2] & BIT(1))
  997. card->ext_perf.feature_support |= SD_EXT_PERF_HOST_MAINT;
  998. /* Cache support at bit 0. */
  999. if ((reg_buf[4] & BIT(0)) && !mmc_card_broken_sd_cache(card))
  1000. card->ext_perf.feature_support |= SD_EXT_PERF_CACHE;
  1001. /* Command queue support indicated via queue depth bits (0 to 4). */
  1002. if (reg_buf[6] & 0x1f)
  1003. card->ext_perf.feature_support |= SD_EXT_PERF_CMD_QUEUE;
  1004. card->ext_perf.fno = fno;
  1005. card->ext_perf.page = page;
  1006. card->ext_perf.offset = offset;
  1007. out:
  1008. kfree(reg_buf);
  1009. return err;
  1010. }
  1011. static int sd_parse_ext_reg(struct mmc_card *card, u8 *gen_info_buf,
  1012. u16 *next_ext_addr)
  1013. {
  1014. u8 num_regs, fno, page;
  1015. u16 sfc, offset, ext = *next_ext_addr;
  1016. u32 reg_addr;
  1017. /*
  1018. * Parse only one register set per extension, as that is sufficient to
  1019. * support the standard functions. This means another 48 bytes in the
  1020. * buffer must be available.
  1021. */
  1022. if (ext + 48 > 512)
  1023. return -EFAULT;
  1024. /* Standard Function Code */
  1025. memcpy(&sfc, &gen_info_buf[ext], 2);
  1026. /* Address to the next extension. */
  1027. memcpy(next_ext_addr, &gen_info_buf[ext + 40], 2);
  1028. /* Number of registers for this extension. */
  1029. num_regs = gen_info_buf[ext + 42];
  1030. /* We support only one register per extension. */
  1031. if (num_regs != 1)
  1032. return 0;
  1033. /* Extension register address. */
  1034. memcpy(&reg_addr, &gen_info_buf[ext + 44], 4);
  1035. /* 9 bits (0 to 8) contains the offset address. */
  1036. offset = reg_addr & 0x1ff;
  1037. /* 8 bits (9 to 16) contains the page number. */
  1038. page = reg_addr >> 9 & 0xff ;
  1039. /* 4 bits (18 to 21) contains the function number. */
  1040. fno = reg_addr >> 18 & 0xf;
  1041. /* Standard Function Code for power management. */
  1042. if (sfc == 0x1)
  1043. return sd_parse_ext_reg_power(card, fno, page, offset);
  1044. /* Standard Function Code for performance enhancement. */
  1045. if (sfc == 0x2)
  1046. return sd_parse_ext_reg_perf(card, fno, page, offset);
  1047. return 0;
  1048. }
  1049. static int sd_read_ext_regs(struct mmc_card *card)
  1050. {
  1051. int err, i;
  1052. u8 num_ext, *gen_info_buf;
  1053. u16 rev, len, next_ext_addr;
  1054. if (mmc_host_is_spi(card->host))
  1055. return 0;
  1056. if (!(card->scr.cmds & SD_SCR_CMD48_SUPPORT))
  1057. return 0;
  1058. gen_info_buf = kzalloc(512, GFP_KERNEL);
  1059. if (!gen_info_buf)
  1060. return -ENOMEM;
  1061. /*
  1062. * Read 512 bytes of general info, which is found at function number 0,
  1063. * at page 0 and with no offset.
  1064. */
  1065. err = sd_read_ext_reg(card, 0, 0, 0, 512, gen_info_buf);
  1066. if (err) {
  1067. pr_err("%s: error %d reading general info of SD ext reg\n",
  1068. mmc_hostname(card->host), err);
  1069. goto out;
  1070. }
  1071. /* General info structure revision. */
  1072. memcpy(&rev, &gen_info_buf[0], 2);
  1073. /* Length of general info in bytes. */
  1074. memcpy(&len, &gen_info_buf[2], 2);
  1075. /* Number of extensions to be find. */
  1076. num_ext = gen_info_buf[4];
  1077. /*
  1078. * We only support revision 0 and limit it to 512 bytes for simplicity.
  1079. * No matter what, let's return zero to allow us to continue using the
  1080. * card, even if we can't support the features from the SD function
  1081. * extensions registers.
  1082. */
  1083. if (rev != 0 || len > 512) {
  1084. pr_warn("%s: non-supported SD ext reg layout\n",
  1085. mmc_hostname(card->host));
  1086. goto out;
  1087. }
  1088. /*
  1089. * Parse the extension registers. The first extension should start
  1090. * immediately after the general info header (16 bytes).
  1091. */
  1092. next_ext_addr = 16;
  1093. for (i = 0; i < num_ext; i++) {
  1094. err = sd_parse_ext_reg(card, gen_info_buf, &next_ext_addr);
  1095. if (err) {
  1096. pr_err("%s: error %d parsing SD ext reg\n",
  1097. mmc_hostname(card->host), err);
  1098. goto out;
  1099. }
  1100. }
  1101. out:
  1102. kfree(gen_info_buf);
  1103. return err;
  1104. }
  1105. static bool sd_cache_enabled(struct mmc_host *host)
  1106. {
  1107. return host->card->ext_perf.feature_enabled & SD_EXT_PERF_CACHE;
  1108. }
  1109. static int sd_flush_cache(struct mmc_host *host)
  1110. {
  1111. struct mmc_card *card = host->card;
  1112. u8 *reg_buf, fno, page;
  1113. u16 offset;
  1114. int err;
  1115. if (!sd_cache_enabled(host))
  1116. return 0;
  1117. reg_buf = kzalloc(512, GFP_KERNEL);
  1118. if (!reg_buf)
  1119. return -ENOMEM;
  1120. /*
  1121. * Set Flush Cache at bit 0 in the performance enhancement register at
  1122. * 261 bytes offset.
  1123. */
  1124. fno = card->ext_perf.fno;
  1125. page = card->ext_perf.page;
  1126. offset = card->ext_perf.offset + 261;
  1127. err = sd_write_ext_reg(card, fno, page, offset, BIT(0));
  1128. if (err) {
  1129. pr_warn("%s: error %d writing Cache Flush bit\n",
  1130. mmc_hostname(host), err);
  1131. goto out;
  1132. }
  1133. err = mmc_poll_for_busy(card, SD_WRITE_EXTR_SINGLE_TIMEOUT_MS, false,
  1134. MMC_BUSY_EXTR_SINGLE);
  1135. if (err)
  1136. goto out;
  1137. /*
  1138. * Read the Flush Cache bit. The card shall reset it, to confirm that
  1139. * it's has completed the flushing of the cache.
  1140. */
  1141. err = sd_read_ext_reg(card, fno, page, offset, 1, reg_buf);
  1142. if (err) {
  1143. pr_warn("%s: error %d reading Cache Flush bit\n",
  1144. mmc_hostname(host), err);
  1145. goto out;
  1146. }
  1147. if (reg_buf[0] & BIT(0))
  1148. err = -ETIMEDOUT;
  1149. out:
  1150. kfree(reg_buf);
  1151. return err;
  1152. }
  1153. static int sd_enable_cache(struct mmc_card *card)
  1154. {
  1155. u8 *reg_buf;
  1156. int err;
  1157. card->ext_perf.feature_enabled &= ~SD_EXT_PERF_CACHE;
  1158. reg_buf = kzalloc(512, GFP_KERNEL);
  1159. if (!reg_buf)
  1160. return -ENOMEM;
  1161. /*
  1162. * Set Cache Enable at bit 0 in the performance enhancement register at
  1163. * 260 bytes offset.
  1164. */
  1165. err = sd_write_ext_reg(card, card->ext_perf.fno, card->ext_perf.page,
  1166. card->ext_perf.offset + 260, BIT(0));
  1167. if (err) {
  1168. pr_warn("%s: error %d writing Cache Enable bit\n",
  1169. mmc_hostname(card->host), err);
  1170. goto out;
  1171. }
  1172. err = mmc_poll_for_busy(card, SD_WRITE_EXTR_SINGLE_TIMEOUT_MS, false,
  1173. MMC_BUSY_EXTR_SINGLE);
  1174. if (!err)
  1175. card->ext_perf.feature_enabled |= SD_EXT_PERF_CACHE;
  1176. out:
  1177. kfree(reg_buf);
  1178. return err;
  1179. }
  1180. /*
  1181. * Handle the detection and initialisation of a card.
  1182. *
  1183. * In the case of a resume, "oldcard" will contain the card
  1184. * we're trying to reinitialise.
  1185. */
  1186. static int mmc_sd_init_card(struct mmc_host *host, u32 ocr,
  1187. struct mmc_card *oldcard)
  1188. {
  1189. struct mmc_card *card;
  1190. int err;
  1191. u32 cid[4];
  1192. u32 rocr = 0;
  1193. bool v18_fixup_failed = false;
  1194. WARN_ON(!host->claimed);
  1195. retry:
  1196. err = mmc_sd_get_cid(host, ocr, cid, &rocr);
  1197. if (err)
  1198. return err;
  1199. if (oldcard) {
  1200. if (memcmp(cid, oldcard->raw_cid, sizeof(cid)) != 0) {
  1201. pr_debug("%s: Perhaps the card was replaced\n",
  1202. mmc_hostname(host));
  1203. return -ENOENT;
  1204. }
  1205. card = oldcard;
  1206. } else {
  1207. /*
  1208. * Allocate card structure.
  1209. */
  1210. card = mmc_alloc_card(host, &sd_type);
  1211. if (IS_ERR(card))
  1212. return PTR_ERR(card);
  1213. card->ocr = ocr;
  1214. card->type = MMC_TYPE_SD;
  1215. memcpy(card->raw_cid, cid, sizeof(card->raw_cid));
  1216. }
  1217. /*
  1218. * Call the optional HC's init_card function to handle quirks.
  1219. */
  1220. if (host->ops->init_card)
  1221. host->ops->init_card(host, card);
  1222. /*
  1223. * For native busses: get card RCA and quit open drain mode.
  1224. */
  1225. if (!mmc_host_is_spi(host)) {
  1226. err = mmc_send_relative_addr(host, &card->rca);
  1227. if (err)
  1228. goto free_card;
  1229. }
  1230. if (!oldcard) {
  1231. u32 sduc_arg = SD_OCR_CCS | SD_OCR_2T;
  1232. bool is_sduc = (rocr & sduc_arg) == sduc_arg;
  1233. err = mmc_sd_get_csd(card, is_sduc);
  1234. if (err)
  1235. goto free_card;
  1236. mmc_decode_cid(card);
  1237. }
  1238. /*
  1239. * handling only for cards supporting DSR and hosts requesting
  1240. * DSR configuration
  1241. */
  1242. if (card->csd.dsr_imp && host->dsr_req)
  1243. mmc_set_dsr(host);
  1244. /*
  1245. * Select card, as all following commands rely on that.
  1246. */
  1247. if (!mmc_host_is_spi(host)) {
  1248. err = mmc_select_card(card);
  1249. if (err)
  1250. goto free_card;
  1251. }
  1252. /* Apply quirks prior to card setup */
  1253. mmc_fixup_device(card, mmc_sd_fixups);
  1254. err = mmc_sd_setup_card(host, card, oldcard != NULL);
  1255. if (err)
  1256. goto free_card;
  1257. /*
  1258. * If the card has not been power cycled, it may still be using 1.8V
  1259. * signaling. Detect that situation and try to initialize a UHS-I (1.8V)
  1260. * transfer mode.
  1261. */
  1262. if (!v18_fixup_failed && !mmc_host_is_spi(host) && mmc_host_can_uhs(host) &&
  1263. mmc_sd_card_using_v18(card) &&
  1264. host->ios.signal_voltage != MMC_SIGNAL_VOLTAGE_180) {
  1265. if (mmc_host_set_uhs_voltage(host) ||
  1266. mmc_sd_init_uhs_card(card)) {
  1267. v18_fixup_failed = true;
  1268. mmc_power_cycle(host, ocr);
  1269. if (!oldcard)
  1270. mmc_remove_card(card);
  1271. goto retry;
  1272. }
  1273. goto cont;
  1274. }
  1275. /* Initialization sequence for UHS-I cards */
  1276. if (rocr & SD_ROCR_S18A && mmc_host_can_uhs(host)) {
  1277. err = mmc_sd_init_uhs_card(card);
  1278. if (err)
  1279. goto free_card;
  1280. } else {
  1281. /*
  1282. * Attempt to change to high-speed (if supported)
  1283. */
  1284. err = mmc_sd_switch_hs(card);
  1285. if (err > 0)
  1286. mmc_set_timing(card->host, MMC_TIMING_SD_HS);
  1287. else if (err)
  1288. goto free_card;
  1289. /*
  1290. * Set bus speed.
  1291. */
  1292. mmc_set_clock(host, mmc_sd_get_max_clock(card));
  1293. if (host->ios.timing == MMC_TIMING_SD_HS &&
  1294. host->ops->prepare_sd_hs_tuning) {
  1295. err = host->ops->prepare_sd_hs_tuning(host, card);
  1296. if (err)
  1297. goto free_card;
  1298. }
  1299. /*
  1300. * Switch to wider bus (if supported).
  1301. */
  1302. if ((host->caps & MMC_CAP_4_BIT_DATA) &&
  1303. (card->scr.bus_widths & SD_SCR_BUS_WIDTH_4)) {
  1304. err = mmc_app_set_bus_width(card, MMC_BUS_WIDTH_4);
  1305. if (err)
  1306. goto free_card;
  1307. mmc_set_bus_width(host, MMC_BUS_WIDTH_4);
  1308. }
  1309. if (host->ios.timing == MMC_TIMING_SD_HS &&
  1310. host->ops->execute_sd_hs_tuning) {
  1311. err = host->ops->execute_sd_hs_tuning(host, card);
  1312. if (err)
  1313. goto free_card;
  1314. }
  1315. }
  1316. cont:
  1317. if (!oldcard) {
  1318. /* Read/parse the extension registers. */
  1319. err = sd_read_ext_regs(card);
  1320. if (err)
  1321. goto free_card;
  1322. }
  1323. /* Enable internal SD cache if supported. */
  1324. if (card->ext_perf.feature_support & SD_EXT_PERF_CACHE) {
  1325. err = sd_enable_cache(card);
  1326. if (err)
  1327. goto free_card;
  1328. }
  1329. if (!mmc_card_ult_capacity(card) && host->cqe_ops && !host->cqe_enabled) {
  1330. err = host->cqe_ops->cqe_enable(host, card);
  1331. if (!err) {
  1332. host->cqe_enabled = true;
  1333. host->hsq_enabled = true;
  1334. pr_info("%s: Host Software Queue enabled\n",
  1335. mmc_hostname(host));
  1336. }
  1337. }
  1338. if (host->caps2 & MMC_CAP2_AVOID_3_3V &&
  1339. host->ios.signal_voltage == MMC_SIGNAL_VOLTAGE_330) {
  1340. pr_err("%s: Host failed to negotiate down from 3.3V\n",
  1341. mmc_hostname(host));
  1342. err = -EINVAL;
  1343. goto free_card;
  1344. }
  1345. host->card = card;
  1346. return 0;
  1347. free_card:
  1348. if (!oldcard)
  1349. mmc_remove_card(card);
  1350. return err;
  1351. }
  1352. /*
  1353. * Card detection - card is alive.
  1354. */
  1355. static int mmc_sd_alive(struct mmc_host *host)
  1356. {
  1357. return mmc_send_status(host->card, NULL);
  1358. }
  1359. /*
  1360. * Card detection callback from host.
  1361. */
  1362. static void mmc_sd_detect(struct mmc_host *host)
  1363. {
  1364. int err;
  1365. mmc_get_card(host->card, NULL);
  1366. /*
  1367. * Just check if our card has been removed.
  1368. */
  1369. err = _mmc_detect_card_removed(host);
  1370. mmc_put_card(host->card, NULL);
  1371. if (err) {
  1372. mmc_remove_card(host->card);
  1373. host->card = NULL;
  1374. mmc_claim_host(host);
  1375. mmc_detach_bus(host);
  1376. mmc_power_off(host);
  1377. mmc_release_host(host);
  1378. }
  1379. }
  1380. static int sd_can_poweroff_notify(struct mmc_card *card)
  1381. {
  1382. return card->ext_power.feature_support & SD_EXT_POWER_OFF_NOTIFY;
  1383. }
  1384. static int sd_busy_poweroff_notify_cb(void *cb_data, bool *busy)
  1385. {
  1386. struct sd_busy_data *data = cb_data;
  1387. struct mmc_card *card = data->card;
  1388. int err;
  1389. /*
  1390. * Read the status register for the power management function. It's at
  1391. * one byte offset and is one byte long. The Power Off Notification
  1392. * Ready is bit 0.
  1393. */
  1394. err = sd_read_ext_reg(card, card->ext_power.fno, card->ext_power.page,
  1395. card->ext_power.offset + 1, 1, data->reg_buf);
  1396. if (err) {
  1397. pr_warn("%s: error %d reading status reg of PM func\n",
  1398. mmc_hostname(card->host), err);
  1399. return err;
  1400. }
  1401. *busy = !(data->reg_buf[0] & BIT(0));
  1402. return 0;
  1403. }
  1404. static int sd_poweroff_notify(struct mmc_card *card)
  1405. {
  1406. struct sd_busy_data cb_data;
  1407. u8 *reg_buf;
  1408. int err;
  1409. reg_buf = kzalloc(512, GFP_KERNEL);
  1410. if (!reg_buf)
  1411. return -ENOMEM;
  1412. /*
  1413. * Set the Power Off Notification bit in the power management settings
  1414. * register at 2 bytes offset.
  1415. */
  1416. err = sd_write_ext_reg(card, card->ext_power.fno, card->ext_power.page,
  1417. card->ext_power.offset + 2, BIT(0));
  1418. if (err) {
  1419. pr_warn("%s: error %d writing Power Off Notify bit\n",
  1420. mmc_hostname(card->host), err);
  1421. goto out;
  1422. }
  1423. /* Find out when the command is completed. */
  1424. err = mmc_poll_for_busy(card, SD_WRITE_EXTR_SINGLE_TIMEOUT_MS, false,
  1425. MMC_BUSY_EXTR_SINGLE);
  1426. if (err)
  1427. goto out;
  1428. cb_data.card = card;
  1429. cb_data.reg_buf = reg_buf;
  1430. err = __mmc_poll_for_busy(card->host, 0, SD_POWEROFF_NOTIFY_TIMEOUT_MS,
  1431. &sd_busy_poweroff_notify_cb, &cb_data);
  1432. out:
  1433. kfree(reg_buf);
  1434. return err;
  1435. }
  1436. static int _mmc_sd_suspend(struct mmc_host *host)
  1437. {
  1438. struct mmc_card *card = host->card;
  1439. int err = 0;
  1440. mmc_claim_host(host);
  1441. if (mmc_card_suspended(card))
  1442. goto out;
  1443. if (sd_can_poweroff_notify(card))
  1444. err = sd_poweroff_notify(card);
  1445. else if (!mmc_host_is_spi(host))
  1446. err = mmc_deselect_cards(host);
  1447. if (!err) {
  1448. mmc_power_off(host);
  1449. mmc_card_set_suspended(card);
  1450. }
  1451. out:
  1452. mmc_release_host(host);
  1453. return err;
  1454. }
  1455. /*
  1456. * Host is being removed. Free up the current card and do a graceful power-off.
  1457. */
  1458. static void mmc_sd_remove(struct mmc_host *host)
  1459. {
  1460. get_device(&host->card->dev);
  1461. mmc_remove_card(host->card);
  1462. _mmc_sd_suspend(host);
  1463. put_device(&host->card->dev);
  1464. host->card = NULL;
  1465. }
  1466. /*
  1467. * Callback for suspend
  1468. */
  1469. static int mmc_sd_suspend(struct mmc_host *host)
  1470. {
  1471. int err;
  1472. err = _mmc_sd_suspend(host);
  1473. if (!err) {
  1474. pm_runtime_disable(&host->card->dev);
  1475. pm_runtime_set_suspended(&host->card->dev);
  1476. }
  1477. return err;
  1478. }
  1479. /*
  1480. * This function tries to determine if the same card is still present
  1481. * and, if so, restore all state to it.
  1482. */
  1483. static int _mmc_sd_resume(struct mmc_host *host)
  1484. {
  1485. int err = 0;
  1486. mmc_claim_host(host);
  1487. if (!mmc_card_suspended(host->card))
  1488. goto out;
  1489. mmc_power_up(host, host->card->ocr);
  1490. err = mmc_sd_init_card(host, host->card->ocr, host->card);
  1491. mmc_card_clr_suspended(host->card);
  1492. out:
  1493. mmc_release_host(host);
  1494. return err;
  1495. }
  1496. /*
  1497. * Callback for resume
  1498. */
  1499. static int mmc_sd_resume(struct mmc_host *host)
  1500. {
  1501. pm_runtime_enable(&host->card->dev);
  1502. return 0;
  1503. }
  1504. /*
  1505. * Callback for runtime_suspend.
  1506. */
  1507. static int mmc_sd_runtime_suspend(struct mmc_host *host)
  1508. {
  1509. int err;
  1510. if (!(host->caps & MMC_CAP_AGGRESSIVE_PM))
  1511. return 0;
  1512. err = _mmc_sd_suspend(host);
  1513. if (err)
  1514. pr_err("%s: error %d doing aggressive suspend\n",
  1515. mmc_hostname(host), err);
  1516. return err;
  1517. }
  1518. /*
  1519. * Callback for runtime_resume.
  1520. */
  1521. static int mmc_sd_runtime_resume(struct mmc_host *host)
  1522. {
  1523. int err;
  1524. err = _mmc_sd_resume(host);
  1525. if (err && err != -ENOMEDIUM)
  1526. pr_err("%s: error %d doing runtime resume\n",
  1527. mmc_hostname(host), err);
  1528. return 0;
  1529. }
  1530. static int mmc_sd_hw_reset(struct mmc_host *host)
  1531. {
  1532. mmc_power_cycle(host, host->card->ocr);
  1533. return mmc_sd_init_card(host, host->card->ocr, host->card);
  1534. }
  1535. static const struct mmc_bus_ops mmc_sd_ops = {
  1536. .remove = mmc_sd_remove,
  1537. .detect = mmc_sd_detect,
  1538. .runtime_suspend = mmc_sd_runtime_suspend,
  1539. .runtime_resume = mmc_sd_runtime_resume,
  1540. .suspend = mmc_sd_suspend,
  1541. .resume = mmc_sd_resume,
  1542. .alive = mmc_sd_alive,
  1543. .shutdown = mmc_sd_suspend,
  1544. .hw_reset = mmc_sd_hw_reset,
  1545. .cache_enabled = sd_cache_enabled,
  1546. .flush_cache = sd_flush_cache,
  1547. };
  1548. /*
  1549. * Starting point for SD card init.
  1550. */
  1551. int mmc_attach_sd(struct mmc_host *host)
  1552. {
  1553. int err;
  1554. u32 ocr, rocr;
  1555. WARN_ON(!host->claimed);
  1556. err = mmc_send_app_op_cond(host, 0, &ocr);
  1557. if (err)
  1558. return err;
  1559. mmc_attach_bus(host, &mmc_sd_ops);
  1560. if (host->ocr_avail_sd)
  1561. host->ocr_avail = host->ocr_avail_sd;
  1562. /*
  1563. * We need to get OCR a different way for SPI.
  1564. */
  1565. if (mmc_host_is_spi(host)) {
  1566. mmc_go_idle(host);
  1567. err = mmc_spi_read_ocr(host, 0, &ocr);
  1568. if (err)
  1569. goto err;
  1570. }
  1571. /*
  1572. * Some SD cards claims an out of spec VDD voltage range. Let's treat
  1573. * these bits as being in-valid and especially also bit7.
  1574. */
  1575. ocr &= ~0x7FFF;
  1576. rocr = mmc_select_voltage(host, ocr);
  1577. /*
  1578. * Can we support the voltage(s) of the card(s)?
  1579. */
  1580. if (!rocr) {
  1581. err = -EINVAL;
  1582. goto err;
  1583. }
  1584. /*
  1585. * Detect and init the card.
  1586. */
  1587. err = mmc_sd_init_card(host, rocr, NULL);
  1588. if (err)
  1589. goto err;
  1590. mmc_release_host(host);
  1591. err = mmc_add_card(host->card);
  1592. if (err)
  1593. goto remove_card;
  1594. mmc_claim_host(host);
  1595. return 0;
  1596. remove_card:
  1597. mmc_remove_card(host->card);
  1598. host->card = NULL;
  1599. mmc_claim_host(host);
  1600. err:
  1601. mmc_detach_bus(host);
  1602. pr_err("%s: error %d whilst initialising SD card\n",
  1603. mmc_hostname(host), err);
  1604. return err;
  1605. }