spi-nor.c 84 KB

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