spi-nor.c 86 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999
  1. /*
  2. * Based on m25p80.c, by Mike Lavender (mike@steroidmicros.com), with
  3. * influence from lart.c (Abraham Van Der Merwe) and mtd_dataflash.c
  4. *
  5. * Copyright (C) 2005, Intec Automation Inc.
  6. * Copyright (C) 2014, Freescale Semiconductor, Inc.
  7. *
  8. * This code is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License version 2 as
  10. * published by the Free Software Foundation.
  11. */
  12. #include <linux/err.h>
  13. #include <linux/errno.h>
  14. #include <linux/module.h>
  15. #include <linux/device.h>
  16. #include <linux/mutex.h>
  17. #include <linux/math64.h>
  18. #include <linux/sizes.h>
  19. #include <linux/slab.h>
  20. #include <linux/mtd/mtd.h>
  21. #include <linux/of_platform.h>
  22. #include <linux/spi/flash.h>
  23. #include <linux/mtd/spi-nor.h>
  24. /* Define max times to check status register before we give up. */
  25. /*
  26. * For everything but full-chip erase; probably could be much smaller, but kept
  27. * around for safety for now
  28. */
  29. #define DEFAULT_READY_WAIT_JIFFIES (40UL * HZ)
  30. /*
  31. * For full-chip erase, calibrated to a 2MB flash (M25P16); should be scaled up
  32. * for larger flash
  33. */
  34. #define CHIP_ERASE_2MB_READY_WAIT_JIFFIES (40UL * HZ)
  35. #define SPI_NOR_MAX_ID_LEN 6
  36. #define SPI_NOR_MAX_ADDR_WIDTH 4
  37. struct flash_info {
  38. char *name;
  39. /*
  40. * This array stores the ID bytes.
  41. * The first three bytes are the JEDIC ID.
  42. * JEDEC ID zero means "no ID" (mostly older chips).
  43. */
  44. u8 id[SPI_NOR_MAX_ID_LEN];
  45. u8 id_len;
  46. /* The size listed here is what works with SPINOR_OP_SE, which isn't
  47. * necessarily called a "sector" by the vendor.
  48. */
  49. unsigned sector_size;
  50. u16 n_sectors;
  51. u16 page_size;
  52. u16 addr_width;
  53. u16 flags;
  54. #define SECT_4K BIT(0) /* SPINOR_OP_BE_4K works uniformly */
  55. #define SPI_NOR_NO_ERASE BIT(1) /* No erase command needed */
  56. #define SST_WRITE BIT(2) /* use SST byte programming */
  57. #define SPI_NOR_NO_FR BIT(3) /* Can't do fastread */
  58. #define SECT_4K_PMC BIT(4) /* SPINOR_OP_BE_4K_PMC works uniformly */
  59. #define SPI_NOR_DUAL_READ BIT(5) /* Flash supports Dual Read */
  60. #define SPI_NOR_QUAD_READ BIT(6) /* Flash supports Quad Read */
  61. #define USE_FSR BIT(7) /* use flag status register */
  62. #define SPI_NOR_HAS_LOCK BIT(8) /* Flash supports lock/unlock via SR */
  63. #define SPI_NOR_HAS_TB BIT(9) /*
  64. * Flash SR has Top/Bottom (TB) protect
  65. * bit. Must be used with
  66. * SPI_NOR_HAS_LOCK.
  67. */
  68. #define SPI_S3AN BIT(10) /*
  69. * Xilinx Spartan 3AN In-System Flash
  70. * (MFR cannot be used for probing
  71. * because it has the same value as
  72. * ATMEL flashes)
  73. */
  74. #define SPI_NOR_4B_OPCODES BIT(11) /*
  75. * Use dedicated 4byte address op codes
  76. * to support memory size above 128Mib.
  77. */
  78. #define NO_CHIP_ERASE BIT(12) /* Chip does not support chip erase */
  79. #define SPI_NOR_SKIP_SFDP BIT(13) /* Skip parsing of SFDP tables */
  80. #define USE_CLSR BIT(14) /* use CLSR command */
  81. int (*quad_enable)(struct spi_nor *nor);
  82. };
  83. #define JEDEC_MFR(info) ((info)->id[0])
  84. static const struct flash_info *spi_nor_match_id(const char *name);
  85. /*
  86. * Read the status register, returning its value in the location
  87. * Return the status register value.
  88. * Returns negative if error occurred.
  89. */
  90. static int read_sr(struct spi_nor *nor)
  91. {
  92. int ret;
  93. u8 val;
  94. ret = nor->read_reg(nor, SPINOR_OP_RDSR, &val, 1);
  95. if (ret < 0) {
  96. pr_err("error %d reading SR\n", (int) ret);
  97. return ret;
  98. }
  99. return val;
  100. }
  101. /*
  102. * Read the flag status register, returning its value in the location
  103. * Return the status register value.
  104. * Returns negative if error occurred.
  105. */
  106. static int read_fsr(struct spi_nor *nor)
  107. {
  108. int ret;
  109. u8 val;
  110. ret = nor->read_reg(nor, SPINOR_OP_RDFSR, &val, 1);
  111. if (ret < 0) {
  112. pr_err("error %d reading FSR\n", ret);
  113. return ret;
  114. }
  115. return val;
  116. }
  117. /*
  118. * Read configuration register, returning its value in the
  119. * location. Return the configuration register value.
  120. * Returns negative if error occurred.
  121. */
  122. static int read_cr(struct spi_nor *nor)
  123. {
  124. int ret;
  125. u8 val;
  126. ret = nor->read_reg(nor, SPINOR_OP_RDCR, &val, 1);
  127. if (ret < 0) {
  128. dev_err(nor->dev, "error %d reading CR\n", ret);
  129. return ret;
  130. }
  131. return val;
  132. }
  133. /*
  134. * Write status register 1 byte
  135. * Returns negative if error occurred.
  136. */
  137. static inline int write_sr(struct spi_nor *nor, u8 val)
  138. {
  139. nor->cmd_buf[0] = val;
  140. return nor->write_reg(nor, SPINOR_OP_WRSR, nor->cmd_buf, 1);
  141. }
  142. /*
  143. * Set write enable latch with Write Enable command.
  144. * Returns negative if error occurred.
  145. */
  146. static inline int write_enable(struct spi_nor *nor)
  147. {
  148. return nor->write_reg(nor, SPINOR_OP_WREN, NULL, 0);
  149. }
  150. /*
  151. * Send write disable instruction to the chip.
  152. */
  153. static inline int write_disable(struct spi_nor *nor)
  154. {
  155. return nor->write_reg(nor, SPINOR_OP_WRDI, NULL, 0);
  156. }
  157. static inline struct spi_nor *mtd_to_spi_nor(struct mtd_info *mtd)
  158. {
  159. return mtd->priv;
  160. }
  161. static u8 spi_nor_convert_opcode(u8 opcode, const u8 table[][2], size_t size)
  162. {
  163. size_t i;
  164. for (i = 0; i < size; i++)
  165. if (table[i][0] == opcode)
  166. return table[i][1];
  167. /* No conversion found, keep input op code. */
  168. return opcode;
  169. }
  170. static inline u8 spi_nor_convert_3to4_read(u8 opcode)
  171. {
  172. static const u8 spi_nor_3to4_read[][2] = {
  173. { SPINOR_OP_READ, SPINOR_OP_READ_4B },
  174. { SPINOR_OP_READ_FAST, SPINOR_OP_READ_FAST_4B },
  175. { SPINOR_OP_READ_1_1_2, SPINOR_OP_READ_1_1_2_4B },
  176. { SPINOR_OP_READ_1_2_2, SPINOR_OP_READ_1_2_2_4B },
  177. { SPINOR_OP_READ_1_1_4, SPINOR_OP_READ_1_1_4_4B },
  178. { SPINOR_OP_READ_1_4_4, SPINOR_OP_READ_1_4_4_4B },
  179. { SPINOR_OP_READ_1_1_1_DTR, SPINOR_OP_READ_1_1_1_DTR_4B },
  180. { SPINOR_OP_READ_1_2_2_DTR, SPINOR_OP_READ_1_2_2_DTR_4B },
  181. { SPINOR_OP_READ_1_4_4_DTR, SPINOR_OP_READ_1_4_4_DTR_4B },
  182. };
  183. return spi_nor_convert_opcode(opcode, spi_nor_3to4_read,
  184. ARRAY_SIZE(spi_nor_3to4_read));
  185. }
  186. static inline u8 spi_nor_convert_3to4_program(u8 opcode)
  187. {
  188. static const u8 spi_nor_3to4_program[][2] = {
  189. { SPINOR_OP_PP, SPINOR_OP_PP_4B },
  190. { SPINOR_OP_PP_1_1_4, SPINOR_OP_PP_1_1_4_4B },
  191. { SPINOR_OP_PP_1_4_4, SPINOR_OP_PP_1_4_4_4B },
  192. };
  193. return spi_nor_convert_opcode(opcode, spi_nor_3to4_program,
  194. ARRAY_SIZE(spi_nor_3to4_program));
  195. }
  196. static inline u8 spi_nor_convert_3to4_erase(u8 opcode)
  197. {
  198. static const u8 spi_nor_3to4_erase[][2] = {
  199. { SPINOR_OP_BE_4K, SPINOR_OP_BE_4K_4B },
  200. { SPINOR_OP_BE_32K, SPINOR_OP_BE_32K_4B },
  201. { SPINOR_OP_SE, SPINOR_OP_SE_4B },
  202. };
  203. return spi_nor_convert_opcode(opcode, spi_nor_3to4_erase,
  204. ARRAY_SIZE(spi_nor_3to4_erase));
  205. }
  206. static void spi_nor_set_4byte_opcodes(struct spi_nor *nor,
  207. const struct flash_info *info)
  208. {
  209. /* Do some manufacturer fixups first */
  210. switch (JEDEC_MFR(info)) {
  211. case SNOR_MFR_SPANSION:
  212. /* No small sector erase for 4-byte command set */
  213. nor->erase_opcode = SPINOR_OP_SE;
  214. nor->mtd.erasesize = info->sector_size;
  215. break;
  216. default:
  217. break;
  218. }
  219. nor->read_opcode = spi_nor_convert_3to4_read(nor->read_opcode);
  220. nor->program_opcode = spi_nor_convert_3to4_program(nor->program_opcode);
  221. nor->erase_opcode = spi_nor_convert_3to4_erase(nor->erase_opcode);
  222. }
  223. /* Enable/disable 4-byte addressing mode. */
  224. static inline int set_4byte(struct spi_nor *nor, const struct flash_info *info,
  225. int enable)
  226. {
  227. int status;
  228. bool need_wren = false;
  229. u8 cmd;
  230. switch (JEDEC_MFR(info)) {
  231. case SNOR_MFR_MICRON:
  232. /* Some Micron need WREN command; all will accept it */
  233. need_wren = true;
  234. case SNOR_MFR_MACRONIX:
  235. case SNOR_MFR_WINBOND:
  236. if (need_wren)
  237. write_enable(nor);
  238. cmd = enable ? SPINOR_OP_EN4B : SPINOR_OP_EX4B;
  239. status = nor->write_reg(nor, cmd, NULL, 0);
  240. if (need_wren)
  241. write_disable(nor);
  242. if (!status && !enable &&
  243. JEDEC_MFR(info) == SNOR_MFR_WINBOND) {
  244. /*
  245. * On Winbond W25Q256FV, leaving 4byte mode causes
  246. * the Extended Address Register to be set to 1, so all
  247. * 3-byte-address reads come from the second 16M.
  248. * We must clear the register to enable normal behavior.
  249. */
  250. write_enable(nor);
  251. nor->cmd_buf[0] = 0;
  252. nor->write_reg(nor, SPINOR_OP_WREAR, nor->cmd_buf, 1);
  253. write_disable(nor);
  254. }
  255. return status;
  256. default:
  257. /* Spansion style */
  258. nor->cmd_buf[0] = enable << 7;
  259. return nor->write_reg(nor, SPINOR_OP_BRWR, nor->cmd_buf, 1);
  260. }
  261. }
  262. static int s3an_sr_ready(struct spi_nor *nor)
  263. {
  264. int ret;
  265. u8 val;
  266. ret = nor->read_reg(nor, SPINOR_OP_XRDSR, &val, 1);
  267. if (ret < 0) {
  268. dev_err(nor->dev, "error %d reading XRDSR\n", (int) ret);
  269. return ret;
  270. }
  271. return !!(val & XSR_RDY);
  272. }
  273. static inline int spi_nor_sr_ready(struct spi_nor *nor)
  274. {
  275. int sr = read_sr(nor);
  276. if (sr < 0)
  277. return sr;
  278. if (nor->flags & SNOR_F_USE_CLSR && sr & (SR_E_ERR | SR_P_ERR)) {
  279. if (sr & SR_E_ERR)
  280. dev_err(nor->dev, "Erase Error occurred\n");
  281. else
  282. dev_err(nor->dev, "Programming Error occurred\n");
  283. nor->write_reg(nor, SPINOR_OP_CLSR, NULL, 0);
  284. return -EIO;
  285. }
  286. return !(sr & SR_WIP);
  287. }
  288. static inline int spi_nor_fsr_ready(struct spi_nor *nor)
  289. {
  290. int fsr = read_fsr(nor);
  291. if (fsr < 0)
  292. return fsr;
  293. if (fsr & (FSR_E_ERR | FSR_P_ERR)) {
  294. if (fsr & FSR_E_ERR)
  295. dev_err(nor->dev, "Erase operation failed.\n");
  296. else
  297. dev_err(nor->dev, "Program operation failed.\n");
  298. if (fsr & FSR_PT_ERR)
  299. dev_err(nor->dev,
  300. "Attempted to modify a protected sector.\n");
  301. nor->write_reg(nor, SPINOR_OP_CLFSR, NULL, 0);
  302. return -EIO;
  303. }
  304. return fsr & FSR_READY;
  305. }
  306. static int spi_nor_ready(struct spi_nor *nor)
  307. {
  308. int sr, fsr;
  309. if (nor->flags & SNOR_F_READY_XSR_RDY)
  310. sr = s3an_sr_ready(nor);
  311. else
  312. sr = spi_nor_sr_ready(nor);
  313. if (sr < 0)
  314. return sr;
  315. fsr = nor->flags & SNOR_F_USE_FSR ? spi_nor_fsr_ready(nor) : 1;
  316. if (fsr < 0)
  317. return fsr;
  318. return sr && fsr;
  319. }
  320. /*
  321. * Service routine to read status register until ready, or timeout occurs.
  322. * Returns non-zero if error.
  323. */
  324. static int spi_nor_wait_till_ready_with_timeout(struct spi_nor *nor,
  325. unsigned long timeout_jiffies)
  326. {
  327. unsigned long deadline;
  328. int timeout = 0, ret;
  329. deadline = jiffies + timeout_jiffies;
  330. while (!timeout) {
  331. if (time_after_eq(jiffies, deadline))
  332. timeout = 1;
  333. ret = spi_nor_ready(nor);
  334. if (ret < 0)
  335. return ret;
  336. if (ret)
  337. return 0;
  338. cond_resched();
  339. }
  340. dev_err(nor->dev, "flash operation timed out\n");
  341. return -ETIMEDOUT;
  342. }
  343. static int spi_nor_wait_till_ready(struct spi_nor *nor)
  344. {
  345. return spi_nor_wait_till_ready_with_timeout(nor,
  346. DEFAULT_READY_WAIT_JIFFIES);
  347. }
  348. /*
  349. * Erase the whole flash memory
  350. *
  351. * Returns 0 if successful, non-zero otherwise.
  352. */
  353. static int erase_chip(struct spi_nor *nor)
  354. {
  355. dev_dbg(nor->dev, " %lldKiB\n", (long long)(nor->mtd.size >> 10));
  356. return nor->write_reg(nor, SPINOR_OP_CHIP_ERASE, NULL, 0);
  357. }
  358. static int spi_nor_lock_and_prep(struct spi_nor *nor, enum spi_nor_ops ops)
  359. {
  360. int ret = 0;
  361. mutex_lock(&nor->lock);
  362. if (nor->prepare) {
  363. ret = nor->prepare(nor, ops);
  364. if (ret) {
  365. dev_err(nor->dev, "failed in the preparation.\n");
  366. mutex_unlock(&nor->lock);
  367. return ret;
  368. }
  369. }
  370. return ret;
  371. }
  372. static void spi_nor_unlock_and_unprep(struct spi_nor *nor, enum spi_nor_ops ops)
  373. {
  374. if (nor->unprepare)
  375. nor->unprepare(nor, ops);
  376. mutex_unlock(&nor->lock);
  377. }
  378. /*
  379. * This code converts an address to the Default Address Mode, that has non
  380. * power of two page sizes. We must support this mode because it is the default
  381. * mode supported by Xilinx tools, it can access the whole flash area and
  382. * changing over to the Power-of-two mode is irreversible and corrupts the
  383. * original data.
  384. * Addr can safely be unsigned int, the biggest S3AN device is smaller than
  385. * 4 MiB.
  386. */
  387. static loff_t spi_nor_s3an_addr_convert(struct spi_nor *nor, unsigned int addr)
  388. {
  389. unsigned int offset;
  390. unsigned int page;
  391. offset = addr % nor->page_size;
  392. page = addr / nor->page_size;
  393. page <<= (nor->page_size > 512) ? 10 : 9;
  394. return page | offset;
  395. }
  396. /*
  397. * Initiate the erasure of a single sector
  398. */
  399. static int spi_nor_erase_sector(struct spi_nor *nor, u32 addr)
  400. {
  401. u8 buf[SPI_NOR_MAX_ADDR_WIDTH];
  402. int i;
  403. if (nor->flags & SNOR_F_S3AN_ADDR_DEFAULT)
  404. addr = spi_nor_s3an_addr_convert(nor, addr);
  405. if (nor->erase)
  406. return nor->erase(nor, addr);
  407. /*
  408. * Default implementation, if driver doesn't have a specialized HW
  409. * control
  410. */
  411. for (i = nor->addr_width - 1; i >= 0; i--) {
  412. buf[i] = addr & 0xff;
  413. addr >>= 8;
  414. }
  415. return nor->write_reg(nor, nor->erase_opcode, buf, nor->addr_width);
  416. }
  417. /*
  418. * Erase an address range on the nor chip. The address range may extend
  419. * one or more erase sectors. Return an error is there is a problem erasing.
  420. */
  421. static int spi_nor_erase(struct mtd_info *mtd, struct erase_info *instr)
  422. {
  423. struct spi_nor *nor = mtd_to_spi_nor(mtd);
  424. u32 addr, len;
  425. uint32_t rem;
  426. int ret;
  427. dev_dbg(nor->dev, "at 0x%llx, len %lld\n", (long long)instr->addr,
  428. (long long)instr->len);
  429. div_u64_rem(instr->len, mtd->erasesize, &rem);
  430. if (rem)
  431. return -EINVAL;
  432. addr = instr->addr;
  433. len = instr->len;
  434. ret = spi_nor_lock_and_prep(nor, SPI_NOR_OPS_ERASE);
  435. if (ret)
  436. return ret;
  437. /* whole-chip erase? */
  438. if (len == mtd->size && !(nor->flags & SNOR_F_NO_OP_CHIP_ERASE)) {
  439. unsigned long timeout;
  440. write_enable(nor);
  441. if (erase_chip(nor)) {
  442. ret = -EIO;
  443. goto erase_err;
  444. }
  445. /*
  446. * Scale the timeout linearly with the size of the flash, with
  447. * a minimum calibrated to an old 2MB flash. We could try to
  448. * pull these from CFI/SFDP, but these values should be good
  449. * enough for now.
  450. */
  451. timeout = max(CHIP_ERASE_2MB_READY_WAIT_JIFFIES,
  452. CHIP_ERASE_2MB_READY_WAIT_JIFFIES *
  453. (unsigned long)(mtd->size / SZ_2M));
  454. ret = spi_nor_wait_till_ready_with_timeout(nor, timeout);
  455. if (ret)
  456. goto erase_err;
  457. /* REVISIT in some cases we could speed up erasing large regions
  458. * by using SPINOR_OP_SE instead of SPINOR_OP_BE_4K. We may have set up
  459. * to use "small sector erase", but that's not always optimal.
  460. */
  461. /* "sector"-at-a-time erase */
  462. } else {
  463. while (len) {
  464. write_enable(nor);
  465. ret = spi_nor_erase_sector(nor, addr);
  466. if (ret)
  467. goto erase_err;
  468. addr += mtd->erasesize;
  469. len -= mtd->erasesize;
  470. ret = spi_nor_wait_till_ready(nor);
  471. if (ret)
  472. goto erase_err;
  473. }
  474. }
  475. write_disable(nor);
  476. erase_err:
  477. spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_ERASE);
  478. return ret;
  479. }
  480. /* Write status register and ensure bits in mask match written values */
  481. static int write_sr_and_check(struct spi_nor *nor, u8 status_new, u8 mask)
  482. {
  483. int ret;
  484. write_enable(nor);
  485. ret = write_sr(nor, status_new);
  486. if (ret)
  487. return ret;
  488. ret = spi_nor_wait_till_ready(nor);
  489. if (ret)
  490. return ret;
  491. ret = read_sr(nor);
  492. if (ret < 0)
  493. return ret;
  494. return ((ret & mask) != (status_new & mask)) ? -EIO : 0;
  495. }
  496. static void stm_get_locked_range(struct spi_nor *nor, u8 sr, loff_t *ofs,
  497. uint64_t *len)
  498. {
  499. struct mtd_info *mtd = &nor->mtd;
  500. u8 mask = SR_BP2 | SR_BP1 | SR_BP0;
  501. int shift = ffs(mask) - 1;
  502. int pow;
  503. if (!(sr & mask)) {
  504. /* No protection */
  505. *ofs = 0;
  506. *len = 0;
  507. } else {
  508. pow = ((sr & mask) ^ mask) >> shift;
  509. *len = mtd->size >> pow;
  510. if (nor->flags & SNOR_F_HAS_SR_TB && sr & SR_TB)
  511. *ofs = 0;
  512. else
  513. *ofs = mtd->size - *len;
  514. }
  515. }
  516. /*
  517. * Return 1 if the entire region is locked (if @locked is true) or unlocked (if
  518. * @locked is false); 0 otherwise
  519. */
  520. static int stm_check_lock_status_sr(struct spi_nor *nor, loff_t ofs, uint64_t len,
  521. u8 sr, bool locked)
  522. {
  523. loff_t lock_offs;
  524. uint64_t lock_len;
  525. if (!len)
  526. return 1;
  527. stm_get_locked_range(nor, sr, &lock_offs, &lock_len);
  528. if (locked)
  529. /* Requested range is a sub-range of locked range */
  530. return (ofs + len <= lock_offs + lock_len) && (ofs >= lock_offs);
  531. else
  532. /* Requested range does not overlap with locked range */
  533. return (ofs >= lock_offs + lock_len) || (ofs + len <= lock_offs);
  534. }
  535. static int stm_is_locked_sr(struct spi_nor *nor, loff_t ofs, uint64_t len,
  536. u8 sr)
  537. {
  538. return stm_check_lock_status_sr(nor, ofs, len, sr, true);
  539. }
  540. static int stm_is_unlocked_sr(struct spi_nor *nor, loff_t ofs, uint64_t len,
  541. u8 sr)
  542. {
  543. return stm_check_lock_status_sr(nor, ofs, len, sr, false);
  544. }
  545. /*
  546. * Lock a region of the flash. Compatible with ST Micro and similar flash.
  547. * Supports the block protection bits BP{0,1,2} in the status register
  548. * (SR). Does not support these features found in newer SR bitfields:
  549. * - SEC: sector/block protect - only handle SEC=0 (block protect)
  550. * - CMP: complement protect - only support CMP=0 (range is not complemented)
  551. *
  552. * Support for the following is provided conditionally for some flash:
  553. * - TB: top/bottom protect
  554. *
  555. * Sample table portion for 8MB flash (Winbond w25q64fw):
  556. *
  557. * SEC | TB | BP2 | BP1 | BP0 | Prot Length | Protected Portion
  558. * --------------------------------------------------------------------------
  559. * X | X | 0 | 0 | 0 | NONE | NONE
  560. * 0 | 0 | 0 | 0 | 1 | 128 KB | Upper 1/64
  561. * 0 | 0 | 0 | 1 | 0 | 256 KB | Upper 1/32
  562. * 0 | 0 | 0 | 1 | 1 | 512 KB | Upper 1/16
  563. * 0 | 0 | 1 | 0 | 0 | 1 MB | Upper 1/8
  564. * 0 | 0 | 1 | 0 | 1 | 2 MB | Upper 1/4
  565. * 0 | 0 | 1 | 1 | 0 | 4 MB | Upper 1/2
  566. * X | X | 1 | 1 | 1 | 8 MB | ALL
  567. * ------|-------|-------|-------|-------|---------------|-------------------
  568. * 0 | 1 | 0 | 0 | 1 | 128 KB | Lower 1/64
  569. * 0 | 1 | 0 | 1 | 0 | 256 KB | Lower 1/32
  570. * 0 | 1 | 0 | 1 | 1 | 512 KB | Lower 1/16
  571. * 0 | 1 | 1 | 0 | 0 | 1 MB | Lower 1/8
  572. * 0 | 1 | 1 | 0 | 1 | 2 MB | Lower 1/4
  573. * 0 | 1 | 1 | 1 | 0 | 4 MB | Lower 1/2
  574. *
  575. * Returns negative on errors, 0 on success.
  576. */
  577. static int stm_lock(struct spi_nor *nor, loff_t ofs, uint64_t len)
  578. {
  579. struct mtd_info *mtd = &nor->mtd;
  580. int status_old, status_new;
  581. u8 mask = SR_BP2 | SR_BP1 | SR_BP0;
  582. u8 shift = ffs(mask) - 1, pow, val;
  583. loff_t lock_len;
  584. bool can_be_top = true, can_be_bottom = nor->flags & SNOR_F_HAS_SR_TB;
  585. bool use_top;
  586. status_old = read_sr(nor);
  587. if (status_old < 0)
  588. return status_old;
  589. /* If nothing in our range is unlocked, we don't need to do anything */
  590. if (stm_is_locked_sr(nor, ofs, len, status_old))
  591. return 0;
  592. /* If anything below us is unlocked, we can't use 'bottom' protection */
  593. if (!stm_is_locked_sr(nor, 0, ofs, status_old))
  594. can_be_bottom = false;
  595. /* If anything above us is unlocked, we can't use 'top' protection */
  596. if (!stm_is_locked_sr(nor, ofs + len, mtd->size - (ofs + len),
  597. status_old))
  598. can_be_top = false;
  599. if (!can_be_bottom && !can_be_top)
  600. return -EINVAL;
  601. /* Prefer top, if both are valid */
  602. use_top = can_be_top;
  603. /* lock_len: length of region that should end up locked */
  604. if (use_top)
  605. lock_len = mtd->size - ofs;
  606. else
  607. lock_len = ofs + len;
  608. /*
  609. * Need smallest pow such that:
  610. *
  611. * 1 / (2^pow) <= (len / size)
  612. *
  613. * so (assuming power-of-2 size) we do:
  614. *
  615. * pow = ceil(log2(size / len)) = log2(size) - floor(log2(len))
  616. */
  617. pow = ilog2(mtd->size) - ilog2(lock_len);
  618. val = mask - (pow << shift);
  619. if (val & ~mask)
  620. return -EINVAL;
  621. /* Don't "lock" with no region! */
  622. if (!(val & mask))
  623. return -EINVAL;
  624. status_new = (status_old & ~mask & ~SR_TB) | val;
  625. /* Disallow further writes if WP pin is asserted */
  626. status_new |= SR_SRWD;
  627. if (!use_top)
  628. status_new |= SR_TB;
  629. /* Don't bother if they're the same */
  630. if (status_new == status_old)
  631. return 0;
  632. /* Only modify protection if it will not unlock other areas */
  633. if ((status_new & mask) < (status_old & mask))
  634. return -EINVAL;
  635. return write_sr_and_check(nor, status_new, mask);
  636. }
  637. /*
  638. * Unlock a region of the flash. See stm_lock() for more info
  639. *
  640. * Returns negative on errors, 0 on success.
  641. */
  642. static int stm_unlock(struct spi_nor *nor, loff_t ofs, uint64_t len)
  643. {
  644. struct mtd_info *mtd = &nor->mtd;
  645. int status_old, status_new;
  646. u8 mask = SR_BP2 | SR_BP1 | SR_BP0;
  647. u8 shift = ffs(mask) - 1, pow, val;
  648. loff_t lock_len;
  649. bool can_be_top = true, can_be_bottom = nor->flags & SNOR_F_HAS_SR_TB;
  650. bool use_top;
  651. status_old = read_sr(nor);
  652. if (status_old < 0)
  653. return status_old;
  654. /* If nothing in our range is locked, we don't need to do anything */
  655. if (stm_is_unlocked_sr(nor, ofs, len, status_old))
  656. return 0;
  657. /* If anything below us is locked, we can't use 'top' protection */
  658. if (!stm_is_unlocked_sr(nor, 0, ofs, status_old))
  659. can_be_top = false;
  660. /* If anything above us is locked, we can't use 'bottom' protection */
  661. if (!stm_is_unlocked_sr(nor, ofs + len, mtd->size - (ofs + len),
  662. status_old))
  663. can_be_bottom = false;
  664. if (!can_be_bottom && !can_be_top)
  665. return -EINVAL;
  666. /* Prefer top, if both are valid */
  667. use_top = can_be_top;
  668. /* lock_len: length of region that should remain locked */
  669. if (use_top)
  670. lock_len = mtd->size - (ofs + len);
  671. else
  672. lock_len = ofs;
  673. /*
  674. * Need largest pow such that:
  675. *
  676. * 1 / (2^pow) >= (len / size)
  677. *
  678. * so (assuming power-of-2 size) we do:
  679. *
  680. * pow = floor(log2(size / len)) = log2(size) - ceil(log2(len))
  681. */
  682. pow = ilog2(mtd->size) - order_base_2(lock_len);
  683. if (lock_len == 0) {
  684. val = 0; /* fully unlocked */
  685. } else {
  686. val = mask - (pow << shift);
  687. /* Some power-of-two sizes are not supported */
  688. if (val & ~mask)
  689. return -EINVAL;
  690. }
  691. status_new = (status_old & ~mask & ~SR_TB) | val;
  692. /* Don't protect status register if we're fully unlocked */
  693. if (lock_len == 0)
  694. status_new &= ~SR_SRWD;
  695. if (!use_top)
  696. status_new |= SR_TB;
  697. /* Don't bother if they're the same */
  698. if (status_new == status_old)
  699. return 0;
  700. /* Only modify protection if it will not lock other areas */
  701. if ((status_new & mask) > (status_old & mask))
  702. return -EINVAL;
  703. return write_sr_and_check(nor, status_new, mask);
  704. }
  705. /*
  706. * Check if a region of the flash is (completely) locked. See stm_lock() for
  707. * more info.
  708. *
  709. * Returns 1 if entire region is locked, 0 if any portion is unlocked, and
  710. * negative on errors.
  711. */
  712. static int stm_is_locked(struct spi_nor *nor, loff_t ofs, uint64_t len)
  713. {
  714. int status;
  715. status = read_sr(nor);
  716. if (status < 0)
  717. return status;
  718. return stm_is_locked_sr(nor, ofs, len, status);
  719. }
  720. static int spi_nor_lock(struct mtd_info *mtd, loff_t ofs, uint64_t len)
  721. {
  722. struct spi_nor *nor = mtd_to_spi_nor(mtd);
  723. int ret;
  724. ret = spi_nor_lock_and_prep(nor, SPI_NOR_OPS_LOCK);
  725. if (ret)
  726. return ret;
  727. ret = nor->flash_lock(nor, ofs, len);
  728. spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_UNLOCK);
  729. return ret;
  730. }
  731. static int spi_nor_unlock(struct mtd_info *mtd, loff_t ofs, uint64_t len)
  732. {
  733. struct spi_nor *nor = mtd_to_spi_nor(mtd);
  734. int ret;
  735. ret = spi_nor_lock_and_prep(nor, SPI_NOR_OPS_UNLOCK);
  736. if (ret)
  737. return ret;
  738. ret = nor->flash_unlock(nor, ofs, len);
  739. spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_LOCK);
  740. return ret;
  741. }
  742. static int spi_nor_is_locked(struct mtd_info *mtd, loff_t ofs, uint64_t len)
  743. {
  744. struct spi_nor *nor = mtd_to_spi_nor(mtd);
  745. int ret;
  746. ret = spi_nor_lock_and_prep(nor, SPI_NOR_OPS_UNLOCK);
  747. if (ret)
  748. return ret;
  749. ret = nor->flash_is_locked(nor, ofs, len);
  750. spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_LOCK);
  751. return ret;
  752. }
  753. static int macronix_quad_enable(struct spi_nor *nor);
  754. /* Used when the "_ext_id" is two bytes at most */
  755. #define INFO(_jedec_id, _ext_id, _sector_size, _n_sectors, _flags) \
  756. .id = { \
  757. ((_jedec_id) >> 16) & 0xff, \
  758. ((_jedec_id) >> 8) & 0xff, \
  759. (_jedec_id) & 0xff, \
  760. ((_ext_id) >> 8) & 0xff, \
  761. (_ext_id) & 0xff, \
  762. }, \
  763. .id_len = (!(_jedec_id) ? 0 : (3 + ((_ext_id) ? 2 : 0))), \
  764. .sector_size = (_sector_size), \
  765. .n_sectors = (_n_sectors), \
  766. .page_size = 256, \
  767. .flags = (_flags),
  768. #define INFO6(_jedec_id, _ext_id, _sector_size, _n_sectors, _flags) \
  769. .id = { \
  770. ((_jedec_id) >> 16) & 0xff, \
  771. ((_jedec_id) >> 8) & 0xff, \
  772. (_jedec_id) & 0xff, \
  773. ((_ext_id) >> 16) & 0xff, \
  774. ((_ext_id) >> 8) & 0xff, \
  775. (_ext_id) & 0xff, \
  776. }, \
  777. .id_len = 6, \
  778. .sector_size = (_sector_size), \
  779. .n_sectors = (_n_sectors), \
  780. .page_size = 256, \
  781. .flags = (_flags),
  782. #define CAT25_INFO(_sector_size, _n_sectors, _page_size, _addr_width, _flags) \
  783. .sector_size = (_sector_size), \
  784. .n_sectors = (_n_sectors), \
  785. .page_size = (_page_size), \
  786. .addr_width = (_addr_width), \
  787. .flags = (_flags),
  788. #define S3AN_INFO(_jedec_id, _n_sectors, _page_size) \
  789. .id = { \
  790. ((_jedec_id) >> 16) & 0xff, \
  791. ((_jedec_id) >> 8) & 0xff, \
  792. (_jedec_id) & 0xff \
  793. }, \
  794. .id_len = 3, \
  795. .sector_size = (8*_page_size), \
  796. .n_sectors = (_n_sectors), \
  797. .page_size = _page_size, \
  798. .addr_width = 3, \
  799. .flags = SPI_NOR_NO_FR | SPI_S3AN,
  800. /* NOTE: double check command sets and memory organization when you add
  801. * more nor chips. This current list focusses on newer chips, which
  802. * have been converging on command sets which including JEDEC ID.
  803. *
  804. * All newly added entries should describe *hardware* and should use SECT_4K
  805. * (or SECT_4K_PMC) if hardware supports erasing 4 KiB sectors. For usage
  806. * scenarios excluding small sectors there is config option that can be
  807. * disabled: CONFIG_MTD_SPI_NOR_USE_4K_SECTORS.
  808. * For historical (and compatibility) reasons (before we got above config) some
  809. * old entries may be missing 4K flag.
  810. */
  811. static const struct flash_info spi_nor_ids[] = {
  812. /* Atmel -- some are (confusingly) marketed as "DataFlash" */
  813. { "at25fs010", INFO(0x1f6601, 0, 32 * 1024, 4, SECT_4K) },
  814. { "at25fs040", INFO(0x1f6604, 0, 64 * 1024, 8, SECT_4K) },
  815. { "at25df041a", INFO(0x1f4401, 0, 64 * 1024, 8, SECT_4K) },
  816. { "at25df321", INFO(0x1f4700, 0, 64 * 1024, 64, SECT_4K) },
  817. { "at25df321a", INFO(0x1f4701, 0, 64 * 1024, 64, SECT_4K) },
  818. { "at25df641", INFO(0x1f4800, 0, 64 * 1024, 128, SECT_4K) },
  819. { "at26f004", INFO(0x1f0400, 0, 64 * 1024, 8, SECT_4K) },
  820. { "at26df081a", INFO(0x1f4501, 0, 64 * 1024, 16, SECT_4K) },
  821. { "at26df161a", INFO(0x1f4601, 0, 64 * 1024, 32, SECT_4K) },
  822. { "at26df321", INFO(0x1f4700, 0, 64 * 1024, 64, SECT_4K) },
  823. { "at45db081d", INFO(0x1f2500, 0, 64 * 1024, 16, SECT_4K) },
  824. /* EON -- en25xxx */
  825. { "en25f32", INFO(0x1c3116, 0, 64 * 1024, 64, SECT_4K) },
  826. { "en25p32", INFO(0x1c2016, 0, 64 * 1024, 64, 0) },
  827. { "en25q32b", INFO(0x1c3016, 0, 64 * 1024, 64, 0) },
  828. { "en25p64", INFO(0x1c2017, 0, 64 * 1024, 128, 0) },
  829. { "en25q64", INFO(0x1c3017, 0, 64 * 1024, 128, SECT_4K) },
  830. { "en25qh32", INFO(0x1c7016, 0, 64 * 1024, 64, 0) },
  831. { "en25qh128", INFO(0x1c7018, 0, 64 * 1024, 256, 0) },
  832. { "en25qh256", INFO(0x1c7019, 0, 64 * 1024, 512, 0) },
  833. { "en25s64", INFO(0x1c3817, 0, 64 * 1024, 128, SECT_4K) },
  834. /* ESMT */
  835. { "f25l32pa", INFO(0x8c2016, 0, 64 * 1024, 64, SECT_4K | SPI_NOR_HAS_LOCK) },
  836. { "f25l32qa", INFO(0x8c4116, 0, 64 * 1024, 64, SECT_4K | SPI_NOR_HAS_LOCK) },
  837. { "f25l64qa", INFO(0x8c4117, 0, 64 * 1024, 128, SECT_4K | SPI_NOR_HAS_LOCK) },
  838. /* Everspin */
  839. { "mr25h128", CAT25_INFO( 16 * 1024, 1, 256, 2, SPI_NOR_NO_ERASE | SPI_NOR_NO_FR) },
  840. { "mr25h256", CAT25_INFO( 32 * 1024, 1, 256, 2, SPI_NOR_NO_ERASE | SPI_NOR_NO_FR) },
  841. { "mr25h10", CAT25_INFO(128 * 1024, 1, 256, 3, SPI_NOR_NO_ERASE | SPI_NOR_NO_FR) },
  842. { "mr25h40", CAT25_INFO(512 * 1024, 1, 256, 3, SPI_NOR_NO_ERASE | SPI_NOR_NO_FR) },
  843. /* Fujitsu */
  844. { "mb85rs1mt", INFO(0x047f27, 0, 128 * 1024, 1, SPI_NOR_NO_ERASE) },
  845. /* GigaDevice */
  846. {
  847. "gd25q16", INFO(0xc84015, 0, 64 * 1024, 32,
  848. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ |
  849. SPI_NOR_HAS_LOCK | SPI_NOR_HAS_TB)
  850. },
  851. {
  852. "gd25q32", INFO(0xc84016, 0, 64 * 1024, 64,
  853. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ |
  854. SPI_NOR_HAS_LOCK | SPI_NOR_HAS_TB)
  855. },
  856. {
  857. "gd25lq32", INFO(0xc86016, 0, 64 * 1024, 64,
  858. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ |
  859. SPI_NOR_HAS_LOCK | SPI_NOR_HAS_TB)
  860. },
  861. {
  862. "gd25q64", INFO(0xc84017, 0, 64 * 1024, 128,
  863. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ |
  864. SPI_NOR_HAS_LOCK | SPI_NOR_HAS_TB)
  865. },
  866. {
  867. "gd25lq64c", INFO(0xc86017, 0, 64 * 1024, 128,
  868. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ |
  869. SPI_NOR_HAS_LOCK | SPI_NOR_HAS_TB)
  870. },
  871. {
  872. "gd25q128", INFO(0xc84018, 0, 64 * 1024, 256,
  873. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ |
  874. SPI_NOR_HAS_LOCK | SPI_NOR_HAS_TB)
  875. },
  876. {
  877. "gd25q256", INFO(0xc84019, 0, 64 * 1024, 512,
  878. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ |
  879. SPI_NOR_4B_OPCODES | SPI_NOR_HAS_LOCK | SPI_NOR_HAS_TB)
  880. .quad_enable = macronix_quad_enable,
  881. },
  882. /* Intel/Numonyx -- xxxs33b */
  883. { "160s33b", INFO(0x898911, 0, 64 * 1024, 32, 0) },
  884. { "320s33b", INFO(0x898912, 0, 64 * 1024, 64, 0) },
  885. { "640s33b", INFO(0x898913, 0, 64 * 1024, 128, 0) },
  886. /* ISSI */
  887. { "is25cd512", INFO(0x7f9d20, 0, 32 * 1024, 2, SECT_4K) },
  888. { "is25lq040b", INFO(0x9d4013, 0, 64 * 1024, 8,
  889. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  890. { "is25lp080d", INFO(0x9d6014, 0, 64 * 1024, 16,
  891. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  892. { "is25lp128", INFO(0x9d6018, 0, 64 * 1024, 256,
  893. SECT_4K | SPI_NOR_DUAL_READ) },
  894. { "is25lp256", INFO(0x9d6019, 0, 64 * 1024, 512,
  895. SECT_4K | SPI_NOR_DUAL_READ) },
  896. { "is25wp032", INFO(0x9d7016, 0, 64 * 1024, 64,
  897. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  898. { "is25wp064", INFO(0x9d7017, 0, 64 * 1024, 128,
  899. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  900. { "is25wp128", INFO(0x9d7018, 0, 64 * 1024, 256,
  901. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  902. /* Macronix */
  903. { "mx25l512e", INFO(0xc22010, 0, 64 * 1024, 1, SECT_4K) },
  904. { "mx25l2005a", INFO(0xc22012, 0, 64 * 1024, 4, SECT_4K) },
  905. { "mx25l4005a", INFO(0xc22013, 0, 64 * 1024, 8, SECT_4K) },
  906. { "mx25l8005", INFO(0xc22014, 0, 64 * 1024, 16, 0) },
  907. { "mx25l1606e", INFO(0xc22015, 0, 64 * 1024, 32, SECT_4K) },
  908. { "mx25l3205d", INFO(0xc22016, 0, 64 * 1024, 64, SECT_4K) },
  909. { "mx25l3255e", INFO(0xc29e16, 0, 64 * 1024, 64, SECT_4K) },
  910. { "mx25l6405d", INFO(0xc22017, 0, 64 * 1024, 128, SECT_4K) },
  911. { "mx25u2033e", INFO(0xc22532, 0, 64 * 1024, 4, SECT_4K) },
  912. { "mx25u4035", INFO(0xc22533, 0, 64 * 1024, 8, SECT_4K) },
  913. { "mx25u8035", INFO(0xc22534, 0, 64 * 1024, 16, SECT_4K) },
  914. { "mx25u6435f", INFO(0xc22537, 0, 64 * 1024, 128, SECT_4K) },
  915. { "mx25l12805d", INFO(0xc22018, 0, 64 * 1024, 256, 0) },
  916. { "mx25l12855e", INFO(0xc22618, 0, 64 * 1024, 256, 0) },
  917. { "mx25l25635e", INFO(0xc22019, 0, 64 * 1024, 512, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  918. { "mx25u25635f", INFO(0xc22539, 0, 64 * 1024, 512, SECT_4K | SPI_NOR_4B_OPCODES) },
  919. { "mx25l25655e", INFO(0xc22619, 0, 64 * 1024, 512, 0) },
  920. { "mx66l51235l", INFO(0xc2201a, 0, 64 * 1024, 1024, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | SPI_NOR_4B_OPCODES) },
  921. { "mx66u51235f", INFO(0xc2253a, 0, 64 * 1024, 1024, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | SPI_NOR_4B_OPCODES) },
  922. { "mx66l1g45g", INFO(0xc2201b, 0, 64 * 1024, 2048, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  923. { "mx66l1g55g", INFO(0xc2261b, 0, 64 * 1024, 2048, SPI_NOR_QUAD_READ) },
  924. /* Micron */
  925. { "n25q016a", INFO(0x20bb15, 0, 64 * 1024, 32, SECT_4K | SPI_NOR_QUAD_READ) },
  926. { "n25q032", INFO(0x20ba16, 0, 64 * 1024, 64, SPI_NOR_QUAD_READ) },
  927. { "n25q032a", INFO(0x20bb16, 0, 64 * 1024, 64, SPI_NOR_QUAD_READ) },
  928. { "n25q064", INFO(0x20ba17, 0, 64 * 1024, 128, SECT_4K | SPI_NOR_QUAD_READ) },
  929. { "n25q064a", INFO(0x20bb17, 0, 64 * 1024, 128, SECT_4K | SPI_NOR_QUAD_READ) },
  930. { "n25q128a11", INFO(0x20bb18, 0, 64 * 1024, 256, SECT_4K | SPI_NOR_QUAD_READ) },
  931. { "n25q128a13", INFO(0x20ba18, 0, 64 * 1024, 256, SECT_4K | SPI_NOR_QUAD_READ) },
  932. { "n25q256a", INFO(0x20ba19, 0, 64 * 1024, 512, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  933. { "n25q256ax1", INFO(0x20bb19, 0, 64 * 1024, 512, SECT_4K | SPI_NOR_QUAD_READ) },
  934. { "n25q512a", INFO(0x20bb20, 0, 64 * 1024, 1024, SECT_4K | USE_FSR | SPI_NOR_QUAD_READ) },
  935. { "n25q512ax3", INFO(0x20ba20, 0, 64 * 1024, 1024, SECT_4K | USE_FSR | SPI_NOR_QUAD_READ) },
  936. { "n25q00", INFO(0x20ba21, 0, 64 * 1024, 2048, SECT_4K | USE_FSR | SPI_NOR_QUAD_READ | NO_CHIP_ERASE) },
  937. { "n25q00a", INFO(0x20bb21, 0, 64 * 1024, 2048, SECT_4K | USE_FSR | SPI_NOR_QUAD_READ | NO_CHIP_ERASE) },
  938. { "mt25qu02g", INFO(0x20bb22, 0, 64 * 1024, 4096, SECT_4K | USE_FSR | SPI_NOR_QUAD_READ | NO_CHIP_ERASE) },
  939. /* PMC */
  940. { "pm25lv512", INFO(0, 0, 32 * 1024, 2, SECT_4K_PMC) },
  941. { "pm25lv010", INFO(0, 0, 32 * 1024, 4, SECT_4K_PMC) },
  942. { "pm25lq032", INFO(0x7f9d46, 0, 64 * 1024, 64, SECT_4K) },
  943. /* Spansion/Cypress -- single (large) sector size only, at least
  944. * for the chips listed here (without boot sectors).
  945. */
  946. { "s25sl032p", INFO(0x010215, 0x4d00, 64 * 1024, 64, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  947. { "s25sl064p", INFO(0x010216, 0x4d00, 64 * 1024, 128, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  948. { "s25fl256s0", INFO(0x010219, 0x4d00, 256 * 1024, 128, USE_CLSR) },
  949. { "s25fl256s1", INFO(0x010219, 0x4d01, 64 * 1024, 512, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | USE_CLSR) },
  950. { "s25fl512s", INFO(0x010220, 0x4d00, 256 * 1024, 256, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | USE_CLSR) },
  951. { "s70fl01gs", INFO(0x010221, 0x4d00, 256 * 1024, 256, 0) },
  952. { "s25sl12800", INFO(0x012018, 0x0300, 256 * 1024, 64, 0) },
  953. { "s25sl12801", INFO(0x012018, 0x0301, 64 * 1024, 256, 0) },
  954. { "s25fl128s", INFO6(0x012018, 0x4d0180, 64 * 1024, 256, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | USE_CLSR) },
  955. { "s25fl129p0", INFO(0x012018, 0x4d00, 256 * 1024, 64, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | USE_CLSR) },
  956. { "s25fl129p1", INFO(0x012018, 0x4d01, 64 * 1024, 256, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | USE_CLSR) },
  957. { "s25sl004a", INFO(0x010212, 0, 64 * 1024, 8, 0) },
  958. { "s25sl008a", INFO(0x010213, 0, 64 * 1024, 16, 0) },
  959. { "s25sl016a", INFO(0x010214, 0, 64 * 1024, 32, 0) },
  960. { "s25sl032a", INFO(0x010215, 0, 64 * 1024, 64, 0) },
  961. { "s25sl064a", INFO(0x010216, 0, 64 * 1024, 128, 0) },
  962. { "s25fl004k", INFO(0xef4013, 0, 64 * 1024, 8, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  963. { "s25fl008k", INFO(0xef4014, 0, 64 * 1024, 16, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  964. { "s25fl016k", INFO(0xef4015, 0, 64 * 1024, 32, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  965. { "s25fl064k", INFO(0xef4017, 0, 64 * 1024, 128, SECT_4K) },
  966. { "s25fl116k", INFO(0x014015, 0, 64 * 1024, 32, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  967. { "s25fl132k", INFO(0x014016, 0, 64 * 1024, 64, SECT_4K) },
  968. { "s25fl164k", INFO(0x014017, 0, 64 * 1024, 128, SECT_4K) },
  969. { "s25fl204k", INFO(0x014013, 0, 64 * 1024, 8, SECT_4K | SPI_NOR_DUAL_READ) },
  970. { "s25fl208k", INFO(0x014014, 0, 64 * 1024, 16, SECT_4K | SPI_NOR_DUAL_READ) },
  971. { "s25fl064l", INFO(0x016017, 0, 64 * 1024, 128, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | SPI_NOR_4B_OPCODES) },
  972. { "s25fl128l", INFO(0x016018, 0, 64 * 1024, 256, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | SPI_NOR_4B_OPCODES) },
  973. { "s25fl256l", INFO(0x016019, 0, 64 * 1024, 512, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | SPI_NOR_4B_OPCODES) },
  974. /* SST -- large erase sizes are "overlays", "sectors" are 4K */
  975. { "sst25vf040b", INFO(0xbf258d, 0, 64 * 1024, 8, SECT_4K | SST_WRITE) },
  976. { "sst25vf080b", INFO(0xbf258e, 0, 64 * 1024, 16, SECT_4K | SST_WRITE) },
  977. { "sst25vf016b", INFO(0xbf2541, 0, 64 * 1024, 32, SECT_4K | SST_WRITE) },
  978. { "sst25vf032b", INFO(0xbf254a, 0, 64 * 1024, 64, SECT_4K | SST_WRITE) },
  979. { "sst25vf064c", INFO(0xbf254b, 0, 64 * 1024, 128, SECT_4K) },
  980. { "sst25wf512", INFO(0xbf2501, 0, 64 * 1024, 1, SECT_4K | SST_WRITE) },
  981. { "sst25wf010", INFO(0xbf2502, 0, 64 * 1024, 2, SECT_4K | SST_WRITE) },
  982. { "sst25wf020", INFO(0xbf2503, 0, 64 * 1024, 4, SECT_4K | SST_WRITE) },
  983. { "sst25wf020a", INFO(0x621612, 0, 64 * 1024, 4, SECT_4K) },
  984. { "sst25wf040b", INFO(0x621613, 0, 64 * 1024, 8, SECT_4K) },
  985. { "sst25wf040", INFO(0xbf2504, 0, 64 * 1024, 8, SECT_4K | SST_WRITE) },
  986. { "sst25wf080", INFO(0xbf2505, 0, 64 * 1024, 16, SECT_4K | SST_WRITE) },
  987. { "sst26vf064b", INFO(0xbf2643, 0, 64 * 1024, 128, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  988. /* ST Microelectronics -- newer production may have feature updates */
  989. { "m25p05", INFO(0x202010, 0, 32 * 1024, 2, 0) },
  990. { "m25p10", INFO(0x202011, 0, 32 * 1024, 4, 0) },
  991. { "m25p20", INFO(0x202012, 0, 64 * 1024, 4, 0) },
  992. { "m25p40", INFO(0x202013, 0, 64 * 1024, 8, 0) },
  993. { "m25p80", INFO(0x202014, 0, 64 * 1024, 16, 0) },
  994. { "m25p16", INFO(0x202015, 0, 64 * 1024, 32, 0) },
  995. { "m25p32", INFO(0x202016, 0, 64 * 1024, 64, 0) },
  996. { "m25p64", INFO(0x202017, 0, 64 * 1024, 128, 0) },
  997. { "m25p128", INFO(0x202018, 0, 256 * 1024, 64, 0) },
  998. { "m25p05-nonjedec", INFO(0, 0, 32 * 1024, 2, 0) },
  999. { "m25p10-nonjedec", INFO(0, 0, 32 * 1024, 4, 0) },
  1000. { "m25p20-nonjedec", INFO(0, 0, 64 * 1024, 4, 0) },
  1001. { "m25p40-nonjedec", INFO(0, 0, 64 * 1024, 8, 0) },
  1002. { "m25p80-nonjedec", INFO(0, 0, 64 * 1024, 16, 0) },
  1003. { "m25p16-nonjedec", INFO(0, 0, 64 * 1024, 32, 0) },
  1004. { "m25p32-nonjedec", INFO(0, 0, 64 * 1024, 64, 0) },
  1005. { "m25p64-nonjedec", INFO(0, 0, 64 * 1024, 128, 0) },
  1006. { "m25p128-nonjedec", INFO(0, 0, 256 * 1024, 64, 0) },
  1007. { "m45pe10", INFO(0x204011, 0, 64 * 1024, 2, 0) },
  1008. { "m45pe80", INFO(0x204014, 0, 64 * 1024, 16, 0) },
  1009. { "m45pe16", INFO(0x204015, 0, 64 * 1024, 32, 0) },
  1010. { "m25pe20", INFO(0x208012, 0, 64 * 1024, 4, 0) },
  1011. { "m25pe80", INFO(0x208014, 0, 64 * 1024, 16, 0) },
  1012. { "m25pe16", INFO(0x208015, 0, 64 * 1024, 32, SECT_4K) },
  1013. { "m25px16", INFO(0x207115, 0, 64 * 1024, 32, SECT_4K) },
  1014. { "m25px32", INFO(0x207116, 0, 64 * 1024, 64, SECT_4K) },
  1015. { "m25px32-s0", INFO(0x207316, 0, 64 * 1024, 64, SECT_4K) },
  1016. { "m25px32-s1", INFO(0x206316, 0, 64 * 1024, 64, SECT_4K) },
  1017. { "m25px64", INFO(0x207117, 0, 64 * 1024, 128, 0) },
  1018. { "m25px80", INFO(0x207114, 0, 64 * 1024, 16, 0) },
  1019. /* Winbond -- w25x "blocks" are 64K, "sectors" are 4KiB */
  1020. { "w25x05", INFO(0xef3010, 0, 64 * 1024, 1, SECT_4K) },
  1021. { "w25x10", INFO(0xef3011, 0, 64 * 1024, 2, SECT_4K) },
  1022. { "w25x20", INFO(0xef3012, 0, 64 * 1024, 4, SECT_4K) },
  1023. { "w25x40", INFO(0xef3013, 0, 64 * 1024, 8, SECT_4K) },
  1024. { "w25x80", INFO(0xef3014, 0, 64 * 1024, 16, SECT_4K) },
  1025. { "w25x16", INFO(0xef3015, 0, 64 * 1024, 32, SECT_4K) },
  1026. {
  1027. "w25q16dw", INFO(0xef6015, 0, 64 * 1024, 32,
  1028. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ |
  1029. SPI_NOR_HAS_LOCK | SPI_NOR_HAS_TB)
  1030. },
  1031. { "w25x32", INFO(0xef3016, 0, 64 * 1024, 64, SECT_4K) },
  1032. { "w25q20cl", INFO(0xef4012, 0, 64 * 1024, 4, SECT_4K) },
  1033. { "w25q20bw", INFO(0xef5012, 0, 64 * 1024, 4, SECT_4K) },
  1034. { "w25q20ew", INFO(0xef6012, 0, 64 * 1024, 4, SECT_4K) },
  1035. { "w25q32", INFO(0xef4016, 0, 64 * 1024, 64, SECT_4K) },
  1036. {
  1037. "w25q32dw", INFO(0xef6016, 0, 64 * 1024, 64,
  1038. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ |
  1039. SPI_NOR_HAS_LOCK | SPI_NOR_HAS_TB)
  1040. },
  1041. {
  1042. "w25q32jv", INFO(0xef7016, 0, 64 * 1024, 64,
  1043. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ |
  1044. SPI_NOR_HAS_LOCK | SPI_NOR_HAS_TB)
  1045. },
  1046. { "w25x64", INFO(0xef3017, 0, 64 * 1024, 128, SECT_4K) },
  1047. { "w25q64", INFO(0xef4017, 0, 64 * 1024, 128, SECT_4K) },
  1048. {
  1049. "w25q64dw", INFO(0xef6017, 0, 64 * 1024, 128,
  1050. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ |
  1051. SPI_NOR_HAS_LOCK | SPI_NOR_HAS_TB)
  1052. },
  1053. {
  1054. "w25q128fw", INFO(0xef6018, 0, 64 * 1024, 256,
  1055. SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ |
  1056. SPI_NOR_HAS_LOCK | SPI_NOR_HAS_TB)
  1057. },
  1058. { "w25q80", INFO(0xef5014, 0, 64 * 1024, 16, SECT_4K) },
  1059. { "w25q80bl", INFO(0xef4014, 0, 64 * 1024, 16, SECT_4K) },
  1060. { "w25q128", INFO(0xef4018, 0, 64 * 1024, 256, SECT_4K) },
  1061. { "w25q256", INFO(0xef4019, 0, 64 * 1024, 512, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  1062. { "w25m512jv", INFO(0xef7119, 0, 64 * 1024, 1024,
  1063. SECT_4K | SPI_NOR_QUAD_READ | SPI_NOR_DUAL_READ) },
  1064. /* Catalyst / On Semiconductor -- non-JEDEC */
  1065. { "cat25c11", CAT25_INFO( 16, 8, 16, 1, SPI_NOR_NO_ERASE | SPI_NOR_NO_FR) },
  1066. { "cat25c03", CAT25_INFO( 32, 8, 16, 2, SPI_NOR_NO_ERASE | SPI_NOR_NO_FR) },
  1067. { "cat25c09", CAT25_INFO( 128, 8, 32, 2, SPI_NOR_NO_ERASE | SPI_NOR_NO_FR) },
  1068. { "cat25c17", CAT25_INFO( 256, 8, 32, 2, SPI_NOR_NO_ERASE | SPI_NOR_NO_FR) },
  1069. { "cat25128", CAT25_INFO(2048, 8, 64, 2, SPI_NOR_NO_ERASE | SPI_NOR_NO_FR) },
  1070. /* Xilinx S3AN Internal Flash */
  1071. { "3S50AN", S3AN_INFO(0x1f2200, 64, 264) },
  1072. { "3S200AN", S3AN_INFO(0x1f2400, 256, 264) },
  1073. { "3S400AN", S3AN_INFO(0x1f2400, 256, 264) },
  1074. { "3S700AN", S3AN_INFO(0x1f2500, 512, 264) },
  1075. { "3S1400AN", S3AN_INFO(0x1f2600, 512, 528) },
  1076. /* XMC (Wuhan Xinxin Semiconductor Manufacturing Corp.) */
  1077. { "XM25QH64A", INFO(0x207017, 0, 64 * 1024, 128, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  1078. { "XM25QH128A", INFO(0x207018, 0, 64 * 1024, 256, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) },
  1079. { },
  1080. };
  1081. static const struct flash_info *spi_nor_read_id(struct spi_nor *nor)
  1082. {
  1083. int tmp;
  1084. u8 id[SPI_NOR_MAX_ID_LEN];
  1085. const struct flash_info *info;
  1086. tmp = nor->read_reg(nor, SPINOR_OP_RDID, id, SPI_NOR_MAX_ID_LEN);
  1087. if (tmp < 0) {
  1088. dev_dbg(nor->dev, "error %d reading JEDEC ID\n", tmp);
  1089. return ERR_PTR(tmp);
  1090. }
  1091. for (tmp = 0; tmp < ARRAY_SIZE(spi_nor_ids) - 1; tmp++) {
  1092. info = &spi_nor_ids[tmp];
  1093. if (info->id_len) {
  1094. if (!memcmp(info->id, id, info->id_len))
  1095. return &spi_nor_ids[tmp];
  1096. }
  1097. }
  1098. dev_err(nor->dev, "unrecognized JEDEC id bytes: %02x, %02x, %02x\n",
  1099. id[0], id[1], id[2]);
  1100. return ERR_PTR(-ENODEV);
  1101. }
  1102. static int spi_nor_read(struct mtd_info *mtd, loff_t from, size_t len,
  1103. size_t *retlen, u_char *buf)
  1104. {
  1105. struct spi_nor *nor = mtd_to_spi_nor(mtd);
  1106. int ret;
  1107. dev_dbg(nor->dev, "from 0x%08x, len %zd\n", (u32)from, len);
  1108. ret = spi_nor_lock_and_prep(nor, SPI_NOR_OPS_READ);
  1109. if (ret)
  1110. return ret;
  1111. while (len) {
  1112. loff_t addr = from;
  1113. if (nor->flags & SNOR_F_S3AN_ADDR_DEFAULT)
  1114. addr = spi_nor_s3an_addr_convert(nor, addr);
  1115. ret = nor->read(nor, addr, len, buf);
  1116. if (ret == 0) {
  1117. /* We shouldn't see 0-length reads */
  1118. ret = -EIO;
  1119. goto read_err;
  1120. }
  1121. if (ret < 0)
  1122. goto read_err;
  1123. WARN_ON(ret > len);
  1124. *retlen += ret;
  1125. buf += ret;
  1126. from += ret;
  1127. len -= ret;
  1128. }
  1129. ret = 0;
  1130. read_err:
  1131. spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_READ);
  1132. return ret;
  1133. }
  1134. static int sst_write(struct mtd_info *mtd, loff_t to, size_t len,
  1135. size_t *retlen, const u_char *buf)
  1136. {
  1137. struct spi_nor *nor = mtd_to_spi_nor(mtd);
  1138. size_t actual;
  1139. int ret;
  1140. dev_dbg(nor->dev, "to 0x%08x, len %zd\n", (u32)to, len);
  1141. ret = spi_nor_lock_and_prep(nor, SPI_NOR_OPS_WRITE);
  1142. if (ret)
  1143. return ret;
  1144. write_enable(nor);
  1145. nor->sst_write_second = false;
  1146. actual = to % 2;
  1147. /* Start write from odd address. */
  1148. if (actual) {
  1149. nor->program_opcode = SPINOR_OP_BP;
  1150. /* write one byte. */
  1151. ret = nor->write(nor, to, 1, buf);
  1152. if (ret < 0)
  1153. goto sst_write_err;
  1154. WARN(ret != 1, "While writing 1 byte written %i bytes\n",
  1155. (int)ret);
  1156. ret = spi_nor_wait_till_ready(nor);
  1157. if (ret)
  1158. goto sst_write_err;
  1159. }
  1160. to += actual;
  1161. /* Write out most of the data here. */
  1162. for (; actual < len - 1; actual += 2) {
  1163. nor->program_opcode = SPINOR_OP_AAI_WP;
  1164. /* write two bytes. */
  1165. ret = nor->write(nor, to, 2, buf + actual);
  1166. if (ret < 0)
  1167. goto sst_write_err;
  1168. WARN(ret != 2, "While writing 2 bytes written %i bytes\n",
  1169. (int)ret);
  1170. ret = spi_nor_wait_till_ready(nor);
  1171. if (ret)
  1172. goto sst_write_err;
  1173. to += 2;
  1174. nor->sst_write_second = true;
  1175. }
  1176. nor->sst_write_second = false;
  1177. write_disable(nor);
  1178. ret = spi_nor_wait_till_ready(nor);
  1179. if (ret)
  1180. goto sst_write_err;
  1181. /* Write out trailing byte if it exists. */
  1182. if (actual != len) {
  1183. write_enable(nor);
  1184. nor->program_opcode = SPINOR_OP_BP;
  1185. ret = nor->write(nor, to, 1, buf + actual);
  1186. if (ret < 0)
  1187. goto sst_write_err;
  1188. WARN(ret != 1, "While writing 1 byte written %i bytes\n",
  1189. (int)ret);
  1190. ret = spi_nor_wait_till_ready(nor);
  1191. if (ret)
  1192. goto sst_write_err;
  1193. write_disable(nor);
  1194. actual += 1;
  1195. }
  1196. sst_write_err:
  1197. *retlen += actual;
  1198. spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_WRITE);
  1199. return ret;
  1200. }
  1201. /*
  1202. * Write an address range to the nor chip. Data must be written in
  1203. * FLASH_PAGESIZE chunks. The address range may be any size provided
  1204. * it is within the physical boundaries.
  1205. */
  1206. static int spi_nor_write(struct mtd_info *mtd, loff_t to, size_t len,
  1207. size_t *retlen, const u_char *buf)
  1208. {
  1209. struct spi_nor *nor = mtd_to_spi_nor(mtd);
  1210. size_t page_offset, page_remain, i;
  1211. ssize_t ret;
  1212. dev_dbg(nor->dev, "to 0x%08x, len %zd\n", (u32)to, len);
  1213. ret = spi_nor_lock_and_prep(nor, SPI_NOR_OPS_WRITE);
  1214. if (ret)
  1215. return ret;
  1216. for (i = 0; i < len; ) {
  1217. ssize_t written;
  1218. loff_t addr = to + i;
  1219. /*
  1220. * If page_size is a power of two, the offset can be quickly
  1221. * calculated with an AND operation. On the other cases we
  1222. * need to do a modulus operation (more expensive).
  1223. * Power of two numbers have only one bit set and we can use
  1224. * the instruction hweight32 to detect if we need to do a
  1225. * modulus (do_div()) or not.
  1226. */
  1227. if (hweight32(nor->page_size) == 1) {
  1228. page_offset = addr & (nor->page_size - 1);
  1229. } else {
  1230. uint64_t aux = addr;
  1231. page_offset = do_div(aux, nor->page_size);
  1232. }
  1233. /* the size of data remaining on the first page */
  1234. page_remain = min_t(size_t,
  1235. nor->page_size - page_offset, len - i);
  1236. if (nor->flags & SNOR_F_S3AN_ADDR_DEFAULT)
  1237. addr = spi_nor_s3an_addr_convert(nor, addr);
  1238. write_enable(nor);
  1239. ret = nor->write(nor, addr, page_remain, buf + i);
  1240. if (ret < 0)
  1241. goto write_err;
  1242. written = ret;
  1243. ret = spi_nor_wait_till_ready(nor);
  1244. if (ret)
  1245. goto write_err;
  1246. *retlen += written;
  1247. i += written;
  1248. if (written != page_remain) {
  1249. dev_err(nor->dev,
  1250. "While writing %zu bytes written %zd bytes\n",
  1251. page_remain, written);
  1252. ret = -EIO;
  1253. goto write_err;
  1254. }
  1255. }
  1256. write_err:
  1257. spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_WRITE);
  1258. return ret;
  1259. }
  1260. /**
  1261. * macronix_quad_enable() - set QE bit in Status Register.
  1262. * @nor: pointer to a 'struct spi_nor'
  1263. *
  1264. * Set the Quad Enable (QE) bit in the Status Register.
  1265. *
  1266. * bit 6 of the Status Register is the QE bit for Macronix like QSPI memories.
  1267. *
  1268. * Return: 0 on success, -errno otherwise.
  1269. */
  1270. static int macronix_quad_enable(struct spi_nor *nor)
  1271. {
  1272. int ret, val;
  1273. val = read_sr(nor);
  1274. if (val < 0)
  1275. return val;
  1276. if (val & SR_QUAD_EN_MX)
  1277. return 0;
  1278. write_enable(nor);
  1279. write_sr(nor, val | SR_QUAD_EN_MX);
  1280. ret = spi_nor_wait_till_ready(nor);
  1281. if (ret)
  1282. return ret;
  1283. ret = read_sr(nor);
  1284. if (!(ret > 0 && (ret & SR_QUAD_EN_MX))) {
  1285. dev_err(nor->dev, "Macronix Quad bit not set\n");
  1286. return -EINVAL;
  1287. }
  1288. return 0;
  1289. }
  1290. /*
  1291. * Write status Register and configuration register with 2 bytes
  1292. * The first byte will be written to the status register, while the
  1293. * second byte will be written to the configuration register.
  1294. * Return negative if error occurred.
  1295. */
  1296. static int write_sr_cr(struct spi_nor *nor, u8 *sr_cr)
  1297. {
  1298. int ret;
  1299. write_enable(nor);
  1300. ret = nor->write_reg(nor, SPINOR_OP_WRSR, sr_cr, 2);
  1301. if (ret < 0) {
  1302. dev_err(nor->dev,
  1303. "error while writing configuration register\n");
  1304. return -EINVAL;
  1305. }
  1306. ret = spi_nor_wait_till_ready(nor);
  1307. if (ret) {
  1308. dev_err(nor->dev,
  1309. "timeout while writing configuration register\n");
  1310. return ret;
  1311. }
  1312. return 0;
  1313. }
  1314. /**
  1315. * spansion_quad_enable() - set QE bit in Configuraiton Register.
  1316. * @nor: pointer to a 'struct spi_nor'
  1317. *
  1318. * Set the Quad Enable (QE) bit in the Configuration Register.
  1319. * This function is kept for legacy purpose because it has been used for a
  1320. * long time without anybody complaining but it should be considered as
  1321. * deprecated and maybe buggy.
  1322. * First, this function doesn't care about the previous values of the Status
  1323. * and Configuration Registers when it sets the QE bit (bit 1) in the
  1324. * Configuration Register: all other bits are cleared, which may have unwanted
  1325. * side effects like removing some block protections.
  1326. * Secondly, it uses the Read Configuration Register (35h) instruction though
  1327. * some very old and few memories don't support this instruction. If a pull-up
  1328. * resistor is present on the MISO/IO1 line, we might still be able to pass the
  1329. * "read back" test because the QSPI memory doesn't recognize the command,
  1330. * so leaves the MISO/IO1 line state unchanged, hence read_cr() returns 0xFF.
  1331. *
  1332. * bit 1 of the Configuration Register is the QE bit for Spansion like QSPI
  1333. * memories.
  1334. *
  1335. * Return: 0 on success, -errno otherwise.
  1336. */
  1337. static int spansion_quad_enable(struct spi_nor *nor)
  1338. {
  1339. u8 sr_cr[2] = {0, CR_QUAD_EN_SPAN};
  1340. int ret;
  1341. ret = write_sr_cr(nor, sr_cr);
  1342. if (ret)
  1343. return ret;
  1344. /* read back and check it */
  1345. ret = read_cr(nor);
  1346. if (!(ret > 0 && (ret & CR_QUAD_EN_SPAN))) {
  1347. dev_err(nor->dev, "Spansion Quad bit not set\n");
  1348. return -EINVAL;
  1349. }
  1350. return 0;
  1351. }
  1352. /**
  1353. * spansion_no_read_cr_quad_enable() - set QE bit in Configuration Register.
  1354. * @nor: pointer to a 'struct spi_nor'
  1355. *
  1356. * Set the Quad Enable (QE) bit in the Configuration Register.
  1357. * This function should be used with QSPI memories not supporting the Read
  1358. * Configuration Register (35h) instruction.
  1359. *
  1360. * bit 1 of the Configuration Register is the QE bit for Spansion like QSPI
  1361. * memories.
  1362. *
  1363. * Return: 0 on success, -errno otherwise.
  1364. */
  1365. static int spansion_no_read_cr_quad_enable(struct spi_nor *nor)
  1366. {
  1367. u8 sr_cr[2];
  1368. int ret;
  1369. /* Keep the current value of the Status Register. */
  1370. ret = read_sr(nor);
  1371. if (ret < 0) {
  1372. dev_err(nor->dev, "error while reading status register\n");
  1373. return -EINVAL;
  1374. }
  1375. sr_cr[0] = ret;
  1376. sr_cr[1] = CR_QUAD_EN_SPAN;
  1377. return write_sr_cr(nor, sr_cr);
  1378. }
  1379. /**
  1380. * spansion_read_cr_quad_enable() - set QE bit in Configuration Register.
  1381. * @nor: pointer to a 'struct spi_nor'
  1382. *
  1383. * Set the Quad Enable (QE) bit in the Configuration Register.
  1384. * This function should be used with QSPI memories supporting the Read
  1385. * Configuration Register (35h) instruction.
  1386. *
  1387. * bit 1 of the Configuration Register is the QE bit for Spansion like QSPI
  1388. * memories.
  1389. *
  1390. * Return: 0 on success, -errno otherwise.
  1391. */
  1392. static int spansion_read_cr_quad_enable(struct spi_nor *nor)
  1393. {
  1394. struct device *dev = nor->dev;
  1395. u8 sr_cr[2];
  1396. int ret;
  1397. /* Check current Quad Enable bit value. */
  1398. ret = read_cr(nor);
  1399. if (ret < 0) {
  1400. dev_err(dev, "error while reading configuration register\n");
  1401. return -EINVAL;
  1402. }
  1403. if (ret & CR_QUAD_EN_SPAN)
  1404. return 0;
  1405. sr_cr[1] = ret | CR_QUAD_EN_SPAN;
  1406. /* Keep the current value of the Status Register. */
  1407. ret = read_sr(nor);
  1408. if (ret < 0) {
  1409. dev_err(dev, "error while reading status register\n");
  1410. return -EINVAL;
  1411. }
  1412. sr_cr[0] = ret;
  1413. ret = write_sr_cr(nor, sr_cr);
  1414. if (ret)
  1415. return ret;
  1416. /* Read back and check it. */
  1417. ret = read_cr(nor);
  1418. if (!(ret > 0 && (ret & CR_QUAD_EN_SPAN))) {
  1419. dev_err(nor->dev, "Spansion Quad bit not set\n");
  1420. return -EINVAL;
  1421. }
  1422. return 0;
  1423. }
  1424. /**
  1425. * sr2_bit7_quad_enable() - set QE bit in Status Register 2.
  1426. * @nor: pointer to a 'struct spi_nor'
  1427. *
  1428. * Set the Quad Enable (QE) bit in the Status Register 2.
  1429. *
  1430. * This is one of the procedures to set the QE bit described in the SFDP
  1431. * (JESD216 rev B) specification but no manufacturer using this procedure has
  1432. * been identified yet, hence the name of the function.
  1433. *
  1434. * Return: 0 on success, -errno otherwise.
  1435. */
  1436. static int sr2_bit7_quad_enable(struct spi_nor *nor)
  1437. {
  1438. u8 sr2;
  1439. int ret;
  1440. /* Check current Quad Enable bit value. */
  1441. ret = nor->read_reg(nor, SPINOR_OP_RDSR2, &sr2, 1);
  1442. if (ret)
  1443. return ret;
  1444. if (sr2 & SR2_QUAD_EN_BIT7)
  1445. return 0;
  1446. /* Update the Quad Enable bit. */
  1447. sr2 |= SR2_QUAD_EN_BIT7;
  1448. write_enable(nor);
  1449. ret = nor->write_reg(nor, SPINOR_OP_WRSR2, &sr2, 1);
  1450. if (ret < 0) {
  1451. dev_err(nor->dev, "error while writing status register 2\n");
  1452. return -EINVAL;
  1453. }
  1454. ret = spi_nor_wait_till_ready(nor);
  1455. if (ret < 0) {
  1456. dev_err(nor->dev, "timeout while writing status register 2\n");
  1457. return ret;
  1458. }
  1459. /* Read back and check it. */
  1460. ret = nor->read_reg(nor, SPINOR_OP_RDSR2, &sr2, 1);
  1461. if (!(ret > 0 && (sr2 & SR2_QUAD_EN_BIT7))) {
  1462. dev_err(nor->dev, "SR2 Quad bit not set\n");
  1463. return -EINVAL;
  1464. }
  1465. return 0;
  1466. }
  1467. static int spi_nor_check(struct spi_nor *nor)
  1468. {
  1469. if (!nor->dev || !nor->read || !nor->write ||
  1470. !nor->read_reg || !nor->write_reg) {
  1471. pr_err("spi-nor: please fill all the necessary fields!\n");
  1472. return -EINVAL;
  1473. }
  1474. return 0;
  1475. }
  1476. static int s3an_nor_scan(const struct flash_info *info, struct spi_nor *nor)
  1477. {
  1478. int ret;
  1479. u8 val;
  1480. ret = nor->read_reg(nor, SPINOR_OP_XRDSR, &val, 1);
  1481. if (ret < 0) {
  1482. dev_err(nor->dev, "error %d reading XRDSR\n", (int) ret);
  1483. return ret;
  1484. }
  1485. nor->erase_opcode = SPINOR_OP_XSE;
  1486. nor->program_opcode = SPINOR_OP_XPP;
  1487. nor->read_opcode = SPINOR_OP_READ;
  1488. nor->flags |= SNOR_F_NO_OP_CHIP_ERASE;
  1489. /*
  1490. * This flashes have a page size of 264 or 528 bytes (known as
  1491. * Default addressing mode). It can be changed to a more standard
  1492. * Power of two mode where the page size is 256/512. This comes
  1493. * with a price: there is 3% less of space, the data is corrupted
  1494. * and the page size cannot be changed back to default addressing
  1495. * mode.
  1496. *
  1497. * The current addressing mode can be read from the XRDSR register
  1498. * and should not be changed, because is a destructive operation.
  1499. */
  1500. if (val & XSR_PAGESIZE) {
  1501. /* Flash in Power of 2 mode */
  1502. nor->page_size = (nor->page_size == 264) ? 256 : 512;
  1503. nor->mtd.writebufsize = nor->page_size;
  1504. nor->mtd.size = 8 * nor->page_size * info->n_sectors;
  1505. nor->mtd.erasesize = 8 * nor->page_size;
  1506. } else {
  1507. /* Flash in Default addressing mode */
  1508. nor->flags |= SNOR_F_S3AN_ADDR_DEFAULT;
  1509. }
  1510. return 0;
  1511. }
  1512. struct spi_nor_read_command {
  1513. u8 num_mode_clocks;
  1514. u8 num_wait_states;
  1515. u8 opcode;
  1516. enum spi_nor_protocol proto;
  1517. };
  1518. struct spi_nor_pp_command {
  1519. u8 opcode;
  1520. enum spi_nor_protocol proto;
  1521. };
  1522. enum spi_nor_read_command_index {
  1523. SNOR_CMD_READ,
  1524. SNOR_CMD_READ_FAST,
  1525. SNOR_CMD_READ_1_1_1_DTR,
  1526. /* Dual SPI */
  1527. SNOR_CMD_READ_1_1_2,
  1528. SNOR_CMD_READ_1_2_2,
  1529. SNOR_CMD_READ_2_2_2,
  1530. SNOR_CMD_READ_1_2_2_DTR,
  1531. /* Quad SPI */
  1532. SNOR_CMD_READ_1_1_4,
  1533. SNOR_CMD_READ_1_4_4,
  1534. SNOR_CMD_READ_4_4_4,
  1535. SNOR_CMD_READ_1_4_4_DTR,
  1536. /* Octo SPI */
  1537. SNOR_CMD_READ_1_1_8,
  1538. SNOR_CMD_READ_1_8_8,
  1539. SNOR_CMD_READ_8_8_8,
  1540. SNOR_CMD_READ_1_8_8_DTR,
  1541. SNOR_CMD_READ_MAX
  1542. };
  1543. enum spi_nor_pp_command_index {
  1544. SNOR_CMD_PP,
  1545. /* Quad SPI */
  1546. SNOR_CMD_PP_1_1_4,
  1547. SNOR_CMD_PP_1_4_4,
  1548. SNOR_CMD_PP_4_4_4,
  1549. /* Octo SPI */
  1550. SNOR_CMD_PP_1_1_8,
  1551. SNOR_CMD_PP_1_8_8,
  1552. SNOR_CMD_PP_8_8_8,
  1553. SNOR_CMD_PP_MAX
  1554. };
  1555. struct spi_nor_flash_parameter {
  1556. u64 size;
  1557. u32 page_size;
  1558. struct spi_nor_hwcaps hwcaps;
  1559. struct spi_nor_read_command reads[SNOR_CMD_READ_MAX];
  1560. struct spi_nor_pp_command page_programs[SNOR_CMD_PP_MAX];
  1561. int (*quad_enable)(struct spi_nor *nor);
  1562. };
  1563. static void
  1564. spi_nor_set_read_settings(struct spi_nor_read_command *read,
  1565. u8 num_mode_clocks,
  1566. u8 num_wait_states,
  1567. u8 opcode,
  1568. enum spi_nor_protocol proto)
  1569. {
  1570. read->num_mode_clocks = num_mode_clocks;
  1571. read->num_wait_states = num_wait_states;
  1572. read->opcode = opcode;
  1573. read->proto = proto;
  1574. }
  1575. static void
  1576. spi_nor_set_pp_settings(struct spi_nor_pp_command *pp,
  1577. u8 opcode,
  1578. enum spi_nor_protocol proto)
  1579. {
  1580. pp->opcode = opcode;
  1581. pp->proto = proto;
  1582. }
  1583. /*
  1584. * Serial Flash Discoverable Parameters (SFDP) parsing.
  1585. */
  1586. /**
  1587. * spi_nor_read_sfdp() - read Serial Flash Discoverable Parameters.
  1588. * @nor: pointer to a 'struct spi_nor'
  1589. * @addr: offset in the SFDP area to start reading data from
  1590. * @len: number of bytes to read
  1591. * @buf: buffer where the SFDP data are copied into (dma-safe memory)
  1592. *
  1593. * Whatever the actual numbers of bytes for address and dummy cycles are
  1594. * for (Fast) Read commands, the Read SFDP (5Ah) instruction is always
  1595. * followed by a 3-byte address and 8 dummy clock cycles.
  1596. *
  1597. * Return: 0 on success, -errno otherwise.
  1598. */
  1599. static int spi_nor_read_sfdp(struct spi_nor *nor, u32 addr,
  1600. size_t len, void *buf)
  1601. {
  1602. u8 addr_width, read_opcode, read_dummy;
  1603. int ret;
  1604. read_opcode = nor->read_opcode;
  1605. addr_width = nor->addr_width;
  1606. read_dummy = nor->read_dummy;
  1607. nor->read_opcode = SPINOR_OP_RDSFDP;
  1608. nor->addr_width = 3;
  1609. nor->read_dummy = 8;
  1610. while (len) {
  1611. ret = nor->read(nor, addr, len, (u8 *)buf);
  1612. if (!ret || ret > len) {
  1613. ret = -EIO;
  1614. goto read_err;
  1615. }
  1616. if (ret < 0)
  1617. goto read_err;
  1618. buf += ret;
  1619. addr += ret;
  1620. len -= ret;
  1621. }
  1622. ret = 0;
  1623. read_err:
  1624. nor->read_opcode = read_opcode;
  1625. nor->addr_width = addr_width;
  1626. nor->read_dummy = read_dummy;
  1627. return ret;
  1628. }
  1629. /**
  1630. * spi_nor_read_sfdp_dma_unsafe() - read Serial Flash Discoverable Parameters.
  1631. * @nor: pointer to a 'struct spi_nor'
  1632. * @addr: offset in the SFDP area to start reading data from
  1633. * @len: number of bytes to read
  1634. * @buf: buffer where the SFDP data are copied into
  1635. *
  1636. * Wrap spi_nor_read_sfdp() using a kmalloc'ed bounce buffer as @buf is now not
  1637. * guaranteed to be dma-safe.
  1638. *
  1639. * Return: -ENOMEM if kmalloc() fails, the return code of spi_nor_read_sfdp()
  1640. * otherwise.
  1641. */
  1642. static int spi_nor_read_sfdp_dma_unsafe(struct spi_nor *nor, u32 addr,
  1643. size_t len, void *buf)
  1644. {
  1645. void *dma_safe_buf;
  1646. int ret;
  1647. dma_safe_buf = kmalloc(len, GFP_KERNEL);
  1648. if (!dma_safe_buf)
  1649. return -ENOMEM;
  1650. ret = spi_nor_read_sfdp(nor, addr, len, dma_safe_buf);
  1651. memcpy(buf, dma_safe_buf, len);
  1652. kfree(dma_safe_buf);
  1653. return ret;
  1654. }
  1655. struct sfdp_parameter_header {
  1656. u8 id_lsb;
  1657. u8 minor;
  1658. u8 major;
  1659. u8 length; /* in double words */
  1660. u8 parameter_table_pointer[3]; /* byte address */
  1661. u8 id_msb;
  1662. };
  1663. #define SFDP_PARAM_HEADER_ID(p) (((p)->id_msb << 8) | (p)->id_lsb)
  1664. #define SFDP_PARAM_HEADER_PTP(p) \
  1665. (((p)->parameter_table_pointer[2] << 16) | \
  1666. ((p)->parameter_table_pointer[1] << 8) | \
  1667. ((p)->parameter_table_pointer[0] << 0))
  1668. #define SFDP_BFPT_ID 0xff00 /* Basic Flash Parameter Table */
  1669. #define SFDP_SECTOR_MAP_ID 0xff81 /* Sector Map Table */
  1670. #define SFDP_SIGNATURE 0x50444653U
  1671. #define SFDP_JESD216_MAJOR 1
  1672. #define SFDP_JESD216_MINOR 0
  1673. #define SFDP_JESD216A_MINOR 5
  1674. #define SFDP_JESD216B_MINOR 6
  1675. struct sfdp_header {
  1676. u32 signature; /* Ox50444653U <=> "SFDP" */
  1677. u8 minor;
  1678. u8 major;
  1679. u8 nph; /* 0-base number of parameter headers */
  1680. u8 unused;
  1681. /* Basic Flash Parameter Table. */
  1682. struct sfdp_parameter_header bfpt_header;
  1683. };
  1684. /* Basic Flash Parameter Table */
  1685. /*
  1686. * JESD216 rev B defines a Basic Flash Parameter Table of 16 DWORDs.
  1687. * They are indexed from 1 but C arrays are indexed from 0.
  1688. */
  1689. #define BFPT_DWORD(i) ((i) - 1)
  1690. #define BFPT_DWORD_MAX 16
  1691. /* The first version of JESB216 defined only 9 DWORDs. */
  1692. #define BFPT_DWORD_MAX_JESD216 9
  1693. /* 1st DWORD. */
  1694. #define BFPT_DWORD1_FAST_READ_1_1_2 BIT(16)
  1695. #define BFPT_DWORD1_ADDRESS_BYTES_MASK GENMASK(18, 17)
  1696. #define BFPT_DWORD1_ADDRESS_BYTES_3_ONLY (0x0UL << 17)
  1697. #define BFPT_DWORD1_ADDRESS_BYTES_3_OR_4 (0x1UL << 17)
  1698. #define BFPT_DWORD1_ADDRESS_BYTES_4_ONLY (0x2UL << 17)
  1699. #define BFPT_DWORD1_DTR BIT(19)
  1700. #define BFPT_DWORD1_FAST_READ_1_2_2 BIT(20)
  1701. #define BFPT_DWORD1_FAST_READ_1_4_4 BIT(21)
  1702. #define BFPT_DWORD1_FAST_READ_1_1_4 BIT(22)
  1703. /* 5th DWORD. */
  1704. #define BFPT_DWORD5_FAST_READ_2_2_2 BIT(0)
  1705. #define BFPT_DWORD5_FAST_READ_4_4_4 BIT(4)
  1706. /* 11th DWORD. */
  1707. #define BFPT_DWORD11_PAGE_SIZE_SHIFT 4
  1708. #define BFPT_DWORD11_PAGE_SIZE_MASK GENMASK(7, 4)
  1709. /* 15th DWORD. */
  1710. /*
  1711. * (from JESD216 rev B)
  1712. * Quad Enable Requirements (QER):
  1713. * - 000b: Device does not have a QE bit. Device detects 1-1-4 and 1-4-4
  1714. * reads based on instruction. DQ3/HOLD# functions are hold during
  1715. * instruction phase.
  1716. * - 001b: QE is bit 1 of status register 2. It is set via Write Status with
  1717. * two data bytes where bit 1 of the second byte is one.
  1718. * [...]
  1719. * Writing only one byte to the status register has the side-effect of
  1720. * clearing status register 2, including the QE bit. The 100b code is
  1721. * used if writing one byte to the status register does not modify
  1722. * status register 2.
  1723. * - 010b: QE is bit 6 of status register 1. It is set via Write Status with
  1724. * one data byte where bit 6 is one.
  1725. * [...]
  1726. * - 011b: QE is bit 7 of status register 2. It is set via Write status
  1727. * register 2 instruction 3Eh with one data byte where bit 7 is one.
  1728. * [...]
  1729. * The status register 2 is read using instruction 3Fh.
  1730. * - 100b: QE is bit 1 of status register 2. It is set via Write Status with
  1731. * two data bytes where bit 1 of the second byte is one.
  1732. * [...]
  1733. * In contrast to the 001b code, writing one byte to the status
  1734. * register does not modify status register 2.
  1735. * - 101b: QE is bit 1 of status register 2. Status register 1 is read using
  1736. * Read Status instruction 05h. Status register2 is read using
  1737. * instruction 35h. QE is set via Writ Status instruction 01h with
  1738. * two data bytes where bit 1 of the second byte is one.
  1739. * [...]
  1740. */
  1741. #define BFPT_DWORD15_QER_MASK GENMASK(22, 20)
  1742. #define BFPT_DWORD15_QER_NONE (0x0UL << 20) /* Micron */
  1743. #define BFPT_DWORD15_QER_SR2_BIT1_BUGGY (0x1UL << 20)
  1744. #define BFPT_DWORD15_QER_SR1_BIT6 (0x2UL << 20) /* Macronix */
  1745. #define BFPT_DWORD15_QER_SR2_BIT7 (0x3UL << 20)
  1746. #define BFPT_DWORD15_QER_SR2_BIT1_NO_RD (0x4UL << 20)
  1747. #define BFPT_DWORD15_QER_SR2_BIT1 (0x5UL << 20) /* Spansion */
  1748. struct sfdp_bfpt {
  1749. u32 dwords[BFPT_DWORD_MAX];
  1750. };
  1751. /* Fast Read settings. */
  1752. static inline void
  1753. spi_nor_set_read_settings_from_bfpt(struct spi_nor_read_command *read,
  1754. u16 half,
  1755. enum spi_nor_protocol proto)
  1756. {
  1757. read->num_mode_clocks = (half >> 5) & 0x07;
  1758. read->num_wait_states = (half >> 0) & 0x1f;
  1759. read->opcode = (half >> 8) & 0xff;
  1760. read->proto = proto;
  1761. }
  1762. struct sfdp_bfpt_read {
  1763. /* The Fast Read x-y-z hardware capability in params->hwcaps.mask. */
  1764. u32 hwcaps;
  1765. /*
  1766. * The <supported_bit> bit in <supported_dword> BFPT DWORD tells us
  1767. * whether the Fast Read x-y-z command is supported.
  1768. */
  1769. u32 supported_dword;
  1770. u32 supported_bit;
  1771. /*
  1772. * The half-word at offset <setting_shift> in <setting_dword> BFPT DWORD
  1773. * encodes the op code, the number of mode clocks and the number of wait
  1774. * states to be used by Fast Read x-y-z command.
  1775. */
  1776. u32 settings_dword;
  1777. u32 settings_shift;
  1778. /* The SPI protocol for this Fast Read x-y-z command. */
  1779. enum spi_nor_protocol proto;
  1780. };
  1781. static const struct sfdp_bfpt_read sfdp_bfpt_reads[] = {
  1782. /* Fast Read 1-1-2 */
  1783. {
  1784. SNOR_HWCAPS_READ_1_1_2,
  1785. BFPT_DWORD(1), BIT(16), /* Supported bit */
  1786. BFPT_DWORD(4), 0, /* Settings */
  1787. SNOR_PROTO_1_1_2,
  1788. },
  1789. /* Fast Read 1-2-2 */
  1790. {
  1791. SNOR_HWCAPS_READ_1_2_2,
  1792. BFPT_DWORD(1), BIT(20), /* Supported bit */
  1793. BFPT_DWORD(4), 16, /* Settings */
  1794. SNOR_PROTO_1_2_2,
  1795. },
  1796. /* Fast Read 2-2-2 */
  1797. {
  1798. SNOR_HWCAPS_READ_2_2_2,
  1799. BFPT_DWORD(5), BIT(0), /* Supported bit */
  1800. BFPT_DWORD(6), 16, /* Settings */
  1801. SNOR_PROTO_2_2_2,
  1802. },
  1803. /* Fast Read 1-1-4 */
  1804. {
  1805. SNOR_HWCAPS_READ_1_1_4,
  1806. BFPT_DWORD(1), BIT(22), /* Supported bit */
  1807. BFPT_DWORD(3), 16, /* Settings */
  1808. SNOR_PROTO_1_1_4,
  1809. },
  1810. /* Fast Read 1-4-4 */
  1811. {
  1812. SNOR_HWCAPS_READ_1_4_4,
  1813. BFPT_DWORD(1), BIT(21), /* Supported bit */
  1814. BFPT_DWORD(3), 0, /* Settings */
  1815. SNOR_PROTO_1_4_4,
  1816. },
  1817. /* Fast Read 4-4-4 */
  1818. {
  1819. SNOR_HWCAPS_READ_4_4_4,
  1820. BFPT_DWORD(5), BIT(4), /* Supported bit */
  1821. BFPT_DWORD(7), 16, /* Settings */
  1822. SNOR_PROTO_4_4_4,
  1823. },
  1824. };
  1825. struct sfdp_bfpt_erase {
  1826. /*
  1827. * The half-word at offset <shift> in DWORD <dwoard> encodes the
  1828. * op code and erase sector size to be used by Sector Erase commands.
  1829. */
  1830. u32 dword;
  1831. u32 shift;
  1832. };
  1833. static const struct sfdp_bfpt_erase sfdp_bfpt_erases[] = {
  1834. /* Erase Type 1 in DWORD8 bits[15:0] */
  1835. {BFPT_DWORD(8), 0},
  1836. /* Erase Type 2 in DWORD8 bits[31:16] */
  1837. {BFPT_DWORD(8), 16},
  1838. /* Erase Type 3 in DWORD9 bits[15:0] */
  1839. {BFPT_DWORD(9), 0},
  1840. /* Erase Type 4 in DWORD9 bits[31:16] */
  1841. {BFPT_DWORD(9), 16},
  1842. };
  1843. static int spi_nor_hwcaps_read2cmd(u32 hwcaps);
  1844. /**
  1845. * spi_nor_parse_bfpt() - read and parse the Basic Flash Parameter Table.
  1846. * @nor: pointer to a 'struct spi_nor'
  1847. * @bfpt_header: pointer to the 'struct sfdp_parameter_header' describing
  1848. * the Basic Flash Parameter Table length and version
  1849. * @params: pointer to the 'struct spi_nor_flash_parameter' to be
  1850. * filled
  1851. *
  1852. * The Basic Flash Parameter Table is the main and only mandatory table as
  1853. * defined by the SFDP (JESD216) specification.
  1854. * It provides us with the total size (memory density) of the data array and
  1855. * the number of address bytes for Fast Read, Page Program and Sector Erase
  1856. * commands.
  1857. * For Fast READ commands, it also gives the number of mode clock cycles and
  1858. * wait states (regrouped in the number of dummy clock cycles) for each
  1859. * supported instruction op code.
  1860. * For Page Program, the page size is now available since JESD216 rev A, however
  1861. * the supported instruction op codes are still not provided.
  1862. * For Sector Erase commands, this table stores the supported instruction op
  1863. * codes and the associated sector sizes.
  1864. * Finally, the Quad Enable Requirements (QER) are also available since JESD216
  1865. * rev A. The QER bits encode the manufacturer dependent procedure to be
  1866. * executed to set the Quad Enable (QE) bit in some internal register of the
  1867. * Quad SPI memory. Indeed the QE bit, when it exists, must be set before
  1868. * sending any Quad SPI command to the memory. Actually, setting the QE bit
  1869. * tells the memory to reassign its WP# and HOLD#/RESET# pins to functions IO2
  1870. * and IO3 hence enabling 4 (Quad) I/O lines.
  1871. *
  1872. * Return: 0 on success, -errno otherwise.
  1873. */
  1874. static int spi_nor_parse_bfpt(struct spi_nor *nor,
  1875. const struct sfdp_parameter_header *bfpt_header,
  1876. struct spi_nor_flash_parameter *params)
  1877. {
  1878. struct mtd_info *mtd = &nor->mtd;
  1879. struct sfdp_bfpt bfpt;
  1880. size_t len;
  1881. int i, cmd, err;
  1882. u32 addr;
  1883. u16 half;
  1884. /* JESD216 Basic Flash Parameter Table length is at least 9 DWORDs. */
  1885. if (bfpt_header->length < BFPT_DWORD_MAX_JESD216)
  1886. return -EINVAL;
  1887. /* Read the Basic Flash Parameter Table. */
  1888. len = min_t(size_t, sizeof(bfpt),
  1889. bfpt_header->length * sizeof(u32));
  1890. addr = SFDP_PARAM_HEADER_PTP(bfpt_header);
  1891. memset(&bfpt, 0, sizeof(bfpt));
  1892. err = spi_nor_read_sfdp_dma_unsafe(nor, addr, len, &bfpt);
  1893. if (err < 0)
  1894. return err;
  1895. /* Fix endianness of the BFPT DWORDs. */
  1896. for (i = 0; i < BFPT_DWORD_MAX; i++)
  1897. bfpt.dwords[i] = le32_to_cpu(bfpt.dwords[i]);
  1898. /* Number of address bytes. */
  1899. switch (bfpt.dwords[BFPT_DWORD(1)] & BFPT_DWORD1_ADDRESS_BYTES_MASK) {
  1900. case BFPT_DWORD1_ADDRESS_BYTES_3_ONLY:
  1901. nor->addr_width = 3;
  1902. break;
  1903. case BFPT_DWORD1_ADDRESS_BYTES_4_ONLY:
  1904. nor->addr_width = 4;
  1905. break;
  1906. default:
  1907. break;
  1908. }
  1909. /* Flash Memory Density (in bits). */
  1910. params->size = bfpt.dwords[BFPT_DWORD(2)];
  1911. if (params->size & BIT(31)) {
  1912. params->size &= ~BIT(31);
  1913. /*
  1914. * Prevent overflows on params->size. Anyway, a NOR of 2^64
  1915. * bits is unlikely to exist so this error probably means
  1916. * the BFPT we are reading is corrupted/wrong.
  1917. */
  1918. if (params->size > 63)
  1919. return -EINVAL;
  1920. params->size = 1ULL << params->size;
  1921. } else {
  1922. params->size++;
  1923. }
  1924. params->size >>= 3; /* Convert to bytes. */
  1925. /* Fast Read settings. */
  1926. for (i = 0; i < ARRAY_SIZE(sfdp_bfpt_reads); i++) {
  1927. const struct sfdp_bfpt_read *rd = &sfdp_bfpt_reads[i];
  1928. struct spi_nor_read_command *read;
  1929. if (!(bfpt.dwords[rd->supported_dword] & rd->supported_bit)) {
  1930. params->hwcaps.mask &= ~rd->hwcaps;
  1931. continue;
  1932. }
  1933. params->hwcaps.mask |= rd->hwcaps;
  1934. cmd = spi_nor_hwcaps_read2cmd(rd->hwcaps);
  1935. read = &params->reads[cmd];
  1936. half = bfpt.dwords[rd->settings_dword] >> rd->settings_shift;
  1937. spi_nor_set_read_settings_from_bfpt(read, half, rd->proto);
  1938. }
  1939. /* Sector Erase settings. */
  1940. for (i = 0; i < ARRAY_SIZE(sfdp_bfpt_erases); i++) {
  1941. const struct sfdp_bfpt_erase *er = &sfdp_bfpt_erases[i];
  1942. u32 erasesize;
  1943. u8 opcode;
  1944. half = bfpt.dwords[er->dword] >> er->shift;
  1945. erasesize = half & 0xff;
  1946. /* erasesize == 0 means this Erase Type is not supported. */
  1947. if (!erasesize)
  1948. continue;
  1949. erasesize = 1U << erasesize;
  1950. opcode = (half >> 8) & 0xff;
  1951. #ifdef CONFIG_MTD_SPI_NOR_USE_4K_SECTORS
  1952. if (erasesize == SZ_4K) {
  1953. nor->erase_opcode = opcode;
  1954. mtd->erasesize = erasesize;
  1955. break;
  1956. }
  1957. #endif
  1958. if (!mtd->erasesize || mtd->erasesize < erasesize) {
  1959. nor->erase_opcode = opcode;
  1960. mtd->erasesize = erasesize;
  1961. }
  1962. }
  1963. /* Stop here if not JESD216 rev A or later. */
  1964. if (bfpt_header->length < BFPT_DWORD_MAX)
  1965. return 0;
  1966. /* Page size: this field specifies 'N' so the page size = 2^N bytes. */
  1967. params->page_size = bfpt.dwords[BFPT_DWORD(11)];
  1968. params->page_size &= BFPT_DWORD11_PAGE_SIZE_MASK;
  1969. params->page_size >>= BFPT_DWORD11_PAGE_SIZE_SHIFT;
  1970. params->page_size = 1U << params->page_size;
  1971. /* Quad Enable Requirements. */
  1972. switch (bfpt.dwords[BFPT_DWORD(15)] & BFPT_DWORD15_QER_MASK) {
  1973. case BFPT_DWORD15_QER_NONE:
  1974. params->quad_enable = NULL;
  1975. break;
  1976. case BFPT_DWORD15_QER_SR2_BIT1_BUGGY:
  1977. case BFPT_DWORD15_QER_SR2_BIT1_NO_RD:
  1978. params->quad_enable = spansion_no_read_cr_quad_enable;
  1979. break;
  1980. case BFPT_DWORD15_QER_SR1_BIT6:
  1981. params->quad_enable = macronix_quad_enable;
  1982. break;
  1983. case BFPT_DWORD15_QER_SR2_BIT7:
  1984. params->quad_enable = sr2_bit7_quad_enable;
  1985. break;
  1986. case BFPT_DWORD15_QER_SR2_BIT1:
  1987. params->quad_enable = spansion_read_cr_quad_enable;
  1988. break;
  1989. default:
  1990. return -EINVAL;
  1991. }
  1992. return 0;
  1993. }
  1994. /**
  1995. * spi_nor_parse_sfdp() - parse the Serial Flash Discoverable Parameters.
  1996. * @nor: pointer to a 'struct spi_nor'
  1997. * @params: pointer to the 'struct spi_nor_flash_parameter' to be
  1998. * filled
  1999. *
  2000. * The Serial Flash Discoverable Parameters are described by the JEDEC JESD216
  2001. * specification. This is a standard which tends to supported by almost all
  2002. * (Q)SPI memory manufacturers. Those hard-coded tables allow us to learn at
  2003. * runtime the main parameters needed to perform basic SPI flash operations such
  2004. * as Fast Read, Page Program or Sector Erase commands.
  2005. *
  2006. * Return: 0 on success, -errno otherwise.
  2007. */
  2008. static int spi_nor_parse_sfdp(struct spi_nor *nor,
  2009. struct spi_nor_flash_parameter *params)
  2010. {
  2011. const struct sfdp_parameter_header *param_header, *bfpt_header;
  2012. struct sfdp_parameter_header *param_headers = NULL;
  2013. struct sfdp_header header;
  2014. struct device *dev = nor->dev;
  2015. size_t psize;
  2016. int i, err;
  2017. /* Get the SFDP header. */
  2018. err = spi_nor_read_sfdp_dma_unsafe(nor, 0, sizeof(header), &header);
  2019. if (err < 0)
  2020. return err;
  2021. /* Check the SFDP header version. */
  2022. if (le32_to_cpu(header.signature) != SFDP_SIGNATURE ||
  2023. header.major != SFDP_JESD216_MAJOR)
  2024. return -EINVAL;
  2025. /*
  2026. * Verify that the first and only mandatory parameter header is a
  2027. * Basic Flash Parameter Table header as specified in JESD216.
  2028. */
  2029. bfpt_header = &header.bfpt_header;
  2030. if (SFDP_PARAM_HEADER_ID(bfpt_header) != SFDP_BFPT_ID ||
  2031. bfpt_header->major != SFDP_JESD216_MAJOR)
  2032. return -EINVAL;
  2033. /*
  2034. * Allocate memory then read all parameter headers with a single
  2035. * Read SFDP command. These parameter headers will actually be parsed
  2036. * twice: a first time to get the latest revision of the basic flash
  2037. * parameter table, then a second time to handle the supported optional
  2038. * tables.
  2039. * Hence we read the parameter headers once for all to reduce the
  2040. * processing time. Also we use kmalloc() instead of devm_kmalloc()
  2041. * because we don't need to keep these parameter headers: the allocated
  2042. * memory is always released with kfree() before exiting this function.
  2043. */
  2044. if (header.nph) {
  2045. psize = header.nph * sizeof(*param_headers);
  2046. param_headers = kmalloc(psize, GFP_KERNEL);
  2047. if (!param_headers)
  2048. return -ENOMEM;
  2049. err = spi_nor_read_sfdp(nor, sizeof(header),
  2050. psize, param_headers);
  2051. if (err < 0) {
  2052. dev_err(dev, "failed to read SFDP parameter headers\n");
  2053. goto exit;
  2054. }
  2055. }
  2056. /*
  2057. * Check other parameter headers to get the latest revision of
  2058. * the basic flash parameter table.
  2059. */
  2060. for (i = 0; i < header.nph; i++) {
  2061. param_header = &param_headers[i];
  2062. if (SFDP_PARAM_HEADER_ID(param_header) == SFDP_BFPT_ID &&
  2063. param_header->major == SFDP_JESD216_MAJOR &&
  2064. (param_header->minor > bfpt_header->minor ||
  2065. (param_header->minor == bfpt_header->minor &&
  2066. param_header->length > bfpt_header->length)))
  2067. bfpt_header = param_header;
  2068. }
  2069. err = spi_nor_parse_bfpt(nor, bfpt_header, params);
  2070. if (err)
  2071. goto exit;
  2072. /* Parse other parameter headers. */
  2073. for (i = 0; i < header.nph; i++) {
  2074. param_header = &param_headers[i];
  2075. switch (SFDP_PARAM_HEADER_ID(param_header)) {
  2076. case SFDP_SECTOR_MAP_ID:
  2077. dev_info(dev, "non-uniform erase sector maps are not supported yet.\n");
  2078. break;
  2079. default:
  2080. break;
  2081. }
  2082. if (err)
  2083. goto exit;
  2084. }
  2085. exit:
  2086. kfree(param_headers);
  2087. return err;
  2088. }
  2089. static int spi_nor_init_params(struct spi_nor *nor,
  2090. const struct flash_info *info,
  2091. struct spi_nor_flash_parameter *params)
  2092. {
  2093. /* Set legacy flash parameters as default. */
  2094. memset(params, 0, sizeof(*params));
  2095. /* Set SPI NOR sizes. */
  2096. params->size = info->sector_size * info->n_sectors;
  2097. params->page_size = info->page_size;
  2098. /* (Fast) Read settings. */
  2099. params->hwcaps.mask |= SNOR_HWCAPS_READ;
  2100. spi_nor_set_read_settings(&params->reads[SNOR_CMD_READ],
  2101. 0, 0, SPINOR_OP_READ,
  2102. SNOR_PROTO_1_1_1);
  2103. if (!(info->flags & SPI_NOR_NO_FR)) {
  2104. params->hwcaps.mask |= SNOR_HWCAPS_READ_FAST;
  2105. spi_nor_set_read_settings(&params->reads[SNOR_CMD_READ_FAST],
  2106. 0, 8, SPINOR_OP_READ_FAST,
  2107. SNOR_PROTO_1_1_1);
  2108. }
  2109. if (info->flags & SPI_NOR_DUAL_READ) {
  2110. params->hwcaps.mask |= SNOR_HWCAPS_READ_1_1_2;
  2111. spi_nor_set_read_settings(&params->reads[SNOR_CMD_READ_1_1_2],
  2112. 0, 8, SPINOR_OP_READ_1_1_2,
  2113. SNOR_PROTO_1_1_2);
  2114. }
  2115. if (info->flags & SPI_NOR_QUAD_READ) {
  2116. params->hwcaps.mask |= SNOR_HWCAPS_READ_1_1_4;
  2117. spi_nor_set_read_settings(&params->reads[SNOR_CMD_READ_1_1_4],
  2118. 0, 8, SPINOR_OP_READ_1_1_4,
  2119. SNOR_PROTO_1_1_4);
  2120. }
  2121. /* Page Program settings. */
  2122. params->hwcaps.mask |= SNOR_HWCAPS_PP;
  2123. spi_nor_set_pp_settings(&params->page_programs[SNOR_CMD_PP],
  2124. SPINOR_OP_PP, SNOR_PROTO_1_1_1);
  2125. /* Select the procedure to set the Quad Enable bit. */
  2126. if (params->hwcaps.mask & (SNOR_HWCAPS_READ_QUAD |
  2127. SNOR_HWCAPS_PP_QUAD)) {
  2128. switch (JEDEC_MFR(info)) {
  2129. case SNOR_MFR_MACRONIX:
  2130. params->quad_enable = macronix_quad_enable;
  2131. break;
  2132. case SNOR_MFR_MICRON:
  2133. break;
  2134. default:
  2135. /* Kept only for backward compatibility purpose. */
  2136. params->quad_enable = spansion_quad_enable;
  2137. break;
  2138. }
  2139. /*
  2140. * Some manufacturer like GigaDevice may use different
  2141. * bit to set QE on different memories, so the MFR can't
  2142. * indicate the quad_enable method for this case, we need
  2143. * set it in flash info list.
  2144. */
  2145. if (info->quad_enable)
  2146. params->quad_enable = info->quad_enable;
  2147. }
  2148. /* Override the parameters with data read from SFDP tables. */
  2149. nor->addr_width = 0;
  2150. nor->mtd.erasesize = 0;
  2151. if ((info->flags & (SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ)) &&
  2152. !(info->flags & SPI_NOR_SKIP_SFDP)) {
  2153. struct spi_nor_flash_parameter sfdp_params;
  2154. memcpy(&sfdp_params, params, sizeof(sfdp_params));
  2155. if (spi_nor_parse_sfdp(nor, &sfdp_params)) {
  2156. nor->addr_width = 0;
  2157. nor->mtd.erasesize = 0;
  2158. } else {
  2159. memcpy(params, &sfdp_params, sizeof(*params));
  2160. }
  2161. }
  2162. return 0;
  2163. }
  2164. static int spi_nor_hwcaps2cmd(u32 hwcaps, const int table[][2], size_t size)
  2165. {
  2166. size_t i;
  2167. for (i = 0; i < size; i++)
  2168. if (table[i][0] == (int)hwcaps)
  2169. return table[i][1];
  2170. return -EINVAL;
  2171. }
  2172. static int spi_nor_hwcaps_read2cmd(u32 hwcaps)
  2173. {
  2174. static const int hwcaps_read2cmd[][2] = {
  2175. { SNOR_HWCAPS_READ, SNOR_CMD_READ },
  2176. { SNOR_HWCAPS_READ_FAST, SNOR_CMD_READ_FAST },
  2177. { SNOR_HWCAPS_READ_1_1_1_DTR, SNOR_CMD_READ_1_1_1_DTR },
  2178. { SNOR_HWCAPS_READ_1_1_2, SNOR_CMD_READ_1_1_2 },
  2179. { SNOR_HWCAPS_READ_1_2_2, SNOR_CMD_READ_1_2_2 },
  2180. { SNOR_HWCAPS_READ_2_2_2, SNOR_CMD_READ_2_2_2 },
  2181. { SNOR_HWCAPS_READ_1_2_2_DTR, SNOR_CMD_READ_1_2_2_DTR },
  2182. { SNOR_HWCAPS_READ_1_1_4, SNOR_CMD_READ_1_1_4 },
  2183. { SNOR_HWCAPS_READ_1_4_4, SNOR_CMD_READ_1_4_4 },
  2184. { SNOR_HWCAPS_READ_4_4_4, SNOR_CMD_READ_4_4_4 },
  2185. { SNOR_HWCAPS_READ_1_4_4_DTR, SNOR_CMD_READ_1_4_4_DTR },
  2186. { SNOR_HWCAPS_READ_1_1_8, SNOR_CMD_READ_1_1_8 },
  2187. { SNOR_HWCAPS_READ_1_8_8, SNOR_CMD_READ_1_8_8 },
  2188. { SNOR_HWCAPS_READ_8_8_8, SNOR_CMD_READ_8_8_8 },
  2189. { SNOR_HWCAPS_READ_1_8_8_DTR, SNOR_CMD_READ_1_8_8_DTR },
  2190. };
  2191. return spi_nor_hwcaps2cmd(hwcaps, hwcaps_read2cmd,
  2192. ARRAY_SIZE(hwcaps_read2cmd));
  2193. }
  2194. static int spi_nor_hwcaps_pp2cmd(u32 hwcaps)
  2195. {
  2196. static const int hwcaps_pp2cmd[][2] = {
  2197. { SNOR_HWCAPS_PP, SNOR_CMD_PP },
  2198. { SNOR_HWCAPS_PP_1_1_4, SNOR_CMD_PP_1_1_4 },
  2199. { SNOR_HWCAPS_PP_1_4_4, SNOR_CMD_PP_1_4_4 },
  2200. { SNOR_HWCAPS_PP_4_4_4, SNOR_CMD_PP_4_4_4 },
  2201. { SNOR_HWCAPS_PP_1_1_8, SNOR_CMD_PP_1_1_8 },
  2202. { SNOR_HWCAPS_PP_1_8_8, SNOR_CMD_PP_1_8_8 },
  2203. { SNOR_HWCAPS_PP_8_8_8, SNOR_CMD_PP_8_8_8 },
  2204. };
  2205. return spi_nor_hwcaps2cmd(hwcaps, hwcaps_pp2cmd,
  2206. ARRAY_SIZE(hwcaps_pp2cmd));
  2207. }
  2208. static int spi_nor_select_read(struct spi_nor *nor,
  2209. const struct spi_nor_flash_parameter *params,
  2210. u32 shared_hwcaps)
  2211. {
  2212. int cmd, best_match = fls(shared_hwcaps & SNOR_HWCAPS_READ_MASK) - 1;
  2213. const struct spi_nor_read_command *read;
  2214. if (best_match < 0)
  2215. return -EINVAL;
  2216. cmd = spi_nor_hwcaps_read2cmd(BIT(best_match));
  2217. if (cmd < 0)
  2218. return -EINVAL;
  2219. read = &params->reads[cmd];
  2220. nor->read_opcode = read->opcode;
  2221. nor->read_proto = read->proto;
  2222. /*
  2223. * In the spi-nor framework, we don't need to make the difference
  2224. * between mode clock cycles and wait state clock cycles.
  2225. * Indeed, the value of the mode clock cycles is used by a QSPI
  2226. * flash memory to know whether it should enter or leave its 0-4-4
  2227. * (Continuous Read / XIP) mode.
  2228. * eXecution In Place is out of the scope of the mtd sub-system.
  2229. * Hence we choose to merge both mode and wait state clock cycles
  2230. * into the so called dummy clock cycles.
  2231. */
  2232. nor->read_dummy = read->num_mode_clocks + read->num_wait_states;
  2233. return 0;
  2234. }
  2235. static int spi_nor_select_pp(struct spi_nor *nor,
  2236. const struct spi_nor_flash_parameter *params,
  2237. u32 shared_hwcaps)
  2238. {
  2239. int cmd, best_match = fls(shared_hwcaps & SNOR_HWCAPS_PP_MASK) - 1;
  2240. const struct spi_nor_pp_command *pp;
  2241. if (best_match < 0)
  2242. return -EINVAL;
  2243. cmd = spi_nor_hwcaps_pp2cmd(BIT(best_match));
  2244. if (cmd < 0)
  2245. return -EINVAL;
  2246. pp = &params->page_programs[cmd];
  2247. nor->program_opcode = pp->opcode;
  2248. nor->write_proto = pp->proto;
  2249. return 0;
  2250. }
  2251. static int spi_nor_select_erase(struct spi_nor *nor,
  2252. const struct flash_info *info)
  2253. {
  2254. struct mtd_info *mtd = &nor->mtd;
  2255. /* Do nothing if already configured from SFDP. */
  2256. if (mtd->erasesize)
  2257. return 0;
  2258. #ifdef CONFIG_MTD_SPI_NOR_USE_4K_SECTORS
  2259. /* prefer "small sector" erase if possible */
  2260. if (info->flags & SECT_4K) {
  2261. nor->erase_opcode = SPINOR_OP_BE_4K;
  2262. mtd->erasesize = 4096;
  2263. } else if (info->flags & SECT_4K_PMC) {
  2264. nor->erase_opcode = SPINOR_OP_BE_4K_PMC;
  2265. mtd->erasesize = 4096;
  2266. } else
  2267. #endif
  2268. {
  2269. nor->erase_opcode = SPINOR_OP_SE;
  2270. mtd->erasesize = info->sector_size;
  2271. }
  2272. return 0;
  2273. }
  2274. static int spi_nor_setup(struct spi_nor *nor, const struct flash_info *info,
  2275. const struct spi_nor_flash_parameter *params,
  2276. const struct spi_nor_hwcaps *hwcaps)
  2277. {
  2278. u32 ignored_mask, shared_mask;
  2279. bool enable_quad_io;
  2280. int err;
  2281. /*
  2282. * Keep only the hardware capabilities supported by both the SPI
  2283. * controller and the SPI flash memory.
  2284. */
  2285. shared_mask = hwcaps->mask & params->hwcaps.mask;
  2286. /* SPI n-n-n protocols are not supported yet. */
  2287. ignored_mask = (SNOR_HWCAPS_READ_2_2_2 |
  2288. SNOR_HWCAPS_READ_4_4_4 |
  2289. SNOR_HWCAPS_READ_8_8_8 |
  2290. SNOR_HWCAPS_PP_4_4_4 |
  2291. SNOR_HWCAPS_PP_8_8_8);
  2292. if (shared_mask & ignored_mask) {
  2293. dev_dbg(nor->dev,
  2294. "SPI n-n-n protocols are not supported yet.\n");
  2295. shared_mask &= ~ignored_mask;
  2296. }
  2297. /* Select the (Fast) Read command. */
  2298. err = spi_nor_select_read(nor, params, shared_mask);
  2299. if (err) {
  2300. dev_err(nor->dev,
  2301. "can't select read settings supported by both the SPI controller and memory.\n");
  2302. return err;
  2303. }
  2304. /* Select the Page Program command. */
  2305. err = spi_nor_select_pp(nor, params, shared_mask);
  2306. if (err) {
  2307. dev_err(nor->dev,
  2308. "can't select write settings supported by both the SPI controller and memory.\n");
  2309. return err;
  2310. }
  2311. /* Select the Sector Erase command. */
  2312. err = spi_nor_select_erase(nor, info);
  2313. if (err) {
  2314. dev_err(nor->dev,
  2315. "can't select erase settings supported by both the SPI controller and memory.\n");
  2316. return err;
  2317. }
  2318. /* Enable Quad I/O if needed. */
  2319. enable_quad_io = (spi_nor_get_protocol_width(nor->read_proto) == 4 ||
  2320. spi_nor_get_protocol_width(nor->write_proto) == 4);
  2321. if (enable_quad_io && params->quad_enable)
  2322. nor->quad_enable = params->quad_enable;
  2323. else
  2324. nor->quad_enable = NULL;
  2325. return 0;
  2326. }
  2327. static int spi_nor_init(struct spi_nor *nor)
  2328. {
  2329. int err;
  2330. /*
  2331. * Atmel, SST, Intel/Numonyx, and others serial NOR tend to power up
  2332. * with the software protection bits set
  2333. */
  2334. if (JEDEC_MFR(nor->info) == SNOR_MFR_ATMEL ||
  2335. JEDEC_MFR(nor->info) == SNOR_MFR_INTEL ||
  2336. JEDEC_MFR(nor->info) == SNOR_MFR_SST ||
  2337. nor->info->flags & SPI_NOR_HAS_LOCK) {
  2338. write_enable(nor);
  2339. write_sr(nor, 0);
  2340. spi_nor_wait_till_ready(nor);
  2341. }
  2342. if (nor->quad_enable) {
  2343. err = nor->quad_enable(nor);
  2344. if (err) {
  2345. dev_err(nor->dev, "quad mode not supported\n");
  2346. return err;
  2347. }
  2348. }
  2349. if ((nor->addr_width == 4) &&
  2350. (JEDEC_MFR(nor->info) != SNOR_MFR_SPANSION) &&
  2351. !(nor->info->flags & SPI_NOR_4B_OPCODES))
  2352. set_4byte(nor, nor->info, 1);
  2353. return 0;
  2354. }
  2355. /* mtd resume handler */
  2356. static void spi_nor_resume(struct mtd_info *mtd)
  2357. {
  2358. struct spi_nor *nor = mtd_to_spi_nor(mtd);
  2359. struct device *dev = nor->dev;
  2360. int ret;
  2361. /* re-initialize the nor chip */
  2362. ret = spi_nor_init(nor);
  2363. if (ret)
  2364. dev_err(dev, "resume() failed\n");
  2365. }
  2366. void spi_nor_restore(struct spi_nor *nor)
  2367. {
  2368. /* restore the addressing mode */
  2369. if ((nor->addr_width == 4) &&
  2370. (JEDEC_MFR(nor->info) != SNOR_MFR_SPANSION) &&
  2371. !(nor->info->flags & SPI_NOR_4B_OPCODES))
  2372. set_4byte(nor, nor->info, 0);
  2373. }
  2374. EXPORT_SYMBOL_GPL(spi_nor_restore);
  2375. int spi_nor_scan(struct spi_nor *nor, const char *name,
  2376. const struct spi_nor_hwcaps *hwcaps)
  2377. {
  2378. struct spi_nor_flash_parameter params;
  2379. const struct flash_info *info = NULL;
  2380. struct device *dev = nor->dev;
  2381. struct mtd_info *mtd = &nor->mtd;
  2382. struct device_node *np = spi_nor_get_flash_node(nor);
  2383. int ret;
  2384. int i;
  2385. ret = spi_nor_check(nor);
  2386. if (ret)
  2387. return ret;
  2388. /* Reset SPI protocol for all commands. */
  2389. nor->reg_proto = SNOR_PROTO_1_1_1;
  2390. nor->read_proto = SNOR_PROTO_1_1_1;
  2391. nor->write_proto = SNOR_PROTO_1_1_1;
  2392. if (name)
  2393. info = spi_nor_match_id(name);
  2394. /* Try to auto-detect if chip name wasn't specified or not found */
  2395. if (!info)
  2396. info = spi_nor_read_id(nor);
  2397. if (IS_ERR_OR_NULL(info))
  2398. return -ENOENT;
  2399. /*
  2400. * If caller has specified name of flash model that can normally be
  2401. * detected using JEDEC, let's verify it.
  2402. */
  2403. if (name && info->id_len) {
  2404. const struct flash_info *jinfo;
  2405. jinfo = spi_nor_read_id(nor);
  2406. if (IS_ERR(jinfo)) {
  2407. return PTR_ERR(jinfo);
  2408. } else if (jinfo != info) {
  2409. /*
  2410. * JEDEC knows better, so overwrite platform ID. We
  2411. * can't trust partitions any longer, but we'll let
  2412. * mtd apply them anyway, since some partitions may be
  2413. * marked read-only, and we don't want to lose that
  2414. * information, even if it's not 100% accurate.
  2415. */
  2416. dev_warn(dev, "found %s, expected %s\n",
  2417. jinfo->name, info->name);
  2418. info = jinfo;
  2419. }
  2420. }
  2421. mutex_init(&nor->lock);
  2422. /*
  2423. * Make sure the XSR_RDY flag is set before calling
  2424. * spi_nor_wait_till_ready(). Xilinx S3AN share MFR
  2425. * with Atmel spi-nor
  2426. */
  2427. if (info->flags & SPI_S3AN)
  2428. nor->flags |= SNOR_F_READY_XSR_RDY;
  2429. /* Parse the Serial Flash Discoverable Parameters table. */
  2430. ret = spi_nor_init_params(nor, info, &params);
  2431. if (ret)
  2432. return ret;
  2433. if (!mtd->name)
  2434. mtd->name = dev_name(dev);
  2435. mtd->priv = nor;
  2436. mtd->type = MTD_NORFLASH;
  2437. mtd->writesize = 1;
  2438. mtd->flags = MTD_CAP_NORFLASH;
  2439. mtd->size = params.size;
  2440. mtd->_erase = spi_nor_erase;
  2441. mtd->_read = spi_nor_read;
  2442. mtd->_resume = spi_nor_resume;
  2443. /* NOR protection support for STmicro/Micron chips and similar */
  2444. if (JEDEC_MFR(info) == SNOR_MFR_MICRON ||
  2445. info->flags & SPI_NOR_HAS_LOCK) {
  2446. nor->flash_lock = stm_lock;
  2447. nor->flash_unlock = stm_unlock;
  2448. nor->flash_is_locked = stm_is_locked;
  2449. }
  2450. if (nor->flash_lock && nor->flash_unlock && nor->flash_is_locked) {
  2451. mtd->_lock = spi_nor_lock;
  2452. mtd->_unlock = spi_nor_unlock;
  2453. mtd->_is_locked = spi_nor_is_locked;
  2454. }
  2455. /* sst nor chips use AAI word program */
  2456. if (info->flags & SST_WRITE)
  2457. mtd->_write = sst_write;
  2458. else
  2459. mtd->_write = spi_nor_write;
  2460. if (info->flags & USE_FSR)
  2461. nor->flags |= SNOR_F_USE_FSR;
  2462. if (info->flags & SPI_NOR_HAS_TB)
  2463. nor->flags |= SNOR_F_HAS_SR_TB;
  2464. if (info->flags & NO_CHIP_ERASE)
  2465. nor->flags |= SNOR_F_NO_OP_CHIP_ERASE;
  2466. if (info->flags & USE_CLSR)
  2467. nor->flags |= SNOR_F_USE_CLSR;
  2468. if (info->flags & SPI_NOR_NO_ERASE)
  2469. mtd->flags |= MTD_NO_ERASE;
  2470. mtd->dev.parent = dev;
  2471. nor->page_size = params.page_size;
  2472. mtd->writebufsize = nor->page_size;
  2473. if (np) {
  2474. /* If we were instantiated by DT, use it */
  2475. if (of_property_read_bool(np, "m25p,fast-read"))
  2476. params.hwcaps.mask |= SNOR_HWCAPS_READ_FAST;
  2477. else
  2478. params.hwcaps.mask &= ~SNOR_HWCAPS_READ_FAST;
  2479. } else {
  2480. /* If we weren't instantiated by DT, default to fast-read */
  2481. params.hwcaps.mask |= SNOR_HWCAPS_READ_FAST;
  2482. }
  2483. /* Some devices cannot do fast-read, no matter what DT tells us */
  2484. if (info->flags & SPI_NOR_NO_FR)
  2485. params.hwcaps.mask &= ~SNOR_HWCAPS_READ_FAST;
  2486. /*
  2487. * Configure the SPI memory:
  2488. * - select op codes for (Fast) Read, Page Program and Sector Erase.
  2489. * - set the number of dummy cycles (mode cycles + wait states).
  2490. * - set the SPI protocols for register and memory accesses.
  2491. * - set the Quad Enable bit if needed (required by SPI x-y-4 protos).
  2492. */
  2493. ret = spi_nor_setup(nor, info, &params, hwcaps);
  2494. if (ret)
  2495. return ret;
  2496. if (nor->addr_width) {
  2497. /* already configured from SFDP */
  2498. } else if (info->addr_width) {
  2499. nor->addr_width = info->addr_width;
  2500. } else if (mtd->size > 0x1000000) {
  2501. /* enable 4-byte addressing if the device exceeds 16MiB */
  2502. nor->addr_width = 4;
  2503. if (JEDEC_MFR(info) == SNOR_MFR_SPANSION ||
  2504. info->flags & SPI_NOR_4B_OPCODES)
  2505. spi_nor_set_4byte_opcodes(nor, info);
  2506. } else {
  2507. nor->addr_width = 3;
  2508. }
  2509. if (nor->addr_width > SPI_NOR_MAX_ADDR_WIDTH) {
  2510. dev_err(dev, "address width is too large: %u\n",
  2511. nor->addr_width);
  2512. return -EINVAL;
  2513. }
  2514. if (info->flags & SPI_S3AN) {
  2515. ret = s3an_nor_scan(info, nor);
  2516. if (ret)
  2517. return ret;
  2518. }
  2519. /* Send all the required SPI flash commands to initialize device */
  2520. nor->info = info;
  2521. ret = spi_nor_init(nor);
  2522. if (ret)
  2523. return ret;
  2524. dev_info(dev, "%s (%lld Kbytes)\n", info->name,
  2525. (long long)mtd->size >> 10);
  2526. dev_dbg(dev,
  2527. "mtd .name = %s, .size = 0x%llx (%lldMiB), "
  2528. ".erasesize = 0x%.8x (%uKiB) .numeraseregions = %d\n",
  2529. mtd->name, (long long)mtd->size, (long long)(mtd->size >> 20),
  2530. mtd->erasesize, mtd->erasesize / 1024, mtd->numeraseregions);
  2531. if (mtd->numeraseregions)
  2532. for (i = 0; i < mtd->numeraseregions; i++)
  2533. dev_dbg(dev,
  2534. "mtd.eraseregions[%d] = { .offset = 0x%llx, "
  2535. ".erasesize = 0x%.8x (%uKiB), "
  2536. ".numblocks = %d }\n",
  2537. i, (long long)mtd->eraseregions[i].offset,
  2538. mtd->eraseregions[i].erasesize,
  2539. mtd->eraseregions[i].erasesize / 1024,
  2540. mtd->eraseregions[i].numblocks);
  2541. return 0;
  2542. }
  2543. EXPORT_SYMBOL_GPL(spi_nor_scan);
  2544. static const struct flash_info *spi_nor_match_id(const char *name)
  2545. {
  2546. const struct flash_info *id = spi_nor_ids;
  2547. while (id->name) {
  2548. if (!strcmp(name, id->name))
  2549. return id;
  2550. id++;
  2551. }
  2552. return NULL;
  2553. }
  2554. MODULE_LICENSE("GPL");
  2555. MODULE_AUTHOR("Huang Shijie <shijie8@gmail.com>");
  2556. MODULE_AUTHOR("Mike Lavender");
  2557. MODULE_DESCRIPTION("framework for SPI NOR");