spi-nor.c 86 KB

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