stm32_fmc2_nand.c 55 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (C) STMicroelectronics 2018
  4. * Author: Christophe Kerello <christophe.kerello@st.com>
  5. */
  6. #include <linux/bitfield.h>
  7. #include <linux/clk.h>
  8. #include <linux/dmaengine.h>
  9. #include <linux/dma-mapping.h>
  10. #include <linux/errno.h>
  11. #include <linux/gpio/consumer.h>
  12. #include <linux/interrupt.h>
  13. #include <linux/iopoll.h>
  14. #include <linux/mfd/syscon.h>
  15. #include <linux/module.h>
  16. #include <linux/mtd/rawnand.h>
  17. #include <linux/of_address.h>
  18. #include <linux/of_device.h>
  19. #include <linux/pinctrl/consumer.h>
  20. #include <linux/platform_device.h>
  21. #include <linux/regmap.h>
  22. #include <linux/reset.h>
  23. /* Bad block marker length */
  24. #define FMC2_BBM_LEN 2
  25. /* ECC step size */
  26. #define FMC2_ECC_STEP_SIZE 512
  27. /* BCHDSRx registers length */
  28. #define FMC2_BCHDSRS_LEN 20
  29. /* HECCR length */
  30. #define FMC2_HECCR_LEN 4
  31. /* Max requests done for a 8k nand page size */
  32. #define FMC2_MAX_SG 16
  33. /* Max chip enable */
  34. #define FMC2_MAX_CE 4
  35. /* Max ECC buffer length */
  36. #define FMC2_MAX_ECC_BUF_LEN (FMC2_BCHDSRS_LEN * FMC2_MAX_SG)
  37. #define FMC2_TIMEOUT_MS 5000
  38. /* Timings */
  39. #define FMC2_THIZ 1
  40. #define FMC2_TIO 8000
  41. #define FMC2_TSYNC 3000
  42. #define FMC2_PCR_TIMING_MASK 0xf
  43. #define FMC2_PMEM_PATT_TIMING_MASK 0xff
  44. /* FMC2 Controller Registers */
  45. #define FMC2_BCR1 0x0
  46. #define FMC2_PCR 0x80
  47. #define FMC2_SR 0x84
  48. #define FMC2_PMEM 0x88
  49. #define FMC2_PATT 0x8c
  50. #define FMC2_HECCR 0x94
  51. #define FMC2_ISR 0x184
  52. #define FMC2_ICR 0x188
  53. #define FMC2_CSQCR 0x200
  54. #define FMC2_CSQCFGR1 0x204
  55. #define FMC2_CSQCFGR2 0x208
  56. #define FMC2_CSQCFGR3 0x20c
  57. #define FMC2_CSQAR1 0x210
  58. #define FMC2_CSQAR2 0x214
  59. #define FMC2_CSQIER 0x220
  60. #define FMC2_CSQISR 0x224
  61. #define FMC2_CSQICR 0x228
  62. #define FMC2_CSQEMSR 0x230
  63. #define FMC2_BCHIER 0x250
  64. #define FMC2_BCHISR 0x254
  65. #define FMC2_BCHICR 0x258
  66. #define FMC2_BCHPBR1 0x260
  67. #define FMC2_BCHPBR2 0x264
  68. #define FMC2_BCHPBR3 0x268
  69. #define FMC2_BCHPBR4 0x26c
  70. #define FMC2_BCHDSR0 0x27c
  71. #define FMC2_BCHDSR1 0x280
  72. #define FMC2_BCHDSR2 0x284
  73. #define FMC2_BCHDSR3 0x288
  74. #define FMC2_BCHDSR4 0x28c
  75. /* Register: FMC2_BCR1 */
  76. #define FMC2_BCR1_FMC2EN BIT(31)
  77. /* Register: FMC2_PCR */
  78. #define FMC2_PCR_PWAITEN BIT(1)
  79. #define FMC2_PCR_PBKEN BIT(2)
  80. #define FMC2_PCR_PWID GENMASK(5, 4)
  81. #define FMC2_PCR_PWID_BUSWIDTH_8 0
  82. #define FMC2_PCR_PWID_BUSWIDTH_16 1
  83. #define FMC2_PCR_ECCEN BIT(6)
  84. #define FMC2_PCR_ECCALG BIT(8)
  85. #define FMC2_PCR_TCLR GENMASK(12, 9)
  86. #define FMC2_PCR_TCLR_DEFAULT 0xf
  87. #define FMC2_PCR_TAR GENMASK(16, 13)
  88. #define FMC2_PCR_TAR_DEFAULT 0xf
  89. #define FMC2_PCR_ECCSS GENMASK(19, 17)
  90. #define FMC2_PCR_ECCSS_512 1
  91. #define FMC2_PCR_ECCSS_2048 3
  92. #define FMC2_PCR_BCHECC BIT(24)
  93. #define FMC2_PCR_WEN BIT(25)
  94. /* Register: FMC2_SR */
  95. #define FMC2_SR_NWRF BIT(6)
  96. /* Register: FMC2_PMEM */
  97. #define FMC2_PMEM_MEMSET GENMASK(7, 0)
  98. #define FMC2_PMEM_MEMWAIT GENMASK(15, 8)
  99. #define FMC2_PMEM_MEMHOLD GENMASK(23, 16)
  100. #define FMC2_PMEM_MEMHIZ GENMASK(31, 24)
  101. #define FMC2_PMEM_DEFAULT 0x0a0a0a0a
  102. /* Register: FMC2_PATT */
  103. #define FMC2_PATT_ATTSET GENMASK(7, 0)
  104. #define FMC2_PATT_ATTWAIT GENMASK(15, 8)
  105. #define FMC2_PATT_ATTHOLD GENMASK(23, 16)
  106. #define FMC2_PATT_ATTHIZ GENMASK(31, 24)
  107. #define FMC2_PATT_DEFAULT 0x0a0a0a0a
  108. /* Register: FMC2_ISR */
  109. #define FMC2_ISR_IHLF BIT(1)
  110. /* Register: FMC2_ICR */
  111. #define FMC2_ICR_CIHLF BIT(1)
  112. /* Register: FMC2_CSQCR */
  113. #define FMC2_CSQCR_CSQSTART BIT(0)
  114. /* Register: FMC2_CSQCFGR1 */
  115. #define FMC2_CSQCFGR1_CMD2EN BIT(1)
  116. #define FMC2_CSQCFGR1_DMADEN BIT(2)
  117. #define FMC2_CSQCFGR1_ACYNBR GENMASK(6, 4)
  118. #define FMC2_CSQCFGR1_CMD1 GENMASK(15, 8)
  119. #define FMC2_CSQCFGR1_CMD2 GENMASK(23, 16)
  120. #define FMC2_CSQCFGR1_CMD1T BIT(24)
  121. #define FMC2_CSQCFGR1_CMD2T BIT(25)
  122. /* Register: FMC2_CSQCFGR2 */
  123. #define FMC2_CSQCFGR2_SQSDTEN BIT(0)
  124. #define FMC2_CSQCFGR2_RCMD2EN BIT(1)
  125. #define FMC2_CSQCFGR2_DMASEN BIT(2)
  126. #define FMC2_CSQCFGR2_RCMD1 GENMASK(15, 8)
  127. #define FMC2_CSQCFGR2_RCMD2 GENMASK(23, 16)
  128. #define FMC2_CSQCFGR2_RCMD1T BIT(24)
  129. #define FMC2_CSQCFGR2_RCMD2T BIT(25)
  130. /* Register: FMC2_CSQCFGR3 */
  131. #define FMC2_CSQCFGR3_SNBR GENMASK(13, 8)
  132. #define FMC2_CSQCFGR3_AC1T BIT(16)
  133. #define FMC2_CSQCFGR3_AC2T BIT(17)
  134. #define FMC2_CSQCFGR3_AC3T BIT(18)
  135. #define FMC2_CSQCFGR3_AC4T BIT(19)
  136. #define FMC2_CSQCFGR3_AC5T BIT(20)
  137. #define FMC2_CSQCFGR3_SDT BIT(21)
  138. #define FMC2_CSQCFGR3_RAC1T BIT(22)
  139. #define FMC2_CSQCFGR3_RAC2T BIT(23)
  140. /* Register: FMC2_CSQCAR1 */
  141. #define FMC2_CSQCAR1_ADDC1 GENMASK(7, 0)
  142. #define FMC2_CSQCAR1_ADDC2 GENMASK(15, 8)
  143. #define FMC2_CSQCAR1_ADDC3 GENMASK(23, 16)
  144. #define FMC2_CSQCAR1_ADDC4 GENMASK(31, 24)
  145. /* Register: FMC2_CSQCAR2 */
  146. #define FMC2_CSQCAR2_ADDC5 GENMASK(7, 0)
  147. #define FMC2_CSQCAR2_NANDCEN GENMASK(11, 10)
  148. #define FMC2_CSQCAR2_SAO GENMASK(31, 16)
  149. /* Register: FMC2_CSQIER */
  150. #define FMC2_CSQIER_TCIE BIT(0)
  151. /* Register: FMC2_CSQICR */
  152. #define FMC2_CSQICR_CLEAR_IRQ GENMASK(4, 0)
  153. /* Register: FMC2_CSQEMSR */
  154. #define FMC2_CSQEMSR_SEM GENMASK(15, 0)
  155. /* Register: FMC2_BCHIER */
  156. #define FMC2_BCHIER_DERIE BIT(1)
  157. #define FMC2_BCHIER_EPBRIE BIT(4)
  158. /* Register: FMC2_BCHICR */
  159. #define FMC2_BCHICR_CLEAR_IRQ GENMASK(4, 0)
  160. /* Register: FMC2_BCHDSR0 */
  161. #define FMC2_BCHDSR0_DUE BIT(0)
  162. #define FMC2_BCHDSR0_DEF BIT(1)
  163. #define FMC2_BCHDSR0_DEN GENMASK(7, 4)
  164. /* Register: FMC2_BCHDSR1 */
  165. #define FMC2_BCHDSR1_EBP1 GENMASK(12, 0)
  166. #define FMC2_BCHDSR1_EBP2 GENMASK(28, 16)
  167. /* Register: FMC2_BCHDSR2 */
  168. #define FMC2_BCHDSR2_EBP3 GENMASK(12, 0)
  169. #define FMC2_BCHDSR2_EBP4 GENMASK(28, 16)
  170. /* Register: FMC2_BCHDSR3 */
  171. #define FMC2_BCHDSR3_EBP5 GENMASK(12, 0)
  172. #define FMC2_BCHDSR3_EBP6 GENMASK(28, 16)
  173. /* Register: FMC2_BCHDSR4 */
  174. #define FMC2_BCHDSR4_EBP7 GENMASK(12, 0)
  175. #define FMC2_BCHDSR4_EBP8 GENMASK(28, 16)
  176. enum stm32_fmc2_ecc {
  177. FMC2_ECC_HAM = 1,
  178. FMC2_ECC_BCH4 = 4,
  179. FMC2_ECC_BCH8 = 8
  180. };
  181. enum stm32_fmc2_irq_state {
  182. FMC2_IRQ_UNKNOWN = 0,
  183. FMC2_IRQ_BCH,
  184. FMC2_IRQ_SEQ
  185. };
  186. struct stm32_fmc2_timings {
  187. u8 tclr;
  188. u8 tar;
  189. u8 thiz;
  190. u8 twait;
  191. u8 thold_mem;
  192. u8 tset_mem;
  193. u8 thold_att;
  194. u8 tset_att;
  195. };
  196. struct stm32_fmc2_nand {
  197. struct nand_chip chip;
  198. struct gpio_desc *wp_gpio;
  199. struct stm32_fmc2_timings timings;
  200. int ncs;
  201. int cs_used[FMC2_MAX_CE];
  202. };
  203. static inline struct stm32_fmc2_nand *to_fmc2_nand(struct nand_chip *chip)
  204. {
  205. return container_of(chip, struct stm32_fmc2_nand, chip);
  206. }
  207. struct stm32_fmc2_nfc;
  208. struct stm32_fmc2_nfc_data {
  209. int max_ncs;
  210. int (*set_cdev)(struct stm32_fmc2_nfc *nfc);
  211. };
  212. struct stm32_fmc2_nfc {
  213. struct nand_controller base;
  214. struct stm32_fmc2_nand nand;
  215. struct device *dev;
  216. struct device *cdev;
  217. struct regmap *regmap;
  218. void __iomem *data_base[FMC2_MAX_CE];
  219. void __iomem *cmd_base[FMC2_MAX_CE];
  220. void __iomem *addr_base[FMC2_MAX_CE];
  221. phys_addr_t io_phys_addr;
  222. phys_addr_t data_phys_addr[FMC2_MAX_CE];
  223. struct clk *clk;
  224. u8 irq_state;
  225. const struct stm32_fmc2_nfc_data *data;
  226. struct dma_chan *dma_tx_ch;
  227. struct dma_chan *dma_rx_ch;
  228. struct dma_chan *dma_ecc_ch;
  229. struct sg_table dma_data_sg;
  230. struct sg_table dma_ecc_sg;
  231. u8 *ecc_buf;
  232. dma_addr_t dma_ecc_addr;
  233. int dma_ecc_len;
  234. u32 tx_dma_max_burst;
  235. u32 rx_dma_max_burst;
  236. struct completion complete;
  237. struct completion dma_data_complete;
  238. struct completion dma_ecc_complete;
  239. u8 cs_assigned;
  240. int cs_sel;
  241. };
  242. static inline struct stm32_fmc2_nfc *to_stm32_nfc(struct nand_controller *base)
  243. {
  244. return container_of(base, struct stm32_fmc2_nfc, base);
  245. }
  246. static void stm32_fmc2_nfc_timings_init(struct nand_chip *chip)
  247. {
  248. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  249. struct stm32_fmc2_nand *nand = to_fmc2_nand(chip);
  250. struct stm32_fmc2_timings *timings = &nand->timings;
  251. u32 pmem, patt;
  252. /* Set tclr/tar timings */
  253. regmap_update_bits(nfc->regmap, FMC2_PCR,
  254. FMC2_PCR_TCLR | FMC2_PCR_TAR,
  255. FIELD_PREP(FMC2_PCR_TCLR, timings->tclr) |
  256. FIELD_PREP(FMC2_PCR_TAR, timings->tar));
  257. /* Set tset/twait/thold/thiz timings in common bank */
  258. pmem = FIELD_PREP(FMC2_PMEM_MEMSET, timings->tset_mem);
  259. pmem |= FIELD_PREP(FMC2_PMEM_MEMWAIT, timings->twait);
  260. pmem |= FIELD_PREP(FMC2_PMEM_MEMHOLD, timings->thold_mem);
  261. pmem |= FIELD_PREP(FMC2_PMEM_MEMHIZ, timings->thiz);
  262. regmap_write(nfc->regmap, FMC2_PMEM, pmem);
  263. /* Set tset/twait/thold/thiz timings in attribut bank */
  264. patt = FIELD_PREP(FMC2_PATT_ATTSET, timings->tset_att);
  265. patt |= FIELD_PREP(FMC2_PATT_ATTWAIT, timings->twait);
  266. patt |= FIELD_PREP(FMC2_PATT_ATTHOLD, timings->thold_att);
  267. patt |= FIELD_PREP(FMC2_PATT_ATTHIZ, timings->thiz);
  268. regmap_write(nfc->regmap, FMC2_PATT, patt);
  269. }
  270. static void stm32_fmc2_nfc_setup(struct nand_chip *chip)
  271. {
  272. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  273. u32 pcr = 0, pcr_mask;
  274. /* Configure ECC algorithm (default configuration is Hamming) */
  275. pcr_mask = FMC2_PCR_ECCALG;
  276. pcr_mask |= FMC2_PCR_BCHECC;
  277. if (chip->ecc.strength == FMC2_ECC_BCH8) {
  278. pcr |= FMC2_PCR_ECCALG;
  279. pcr |= FMC2_PCR_BCHECC;
  280. } else if (chip->ecc.strength == FMC2_ECC_BCH4) {
  281. pcr |= FMC2_PCR_ECCALG;
  282. }
  283. /* Set buswidth */
  284. pcr_mask |= FMC2_PCR_PWID;
  285. if (chip->options & NAND_BUSWIDTH_16)
  286. pcr |= FIELD_PREP(FMC2_PCR_PWID, FMC2_PCR_PWID_BUSWIDTH_16);
  287. /* Set ECC sector size */
  288. pcr_mask |= FMC2_PCR_ECCSS;
  289. pcr |= FIELD_PREP(FMC2_PCR_ECCSS, FMC2_PCR_ECCSS_512);
  290. regmap_update_bits(nfc->regmap, FMC2_PCR, pcr_mask, pcr);
  291. }
  292. static int stm32_fmc2_nfc_select_chip(struct nand_chip *chip, int chipnr)
  293. {
  294. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  295. struct stm32_fmc2_nand *nand = to_fmc2_nand(chip);
  296. struct dma_slave_config dma_cfg;
  297. int ret;
  298. if (nand->cs_used[chipnr] == nfc->cs_sel)
  299. return 0;
  300. nfc->cs_sel = nand->cs_used[chipnr];
  301. stm32_fmc2_nfc_setup(chip);
  302. stm32_fmc2_nfc_timings_init(chip);
  303. if (nfc->dma_tx_ch) {
  304. memset(&dma_cfg, 0, sizeof(dma_cfg));
  305. dma_cfg.dst_addr = nfc->data_phys_addr[nfc->cs_sel];
  306. dma_cfg.dst_addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES;
  307. dma_cfg.dst_maxburst = nfc->tx_dma_max_burst /
  308. dma_cfg.dst_addr_width;
  309. ret = dmaengine_slave_config(nfc->dma_tx_ch, &dma_cfg);
  310. if (ret) {
  311. dev_err(nfc->dev, "tx DMA engine slave config failed\n");
  312. return ret;
  313. }
  314. }
  315. if (nfc->dma_rx_ch) {
  316. memset(&dma_cfg, 0, sizeof(dma_cfg));
  317. dma_cfg.src_addr = nfc->data_phys_addr[nfc->cs_sel];
  318. dma_cfg.src_addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES;
  319. dma_cfg.src_maxburst = nfc->rx_dma_max_burst /
  320. dma_cfg.src_addr_width;
  321. ret = dmaengine_slave_config(nfc->dma_rx_ch, &dma_cfg);
  322. if (ret) {
  323. dev_err(nfc->dev, "rx DMA engine slave config failed\n");
  324. return ret;
  325. }
  326. }
  327. if (nfc->dma_ecc_ch) {
  328. /*
  329. * Hamming: we read HECCR register
  330. * BCH4/BCH8: we read BCHDSRSx registers
  331. */
  332. memset(&dma_cfg, 0, sizeof(dma_cfg));
  333. dma_cfg.src_addr = nfc->io_phys_addr;
  334. dma_cfg.src_addr += chip->ecc.strength == FMC2_ECC_HAM ?
  335. FMC2_HECCR : FMC2_BCHDSR0;
  336. dma_cfg.src_addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES;
  337. ret = dmaengine_slave_config(nfc->dma_ecc_ch, &dma_cfg);
  338. if (ret) {
  339. dev_err(nfc->dev, "ECC DMA engine slave config failed\n");
  340. return ret;
  341. }
  342. /* Calculate ECC length needed for one sector */
  343. nfc->dma_ecc_len = chip->ecc.strength == FMC2_ECC_HAM ?
  344. FMC2_HECCR_LEN : FMC2_BCHDSRS_LEN;
  345. }
  346. return 0;
  347. }
  348. static void stm32_fmc2_nfc_set_buswidth_16(struct stm32_fmc2_nfc *nfc, bool set)
  349. {
  350. u32 pcr;
  351. pcr = set ? FIELD_PREP(FMC2_PCR_PWID, FMC2_PCR_PWID_BUSWIDTH_16) :
  352. FIELD_PREP(FMC2_PCR_PWID, FMC2_PCR_PWID_BUSWIDTH_8);
  353. regmap_update_bits(nfc->regmap, FMC2_PCR, FMC2_PCR_PWID, pcr);
  354. }
  355. static void stm32_fmc2_nfc_set_ecc(struct stm32_fmc2_nfc *nfc, bool enable)
  356. {
  357. regmap_update_bits(nfc->regmap, FMC2_PCR, FMC2_PCR_ECCEN,
  358. enable ? FMC2_PCR_ECCEN : 0);
  359. }
  360. static void stm32_fmc2_nfc_enable_seq_irq(struct stm32_fmc2_nfc *nfc)
  361. {
  362. nfc->irq_state = FMC2_IRQ_SEQ;
  363. regmap_update_bits(nfc->regmap, FMC2_CSQIER,
  364. FMC2_CSQIER_TCIE, FMC2_CSQIER_TCIE);
  365. }
  366. static void stm32_fmc2_nfc_disable_seq_irq(struct stm32_fmc2_nfc *nfc)
  367. {
  368. regmap_update_bits(nfc->regmap, FMC2_CSQIER, FMC2_CSQIER_TCIE, 0);
  369. nfc->irq_state = FMC2_IRQ_UNKNOWN;
  370. }
  371. static void stm32_fmc2_nfc_clear_seq_irq(struct stm32_fmc2_nfc *nfc)
  372. {
  373. regmap_write(nfc->regmap, FMC2_CSQICR, FMC2_CSQICR_CLEAR_IRQ);
  374. }
  375. static void stm32_fmc2_nfc_enable_bch_irq(struct stm32_fmc2_nfc *nfc, int mode)
  376. {
  377. nfc->irq_state = FMC2_IRQ_BCH;
  378. if (mode == NAND_ECC_WRITE)
  379. regmap_update_bits(nfc->regmap, FMC2_BCHIER,
  380. FMC2_BCHIER_EPBRIE, FMC2_BCHIER_EPBRIE);
  381. else
  382. regmap_update_bits(nfc->regmap, FMC2_BCHIER,
  383. FMC2_BCHIER_DERIE, FMC2_BCHIER_DERIE);
  384. }
  385. static void stm32_fmc2_nfc_disable_bch_irq(struct stm32_fmc2_nfc *nfc)
  386. {
  387. regmap_update_bits(nfc->regmap, FMC2_BCHIER,
  388. FMC2_BCHIER_DERIE | FMC2_BCHIER_EPBRIE, 0);
  389. nfc->irq_state = FMC2_IRQ_UNKNOWN;
  390. }
  391. static void stm32_fmc2_nfc_clear_bch_irq(struct stm32_fmc2_nfc *nfc)
  392. {
  393. regmap_write(nfc->regmap, FMC2_BCHICR, FMC2_BCHICR_CLEAR_IRQ);
  394. }
  395. /*
  396. * Enable ECC logic and reset syndrome/parity bits previously calculated
  397. * Syndrome/parity bits is cleared by setting the ECCEN bit to 0
  398. */
  399. static void stm32_fmc2_nfc_hwctl(struct nand_chip *chip, int mode)
  400. {
  401. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  402. stm32_fmc2_nfc_set_ecc(nfc, false);
  403. if (chip->ecc.strength != FMC2_ECC_HAM) {
  404. regmap_update_bits(nfc->regmap, FMC2_PCR, FMC2_PCR_WEN,
  405. mode == NAND_ECC_WRITE ? FMC2_PCR_WEN : 0);
  406. reinit_completion(&nfc->complete);
  407. stm32_fmc2_nfc_clear_bch_irq(nfc);
  408. stm32_fmc2_nfc_enable_bch_irq(nfc, mode);
  409. }
  410. stm32_fmc2_nfc_set_ecc(nfc, true);
  411. }
  412. /*
  413. * ECC Hamming calculation
  414. * ECC is 3 bytes for 512 bytes of data (supports error correction up to
  415. * max of 1-bit)
  416. */
  417. static void stm32_fmc2_nfc_ham_set_ecc(const u32 ecc_sta, u8 *ecc)
  418. {
  419. ecc[0] = ecc_sta;
  420. ecc[1] = ecc_sta >> 8;
  421. ecc[2] = ecc_sta >> 16;
  422. }
  423. static int stm32_fmc2_nfc_ham_calculate(struct nand_chip *chip, const u8 *data,
  424. u8 *ecc)
  425. {
  426. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  427. u32 sr, heccr;
  428. int ret;
  429. ret = regmap_read_poll_timeout(nfc->regmap, FMC2_SR, sr,
  430. sr & FMC2_SR_NWRF, 1,
  431. 1000 * FMC2_TIMEOUT_MS);
  432. if (ret) {
  433. dev_err(nfc->dev, "ham timeout\n");
  434. return ret;
  435. }
  436. regmap_read(nfc->regmap, FMC2_HECCR, &heccr);
  437. stm32_fmc2_nfc_ham_set_ecc(heccr, ecc);
  438. stm32_fmc2_nfc_set_ecc(nfc, false);
  439. return 0;
  440. }
  441. static int stm32_fmc2_nfc_ham_correct(struct nand_chip *chip, u8 *dat,
  442. u8 *read_ecc, u8 *calc_ecc)
  443. {
  444. u8 bit_position = 0, b0, b1, b2;
  445. u32 byte_addr = 0, b;
  446. u32 i, shifting = 1;
  447. /* Indicate which bit and byte is faulty (if any) */
  448. b0 = read_ecc[0] ^ calc_ecc[0];
  449. b1 = read_ecc[1] ^ calc_ecc[1];
  450. b2 = read_ecc[2] ^ calc_ecc[2];
  451. b = b0 | (b1 << 8) | (b2 << 16);
  452. /* No errors */
  453. if (likely(!b))
  454. return 0;
  455. /* Calculate bit position */
  456. for (i = 0; i < 3; i++) {
  457. switch (b % 4) {
  458. case 2:
  459. bit_position += shifting;
  460. break;
  461. case 1:
  462. break;
  463. default:
  464. return -EBADMSG;
  465. }
  466. shifting <<= 1;
  467. b >>= 2;
  468. }
  469. /* Calculate byte position */
  470. shifting = 1;
  471. for (i = 0; i < 9; i++) {
  472. switch (b % 4) {
  473. case 2:
  474. byte_addr += shifting;
  475. break;
  476. case 1:
  477. break;
  478. default:
  479. return -EBADMSG;
  480. }
  481. shifting <<= 1;
  482. b >>= 2;
  483. }
  484. /* Flip the bit */
  485. dat[byte_addr] ^= (1 << bit_position);
  486. return 1;
  487. }
  488. /*
  489. * ECC BCH calculation and correction
  490. * ECC is 7/13 bytes for 512 bytes of data (supports error correction up to
  491. * max of 4-bit/8-bit)
  492. */
  493. static int stm32_fmc2_nfc_bch_calculate(struct nand_chip *chip, const u8 *data,
  494. u8 *ecc)
  495. {
  496. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  497. u32 bchpbr;
  498. /* Wait until the BCH code is ready */
  499. if (!wait_for_completion_timeout(&nfc->complete,
  500. msecs_to_jiffies(FMC2_TIMEOUT_MS))) {
  501. dev_err(nfc->dev, "bch timeout\n");
  502. stm32_fmc2_nfc_disable_bch_irq(nfc);
  503. return -ETIMEDOUT;
  504. }
  505. /* Read parity bits */
  506. regmap_read(nfc->regmap, FMC2_BCHPBR1, &bchpbr);
  507. ecc[0] = bchpbr;
  508. ecc[1] = bchpbr >> 8;
  509. ecc[2] = bchpbr >> 16;
  510. ecc[3] = bchpbr >> 24;
  511. regmap_read(nfc->regmap, FMC2_BCHPBR2, &bchpbr);
  512. ecc[4] = bchpbr;
  513. ecc[5] = bchpbr >> 8;
  514. ecc[6] = bchpbr >> 16;
  515. if (chip->ecc.strength == FMC2_ECC_BCH8) {
  516. ecc[7] = bchpbr >> 24;
  517. regmap_read(nfc->regmap, FMC2_BCHPBR3, &bchpbr);
  518. ecc[8] = bchpbr;
  519. ecc[9] = bchpbr >> 8;
  520. ecc[10] = bchpbr >> 16;
  521. ecc[11] = bchpbr >> 24;
  522. regmap_read(nfc->regmap, FMC2_BCHPBR4, &bchpbr);
  523. ecc[12] = bchpbr;
  524. }
  525. stm32_fmc2_nfc_set_ecc(nfc, false);
  526. return 0;
  527. }
  528. static int stm32_fmc2_nfc_bch_decode(int eccsize, u8 *dat, u32 *ecc_sta)
  529. {
  530. u32 bchdsr0 = ecc_sta[0];
  531. u32 bchdsr1 = ecc_sta[1];
  532. u32 bchdsr2 = ecc_sta[2];
  533. u32 bchdsr3 = ecc_sta[3];
  534. u32 bchdsr4 = ecc_sta[4];
  535. u16 pos[8];
  536. int i, den;
  537. unsigned int nb_errs = 0;
  538. /* No errors found */
  539. if (likely(!(bchdsr0 & FMC2_BCHDSR0_DEF)))
  540. return 0;
  541. /* Too many errors detected */
  542. if (unlikely(bchdsr0 & FMC2_BCHDSR0_DUE))
  543. return -EBADMSG;
  544. pos[0] = FIELD_GET(FMC2_BCHDSR1_EBP1, bchdsr1);
  545. pos[1] = FIELD_GET(FMC2_BCHDSR1_EBP2, bchdsr1);
  546. pos[2] = FIELD_GET(FMC2_BCHDSR2_EBP3, bchdsr2);
  547. pos[3] = FIELD_GET(FMC2_BCHDSR2_EBP4, bchdsr2);
  548. pos[4] = FIELD_GET(FMC2_BCHDSR3_EBP5, bchdsr3);
  549. pos[5] = FIELD_GET(FMC2_BCHDSR3_EBP6, bchdsr3);
  550. pos[6] = FIELD_GET(FMC2_BCHDSR4_EBP7, bchdsr4);
  551. pos[7] = FIELD_GET(FMC2_BCHDSR4_EBP8, bchdsr4);
  552. den = FIELD_GET(FMC2_BCHDSR0_DEN, bchdsr0);
  553. for (i = 0; i < den; i++) {
  554. if (pos[i] < eccsize * 8) {
  555. change_bit(pos[i], (unsigned long *)dat);
  556. nb_errs++;
  557. }
  558. }
  559. return nb_errs;
  560. }
  561. static int stm32_fmc2_nfc_bch_correct(struct nand_chip *chip, u8 *dat,
  562. u8 *read_ecc, u8 *calc_ecc)
  563. {
  564. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  565. u32 ecc_sta[5];
  566. /* Wait until the decoding error is ready */
  567. if (!wait_for_completion_timeout(&nfc->complete,
  568. msecs_to_jiffies(FMC2_TIMEOUT_MS))) {
  569. dev_err(nfc->dev, "bch timeout\n");
  570. stm32_fmc2_nfc_disable_bch_irq(nfc);
  571. return -ETIMEDOUT;
  572. }
  573. regmap_bulk_read(nfc->regmap, FMC2_BCHDSR0, ecc_sta, 5);
  574. stm32_fmc2_nfc_set_ecc(nfc, false);
  575. return stm32_fmc2_nfc_bch_decode(chip->ecc.size, dat, ecc_sta);
  576. }
  577. static int stm32_fmc2_nfc_read_page(struct nand_chip *chip, u8 *buf,
  578. int oob_required, int page)
  579. {
  580. struct mtd_info *mtd = nand_to_mtd(chip);
  581. int ret, i, s, stat, eccsize = chip->ecc.size;
  582. int eccbytes = chip->ecc.bytes;
  583. int eccsteps = chip->ecc.steps;
  584. int eccstrength = chip->ecc.strength;
  585. u8 *p = buf;
  586. u8 *ecc_calc = chip->ecc.calc_buf;
  587. u8 *ecc_code = chip->ecc.code_buf;
  588. unsigned int max_bitflips = 0;
  589. ret = nand_read_page_op(chip, page, 0, NULL, 0);
  590. if (ret)
  591. return ret;
  592. for (i = mtd->writesize + FMC2_BBM_LEN, s = 0; s < eccsteps;
  593. s++, i += eccbytes, p += eccsize) {
  594. chip->ecc.hwctl(chip, NAND_ECC_READ);
  595. /* Read the nand page sector (512 bytes) */
  596. ret = nand_change_read_column_op(chip, s * eccsize, p,
  597. eccsize, false);
  598. if (ret)
  599. return ret;
  600. /* Read the corresponding ECC bytes */
  601. ret = nand_change_read_column_op(chip, i, ecc_code,
  602. eccbytes, false);
  603. if (ret)
  604. return ret;
  605. /* Correct the data */
  606. stat = chip->ecc.correct(chip, p, ecc_code, ecc_calc);
  607. if (stat == -EBADMSG)
  608. /* Check for empty pages with bitflips */
  609. stat = nand_check_erased_ecc_chunk(p, eccsize,
  610. ecc_code, eccbytes,
  611. NULL, 0,
  612. eccstrength);
  613. if (stat < 0) {
  614. mtd->ecc_stats.failed++;
  615. } else {
  616. mtd->ecc_stats.corrected += stat;
  617. max_bitflips = max_t(unsigned int, max_bitflips, stat);
  618. }
  619. }
  620. /* Read oob */
  621. if (oob_required) {
  622. ret = nand_change_read_column_op(chip, mtd->writesize,
  623. chip->oob_poi, mtd->oobsize,
  624. false);
  625. if (ret)
  626. return ret;
  627. }
  628. return max_bitflips;
  629. }
  630. /* Sequencer read/write configuration */
  631. static void stm32_fmc2_nfc_rw_page_init(struct nand_chip *chip, int page,
  632. int raw, bool write_data)
  633. {
  634. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  635. struct mtd_info *mtd = nand_to_mtd(chip);
  636. u32 ecc_offset = mtd->writesize + FMC2_BBM_LEN;
  637. /*
  638. * cfg[0] => csqcfgr1, cfg[1] => csqcfgr2, cfg[2] => csqcfgr3
  639. * cfg[3] => csqar1, cfg[4] => csqar2
  640. */
  641. u32 cfg[5];
  642. regmap_update_bits(nfc->regmap, FMC2_PCR, FMC2_PCR_WEN,
  643. write_data ? FMC2_PCR_WEN : 0);
  644. /*
  645. * - Set Program Page/Page Read command
  646. * - Enable DMA request data
  647. * - Set timings
  648. */
  649. cfg[0] = FMC2_CSQCFGR1_DMADEN | FMC2_CSQCFGR1_CMD1T;
  650. if (write_data)
  651. cfg[0] |= FIELD_PREP(FMC2_CSQCFGR1_CMD1, NAND_CMD_SEQIN);
  652. else
  653. cfg[0] |= FIELD_PREP(FMC2_CSQCFGR1_CMD1, NAND_CMD_READ0) |
  654. FMC2_CSQCFGR1_CMD2EN |
  655. FIELD_PREP(FMC2_CSQCFGR1_CMD2, NAND_CMD_READSTART) |
  656. FMC2_CSQCFGR1_CMD2T;
  657. /*
  658. * - Set Random Data Input/Random Data Read command
  659. * - Enable the sequencer to access the Spare data area
  660. * - Enable DMA request status decoding for read
  661. * - Set timings
  662. */
  663. if (write_data)
  664. cfg[1] = FIELD_PREP(FMC2_CSQCFGR2_RCMD1, NAND_CMD_RNDIN);
  665. else
  666. cfg[1] = FIELD_PREP(FMC2_CSQCFGR2_RCMD1, NAND_CMD_RNDOUT) |
  667. FMC2_CSQCFGR2_RCMD2EN |
  668. FIELD_PREP(FMC2_CSQCFGR2_RCMD2, NAND_CMD_RNDOUTSTART) |
  669. FMC2_CSQCFGR2_RCMD1T |
  670. FMC2_CSQCFGR2_RCMD2T;
  671. if (!raw) {
  672. cfg[1] |= write_data ? 0 : FMC2_CSQCFGR2_DMASEN;
  673. cfg[1] |= FMC2_CSQCFGR2_SQSDTEN;
  674. }
  675. /*
  676. * - Set the number of sectors to be written
  677. * - Set timings
  678. */
  679. cfg[2] = FIELD_PREP(FMC2_CSQCFGR3_SNBR, chip->ecc.steps - 1);
  680. if (write_data) {
  681. cfg[2] |= FMC2_CSQCFGR3_RAC2T;
  682. if (chip->options & NAND_ROW_ADDR_3)
  683. cfg[2] |= FMC2_CSQCFGR3_AC5T;
  684. else
  685. cfg[2] |= FMC2_CSQCFGR3_AC4T;
  686. }
  687. /*
  688. * Set the fourth first address cycles
  689. * Byte 1 and byte 2 => column, we start at 0x0
  690. * Byte 3 and byte 4 => page
  691. */
  692. cfg[3] = FIELD_PREP(FMC2_CSQCAR1_ADDC3, page);
  693. cfg[3] |= FIELD_PREP(FMC2_CSQCAR1_ADDC4, page >> 8);
  694. /*
  695. * - Set chip enable number
  696. * - Set ECC byte offset in the spare area
  697. * - Calculate the number of address cycles to be issued
  698. * - Set byte 5 of address cycle if needed
  699. */
  700. cfg[4] = FIELD_PREP(FMC2_CSQCAR2_NANDCEN, nfc->cs_sel);
  701. if (chip->options & NAND_BUSWIDTH_16)
  702. cfg[4] |= FIELD_PREP(FMC2_CSQCAR2_SAO, ecc_offset >> 1);
  703. else
  704. cfg[4] |= FIELD_PREP(FMC2_CSQCAR2_SAO, ecc_offset);
  705. if (chip->options & NAND_ROW_ADDR_3) {
  706. cfg[0] |= FIELD_PREP(FMC2_CSQCFGR1_ACYNBR, 5);
  707. cfg[4] |= FIELD_PREP(FMC2_CSQCAR2_ADDC5, page >> 16);
  708. } else {
  709. cfg[0] |= FIELD_PREP(FMC2_CSQCFGR1_ACYNBR, 4);
  710. }
  711. regmap_bulk_write(nfc->regmap, FMC2_CSQCFGR1, cfg, 5);
  712. }
  713. static void stm32_fmc2_nfc_dma_callback(void *arg)
  714. {
  715. complete((struct completion *)arg);
  716. }
  717. /* Read/write data from/to a page */
  718. static int stm32_fmc2_nfc_xfer(struct nand_chip *chip, const u8 *buf,
  719. int raw, bool write_data)
  720. {
  721. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  722. struct dma_async_tx_descriptor *desc_data, *desc_ecc;
  723. struct scatterlist *sg;
  724. struct dma_chan *dma_ch = nfc->dma_rx_ch;
  725. enum dma_data_direction dma_data_dir = DMA_FROM_DEVICE;
  726. enum dma_transfer_direction dma_transfer_dir = DMA_DEV_TO_MEM;
  727. int eccsteps = chip->ecc.steps;
  728. int eccsize = chip->ecc.size;
  729. unsigned long timeout = msecs_to_jiffies(FMC2_TIMEOUT_MS);
  730. const u8 *p = buf;
  731. int s, ret;
  732. /* Configure DMA data */
  733. if (write_data) {
  734. dma_data_dir = DMA_TO_DEVICE;
  735. dma_transfer_dir = DMA_MEM_TO_DEV;
  736. dma_ch = nfc->dma_tx_ch;
  737. }
  738. for_each_sg(nfc->dma_data_sg.sgl, sg, eccsteps, s) {
  739. sg_set_buf(sg, p, eccsize);
  740. p += eccsize;
  741. }
  742. ret = dma_map_sg(nfc->dev, nfc->dma_data_sg.sgl,
  743. eccsteps, dma_data_dir);
  744. if (!ret)
  745. return -EIO;
  746. desc_data = dmaengine_prep_slave_sg(dma_ch, nfc->dma_data_sg.sgl,
  747. eccsteps, dma_transfer_dir,
  748. DMA_PREP_INTERRUPT);
  749. if (!desc_data) {
  750. ret = -ENOMEM;
  751. goto err_unmap_data;
  752. }
  753. reinit_completion(&nfc->dma_data_complete);
  754. reinit_completion(&nfc->complete);
  755. desc_data->callback = stm32_fmc2_nfc_dma_callback;
  756. desc_data->callback_param = &nfc->dma_data_complete;
  757. ret = dma_submit_error(dmaengine_submit(desc_data));
  758. if (ret)
  759. goto err_unmap_data;
  760. dma_async_issue_pending(dma_ch);
  761. if (!write_data && !raw) {
  762. /* Configure DMA ECC status */
  763. for_each_sg(nfc->dma_ecc_sg.sgl, sg, eccsteps, s) {
  764. sg_dma_address(sg) = nfc->dma_ecc_addr +
  765. s * nfc->dma_ecc_len;
  766. sg_dma_len(sg) = nfc->dma_ecc_len;
  767. }
  768. desc_ecc = dmaengine_prep_slave_sg(nfc->dma_ecc_ch,
  769. nfc->dma_ecc_sg.sgl,
  770. eccsteps, dma_transfer_dir,
  771. DMA_PREP_INTERRUPT);
  772. if (!desc_ecc) {
  773. ret = -ENOMEM;
  774. goto err_unmap_data;
  775. }
  776. reinit_completion(&nfc->dma_ecc_complete);
  777. desc_ecc->callback = stm32_fmc2_nfc_dma_callback;
  778. desc_ecc->callback_param = &nfc->dma_ecc_complete;
  779. ret = dma_submit_error(dmaengine_submit(desc_ecc));
  780. if (ret)
  781. goto err_unmap_data;
  782. dma_async_issue_pending(nfc->dma_ecc_ch);
  783. }
  784. stm32_fmc2_nfc_clear_seq_irq(nfc);
  785. stm32_fmc2_nfc_enable_seq_irq(nfc);
  786. /* Start the transfer */
  787. regmap_update_bits(nfc->regmap, FMC2_CSQCR,
  788. FMC2_CSQCR_CSQSTART, FMC2_CSQCR_CSQSTART);
  789. /* Wait end of sequencer transfer */
  790. if (!wait_for_completion_timeout(&nfc->complete, timeout)) {
  791. dev_err(nfc->dev, "seq timeout\n");
  792. stm32_fmc2_nfc_disable_seq_irq(nfc);
  793. dmaengine_terminate_all(dma_ch);
  794. if (!write_data && !raw)
  795. dmaengine_terminate_all(nfc->dma_ecc_ch);
  796. ret = -ETIMEDOUT;
  797. goto err_unmap_data;
  798. }
  799. /* Wait DMA data transfer completion */
  800. if (!wait_for_completion_timeout(&nfc->dma_data_complete, timeout)) {
  801. dev_err(nfc->dev, "data DMA timeout\n");
  802. dmaengine_terminate_all(dma_ch);
  803. ret = -ETIMEDOUT;
  804. }
  805. /* Wait DMA ECC transfer completion */
  806. if (!write_data && !raw) {
  807. if (!wait_for_completion_timeout(&nfc->dma_ecc_complete,
  808. timeout)) {
  809. dev_err(nfc->dev, "ECC DMA timeout\n");
  810. dmaengine_terminate_all(nfc->dma_ecc_ch);
  811. ret = -ETIMEDOUT;
  812. }
  813. }
  814. err_unmap_data:
  815. dma_unmap_sg(nfc->dev, nfc->dma_data_sg.sgl, eccsteps, dma_data_dir);
  816. return ret;
  817. }
  818. static int stm32_fmc2_nfc_seq_write(struct nand_chip *chip, const u8 *buf,
  819. int oob_required, int page, int raw)
  820. {
  821. struct mtd_info *mtd = nand_to_mtd(chip);
  822. int ret;
  823. /* Configure the sequencer */
  824. stm32_fmc2_nfc_rw_page_init(chip, page, raw, true);
  825. /* Write the page */
  826. ret = stm32_fmc2_nfc_xfer(chip, buf, raw, true);
  827. if (ret)
  828. return ret;
  829. /* Write oob */
  830. if (oob_required) {
  831. unsigned int offset_in_page = mtd->writesize;
  832. const void *buf = chip->oob_poi;
  833. unsigned int len = mtd->oobsize;
  834. if (!raw) {
  835. struct mtd_oob_region oob_free;
  836. mtd_ooblayout_free(mtd, 0, &oob_free);
  837. offset_in_page += oob_free.offset;
  838. buf += oob_free.offset;
  839. len = oob_free.length;
  840. }
  841. ret = nand_change_write_column_op(chip, offset_in_page,
  842. buf, len, false);
  843. if (ret)
  844. return ret;
  845. }
  846. return nand_prog_page_end_op(chip);
  847. }
  848. static int stm32_fmc2_nfc_seq_write_page(struct nand_chip *chip, const u8 *buf,
  849. int oob_required, int page)
  850. {
  851. int ret;
  852. ret = stm32_fmc2_nfc_select_chip(chip, chip->cur_cs);
  853. if (ret)
  854. return ret;
  855. return stm32_fmc2_nfc_seq_write(chip, buf, oob_required, page, false);
  856. }
  857. static int stm32_fmc2_nfc_seq_write_page_raw(struct nand_chip *chip,
  858. const u8 *buf, int oob_required,
  859. int page)
  860. {
  861. int ret;
  862. ret = stm32_fmc2_nfc_select_chip(chip, chip->cur_cs);
  863. if (ret)
  864. return ret;
  865. return stm32_fmc2_nfc_seq_write(chip, buf, oob_required, page, true);
  866. }
  867. /* Get a status indicating which sectors have errors */
  868. static u16 stm32_fmc2_nfc_get_mapping_status(struct stm32_fmc2_nfc *nfc)
  869. {
  870. u32 csqemsr;
  871. regmap_read(nfc->regmap, FMC2_CSQEMSR, &csqemsr);
  872. return FIELD_GET(FMC2_CSQEMSR_SEM, csqemsr);
  873. }
  874. static int stm32_fmc2_nfc_seq_correct(struct nand_chip *chip, u8 *dat,
  875. u8 *read_ecc, u8 *calc_ecc)
  876. {
  877. struct mtd_info *mtd = nand_to_mtd(chip);
  878. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  879. int eccbytes = chip->ecc.bytes;
  880. int eccsteps = chip->ecc.steps;
  881. int eccstrength = chip->ecc.strength;
  882. int i, s, eccsize = chip->ecc.size;
  883. u32 *ecc_sta = (u32 *)nfc->ecc_buf;
  884. u16 sta_map = stm32_fmc2_nfc_get_mapping_status(nfc);
  885. unsigned int max_bitflips = 0;
  886. for (i = 0, s = 0; s < eccsteps; s++, i += eccbytes, dat += eccsize) {
  887. int stat = 0;
  888. if (eccstrength == FMC2_ECC_HAM) {
  889. /* Ecc_sta = FMC2_HECCR */
  890. if (sta_map & BIT(s)) {
  891. stm32_fmc2_nfc_ham_set_ecc(*ecc_sta,
  892. &calc_ecc[i]);
  893. stat = stm32_fmc2_nfc_ham_correct(chip, dat,
  894. &read_ecc[i],
  895. &calc_ecc[i]);
  896. }
  897. ecc_sta++;
  898. } else {
  899. /*
  900. * Ecc_sta[0] = FMC2_BCHDSR0
  901. * Ecc_sta[1] = FMC2_BCHDSR1
  902. * Ecc_sta[2] = FMC2_BCHDSR2
  903. * Ecc_sta[3] = FMC2_BCHDSR3
  904. * Ecc_sta[4] = FMC2_BCHDSR4
  905. */
  906. if (sta_map & BIT(s))
  907. stat = stm32_fmc2_nfc_bch_decode(eccsize, dat,
  908. ecc_sta);
  909. ecc_sta += 5;
  910. }
  911. if (stat == -EBADMSG)
  912. /* Check for empty pages with bitflips */
  913. stat = nand_check_erased_ecc_chunk(dat, eccsize,
  914. &read_ecc[i],
  915. eccbytes,
  916. NULL, 0,
  917. eccstrength);
  918. if (stat < 0) {
  919. mtd->ecc_stats.failed++;
  920. } else {
  921. mtd->ecc_stats.corrected += stat;
  922. max_bitflips = max_t(unsigned int, max_bitflips, stat);
  923. }
  924. }
  925. return max_bitflips;
  926. }
  927. static int stm32_fmc2_nfc_seq_read_page(struct nand_chip *chip, u8 *buf,
  928. int oob_required, int page)
  929. {
  930. struct mtd_info *mtd = nand_to_mtd(chip);
  931. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  932. u8 *ecc_calc = chip->ecc.calc_buf;
  933. u8 *ecc_code = chip->ecc.code_buf;
  934. u16 sta_map;
  935. int ret;
  936. ret = stm32_fmc2_nfc_select_chip(chip, chip->cur_cs);
  937. if (ret)
  938. return ret;
  939. /* Configure the sequencer */
  940. stm32_fmc2_nfc_rw_page_init(chip, page, 0, false);
  941. /* Read the page */
  942. ret = stm32_fmc2_nfc_xfer(chip, buf, 0, false);
  943. if (ret)
  944. return ret;
  945. sta_map = stm32_fmc2_nfc_get_mapping_status(nfc);
  946. /* Check if errors happen */
  947. if (likely(!sta_map)) {
  948. if (oob_required)
  949. return nand_change_read_column_op(chip, mtd->writesize,
  950. chip->oob_poi,
  951. mtd->oobsize, false);
  952. return 0;
  953. }
  954. /* Read oob */
  955. ret = nand_change_read_column_op(chip, mtd->writesize,
  956. chip->oob_poi, mtd->oobsize, false);
  957. if (ret)
  958. return ret;
  959. ret = mtd_ooblayout_get_eccbytes(mtd, ecc_code, chip->oob_poi, 0,
  960. chip->ecc.total);
  961. if (ret)
  962. return ret;
  963. /* Correct data */
  964. return chip->ecc.correct(chip, buf, ecc_code, ecc_calc);
  965. }
  966. static int stm32_fmc2_nfc_seq_read_page_raw(struct nand_chip *chip, u8 *buf,
  967. int oob_required, int page)
  968. {
  969. struct mtd_info *mtd = nand_to_mtd(chip);
  970. int ret;
  971. ret = stm32_fmc2_nfc_select_chip(chip, chip->cur_cs);
  972. if (ret)
  973. return ret;
  974. /* Configure the sequencer */
  975. stm32_fmc2_nfc_rw_page_init(chip, page, 1, false);
  976. /* Read the page */
  977. ret = stm32_fmc2_nfc_xfer(chip, buf, 1, false);
  978. if (ret)
  979. return ret;
  980. /* Read oob */
  981. if (oob_required)
  982. return nand_change_read_column_op(chip, mtd->writesize,
  983. chip->oob_poi, mtd->oobsize,
  984. false);
  985. return 0;
  986. }
  987. static irqreturn_t stm32_fmc2_nfc_irq(int irq, void *dev_id)
  988. {
  989. struct stm32_fmc2_nfc *nfc = (struct stm32_fmc2_nfc *)dev_id;
  990. if (nfc->irq_state == FMC2_IRQ_SEQ)
  991. /* Sequencer is used */
  992. stm32_fmc2_nfc_disable_seq_irq(nfc);
  993. else if (nfc->irq_state == FMC2_IRQ_BCH)
  994. /* BCH is used */
  995. stm32_fmc2_nfc_disable_bch_irq(nfc);
  996. complete(&nfc->complete);
  997. return IRQ_HANDLED;
  998. }
  999. static void stm32_fmc2_nfc_read_data(struct nand_chip *chip, void *buf,
  1000. unsigned int len, bool force_8bit)
  1001. {
  1002. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  1003. void __iomem *io_addr_r = nfc->data_base[nfc->cs_sel];
  1004. if (force_8bit && chip->options & NAND_BUSWIDTH_16)
  1005. /* Reconfigure bus width to 8-bit */
  1006. stm32_fmc2_nfc_set_buswidth_16(nfc, false);
  1007. if (!IS_ALIGNED((uintptr_t)buf, sizeof(u32))) {
  1008. if (!IS_ALIGNED((uintptr_t)buf, sizeof(u16)) && len) {
  1009. *(u8 *)buf = readb_relaxed(io_addr_r);
  1010. buf += sizeof(u8);
  1011. len -= sizeof(u8);
  1012. }
  1013. if (!IS_ALIGNED((uintptr_t)buf, sizeof(u32)) &&
  1014. len >= sizeof(u16)) {
  1015. *(u16 *)buf = readw_relaxed(io_addr_r);
  1016. buf += sizeof(u16);
  1017. len -= sizeof(u16);
  1018. }
  1019. }
  1020. /* Buf is aligned */
  1021. while (len >= sizeof(u32)) {
  1022. *(u32 *)buf = readl_relaxed(io_addr_r);
  1023. buf += sizeof(u32);
  1024. len -= sizeof(u32);
  1025. }
  1026. /* Read remaining bytes */
  1027. if (len >= sizeof(u16)) {
  1028. *(u16 *)buf = readw_relaxed(io_addr_r);
  1029. buf += sizeof(u16);
  1030. len -= sizeof(u16);
  1031. }
  1032. if (len)
  1033. *(u8 *)buf = readb_relaxed(io_addr_r);
  1034. if (force_8bit && chip->options & NAND_BUSWIDTH_16)
  1035. /* Reconfigure bus width to 16-bit */
  1036. stm32_fmc2_nfc_set_buswidth_16(nfc, true);
  1037. }
  1038. static void stm32_fmc2_nfc_write_data(struct nand_chip *chip, const void *buf,
  1039. unsigned int len, bool force_8bit)
  1040. {
  1041. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  1042. void __iomem *io_addr_w = nfc->data_base[nfc->cs_sel];
  1043. if (force_8bit && chip->options & NAND_BUSWIDTH_16)
  1044. /* Reconfigure bus width to 8-bit */
  1045. stm32_fmc2_nfc_set_buswidth_16(nfc, false);
  1046. if (!IS_ALIGNED((uintptr_t)buf, sizeof(u32))) {
  1047. if (!IS_ALIGNED((uintptr_t)buf, sizeof(u16)) && len) {
  1048. writeb_relaxed(*(u8 *)buf, io_addr_w);
  1049. buf += sizeof(u8);
  1050. len -= sizeof(u8);
  1051. }
  1052. if (!IS_ALIGNED((uintptr_t)buf, sizeof(u32)) &&
  1053. len >= sizeof(u16)) {
  1054. writew_relaxed(*(u16 *)buf, io_addr_w);
  1055. buf += sizeof(u16);
  1056. len -= sizeof(u16);
  1057. }
  1058. }
  1059. /* Buf is aligned */
  1060. while (len >= sizeof(u32)) {
  1061. writel_relaxed(*(u32 *)buf, io_addr_w);
  1062. buf += sizeof(u32);
  1063. len -= sizeof(u32);
  1064. }
  1065. /* Write remaining bytes */
  1066. if (len >= sizeof(u16)) {
  1067. writew_relaxed(*(u16 *)buf, io_addr_w);
  1068. buf += sizeof(u16);
  1069. len -= sizeof(u16);
  1070. }
  1071. if (len)
  1072. writeb_relaxed(*(u8 *)buf, io_addr_w);
  1073. if (force_8bit && chip->options & NAND_BUSWIDTH_16)
  1074. /* Reconfigure bus width to 16-bit */
  1075. stm32_fmc2_nfc_set_buswidth_16(nfc, true);
  1076. }
  1077. static int stm32_fmc2_nfc_waitrdy(struct nand_chip *chip,
  1078. unsigned long timeout_ms)
  1079. {
  1080. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  1081. const struct nand_sdr_timings *timings;
  1082. u32 isr, sr;
  1083. /* Check if there is no pending requests to the NAND flash */
  1084. if (regmap_read_poll_timeout(nfc->regmap, FMC2_SR, sr,
  1085. sr & FMC2_SR_NWRF, 1,
  1086. 1000 * FMC2_TIMEOUT_MS))
  1087. dev_warn(nfc->dev, "Waitrdy timeout\n");
  1088. /* Wait tWB before R/B# signal is low */
  1089. timings = nand_get_sdr_timings(nand_get_interface_config(chip));
  1090. ndelay(PSEC_TO_NSEC(timings->tWB_max));
  1091. /* R/B# signal is low, clear high level flag */
  1092. regmap_write(nfc->regmap, FMC2_ICR, FMC2_ICR_CIHLF);
  1093. /* Wait R/B# signal is high */
  1094. return regmap_read_poll_timeout(nfc->regmap, FMC2_ISR, isr,
  1095. isr & FMC2_ISR_IHLF, 5,
  1096. 1000 * FMC2_TIMEOUT_MS);
  1097. }
  1098. static int stm32_fmc2_nfc_exec_op(struct nand_chip *chip,
  1099. const struct nand_operation *op,
  1100. bool check_only)
  1101. {
  1102. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  1103. const struct nand_op_instr *instr = NULL;
  1104. unsigned int op_id, i, timeout;
  1105. int ret;
  1106. if (check_only)
  1107. return 0;
  1108. ret = stm32_fmc2_nfc_select_chip(chip, op->cs);
  1109. if (ret)
  1110. return ret;
  1111. for (op_id = 0; op_id < op->ninstrs; op_id++) {
  1112. instr = &op->instrs[op_id];
  1113. switch (instr->type) {
  1114. case NAND_OP_CMD_INSTR:
  1115. writeb_relaxed(instr->ctx.cmd.opcode,
  1116. nfc->cmd_base[nfc->cs_sel]);
  1117. break;
  1118. case NAND_OP_ADDR_INSTR:
  1119. for (i = 0; i < instr->ctx.addr.naddrs; i++)
  1120. writeb_relaxed(instr->ctx.addr.addrs[i],
  1121. nfc->addr_base[nfc->cs_sel]);
  1122. break;
  1123. case NAND_OP_DATA_IN_INSTR:
  1124. stm32_fmc2_nfc_read_data(chip, instr->ctx.data.buf.in,
  1125. instr->ctx.data.len,
  1126. instr->ctx.data.force_8bit);
  1127. break;
  1128. case NAND_OP_DATA_OUT_INSTR:
  1129. stm32_fmc2_nfc_write_data(chip, instr->ctx.data.buf.out,
  1130. instr->ctx.data.len,
  1131. instr->ctx.data.force_8bit);
  1132. break;
  1133. case NAND_OP_WAITRDY_INSTR:
  1134. timeout = instr->ctx.waitrdy.timeout_ms;
  1135. ret = stm32_fmc2_nfc_waitrdy(chip, timeout);
  1136. break;
  1137. }
  1138. }
  1139. return ret;
  1140. }
  1141. static void stm32_fmc2_nfc_init(struct stm32_fmc2_nfc *nfc)
  1142. {
  1143. u32 pcr;
  1144. regmap_read(nfc->regmap, FMC2_PCR, &pcr);
  1145. /* Set CS used to undefined */
  1146. nfc->cs_sel = -1;
  1147. /* Enable wait feature and nand flash memory bank */
  1148. pcr |= FMC2_PCR_PWAITEN;
  1149. pcr |= FMC2_PCR_PBKEN;
  1150. /* Set buswidth to 8 bits mode for identification */
  1151. pcr &= ~FMC2_PCR_PWID;
  1152. /* ECC logic is disabled */
  1153. pcr &= ~FMC2_PCR_ECCEN;
  1154. /* Default mode */
  1155. pcr &= ~FMC2_PCR_ECCALG;
  1156. pcr &= ~FMC2_PCR_BCHECC;
  1157. pcr &= ~FMC2_PCR_WEN;
  1158. /* Set default ECC sector size */
  1159. pcr &= ~FMC2_PCR_ECCSS;
  1160. pcr |= FIELD_PREP(FMC2_PCR_ECCSS, FMC2_PCR_ECCSS_2048);
  1161. /* Set default tclr/tar timings */
  1162. pcr &= ~FMC2_PCR_TCLR;
  1163. pcr |= FIELD_PREP(FMC2_PCR_TCLR, FMC2_PCR_TCLR_DEFAULT);
  1164. pcr &= ~FMC2_PCR_TAR;
  1165. pcr |= FIELD_PREP(FMC2_PCR_TAR, FMC2_PCR_TAR_DEFAULT);
  1166. /* Enable FMC2 controller */
  1167. if (nfc->dev == nfc->cdev)
  1168. regmap_update_bits(nfc->regmap, FMC2_BCR1,
  1169. FMC2_BCR1_FMC2EN, FMC2_BCR1_FMC2EN);
  1170. regmap_write(nfc->regmap, FMC2_PCR, pcr);
  1171. regmap_write(nfc->regmap, FMC2_PMEM, FMC2_PMEM_DEFAULT);
  1172. regmap_write(nfc->regmap, FMC2_PATT, FMC2_PATT_DEFAULT);
  1173. }
  1174. static void stm32_fmc2_nfc_calc_timings(struct nand_chip *chip,
  1175. const struct nand_sdr_timings *sdrt)
  1176. {
  1177. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  1178. struct stm32_fmc2_nand *nand = to_fmc2_nand(chip);
  1179. struct stm32_fmc2_timings *tims = &nand->timings;
  1180. unsigned long hclk = clk_get_rate(nfc->clk);
  1181. unsigned long hclkp = NSEC_PER_SEC / (hclk / 1000);
  1182. unsigned long timing, tar, tclr, thiz, twait;
  1183. unsigned long tset_mem, tset_att, thold_mem, thold_att;
  1184. tar = max_t(unsigned long, hclkp, sdrt->tAR_min);
  1185. timing = DIV_ROUND_UP(tar, hclkp) - 1;
  1186. tims->tar = min_t(unsigned long, timing, FMC2_PCR_TIMING_MASK);
  1187. tclr = max_t(unsigned long, hclkp, sdrt->tCLR_min);
  1188. timing = DIV_ROUND_UP(tclr, hclkp) - 1;
  1189. tims->tclr = min_t(unsigned long, timing, FMC2_PCR_TIMING_MASK);
  1190. tims->thiz = FMC2_THIZ;
  1191. thiz = (tims->thiz + 1) * hclkp;
  1192. /*
  1193. * tWAIT > tRP
  1194. * tWAIT > tWP
  1195. * tWAIT > tREA + tIO
  1196. */
  1197. twait = max_t(unsigned long, hclkp, sdrt->tRP_min);
  1198. twait = max_t(unsigned long, twait, sdrt->tWP_min);
  1199. twait = max_t(unsigned long, twait, sdrt->tREA_max + FMC2_TIO);
  1200. timing = DIV_ROUND_UP(twait, hclkp);
  1201. tims->twait = clamp_val(timing, 1, FMC2_PMEM_PATT_TIMING_MASK);
  1202. /*
  1203. * tSETUP_MEM > tCS - tWAIT
  1204. * tSETUP_MEM > tALS - tWAIT
  1205. * tSETUP_MEM > tDS - (tWAIT - tHIZ)
  1206. */
  1207. tset_mem = hclkp;
  1208. if (sdrt->tCS_min > twait && (tset_mem < sdrt->tCS_min - twait))
  1209. tset_mem = sdrt->tCS_min - twait;
  1210. if (sdrt->tALS_min > twait && (tset_mem < sdrt->tALS_min - twait))
  1211. tset_mem = sdrt->tALS_min - twait;
  1212. if (twait > thiz && (sdrt->tDS_min > twait - thiz) &&
  1213. (tset_mem < sdrt->tDS_min - (twait - thiz)))
  1214. tset_mem = sdrt->tDS_min - (twait - thiz);
  1215. timing = DIV_ROUND_UP(tset_mem, hclkp);
  1216. tims->tset_mem = clamp_val(timing, 1, FMC2_PMEM_PATT_TIMING_MASK);
  1217. /*
  1218. * tHOLD_MEM > tCH
  1219. * tHOLD_MEM > tREH - tSETUP_MEM
  1220. * tHOLD_MEM > max(tRC, tWC) - (tSETUP_MEM + tWAIT)
  1221. */
  1222. thold_mem = max_t(unsigned long, hclkp, sdrt->tCH_min);
  1223. if (sdrt->tREH_min > tset_mem &&
  1224. (thold_mem < sdrt->tREH_min - tset_mem))
  1225. thold_mem = sdrt->tREH_min - tset_mem;
  1226. if ((sdrt->tRC_min > tset_mem + twait) &&
  1227. (thold_mem < sdrt->tRC_min - (tset_mem + twait)))
  1228. thold_mem = sdrt->tRC_min - (tset_mem + twait);
  1229. if ((sdrt->tWC_min > tset_mem + twait) &&
  1230. (thold_mem < sdrt->tWC_min - (tset_mem + twait)))
  1231. thold_mem = sdrt->tWC_min - (tset_mem + twait);
  1232. timing = DIV_ROUND_UP(thold_mem, hclkp);
  1233. tims->thold_mem = clamp_val(timing, 1, FMC2_PMEM_PATT_TIMING_MASK);
  1234. /*
  1235. * tSETUP_ATT > tCS - tWAIT
  1236. * tSETUP_ATT > tCLS - tWAIT
  1237. * tSETUP_ATT > tALS - tWAIT
  1238. * tSETUP_ATT > tRHW - tHOLD_MEM
  1239. * tSETUP_ATT > tDS - (tWAIT - tHIZ)
  1240. */
  1241. tset_att = hclkp;
  1242. if (sdrt->tCS_min > twait && (tset_att < sdrt->tCS_min - twait))
  1243. tset_att = sdrt->tCS_min - twait;
  1244. if (sdrt->tCLS_min > twait && (tset_att < sdrt->tCLS_min - twait))
  1245. tset_att = sdrt->tCLS_min - twait;
  1246. if (sdrt->tALS_min > twait && (tset_att < sdrt->tALS_min - twait))
  1247. tset_att = sdrt->tALS_min - twait;
  1248. if (sdrt->tRHW_min > thold_mem &&
  1249. (tset_att < sdrt->tRHW_min - thold_mem))
  1250. tset_att = sdrt->tRHW_min - thold_mem;
  1251. if (twait > thiz && (sdrt->tDS_min > twait - thiz) &&
  1252. (tset_att < sdrt->tDS_min - (twait - thiz)))
  1253. tset_att = sdrt->tDS_min - (twait - thiz);
  1254. timing = DIV_ROUND_UP(tset_att, hclkp);
  1255. tims->tset_att = clamp_val(timing, 1, FMC2_PMEM_PATT_TIMING_MASK);
  1256. /*
  1257. * tHOLD_ATT > tALH
  1258. * tHOLD_ATT > tCH
  1259. * tHOLD_ATT > tCLH
  1260. * tHOLD_ATT > tCOH
  1261. * tHOLD_ATT > tDH
  1262. * tHOLD_ATT > tWB + tIO + tSYNC - tSETUP_MEM
  1263. * tHOLD_ATT > tADL - tSETUP_MEM
  1264. * tHOLD_ATT > tWH - tSETUP_MEM
  1265. * tHOLD_ATT > tWHR - tSETUP_MEM
  1266. * tHOLD_ATT > tRC - (tSETUP_ATT + tWAIT)
  1267. * tHOLD_ATT > tWC - (tSETUP_ATT + tWAIT)
  1268. */
  1269. thold_att = max_t(unsigned long, hclkp, sdrt->tALH_min);
  1270. thold_att = max_t(unsigned long, thold_att, sdrt->tCH_min);
  1271. thold_att = max_t(unsigned long, thold_att, sdrt->tCLH_min);
  1272. thold_att = max_t(unsigned long, thold_att, sdrt->tCOH_min);
  1273. thold_att = max_t(unsigned long, thold_att, sdrt->tDH_min);
  1274. if ((sdrt->tWB_max + FMC2_TIO + FMC2_TSYNC > tset_mem) &&
  1275. (thold_att < sdrt->tWB_max + FMC2_TIO + FMC2_TSYNC - tset_mem))
  1276. thold_att = sdrt->tWB_max + FMC2_TIO + FMC2_TSYNC - tset_mem;
  1277. if (sdrt->tADL_min > tset_mem &&
  1278. (thold_att < sdrt->tADL_min - tset_mem))
  1279. thold_att = sdrt->tADL_min - tset_mem;
  1280. if (sdrt->tWH_min > tset_mem &&
  1281. (thold_att < sdrt->tWH_min - tset_mem))
  1282. thold_att = sdrt->tWH_min - tset_mem;
  1283. if (sdrt->tWHR_min > tset_mem &&
  1284. (thold_att < sdrt->tWHR_min - tset_mem))
  1285. thold_att = sdrt->tWHR_min - tset_mem;
  1286. if ((sdrt->tRC_min > tset_att + twait) &&
  1287. (thold_att < sdrt->tRC_min - (tset_att + twait)))
  1288. thold_att = sdrt->tRC_min - (tset_att + twait);
  1289. if ((sdrt->tWC_min > tset_att + twait) &&
  1290. (thold_att < sdrt->tWC_min - (tset_att + twait)))
  1291. thold_att = sdrt->tWC_min - (tset_att + twait);
  1292. timing = DIV_ROUND_UP(thold_att, hclkp);
  1293. tims->thold_att = clamp_val(timing, 1, FMC2_PMEM_PATT_TIMING_MASK);
  1294. }
  1295. static int stm32_fmc2_nfc_setup_interface(struct nand_chip *chip, int chipnr,
  1296. const struct nand_interface_config *conf)
  1297. {
  1298. const struct nand_sdr_timings *sdrt;
  1299. sdrt = nand_get_sdr_timings(conf);
  1300. if (IS_ERR(sdrt))
  1301. return PTR_ERR(sdrt);
  1302. if (conf->timings.mode > 3)
  1303. return -EOPNOTSUPP;
  1304. if (chipnr == NAND_DATA_IFACE_CHECK_ONLY)
  1305. return 0;
  1306. stm32_fmc2_nfc_calc_timings(chip, sdrt);
  1307. stm32_fmc2_nfc_timings_init(chip);
  1308. return 0;
  1309. }
  1310. static int stm32_fmc2_nfc_dma_setup(struct stm32_fmc2_nfc *nfc)
  1311. {
  1312. struct dma_slave_caps caps;
  1313. int ret = 0;
  1314. nfc->dma_tx_ch = dma_request_chan(nfc->dev, "tx");
  1315. if (IS_ERR(nfc->dma_tx_ch)) {
  1316. ret = PTR_ERR(nfc->dma_tx_ch);
  1317. if (ret != -ENODEV && ret != -EPROBE_DEFER)
  1318. dev_err(nfc->dev,
  1319. "failed to request tx DMA channel: %d\n", ret);
  1320. nfc->dma_tx_ch = NULL;
  1321. goto err_dma;
  1322. }
  1323. ret = dma_get_slave_caps(nfc->dma_tx_ch, &caps);
  1324. if (ret)
  1325. return ret;
  1326. nfc->tx_dma_max_burst = caps.max_burst;
  1327. nfc->dma_rx_ch = dma_request_chan(nfc->dev, "rx");
  1328. if (IS_ERR(nfc->dma_rx_ch)) {
  1329. ret = PTR_ERR(nfc->dma_rx_ch);
  1330. if (ret != -ENODEV && ret != -EPROBE_DEFER)
  1331. dev_err(nfc->dev,
  1332. "failed to request rx DMA channel: %d\n", ret);
  1333. nfc->dma_rx_ch = NULL;
  1334. goto err_dma;
  1335. }
  1336. ret = dma_get_slave_caps(nfc->dma_rx_ch, &caps);
  1337. if (ret)
  1338. return ret;
  1339. nfc->rx_dma_max_burst = caps.max_burst;
  1340. nfc->dma_ecc_ch = dma_request_chan(nfc->dev, "ecc");
  1341. if (IS_ERR(nfc->dma_ecc_ch)) {
  1342. ret = PTR_ERR(nfc->dma_ecc_ch);
  1343. if (ret != -ENODEV && ret != -EPROBE_DEFER)
  1344. dev_err(nfc->dev,
  1345. "failed to request ecc DMA channel: %d\n", ret);
  1346. nfc->dma_ecc_ch = NULL;
  1347. goto err_dma;
  1348. }
  1349. ret = sg_alloc_table(&nfc->dma_ecc_sg, FMC2_MAX_SG, GFP_KERNEL);
  1350. if (ret)
  1351. return ret;
  1352. /* Allocate a buffer to store ECC status registers */
  1353. nfc->ecc_buf = dmam_alloc_coherent(nfc->dev, FMC2_MAX_ECC_BUF_LEN,
  1354. &nfc->dma_ecc_addr, GFP_KERNEL);
  1355. if (!nfc->ecc_buf)
  1356. return -ENOMEM;
  1357. ret = sg_alloc_table(&nfc->dma_data_sg, FMC2_MAX_SG, GFP_KERNEL);
  1358. if (ret)
  1359. return ret;
  1360. init_completion(&nfc->dma_data_complete);
  1361. init_completion(&nfc->dma_ecc_complete);
  1362. return 0;
  1363. err_dma:
  1364. if (ret == -ENODEV) {
  1365. dev_warn(nfc->dev,
  1366. "DMAs not defined in the DT, polling mode is used\n");
  1367. ret = 0;
  1368. }
  1369. return ret;
  1370. }
  1371. static void stm32_fmc2_nfc_nand_callbacks_setup(struct nand_chip *chip)
  1372. {
  1373. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  1374. /*
  1375. * Specific callbacks to read/write a page depending on
  1376. * the mode (polling/sequencer) and the algo used (Hamming, BCH).
  1377. */
  1378. if (nfc->dma_tx_ch && nfc->dma_rx_ch && nfc->dma_ecc_ch) {
  1379. /* DMA => use sequencer mode callbacks */
  1380. chip->ecc.correct = stm32_fmc2_nfc_seq_correct;
  1381. chip->ecc.write_page = stm32_fmc2_nfc_seq_write_page;
  1382. chip->ecc.read_page = stm32_fmc2_nfc_seq_read_page;
  1383. chip->ecc.write_page_raw = stm32_fmc2_nfc_seq_write_page_raw;
  1384. chip->ecc.read_page_raw = stm32_fmc2_nfc_seq_read_page_raw;
  1385. } else {
  1386. /* No DMA => use polling mode callbacks */
  1387. chip->ecc.hwctl = stm32_fmc2_nfc_hwctl;
  1388. if (chip->ecc.strength == FMC2_ECC_HAM) {
  1389. /* Hamming is used */
  1390. chip->ecc.calculate = stm32_fmc2_nfc_ham_calculate;
  1391. chip->ecc.correct = stm32_fmc2_nfc_ham_correct;
  1392. chip->ecc.options |= NAND_ECC_GENERIC_ERASED_CHECK;
  1393. } else {
  1394. /* BCH is used */
  1395. chip->ecc.calculate = stm32_fmc2_nfc_bch_calculate;
  1396. chip->ecc.correct = stm32_fmc2_nfc_bch_correct;
  1397. chip->ecc.read_page = stm32_fmc2_nfc_read_page;
  1398. }
  1399. }
  1400. /* Specific configurations depending on the algo used */
  1401. if (chip->ecc.strength == FMC2_ECC_HAM)
  1402. chip->ecc.bytes = chip->options & NAND_BUSWIDTH_16 ? 4 : 3;
  1403. else if (chip->ecc.strength == FMC2_ECC_BCH8)
  1404. chip->ecc.bytes = chip->options & NAND_BUSWIDTH_16 ? 14 : 13;
  1405. else
  1406. chip->ecc.bytes = chip->options & NAND_BUSWIDTH_16 ? 8 : 7;
  1407. }
  1408. static int stm32_fmc2_nfc_ooblayout_ecc(struct mtd_info *mtd, int section,
  1409. struct mtd_oob_region *oobregion)
  1410. {
  1411. struct nand_chip *chip = mtd_to_nand(mtd);
  1412. struct nand_ecc_ctrl *ecc = &chip->ecc;
  1413. if (section)
  1414. return -ERANGE;
  1415. oobregion->length = ecc->total;
  1416. oobregion->offset = FMC2_BBM_LEN;
  1417. return 0;
  1418. }
  1419. static int stm32_fmc2_nfc_ooblayout_free(struct mtd_info *mtd, int section,
  1420. struct mtd_oob_region *oobregion)
  1421. {
  1422. struct nand_chip *chip = mtd_to_nand(mtd);
  1423. struct nand_ecc_ctrl *ecc = &chip->ecc;
  1424. if (section)
  1425. return -ERANGE;
  1426. oobregion->length = mtd->oobsize - ecc->total - FMC2_BBM_LEN;
  1427. oobregion->offset = ecc->total + FMC2_BBM_LEN;
  1428. return 0;
  1429. }
  1430. static const struct mtd_ooblayout_ops stm32_fmc2_nfc_ooblayout_ops = {
  1431. .ecc = stm32_fmc2_nfc_ooblayout_ecc,
  1432. .free = stm32_fmc2_nfc_ooblayout_free,
  1433. };
  1434. static int stm32_fmc2_nfc_calc_ecc_bytes(int step_size, int strength)
  1435. {
  1436. /* Hamming */
  1437. if (strength == FMC2_ECC_HAM)
  1438. return 4;
  1439. /* BCH8 */
  1440. if (strength == FMC2_ECC_BCH8)
  1441. return 14;
  1442. /* BCH4 */
  1443. return 8;
  1444. }
  1445. NAND_ECC_CAPS_SINGLE(stm32_fmc2_nfc_ecc_caps, stm32_fmc2_nfc_calc_ecc_bytes,
  1446. FMC2_ECC_STEP_SIZE,
  1447. FMC2_ECC_HAM, FMC2_ECC_BCH4, FMC2_ECC_BCH8);
  1448. static int stm32_fmc2_nfc_attach_chip(struct nand_chip *chip)
  1449. {
  1450. struct stm32_fmc2_nfc *nfc = to_stm32_nfc(chip->controller);
  1451. struct mtd_info *mtd = nand_to_mtd(chip);
  1452. int ret;
  1453. /*
  1454. * Only NAND_ECC_ENGINE_TYPE_ON_HOST mode is actually supported
  1455. * Hamming => ecc.strength = 1
  1456. * BCH4 => ecc.strength = 4
  1457. * BCH8 => ecc.strength = 8
  1458. * ECC sector size = 512
  1459. */
  1460. if (chip->ecc.engine_type != NAND_ECC_ENGINE_TYPE_ON_HOST) {
  1461. dev_err(nfc->dev,
  1462. "nand_ecc_engine_type is not well defined in the DT\n");
  1463. return -EINVAL;
  1464. }
  1465. /* Default ECC settings in case they are not set in the device tree */
  1466. if (!chip->ecc.size)
  1467. chip->ecc.size = FMC2_ECC_STEP_SIZE;
  1468. if (!chip->ecc.strength)
  1469. chip->ecc.strength = FMC2_ECC_BCH8;
  1470. ret = nand_ecc_choose_conf(chip, &stm32_fmc2_nfc_ecc_caps,
  1471. mtd->oobsize - FMC2_BBM_LEN);
  1472. if (ret) {
  1473. dev_err(nfc->dev, "no valid ECC settings set\n");
  1474. return ret;
  1475. }
  1476. if (mtd->writesize / chip->ecc.size > FMC2_MAX_SG) {
  1477. dev_err(nfc->dev, "nand page size is not supported\n");
  1478. return -EINVAL;
  1479. }
  1480. if (chip->bbt_options & NAND_BBT_USE_FLASH)
  1481. chip->bbt_options |= NAND_BBT_NO_OOB;
  1482. stm32_fmc2_nfc_nand_callbacks_setup(chip);
  1483. mtd_set_ooblayout(mtd, &stm32_fmc2_nfc_ooblayout_ops);
  1484. stm32_fmc2_nfc_setup(chip);
  1485. return 0;
  1486. }
  1487. static const struct nand_controller_ops stm32_fmc2_nfc_controller_ops = {
  1488. .attach_chip = stm32_fmc2_nfc_attach_chip,
  1489. .exec_op = stm32_fmc2_nfc_exec_op,
  1490. .setup_interface = stm32_fmc2_nfc_setup_interface,
  1491. };
  1492. static void stm32_fmc2_nfc_wp_enable(struct stm32_fmc2_nand *nand)
  1493. {
  1494. if (nand->wp_gpio)
  1495. gpiod_set_value(nand->wp_gpio, 1);
  1496. }
  1497. static void stm32_fmc2_nfc_wp_disable(struct stm32_fmc2_nand *nand)
  1498. {
  1499. if (nand->wp_gpio)
  1500. gpiod_set_value(nand->wp_gpio, 0);
  1501. }
  1502. static int stm32_fmc2_nfc_parse_child(struct stm32_fmc2_nfc *nfc,
  1503. struct device_node *dn)
  1504. {
  1505. struct stm32_fmc2_nand *nand = &nfc->nand;
  1506. u32 cs;
  1507. int ret, i;
  1508. if (!of_get_property(dn, "reg", &nand->ncs))
  1509. return -EINVAL;
  1510. nand->ncs /= sizeof(u32);
  1511. if (!nand->ncs) {
  1512. dev_err(nfc->dev, "invalid reg property size\n");
  1513. return -EINVAL;
  1514. }
  1515. for (i = 0; i < nand->ncs; i++) {
  1516. ret = of_property_read_u32_index(dn, "reg", i, &cs);
  1517. if (ret) {
  1518. dev_err(nfc->dev, "could not retrieve reg property: %d\n",
  1519. ret);
  1520. return ret;
  1521. }
  1522. if (cs >= nfc->data->max_ncs) {
  1523. dev_err(nfc->dev, "invalid reg value: %d\n", cs);
  1524. return -EINVAL;
  1525. }
  1526. if (nfc->cs_assigned & BIT(cs)) {
  1527. dev_err(nfc->dev, "cs already assigned: %d\n", cs);
  1528. return -EINVAL;
  1529. }
  1530. nfc->cs_assigned |= BIT(cs);
  1531. nand->cs_used[i] = cs;
  1532. }
  1533. nand->wp_gpio = devm_fwnode_gpiod_get(nfc->dev, of_fwnode_handle(dn),
  1534. "wp", GPIOD_OUT_HIGH, "wp");
  1535. if (IS_ERR(nand->wp_gpio)) {
  1536. ret = PTR_ERR(nand->wp_gpio);
  1537. if (ret != -ENOENT)
  1538. return dev_err_probe(nfc->dev, ret,
  1539. "failed to request WP GPIO\n");
  1540. nand->wp_gpio = NULL;
  1541. }
  1542. nand_set_flash_node(&nand->chip, dn);
  1543. return 0;
  1544. }
  1545. static int stm32_fmc2_nfc_parse_dt(struct stm32_fmc2_nfc *nfc)
  1546. {
  1547. struct device_node *dn = nfc->dev->of_node;
  1548. int nchips = of_get_child_count(dn);
  1549. int ret = 0;
  1550. if (!nchips) {
  1551. dev_err(nfc->dev, "NAND chip not defined\n");
  1552. return -EINVAL;
  1553. }
  1554. if (nchips > 1) {
  1555. dev_err(nfc->dev, "too many NAND chips defined\n");
  1556. return -EINVAL;
  1557. }
  1558. for_each_child_of_node_scoped(dn, child) {
  1559. ret = stm32_fmc2_nfc_parse_child(nfc, child);
  1560. if (ret < 0)
  1561. return ret;
  1562. }
  1563. return ret;
  1564. }
  1565. static int stm32_fmc2_nfc_set_cdev(struct stm32_fmc2_nfc *nfc)
  1566. {
  1567. struct device *dev = nfc->dev;
  1568. bool ebi_found = false;
  1569. if (dev->parent && of_device_is_compatible(dev->parent->of_node,
  1570. "st,stm32mp1-fmc2-ebi"))
  1571. ebi_found = true;
  1572. if (of_device_is_compatible(dev->of_node, "st,stm32mp1-fmc2-nfc")) {
  1573. if (ebi_found) {
  1574. nfc->cdev = dev->parent;
  1575. return 0;
  1576. }
  1577. return -EINVAL;
  1578. }
  1579. if (ebi_found)
  1580. return -EINVAL;
  1581. nfc->cdev = dev;
  1582. return 0;
  1583. }
  1584. static int stm32_fmc2_nfc_probe(struct platform_device *pdev)
  1585. {
  1586. struct device *dev = &pdev->dev;
  1587. struct reset_control *rstc;
  1588. struct stm32_fmc2_nfc *nfc;
  1589. struct stm32_fmc2_nand *nand;
  1590. struct resource *res;
  1591. struct mtd_info *mtd;
  1592. struct nand_chip *chip;
  1593. struct resource cres;
  1594. int chip_cs, mem_region, ret, irq;
  1595. int start_region = 0;
  1596. nfc = devm_kzalloc(dev, sizeof(*nfc), GFP_KERNEL);
  1597. if (!nfc)
  1598. return -ENOMEM;
  1599. nfc->dev = dev;
  1600. nand_controller_init(&nfc->base);
  1601. nfc->base.ops = &stm32_fmc2_nfc_controller_ops;
  1602. nfc->data = of_device_get_match_data(dev);
  1603. if (!nfc->data)
  1604. return -EINVAL;
  1605. if (nfc->data->set_cdev) {
  1606. ret = nfc->data->set_cdev(nfc);
  1607. if (ret)
  1608. return ret;
  1609. } else {
  1610. nfc->cdev = dev->parent;
  1611. }
  1612. ret = stm32_fmc2_nfc_parse_dt(nfc);
  1613. if (ret)
  1614. return ret;
  1615. ret = of_address_to_resource(nfc->cdev->of_node, 0, &cres);
  1616. if (ret)
  1617. return ret;
  1618. nfc->io_phys_addr = cres.start;
  1619. nfc->regmap = device_node_to_regmap(nfc->cdev->of_node);
  1620. if (IS_ERR(nfc->regmap))
  1621. return PTR_ERR(nfc->regmap);
  1622. if (nfc->dev == nfc->cdev)
  1623. start_region = 1;
  1624. for (chip_cs = 0, mem_region = start_region; chip_cs < nfc->data->max_ncs;
  1625. chip_cs++, mem_region += 3) {
  1626. if (!(nfc->cs_assigned & BIT(chip_cs)))
  1627. continue;
  1628. nfc->data_base[chip_cs] = devm_platform_get_and_ioremap_resource(pdev,
  1629. mem_region, &res);
  1630. if (IS_ERR(nfc->data_base[chip_cs]))
  1631. return PTR_ERR(nfc->data_base[chip_cs]);
  1632. nfc->data_phys_addr[chip_cs] = res->start;
  1633. nfc->cmd_base[chip_cs] = devm_platform_ioremap_resource(pdev, mem_region + 1);
  1634. if (IS_ERR(nfc->cmd_base[chip_cs]))
  1635. return PTR_ERR(nfc->cmd_base[chip_cs]);
  1636. nfc->addr_base[chip_cs] = devm_platform_ioremap_resource(pdev, mem_region + 2);
  1637. if (IS_ERR(nfc->addr_base[chip_cs]))
  1638. return PTR_ERR(nfc->addr_base[chip_cs]);
  1639. }
  1640. irq = platform_get_irq(pdev, 0);
  1641. if (irq < 0)
  1642. return irq;
  1643. ret = devm_request_irq(dev, irq, stm32_fmc2_nfc_irq, 0,
  1644. dev_name(dev), nfc);
  1645. if (ret) {
  1646. dev_err(dev, "failed to request irq\n");
  1647. return ret;
  1648. }
  1649. init_completion(&nfc->complete);
  1650. nfc->clk = devm_clk_get_enabled(nfc->cdev, NULL);
  1651. if (IS_ERR(nfc->clk)) {
  1652. dev_err(dev, "can not get and enable the clock\n");
  1653. return PTR_ERR(nfc->clk);
  1654. }
  1655. rstc = devm_reset_control_get(dev, NULL);
  1656. if (IS_ERR(rstc)) {
  1657. ret = PTR_ERR(rstc);
  1658. if (ret == -EPROBE_DEFER)
  1659. return ret;
  1660. } else {
  1661. reset_control_assert(rstc);
  1662. reset_control_deassert(rstc);
  1663. }
  1664. ret = stm32_fmc2_nfc_dma_setup(nfc);
  1665. if (ret)
  1666. goto err_release_dma;
  1667. stm32_fmc2_nfc_init(nfc);
  1668. nand = &nfc->nand;
  1669. chip = &nand->chip;
  1670. mtd = nand_to_mtd(chip);
  1671. mtd->dev.parent = dev;
  1672. chip->controller = &nfc->base;
  1673. chip->options |= NAND_BUSWIDTH_AUTO | NAND_NO_SUBPAGE_WRITE |
  1674. NAND_USES_DMA;
  1675. stm32_fmc2_nfc_wp_disable(nand);
  1676. /* Scan to find existence of the device */
  1677. ret = nand_scan(chip, nand->ncs);
  1678. if (ret)
  1679. goto err_wp_enable;
  1680. ret = mtd_device_register(mtd, NULL, 0);
  1681. if (ret)
  1682. goto err_nand_cleanup;
  1683. platform_set_drvdata(pdev, nfc);
  1684. return 0;
  1685. err_nand_cleanup:
  1686. nand_cleanup(chip);
  1687. err_wp_enable:
  1688. stm32_fmc2_nfc_wp_enable(nand);
  1689. err_release_dma:
  1690. if (nfc->dma_ecc_ch)
  1691. dma_release_channel(nfc->dma_ecc_ch);
  1692. if (nfc->dma_tx_ch)
  1693. dma_release_channel(nfc->dma_tx_ch);
  1694. if (nfc->dma_rx_ch)
  1695. dma_release_channel(nfc->dma_rx_ch);
  1696. sg_free_table(&nfc->dma_data_sg);
  1697. sg_free_table(&nfc->dma_ecc_sg);
  1698. return ret;
  1699. }
  1700. static void stm32_fmc2_nfc_remove(struct platform_device *pdev)
  1701. {
  1702. struct stm32_fmc2_nfc *nfc = platform_get_drvdata(pdev);
  1703. struct stm32_fmc2_nand *nand = &nfc->nand;
  1704. struct nand_chip *chip = &nand->chip;
  1705. int ret;
  1706. ret = mtd_device_unregister(nand_to_mtd(chip));
  1707. WARN_ON(ret);
  1708. nand_cleanup(chip);
  1709. if (nfc->dma_ecc_ch)
  1710. dma_release_channel(nfc->dma_ecc_ch);
  1711. if (nfc->dma_tx_ch)
  1712. dma_release_channel(nfc->dma_tx_ch);
  1713. if (nfc->dma_rx_ch)
  1714. dma_release_channel(nfc->dma_rx_ch);
  1715. sg_free_table(&nfc->dma_data_sg);
  1716. sg_free_table(&nfc->dma_ecc_sg);
  1717. stm32_fmc2_nfc_wp_enable(nand);
  1718. }
  1719. static int __maybe_unused stm32_fmc2_nfc_suspend(struct device *dev)
  1720. {
  1721. struct stm32_fmc2_nfc *nfc = dev_get_drvdata(dev);
  1722. struct stm32_fmc2_nand *nand = &nfc->nand;
  1723. clk_disable_unprepare(nfc->clk);
  1724. stm32_fmc2_nfc_wp_enable(nand);
  1725. pinctrl_pm_select_sleep_state(dev);
  1726. return 0;
  1727. }
  1728. static int __maybe_unused stm32_fmc2_nfc_resume(struct device *dev)
  1729. {
  1730. struct stm32_fmc2_nfc *nfc = dev_get_drvdata(dev);
  1731. struct stm32_fmc2_nand *nand = &nfc->nand;
  1732. int chip_cs, ret;
  1733. pinctrl_pm_select_default_state(dev);
  1734. ret = clk_prepare_enable(nfc->clk);
  1735. if (ret) {
  1736. dev_err(dev, "can not enable the clock\n");
  1737. return ret;
  1738. }
  1739. stm32_fmc2_nfc_init(nfc);
  1740. stm32_fmc2_nfc_wp_disable(nand);
  1741. for (chip_cs = 0; chip_cs < nfc->data->max_ncs; chip_cs++) {
  1742. if (!(nfc->cs_assigned & BIT(chip_cs)))
  1743. continue;
  1744. nand_reset(&nand->chip, chip_cs);
  1745. }
  1746. return 0;
  1747. }
  1748. static SIMPLE_DEV_PM_OPS(stm32_fmc2_nfc_pm_ops, stm32_fmc2_nfc_suspend,
  1749. stm32_fmc2_nfc_resume);
  1750. static const struct stm32_fmc2_nfc_data stm32_fmc2_nfc_mp1_data = {
  1751. .max_ncs = 2,
  1752. .set_cdev = stm32_fmc2_nfc_set_cdev,
  1753. };
  1754. static const struct stm32_fmc2_nfc_data stm32_fmc2_nfc_mp25_data = {
  1755. .max_ncs = 4,
  1756. };
  1757. static const struct of_device_id stm32_fmc2_nfc_match[] = {
  1758. {
  1759. .compatible = "st,stm32mp15-fmc2",
  1760. .data = &stm32_fmc2_nfc_mp1_data,
  1761. },
  1762. {
  1763. .compatible = "st,stm32mp1-fmc2-nfc",
  1764. .data = &stm32_fmc2_nfc_mp1_data,
  1765. },
  1766. {
  1767. .compatible = "st,stm32mp25-fmc2-nfc",
  1768. .data = &stm32_fmc2_nfc_mp25_data,
  1769. },
  1770. {}
  1771. };
  1772. MODULE_DEVICE_TABLE(of, stm32_fmc2_nfc_match);
  1773. static struct platform_driver stm32_fmc2_nfc_driver = {
  1774. .probe = stm32_fmc2_nfc_probe,
  1775. .remove_new = stm32_fmc2_nfc_remove,
  1776. .driver = {
  1777. .name = "stm32_fmc2_nfc",
  1778. .of_match_table = stm32_fmc2_nfc_match,
  1779. .pm = &stm32_fmc2_nfc_pm_ops,
  1780. },
  1781. };
  1782. module_platform_driver(stm32_fmc2_nfc_driver);
  1783. MODULE_ALIAS("platform:stm32_fmc2_nfc");
  1784. MODULE_AUTHOR("Christophe Kerello <christophe.kerello@st.com>");
  1785. MODULE_DESCRIPTION("STMicroelectronics STM32 FMC2 NFC driver");
  1786. MODULE_LICENSE("GPL v2");