xref: /linux/drivers/mtd/nand/raw/fsl_ifc_nand.c (revision 7f4f3b14e8079ecde096bd734af10e30d40c27b7)
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3  * Freescale Integrated Flash Controller NAND driver
4  *
5  * Copyright 2011-2012 Freescale Semiconductor, Inc
6  *
7  * Author: Dipen Dudhat <Dipen.Dudhat@freescale.com>
8  */
9 
10 #include <linux/module.h>
11 #include <linux/platform_device.h>
12 #include <linux/types.h>
13 #include <linux/kernel.h>
14 #include <linux/of_address.h>
15 #include <linux/slab.h>
16 #include <linux/mtd/mtd.h>
17 #include <linux/mtd/rawnand.h>
18 #include <linux/mtd/partitions.h>
19 #include <linux/fsl_ifc.h>
20 #include <linux/iopoll.h>
21 
22 #define ERR_BYTE		0xFF /* Value returned for read
23 					bytes when read failed	*/
24 #define IFC_TIMEOUT_MSECS	1000 /* Maximum timeout to wait
25 					for IFC NAND Machine	*/
26 
27 struct fsl_ifc_ctrl;
28 
29 /* mtd information per set */
30 struct fsl_ifc_mtd {
31 	struct nand_chip chip;
32 	struct fsl_ifc_ctrl *ctrl;
33 
34 	struct device *dev;
35 	int bank;		/* Chip select bank number		*/
36 	unsigned int bufnum_mask; /* bufnum = page & bufnum_mask */
37 	u8 __iomem *vbase;      /* Chip select base virtual address	*/
38 };
39 
40 /* overview of the fsl ifc controller */
41 struct fsl_ifc_nand_ctrl {
42 	struct nand_controller controller;
43 	struct fsl_ifc_mtd *chips[FSL_IFC_BANK_COUNT];
44 
45 	void __iomem *addr;	/* Address of assigned IFC buffer	*/
46 	unsigned int page;	/* Last page written to / read from	*/
47 	unsigned int read_bytes;/* Number of bytes read during command	*/
48 	unsigned int column;	/* Saved column from SEQIN		*/
49 	unsigned int index;	/* Pointer to next byte to 'read'	*/
50 	unsigned int oob;	/* Non zero if operating on OOB data	*/
51 	unsigned int eccread;	/* Non zero for a full-page ECC read	*/
52 	unsigned int counter;	/* counter for the initializations	*/
53 	unsigned int max_bitflips;  /* Saved during READ0 cmd		*/
54 };
55 
56 static struct fsl_ifc_nand_ctrl *ifc_nand_ctrl;
57 
58 /*
59  * Generic flash bbt descriptors
60  */
61 static u8 bbt_pattern[] = {'B', 'b', 't', '0' };
62 static u8 mirror_pattern[] = {'1', 't', 'b', 'B' };
63 
64 static struct nand_bbt_descr bbt_main_descr = {
65 	.options = NAND_BBT_LASTBLOCK | NAND_BBT_CREATE | NAND_BBT_WRITE |
66 		   NAND_BBT_2BIT | NAND_BBT_VERSION,
67 	.offs =	2, /* 0 on 8-bit small page */
68 	.len = 4,
69 	.veroffs = 6,
70 	.maxblocks = 4,
71 	.pattern = bbt_pattern,
72 };
73 
74 static struct nand_bbt_descr bbt_mirror_descr = {
75 	.options = NAND_BBT_LASTBLOCK | NAND_BBT_CREATE | NAND_BBT_WRITE |
76 		   NAND_BBT_2BIT | NAND_BBT_VERSION,
77 	.offs =	2, /* 0 on 8-bit small page */
78 	.len = 4,
79 	.veroffs = 6,
80 	.maxblocks = 4,
81 	.pattern = mirror_pattern,
82 };
83 
84 static int fsl_ifc_ooblayout_ecc(struct mtd_info *mtd, int section,
85 				 struct mtd_oob_region *oobregion)
86 {
87 	struct nand_chip *chip = mtd_to_nand(mtd);
88 
89 	if (section)
90 		return -ERANGE;
91 
92 	oobregion->offset = 8;
93 	oobregion->length = chip->ecc.total;
94 
95 	return 0;
96 }
97 
98 static int fsl_ifc_ooblayout_free(struct mtd_info *mtd, int section,
99 				  struct mtd_oob_region *oobregion)
100 {
101 	struct nand_chip *chip = mtd_to_nand(mtd);
102 
103 	if (section > 1)
104 		return -ERANGE;
105 
106 	if (mtd->writesize == 512 &&
107 	    !(chip->options & NAND_BUSWIDTH_16)) {
108 		if (!section) {
109 			oobregion->offset = 0;
110 			oobregion->length = 5;
111 		} else {
112 			oobregion->offset = 6;
113 			oobregion->length = 2;
114 		}
115 
116 		return 0;
117 	}
118 
119 	if (!section) {
120 		oobregion->offset = 2;
121 		oobregion->length = 6;
122 	} else {
123 		oobregion->offset = chip->ecc.total + 8;
124 		oobregion->length = mtd->oobsize - oobregion->offset;
125 	}
126 
127 	return 0;
128 }
129 
130 static const struct mtd_ooblayout_ops fsl_ifc_ooblayout_ops = {
131 	.ecc = fsl_ifc_ooblayout_ecc,
132 	.free = fsl_ifc_ooblayout_free,
133 };
134 
135 /*
136  * Set up the IFC hardware block and page address fields, and the ifc nand
137  * structure addr field to point to the correct IFC buffer in memory
138  */
139 static void set_addr(struct mtd_info *mtd, int column, int page_addr, int oob)
140 {
141 	struct nand_chip *chip = mtd_to_nand(mtd);
142 	struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
143 	struct fsl_ifc_ctrl *ctrl = priv->ctrl;
144 	struct fsl_ifc_runtime __iomem *ifc = ctrl->rregs;
145 	int buf_num;
146 
147 	ifc_nand_ctrl->page = page_addr;
148 	/* Program ROW0/COL0 */
149 	ifc_out32(page_addr, &ifc->ifc_nand.row0);
150 	ifc_out32((oob ? IFC_NAND_COL_MS : 0) | column, &ifc->ifc_nand.col0);
151 
152 	buf_num = page_addr & priv->bufnum_mask;
153 
154 	ifc_nand_ctrl->addr = priv->vbase + buf_num * (mtd->writesize * 2);
155 	ifc_nand_ctrl->index = column;
156 
157 	/* for OOB data point to the second half of the buffer */
158 	if (oob)
159 		ifc_nand_ctrl->index += mtd->writesize;
160 }
161 
162 /* returns nonzero if entire page is blank */
163 static int check_read_ecc(struct mtd_info *mtd, struct fsl_ifc_ctrl *ctrl,
164 			  u32 eccstat, unsigned int bufnum)
165 {
166 	return  (eccstat >> ((3 - bufnum % 4) * 8)) & 15;
167 }
168 
169 /*
170  * execute IFC NAND command and wait for it to complete
171  */
172 static void fsl_ifc_run_command(struct mtd_info *mtd)
173 {
174 	struct nand_chip *chip = mtd_to_nand(mtd);
175 	struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
176 	struct fsl_ifc_ctrl *ctrl = priv->ctrl;
177 	struct fsl_ifc_nand_ctrl *nctrl = ifc_nand_ctrl;
178 	struct fsl_ifc_runtime __iomem *ifc = ctrl->rregs;
179 	u32 eccstat;
180 	int i;
181 
182 	/* set the chip select for NAND Transaction */
183 	ifc_out32(priv->bank << IFC_NAND_CSEL_SHIFT,
184 		  &ifc->ifc_nand.nand_csel);
185 
186 	dev_vdbg(priv->dev,
187 			"%s: fir0=%08x fcr0=%08x\n",
188 			__func__,
189 			ifc_in32(&ifc->ifc_nand.nand_fir0),
190 			ifc_in32(&ifc->ifc_nand.nand_fcr0));
191 
192 	ctrl->nand_stat = 0;
193 
194 	/* start read/write seq */
195 	ifc_out32(IFC_NAND_SEQ_STRT_FIR_STRT, &ifc->ifc_nand.nandseq_strt);
196 
197 	/* wait for command complete flag or timeout */
198 	wait_event_timeout(ctrl->nand_wait, ctrl->nand_stat,
199 			   msecs_to_jiffies(IFC_TIMEOUT_MSECS));
200 
201 	/* ctrl->nand_stat will be updated from IRQ context */
202 	if (!ctrl->nand_stat)
203 		dev_err(priv->dev, "Controller is not responding\n");
204 	if (ctrl->nand_stat & IFC_NAND_EVTER_STAT_FTOER)
205 		dev_err(priv->dev, "NAND Flash Timeout Error\n");
206 	if (ctrl->nand_stat & IFC_NAND_EVTER_STAT_WPER)
207 		dev_err(priv->dev, "NAND Flash Write Protect Error\n");
208 
209 	nctrl->max_bitflips = 0;
210 
211 	if (nctrl->eccread) {
212 		int errors;
213 		int bufnum = nctrl->page & priv->bufnum_mask;
214 		int sector_start = bufnum * chip->ecc.steps;
215 		int sector_end = sector_start + chip->ecc.steps - 1;
216 		__be32 __iomem *eccstat_regs;
217 
218 		eccstat_regs = ifc->ifc_nand.nand_eccstat;
219 		eccstat = ifc_in32(&eccstat_regs[sector_start / 4]);
220 
221 		for (i = sector_start; i <= sector_end; i++) {
222 			if (i != sector_start && !(i % 4))
223 				eccstat = ifc_in32(&eccstat_regs[i / 4]);
224 
225 			errors = check_read_ecc(mtd, ctrl, eccstat, i);
226 
227 			if (errors == 15) {
228 				/*
229 				 * Uncorrectable error.
230 				 * We'll check for blank pages later.
231 				 *
232 				 * We disable ECCER reporting due to...
233 				 * erratum IFC-A002770 -- so report it now if we
234 				 * see an uncorrectable error in ECCSTAT.
235 				 */
236 				ctrl->nand_stat |= IFC_NAND_EVTER_STAT_ECCER;
237 				continue;
238 			}
239 
240 			mtd->ecc_stats.corrected += errors;
241 			nctrl->max_bitflips = max_t(unsigned int,
242 						    nctrl->max_bitflips,
243 						    errors);
244 		}
245 
246 		nctrl->eccread = 0;
247 	}
248 }
249 
250 static void fsl_ifc_do_read(struct nand_chip *chip,
251 			    int oob,
252 			    struct mtd_info *mtd)
253 {
254 	struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
255 	struct fsl_ifc_ctrl *ctrl = priv->ctrl;
256 	struct fsl_ifc_runtime __iomem *ifc = ctrl->rregs;
257 
258 	/* Program FIR/IFC_NAND_FCR0 for Small/Large page */
259 	if (mtd->writesize > 512) {
260 		ifc_out32((IFC_FIR_OP_CW0 << IFC_NAND_FIR0_OP0_SHIFT) |
261 			  (IFC_FIR_OP_CA0 << IFC_NAND_FIR0_OP1_SHIFT) |
262 			  (IFC_FIR_OP_RA0 << IFC_NAND_FIR0_OP2_SHIFT) |
263 			  (IFC_FIR_OP_CMD1 << IFC_NAND_FIR0_OP3_SHIFT) |
264 			  (IFC_FIR_OP_RBCD << IFC_NAND_FIR0_OP4_SHIFT),
265 			  &ifc->ifc_nand.nand_fir0);
266 		ifc_out32(0x0, &ifc->ifc_nand.nand_fir1);
267 
268 		ifc_out32((NAND_CMD_READ0 << IFC_NAND_FCR0_CMD0_SHIFT) |
269 			  (NAND_CMD_READSTART << IFC_NAND_FCR0_CMD1_SHIFT),
270 			  &ifc->ifc_nand.nand_fcr0);
271 	} else {
272 		ifc_out32((IFC_FIR_OP_CW0 << IFC_NAND_FIR0_OP0_SHIFT) |
273 			  (IFC_FIR_OP_CA0 << IFC_NAND_FIR0_OP1_SHIFT) |
274 			  (IFC_FIR_OP_RA0  << IFC_NAND_FIR0_OP2_SHIFT) |
275 			  (IFC_FIR_OP_RBCD << IFC_NAND_FIR0_OP3_SHIFT),
276 			  &ifc->ifc_nand.nand_fir0);
277 		ifc_out32(0x0, &ifc->ifc_nand.nand_fir1);
278 
279 		if (oob)
280 			ifc_out32(NAND_CMD_READOOB <<
281 				  IFC_NAND_FCR0_CMD0_SHIFT,
282 				  &ifc->ifc_nand.nand_fcr0);
283 		else
284 			ifc_out32(NAND_CMD_READ0 <<
285 				  IFC_NAND_FCR0_CMD0_SHIFT,
286 				  &ifc->ifc_nand.nand_fcr0);
287 	}
288 }
289 
290 /* cmdfunc send commands to the IFC NAND Machine */
291 static void fsl_ifc_cmdfunc(struct nand_chip *chip, unsigned int command,
292 			    int column, int page_addr) {
293 	struct mtd_info *mtd = nand_to_mtd(chip);
294 	struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
295 	struct fsl_ifc_ctrl *ctrl = priv->ctrl;
296 	struct fsl_ifc_runtime __iomem *ifc = ctrl->rregs;
297 
298 	/* clear the read buffer */
299 	ifc_nand_ctrl->read_bytes = 0;
300 	if (command != NAND_CMD_PAGEPROG)
301 		ifc_nand_ctrl->index = 0;
302 
303 	switch (command) {
304 	/* READ0 read the entire buffer to use hardware ECC. */
305 	case NAND_CMD_READ0:
306 		ifc_out32(0, &ifc->ifc_nand.nand_fbcr);
307 		set_addr(mtd, 0, page_addr, 0);
308 
309 		ifc_nand_ctrl->read_bytes = mtd->writesize + mtd->oobsize;
310 		ifc_nand_ctrl->index += column;
311 
312 		if (chip->ecc.engine_type == NAND_ECC_ENGINE_TYPE_ON_HOST)
313 			ifc_nand_ctrl->eccread = 1;
314 
315 		fsl_ifc_do_read(chip, 0, mtd);
316 		fsl_ifc_run_command(mtd);
317 		return;
318 
319 	/* READOOB reads only the OOB because no ECC is performed. */
320 	case NAND_CMD_READOOB:
321 		ifc_out32(mtd->oobsize - column, &ifc->ifc_nand.nand_fbcr);
322 		set_addr(mtd, column, page_addr, 1);
323 
324 		ifc_nand_ctrl->read_bytes = mtd->writesize + mtd->oobsize;
325 
326 		fsl_ifc_do_read(chip, 1, mtd);
327 		fsl_ifc_run_command(mtd);
328 
329 		return;
330 
331 	case NAND_CMD_READID:
332 	case NAND_CMD_PARAM: {
333 		/*
334 		 * For READID, read 8 bytes that are currently used.
335 		 * For PARAM, read all 3 copies of 256-bytes pages.
336 		 */
337 		int len = 8;
338 		int timing = IFC_FIR_OP_RB;
339 		if (command == NAND_CMD_PARAM) {
340 			timing = IFC_FIR_OP_RBCD;
341 			len = 256 * 3;
342 		}
343 
344 		ifc_out32((IFC_FIR_OP_CW0 << IFC_NAND_FIR0_OP0_SHIFT) |
345 			  (IFC_FIR_OP_UA  << IFC_NAND_FIR0_OP1_SHIFT) |
346 			  (timing << IFC_NAND_FIR0_OP2_SHIFT),
347 			  &ifc->ifc_nand.nand_fir0);
348 		ifc_out32(command << IFC_NAND_FCR0_CMD0_SHIFT,
349 			  &ifc->ifc_nand.nand_fcr0);
350 		ifc_out32(column, &ifc->ifc_nand.row3);
351 
352 		ifc_out32(len, &ifc->ifc_nand.nand_fbcr);
353 		ifc_nand_ctrl->read_bytes = len;
354 
355 		set_addr(mtd, 0, 0, 0);
356 		fsl_ifc_run_command(mtd);
357 		return;
358 	}
359 
360 	/* ERASE1 stores the block and page address */
361 	case NAND_CMD_ERASE1:
362 		set_addr(mtd, 0, page_addr, 0);
363 		return;
364 
365 	/* ERASE2 uses the block and page address from ERASE1 */
366 	case NAND_CMD_ERASE2:
367 		ifc_out32((IFC_FIR_OP_CW0 << IFC_NAND_FIR0_OP0_SHIFT) |
368 			  (IFC_FIR_OP_RA0 << IFC_NAND_FIR0_OP1_SHIFT) |
369 			  (IFC_FIR_OP_CMD1 << IFC_NAND_FIR0_OP2_SHIFT),
370 			  &ifc->ifc_nand.nand_fir0);
371 
372 		ifc_out32((NAND_CMD_ERASE1 << IFC_NAND_FCR0_CMD0_SHIFT) |
373 			  (NAND_CMD_ERASE2 << IFC_NAND_FCR0_CMD1_SHIFT),
374 			  &ifc->ifc_nand.nand_fcr0);
375 
376 		ifc_out32(0, &ifc->ifc_nand.nand_fbcr);
377 		ifc_nand_ctrl->read_bytes = 0;
378 		fsl_ifc_run_command(mtd);
379 		return;
380 
381 	/* SEQIN sets up the addr buffer and all registers except the length */
382 	case NAND_CMD_SEQIN: {
383 		u32 nand_fcr0;
384 		ifc_nand_ctrl->column = column;
385 		ifc_nand_ctrl->oob = 0;
386 
387 		if (mtd->writesize > 512) {
388 			nand_fcr0 =
389 				(NAND_CMD_SEQIN << IFC_NAND_FCR0_CMD0_SHIFT) |
390 				(NAND_CMD_STATUS << IFC_NAND_FCR0_CMD1_SHIFT) |
391 				(NAND_CMD_PAGEPROG << IFC_NAND_FCR0_CMD2_SHIFT);
392 
393 			ifc_out32(
394 				(IFC_FIR_OP_CW0 << IFC_NAND_FIR0_OP0_SHIFT) |
395 				(IFC_FIR_OP_CA0 << IFC_NAND_FIR0_OP1_SHIFT) |
396 				(IFC_FIR_OP_RA0 << IFC_NAND_FIR0_OP2_SHIFT) |
397 				(IFC_FIR_OP_WBCD << IFC_NAND_FIR0_OP3_SHIFT) |
398 				(IFC_FIR_OP_CMD2 << IFC_NAND_FIR0_OP4_SHIFT),
399 				&ifc->ifc_nand.nand_fir0);
400 			ifc_out32(
401 				(IFC_FIR_OP_CW1 << IFC_NAND_FIR1_OP5_SHIFT) |
402 				(IFC_FIR_OP_RDSTAT << IFC_NAND_FIR1_OP6_SHIFT) |
403 				(IFC_FIR_OP_NOP << IFC_NAND_FIR1_OP7_SHIFT),
404 				&ifc->ifc_nand.nand_fir1);
405 		} else {
406 			nand_fcr0 = ((NAND_CMD_PAGEPROG <<
407 					IFC_NAND_FCR0_CMD1_SHIFT) |
408 				    (NAND_CMD_SEQIN <<
409 					IFC_NAND_FCR0_CMD2_SHIFT) |
410 				    (NAND_CMD_STATUS <<
411 					IFC_NAND_FCR0_CMD3_SHIFT));
412 
413 			ifc_out32(
414 				(IFC_FIR_OP_CW0 << IFC_NAND_FIR0_OP0_SHIFT) |
415 				(IFC_FIR_OP_CMD2 << IFC_NAND_FIR0_OP1_SHIFT) |
416 				(IFC_FIR_OP_CA0 << IFC_NAND_FIR0_OP2_SHIFT) |
417 				(IFC_FIR_OP_RA0 << IFC_NAND_FIR0_OP3_SHIFT) |
418 				(IFC_FIR_OP_WBCD << IFC_NAND_FIR0_OP4_SHIFT),
419 				&ifc->ifc_nand.nand_fir0);
420 			ifc_out32(
421 				(IFC_FIR_OP_CMD1 << IFC_NAND_FIR1_OP5_SHIFT) |
422 				(IFC_FIR_OP_CW3 << IFC_NAND_FIR1_OP6_SHIFT) |
423 				(IFC_FIR_OP_RDSTAT << IFC_NAND_FIR1_OP7_SHIFT) |
424 				(IFC_FIR_OP_NOP << IFC_NAND_FIR1_OP8_SHIFT),
425 				&ifc->ifc_nand.nand_fir1);
426 
427 			if (column >= mtd->writesize)
428 				nand_fcr0 |=
429 				NAND_CMD_READOOB << IFC_NAND_FCR0_CMD0_SHIFT;
430 			else
431 				nand_fcr0 |=
432 				NAND_CMD_READ0 << IFC_NAND_FCR0_CMD0_SHIFT;
433 		}
434 
435 		if (column >= mtd->writesize) {
436 			/* OOB area --> READOOB */
437 			column -= mtd->writesize;
438 			ifc_nand_ctrl->oob = 1;
439 		}
440 		ifc_out32(nand_fcr0, &ifc->ifc_nand.nand_fcr0);
441 		set_addr(mtd, column, page_addr, ifc_nand_ctrl->oob);
442 		return;
443 	}
444 
445 	/* PAGEPROG reuses all of the setup from SEQIN and adds the length */
446 	case NAND_CMD_PAGEPROG: {
447 		if (ifc_nand_ctrl->oob) {
448 			ifc_out32(ifc_nand_ctrl->index -
449 				  ifc_nand_ctrl->column,
450 				  &ifc->ifc_nand.nand_fbcr);
451 		} else {
452 			ifc_out32(0, &ifc->ifc_nand.nand_fbcr);
453 		}
454 
455 		fsl_ifc_run_command(mtd);
456 		return;
457 	}
458 
459 	case NAND_CMD_STATUS: {
460 		void __iomem *addr;
461 
462 		ifc_out32((IFC_FIR_OP_CW0 << IFC_NAND_FIR0_OP0_SHIFT) |
463 			  (IFC_FIR_OP_RB << IFC_NAND_FIR0_OP1_SHIFT),
464 			  &ifc->ifc_nand.nand_fir0);
465 		ifc_out32(NAND_CMD_STATUS << IFC_NAND_FCR0_CMD0_SHIFT,
466 			  &ifc->ifc_nand.nand_fcr0);
467 		ifc_out32(1, &ifc->ifc_nand.nand_fbcr);
468 		set_addr(mtd, 0, 0, 0);
469 		ifc_nand_ctrl->read_bytes = 1;
470 
471 		fsl_ifc_run_command(mtd);
472 
473 		/*
474 		 * The chip always seems to report that it is
475 		 * write-protected, even when it is not.
476 		 */
477 		addr = ifc_nand_ctrl->addr;
478 		if (chip->options & NAND_BUSWIDTH_16)
479 			ifc_out16(ifc_in16(addr) | (NAND_STATUS_WP), addr);
480 		else
481 			ifc_out8(ifc_in8(addr) | (NAND_STATUS_WP), addr);
482 		return;
483 	}
484 
485 	case NAND_CMD_RESET:
486 		ifc_out32(IFC_FIR_OP_CW0 << IFC_NAND_FIR0_OP0_SHIFT,
487 			  &ifc->ifc_nand.nand_fir0);
488 		ifc_out32(NAND_CMD_RESET << IFC_NAND_FCR0_CMD0_SHIFT,
489 			  &ifc->ifc_nand.nand_fcr0);
490 		fsl_ifc_run_command(mtd);
491 		return;
492 
493 	default:
494 		dev_err(priv->dev, "%s: error, unsupported command 0x%x.\n",
495 					__func__, command);
496 	}
497 }
498 
499 static void fsl_ifc_select_chip(struct nand_chip *chip, int cs)
500 {
501 	/* The hardware does not seem to support multiple
502 	 * chips per bank.
503 	 */
504 }
505 
506 /*
507  * Write buf to the IFC NAND Controller Data Buffer
508  */
509 static void fsl_ifc_write_buf(struct nand_chip *chip, const u8 *buf, int len)
510 {
511 	struct mtd_info *mtd = nand_to_mtd(chip);
512 	struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
513 	unsigned int bufsize = mtd->writesize + mtd->oobsize;
514 
515 	if (len <= 0) {
516 		dev_err(priv->dev, "%s: len %d bytes", __func__, len);
517 		return;
518 	}
519 
520 	if ((unsigned int)len > bufsize - ifc_nand_ctrl->index) {
521 		dev_err(priv->dev,
522 			"%s: beyond end of buffer (%d requested, %u available)\n",
523 			__func__, len, bufsize - ifc_nand_ctrl->index);
524 		len = bufsize - ifc_nand_ctrl->index;
525 	}
526 
527 	memcpy_toio(ifc_nand_ctrl->addr + ifc_nand_ctrl->index, buf, len);
528 	ifc_nand_ctrl->index += len;
529 }
530 
531 /*
532  * Read a byte from either the IFC hardware buffer
533  * read function for 8-bit buswidth
534  */
535 static uint8_t fsl_ifc_read_byte(struct nand_chip *chip)
536 {
537 	struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
538 	unsigned int offset;
539 
540 	/*
541 	 * If there are still bytes in the IFC buffer, then use the
542 	 * next byte.
543 	 */
544 	if (ifc_nand_ctrl->index < ifc_nand_ctrl->read_bytes) {
545 		offset = ifc_nand_ctrl->index++;
546 		return ifc_in8(ifc_nand_ctrl->addr + offset);
547 	}
548 
549 	dev_err(priv->dev, "%s: beyond end of buffer\n", __func__);
550 	return ERR_BYTE;
551 }
552 
553 /*
554  * Read two bytes from the IFC hardware buffer
555  * read function for 16-bit buswith
556  */
557 static uint8_t fsl_ifc_read_byte16(struct nand_chip *chip)
558 {
559 	struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
560 	uint16_t data;
561 
562 	/*
563 	 * If there are still bytes in the IFC buffer, then use the
564 	 * next byte.
565 	 */
566 	if (ifc_nand_ctrl->index < ifc_nand_ctrl->read_bytes) {
567 		data = ifc_in16(ifc_nand_ctrl->addr + ifc_nand_ctrl->index);
568 		ifc_nand_ctrl->index += 2;
569 		return (uint8_t) data;
570 	}
571 
572 	dev_err(priv->dev, "%s: beyond end of buffer\n", __func__);
573 	return ERR_BYTE;
574 }
575 
576 /*
577  * Read from the IFC Controller Data Buffer
578  */
579 static void fsl_ifc_read_buf(struct nand_chip *chip, u8 *buf, int len)
580 {
581 	struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
582 	int avail;
583 
584 	if (len < 0) {
585 		dev_err(priv->dev, "%s: len %d bytes", __func__, len);
586 		return;
587 	}
588 
589 	avail = min((unsigned int)len,
590 			ifc_nand_ctrl->read_bytes - ifc_nand_ctrl->index);
591 	memcpy_fromio(buf, ifc_nand_ctrl->addr + ifc_nand_ctrl->index, avail);
592 	ifc_nand_ctrl->index += avail;
593 
594 	if (len > avail)
595 		dev_err(priv->dev,
596 			"%s: beyond end of buffer (%d requested, %d available)\n",
597 			__func__, len, avail);
598 }
599 
600 /*
601  * This function is called after Program and Erase Operations to
602  * check for success or failure.
603  */
604 static int fsl_ifc_wait(struct nand_chip *chip)
605 {
606 	struct mtd_info *mtd = nand_to_mtd(chip);
607 	struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
608 	struct fsl_ifc_ctrl *ctrl = priv->ctrl;
609 	struct fsl_ifc_runtime __iomem *ifc = ctrl->rregs;
610 	u32 nand_fsr;
611 	int status;
612 
613 	/* Use READ_STATUS command, but wait for the device to be ready */
614 	ifc_out32((IFC_FIR_OP_CW0 << IFC_NAND_FIR0_OP0_SHIFT) |
615 		  (IFC_FIR_OP_RDSTAT << IFC_NAND_FIR0_OP1_SHIFT),
616 		  &ifc->ifc_nand.nand_fir0);
617 	ifc_out32(NAND_CMD_STATUS << IFC_NAND_FCR0_CMD0_SHIFT,
618 		  &ifc->ifc_nand.nand_fcr0);
619 	ifc_out32(1, &ifc->ifc_nand.nand_fbcr);
620 	set_addr(mtd, 0, 0, 0);
621 	ifc_nand_ctrl->read_bytes = 1;
622 
623 	fsl_ifc_run_command(mtd);
624 
625 	nand_fsr = ifc_in32(&ifc->ifc_nand.nand_fsr);
626 	status = nand_fsr >> 24;
627 	/*
628 	 * The chip always seems to report that it is
629 	 * write-protected, even when it is not.
630 	 */
631 	return status | NAND_STATUS_WP;
632 }
633 
634 /*
635  * The controller does not check for bitflips in erased pages,
636  * therefore software must check instead.
637  */
638 static int check_erased_page(struct nand_chip *chip, u8 *buf)
639 {
640 	struct mtd_info *mtd = nand_to_mtd(chip);
641 	u8 *ecc = chip->oob_poi;
642 	const int ecc_size = chip->ecc.bytes;
643 	const int pkt_size = chip->ecc.size;
644 	int i, res, bitflips = 0;
645 	struct mtd_oob_region oobregion = { };
646 
647 	mtd_ooblayout_ecc(mtd, 0, &oobregion);
648 	ecc += oobregion.offset;
649 
650 	for (i = 0; i < chip->ecc.steps; ++i) {
651 		res = nand_check_erased_ecc_chunk(buf, pkt_size, ecc, ecc_size,
652 						  NULL, 0,
653 						  chip->ecc.strength);
654 		if (res < 0)
655 			mtd->ecc_stats.failed++;
656 		else
657 			mtd->ecc_stats.corrected += res;
658 
659 		bitflips = max(res, bitflips);
660 		buf += pkt_size;
661 		ecc += ecc_size;
662 	}
663 
664 	return bitflips;
665 }
666 
667 static int fsl_ifc_read_page(struct nand_chip *chip, uint8_t *buf,
668 			     int oob_required, int page)
669 {
670 	struct mtd_info *mtd = nand_to_mtd(chip);
671 	struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
672 	struct fsl_ifc_ctrl *ctrl = priv->ctrl;
673 	struct fsl_ifc_nand_ctrl *nctrl = ifc_nand_ctrl;
674 
675 	nand_read_page_op(chip, page, 0, buf, mtd->writesize);
676 	if (oob_required)
677 		fsl_ifc_read_buf(chip, chip->oob_poi, mtd->oobsize);
678 
679 	if (ctrl->nand_stat & IFC_NAND_EVTER_STAT_ECCER) {
680 		if (!oob_required)
681 			fsl_ifc_read_buf(chip, chip->oob_poi, mtd->oobsize);
682 
683 		return check_erased_page(chip, buf);
684 	}
685 
686 	if (ctrl->nand_stat != IFC_NAND_EVTER_STAT_OPC)
687 		mtd->ecc_stats.failed++;
688 
689 	return nctrl->max_bitflips;
690 }
691 
692 /* ECC will be calculated automatically, and errors will be detected in
693  * waitfunc.
694  */
695 static int fsl_ifc_write_page(struct nand_chip *chip, const uint8_t *buf,
696 			      int oob_required, int page)
697 {
698 	struct mtd_info *mtd = nand_to_mtd(chip);
699 
700 	nand_prog_page_begin_op(chip, page, 0, buf, mtd->writesize);
701 	fsl_ifc_write_buf(chip, chip->oob_poi, mtd->oobsize);
702 
703 	return nand_prog_page_end_op(chip);
704 }
705 
706 static int fsl_ifc_attach_chip(struct nand_chip *chip)
707 {
708 	struct mtd_info *mtd = nand_to_mtd(chip);
709 	struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
710 	struct fsl_ifc_ctrl *ctrl = priv->ctrl;
711 	struct fsl_ifc_global __iomem *ifc_global = ctrl->gregs;
712 	u32 csor;
713 
714 	csor = ifc_in32(&ifc_global->csor_cs[priv->bank].csor);
715 
716 	/* Must also set CSOR_NAND_ECC_ENC_EN if DEC_EN set */
717 	if (csor & CSOR_NAND_ECC_DEC_EN) {
718 		chip->ecc.engine_type = NAND_ECC_ENGINE_TYPE_ON_HOST;
719 		mtd_set_ooblayout(mtd, &fsl_ifc_ooblayout_ops);
720 
721 		/* Hardware generates ECC per 512 Bytes */
722 		chip->ecc.size = 512;
723 		if ((csor & CSOR_NAND_ECC_MODE_MASK) == CSOR_NAND_ECC_MODE_4) {
724 			chip->ecc.bytes = 8;
725 			chip->ecc.strength = 4;
726 		} else {
727 			chip->ecc.bytes = 16;
728 			chip->ecc.strength = 8;
729 		}
730 	} else {
731 		chip->ecc.engine_type = NAND_ECC_ENGINE_TYPE_SOFT;
732 		chip->ecc.algo = NAND_ECC_ALGO_HAMMING;
733 	}
734 
735 	dev_dbg(priv->dev, "%s: nand->numchips = %d\n", __func__,
736 		nanddev_ntargets(&chip->base));
737 	dev_dbg(priv->dev, "%s: nand->chipsize = %lld\n", __func__,
738 	        nanddev_target_size(&chip->base));
739 	dev_dbg(priv->dev, "%s: nand->pagemask = %8x\n", __func__,
740 							chip->pagemask);
741 	dev_dbg(priv->dev, "%s: nand->legacy.chip_delay = %d\n", __func__,
742 		chip->legacy.chip_delay);
743 	dev_dbg(priv->dev, "%s: nand->badblockpos = %d\n", __func__,
744 							chip->badblockpos);
745 	dev_dbg(priv->dev, "%s: nand->chip_shift = %d\n", __func__,
746 							chip->chip_shift);
747 	dev_dbg(priv->dev, "%s: nand->page_shift = %d\n", __func__,
748 							chip->page_shift);
749 	dev_dbg(priv->dev, "%s: nand->phys_erase_shift = %d\n", __func__,
750 							chip->phys_erase_shift);
751 	dev_dbg(priv->dev, "%s: nand->ecc.engine_type = %d\n", __func__,
752 							chip->ecc.engine_type);
753 	dev_dbg(priv->dev, "%s: nand->ecc.steps = %d\n", __func__,
754 							chip->ecc.steps);
755 	dev_dbg(priv->dev, "%s: nand->ecc.bytes = %d\n", __func__,
756 							chip->ecc.bytes);
757 	dev_dbg(priv->dev, "%s: nand->ecc.total = %d\n", __func__,
758 							chip->ecc.total);
759 	dev_dbg(priv->dev, "%s: mtd->ooblayout = %p\n", __func__,
760 							mtd->ooblayout);
761 	dev_dbg(priv->dev, "%s: mtd->flags = %08x\n", __func__, mtd->flags);
762 	dev_dbg(priv->dev, "%s: mtd->size = %lld\n", __func__, mtd->size);
763 	dev_dbg(priv->dev, "%s: mtd->erasesize = %d\n", __func__,
764 							mtd->erasesize);
765 	dev_dbg(priv->dev, "%s: mtd->writesize = %d\n", __func__,
766 							mtd->writesize);
767 	dev_dbg(priv->dev, "%s: mtd->oobsize = %d\n", __func__,
768 							mtd->oobsize);
769 
770 	return 0;
771 }
772 
773 static const struct nand_controller_ops fsl_ifc_controller_ops = {
774 	.attach_chip = fsl_ifc_attach_chip,
775 };
776 
777 static int fsl_ifc_sram_init(struct fsl_ifc_mtd *priv)
778 {
779 	struct fsl_ifc_ctrl *ctrl = priv->ctrl;
780 	struct fsl_ifc_runtime __iomem *ifc_runtime = ctrl->rregs;
781 	struct fsl_ifc_global __iomem *ifc_global = ctrl->gregs;
782 	uint32_t csor = 0, csor_8k = 0, csor_ext = 0;
783 	uint32_t cs = priv->bank;
784 
785 	if (ctrl->version < FSL_IFC_VERSION_1_1_0)
786 		return 0;
787 
788 	if (ctrl->version > FSL_IFC_VERSION_1_1_0) {
789 		u32 ncfgr, status;
790 		int ret;
791 
792 		/* Trigger auto initialization */
793 		ncfgr = ifc_in32(&ifc_runtime->ifc_nand.ncfgr);
794 		ifc_out32(ncfgr | IFC_NAND_NCFGR_SRAM_INIT_EN, &ifc_runtime->ifc_nand.ncfgr);
795 
796 		/* Wait until done */
797 		ret = readx_poll_timeout(ifc_in32, &ifc_runtime->ifc_nand.ncfgr,
798 					 status, !(status & IFC_NAND_NCFGR_SRAM_INIT_EN),
799 					 10, IFC_TIMEOUT_MSECS * 1000);
800 		if (ret)
801 			dev_err(priv->dev, "Failed to initialize SRAM!\n");
802 
803 		return ret;
804 	}
805 
806 	/* Save CSOR and CSOR_ext */
807 	csor = ifc_in32(&ifc_global->csor_cs[cs].csor);
808 	csor_ext = ifc_in32(&ifc_global->csor_cs[cs].csor_ext);
809 
810 	/* chage PageSize 8K and SpareSize 1K*/
811 	csor_8k = (csor & ~(CSOR_NAND_PGS_MASK)) | 0x0018C000;
812 	ifc_out32(csor_8k, &ifc_global->csor_cs[cs].csor);
813 	ifc_out32(0x0000400, &ifc_global->csor_cs[cs].csor_ext);
814 
815 	/* READID */
816 	ifc_out32((IFC_FIR_OP_CW0 << IFC_NAND_FIR0_OP0_SHIFT) |
817 		    (IFC_FIR_OP_UA  << IFC_NAND_FIR0_OP1_SHIFT) |
818 		    (IFC_FIR_OP_RB << IFC_NAND_FIR0_OP2_SHIFT),
819 		    &ifc_runtime->ifc_nand.nand_fir0);
820 	ifc_out32(NAND_CMD_READID << IFC_NAND_FCR0_CMD0_SHIFT,
821 		    &ifc_runtime->ifc_nand.nand_fcr0);
822 	ifc_out32(0x0, &ifc_runtime->ifc_nand.row3);
823 
824 	ifc_out32(0x0, &ifc_runtime->ifc_nand.nand_fbcr);
825 
826 	/* Program ROW0/COL0 */
827 	ifc_out32(0x0, &ifc_runtime->ifc_nand.row0);
828 	ifc_out32(0x0, &ifc_runtime->ifc_nand.col0);
829 
830 	/* set the chip select for NAND Transaction */
831 	ifc_out32(cs << IFC_NAND_CSEL_SHIFT,
832 		&ifc_runtime->ifc_nand.nand_csel);
833 
834 	/* start read seq */
835 	ifc_out32(IFC_NAND_SEQ_STRT_FIR_STRT,
836 		&ifc_runtime->ifc_nand.nandseq_strt);
837 
838 	/* wait for command complete flag or timeout */
839 	wait_event_timeout(ctrl->nand_wait, ctrl->nand_stat,
840 			   msecs_to_jiffies(IFC_TIMEOUT_MSECS));
841 
842 	if (ctrl->nand_stat != IFC_NAND_EVTER_STAT_OPC) {
843 		pr_err("fsl-ifc: Failed to Initialise SRAM\n");
844 		return -ETIMEDOUT;
845 	}
846 
847 	/* Restore CSOR and CSOR_ext */
848 	ifc_out32(csor, &ifc_global->csor_cs[cs].csor);
849 	ifc_out32(csor_ext, &ifc_global->csor_cs[cs].csor_ext);
850 
851 	return 0;
852 }
853 
854 static int fsl_ifc_chip_init(struct fsl_ifc_mtd *priv)
855 {
856 	struct fsl_ifc_ctrl *ctrl = priv->ctrl;
857 	struct fsl_ifc_global __iomem *ifc_global = ctrl->gregs;
858 	struct fsl_ifc_runtime __iomem *ifc_runtime = ctrl->rregs;
859 	struct nand_chip *chip = &priv->chip;
860 	struct mtd_info *mtd = nand_to_mtd(&priv->chip);
861 	u32 csor;
862 	int ret;
863 
864 	/* Fill in fsl_ifc_mtd structure */
865 	mtd->dev.parent = priv->dev;
866 	nand_set_flash_node(chip, priv->dev->of_node);
867 
868 	/* fill in nand_chip structure */
869 	/* set up function call table */
870 	if ((ifc_in32(&ifc_global->cspr_cs[priv->bank].cspr))
871 		& CSPR_PORT_SIZE_16)
872 		chip->legacy.read_byte = fsl_ifc_read_byte16;
873 	else
874 		chip->legacy.read_byte = fsl_ifc_read_byte;
875 
876 	chip->legacy.write_buf = fsl_ifc_write_buf;
877 	chip->legacy.read_buf = fsl_ifc_read_buf;
878 	chip->legacy.select_chip = fsl_ifc_select_chip;
879 	chip->legacy.cmdfunc = fsl_ifc_cmdfunc;
880 	chip->legacy.waitfunc = fsl_ifc_wait;
881 	chip->legacy.set_features = nand_get_set_features_notsupp;
882 	chip->legacy.get_features = nand_get_set_features_notsupp;
883 
884 	chip->bbt_td = &bbt_main_descr;
885 	chip->bbt_md = &bbt_mirror_descr;
886 
887 	ifc_out32(0x0, &ifc_runtime->ifc_nand.ncfgr);
888 
889 	/* set up nand options */
890 	chip->bbt_options = NAND_BBT_USE_FLASH;
891 	chip->options = NAND_NO_SUBPAGE_WRITE;
892 
893 	if (ifc_in32(&ifc_global->cspr_cs[priv->bank].cspr)
894 		& CSPR_PORT_SIZE_16) {
895 		chip->legacy.read_byte = fsl_ifc_read_byte16;
896 		chip->options |= NAND_BUSWIDTH_16;
897 	} else {
898 		chip->legacy.read_byte = fsl_ifc_read_byte;
899 	}
900 
901 	chip->controller = &ifc_nand_ctrl->controller;
902 	nand_set_controller_data(chip, priv);
903 
904 	chip->ecc.read_page = fsl_ifc_read_page;
905 	chip->ecc.write_page = fsl_ifc_write_page;
906 
907 	csor = ifc_in32(&ifc_global->csor_cs[priv->bank].csor);
908 
909 	switch (csor & CSOR_NAND_PGS_MASK) {
910 	case CSOR_NAND_PGS_512:
911 		if (!(chip->options & NAND_BUSWIDTH_16)) {
912 			/* Avoid conflict with bad block marker */
913 			bbt_main_descr.offs = 0;
914 			bbt_mirror_descr.offs = 0;
915 		}
916 
917 		priv->bufnum_mask = 15;
918 		break;
919 
920 	case CSOR_NAND_PGS_2K:
921 		priv->bufnum_mask = 3;
922 		break;
923 
924 	case CSOR_NAND_PGS_4K:
925 		priv->bufnum_mask = 1;
926 		break;
927 
928 	case CSOR_NAND_PGS_8K:
929 		priv->bufnum_mask = 0;
930 		break;
931 
932 	default:
933 		dev_err(priv->dev, "bad csor %#x: bad page size\n", csor);
934 		return -ENODEV;
935 	}
936 
937 	ret = fsl_ifc_sram_init(priv);
938 	if (ret)
939 		return ret;
940 
941 	/*
942 	 * As IFC version 2.0.0 has 16KB of internal SRAM as compared to older
943 	 * versions which had 8KB. Hence bufnum mask needs to be updated.
944 	 */
945 	if (ctrl->version >= FSL_IFC_VERSION_2_0_0)
946 		priv->bufnum_mask = (priv->bufnum_mask * 2) + 1;
947 
948 	return 0;
949 }
950 
951 static int fsl_ifc_chip_remove(struct fsl_ifc_mtd *priv)
952 {
953 	struct mtd_info *mtd = nand_to_mtd(&priv->chip);
954 
955 	kfree(mtd->name);
956 
957 	if (priv->vbase)
958 		iounmap(priv->vbase);
959 
960 	ifc_nand_ctrl->chips[priv->bank] = NULL;
961 
962 	return 0;
963 }
964 
965 static int match_bank(struct fsl_ifc_global __iomem *ifc_global, int bank,
966 		      phys_addr_t addr)
967 {
968 	u32 cspr = ifc_in32(&ifc_global->cspr_cs[bank].cspr);
969 
970 	if (!(cspr & CSPR_V))
971 		return 0;
972 	if ((cspr & CSPR_MSEL) != CSPR_MSEL_NAND)
973 		return 0;
974 
975 	return (cspr & CSPR_BA) == convert_ifc_address(addr);
976 }
977 
978 static DEFINE_MUTEX(fsl_ifc_nand_mutex);
979 
980 static int fsl_ifc_nand_probe(struct platform_device *dev)
981 {
982 	struct fsl_ifc_runtime __iomem *ifc;
983 	struct fsl_ifc_mtd *priv;
984 	struct resource res;
985 	static const char *part_probe_types[]
986 		= { "cmdlinepart", "RedBoot", "ofpart", NULL };
987 	int ret;
988 	int bank;
989 	struct device_node *node = dev->dev.of_node;
990 	struct mtd_info *mtd;
991 
992 	if (!fsl_ifc_ctrl_dev || !fsl_ifc_ctrl_dev->rregs)
993 		return -ENODEV;
994 	ifc = fsl_ifc_ctrl_dev->rregs;
995 
996 	/* get, allocate and map the memory resource */
997 	ret = of_address_to_resource(node, 0, &res);
998 	if (ret) {
999 		dev_err(&dev->dev, "%s: failed to get resource\n", __func__);
1000 		return ret;
1001 	}
1002 
1003 	/* find which chip select it is connected to */
1004 	for (bank = 0; bank < fsl_ifc_ctrl_dev->banks; bank++) {
1005 		if (match_bank(fsl_ifc_ctrl_dev->gregs, bank, res.start))
1006 			break;
1007 	}
1008 
1009 	if (bank >= fsl_ifc_ctrl_dev->banks) {
1010 		dev_err(&dev->dev, "%s: address did not match any chip selects\n",
1011 			__func__);
1012 		return -ENODEV;
1013 	}
1014 
1015 	priv = devm_kzalloc(&dev->dev, sizeof(*priv), GFP_KERNEL);
1016 	if (!priv)
1017 		return -ENOMEM;
1018 
1019 	mutex_lock(&fsl_ifc_nand_mutex);
1020 	if (!fsl_ifc_ctrl_dev->nand) {
1021 		ifc_nand_ctrl = kzalloc(sizeof(*ifc_nand_ctrl), GFP_KERNEL);
1022 		if (!ifc_nand_ctrl) {
1023 			mutex_unlock(&fsl_ifc_nand_mutex);
1024 			return -ENOMEM;
1025 		}
1026 
1027 		ifc_nand_ctrl->read_bytes = 0;
1028 		ifc_nand_ctrl->index = 0;
1029 		ifc_nand_ctrl->addr = NULL;
1030 		fsl_ifc_ctrl_dev->nand = ifc_nand_ctrl;
1031 
1032 		nand_controller_init(&ifc_nand_ctrl->controller);
1033 	} else {
1034 		ifc_nand_ctrl = fsl_ifc_ctrl_dev->nand;
1035 	}
1036 	mutex_unlock(&fsl_ifc_nand_mutex);
1037 
1038 	ifc_nand_ctrl->chips[bank] = priv;
1039 	priv->bank = bank;
1040 	priv->ctrl = fsl_ifc_ctrl_dev;
1041 	priv->dev = &dev->dev;
1042 
1043 	priv->vbase = ioremap(res.start, resource_size(&res));
1044 	if (!priv->vbase) {
1045 		dev_err(priv->dev, "%s: failed to map chip region\n", __func__);
1046 		ret = -ENOMEM;
1047 		goto err;
1048 	}
1049 
1050 	dev_set_drvdata(priv->dev, priv);
1051 
1052 	ifc_out32(IFC_NAND_EVTER_EN_OPC_EN |
1053 		  IFC_NAND_EVTER_EN_FTOER_EN |
1054 		  IFC_NAND_EVTER_EN_WPER_EN,
1055 		  &ifc->ifc_nand.nand_evter_en);
1056 
1057 	/* enable NAND Machine Interrupts */
1058 	ifc_out32(IFC_NAND_EVTER_INTR_OPCIR_EN |
1059 		  IFC_NAND_EVTER_INTR_FTOERIR_EN |
1060 		  IFC_NAND_EVTER_INTR_WPERIR_EN,
1061 		  &ifc->ifc_nand.nand_evter_intr_en);
1062 
1063 	mtd = nand_to_mtd(&priv->chip);
1064 	mtd->name = kasprintf(GFP_KERNEL, "%llx.flash", (u64)res.start);
1065 	if (!mtd->name) {
1066 		ret = -ENOMEM;
1067 		goto err;
1068 	}
1069 
1070 	ret = fsl_ifc_chip_init(priv);
1071 	if (ret)
1072 		goto err;
1073 
1074 	priv->chip.controller->ops = &fsl_ifc_controller_ops;
1075 	ret = nand_scan(&priv->chip, 1);
1076 	if (ret)
1077 		goto err;
1078 
1079 	/* First look for RedBoot table or partitions on the command
1080 	 * line, these take precedence over device tree information */
1081 	ret = mtd_device_parse_register(mtd, part_probe_types, NULL, NULL, 0);
1082 	if (ret)
1083 		goto cleanup_nand;
1084 
1085 	dev_info(priv->dev, "IFC NAND device at 0x%llx, bank %d\n",
1086 		 (unsigned long long)res.start, priv->bank);
1087 
1088 	return 0;
1089 
1090 cleanup_nand:
1091 	nand_cleanup(&priv->chip);
1092 err:
1093 	fsl_ifc_chip_remove(priv);
1094 
1095 	return ret;
1096 }
1097 
1098 static void fsl_ifc_nand_remove(struct platform_device *dev)
1099 {
1100 	struct fsl_ifc_mtd *priv = dev_get_drvdata(&dev->dev);
1101 	struct nand_chip *chip = &priv->chip;
1102 	int ret;
1103 
1104 	ret = mtd_device_unregister(nand_to_mtd(chip));
1105 	WARN_ON(ret);
1106 	nand_cleanup(chip);
1107 
1108 	fsl_ifc_chip_remove(priv);
1109 
1110 	mutex_lock(&fsl_ifc_nand_mutex);
1111 	ifc_nand_ctrl->counter--;
1112 	if (!ifc_nand_ctrl->counter) {
1113 		fsl_ifc_ctrl_dev->nand = NULL;
1114 		kfree(ifc_nand_ctrl);
1115 	}
1116 	mutex_unlock(&fsl_ifc_nand_mutex);
1117 }
1118 
1119 static const struct of_device_id fsl_ifc_nand_match[] = {
1120 	{
1121 		.compatible = "fsl,ifc-nand",
1122 	},
1123 	{}
1124 };
1125 MODULE_DEVICE_TABLE(of, fsl_ifc_nand_match);
1126 
1127 static struct platform_driver fsl_ifc_nand_driver = {
1128 	.driver = {
1129 		.name	= "fsl,ifc-nand",
1130 		.of_match_table = fsl_ifc_nand_match,
1131 	},
1132 	.probe       = fsl_ifc_nand_probe,
1133 	.remove      = fsl_ifc_nand_remove,
1134 };
1135 
1136 module_platform_driver(fsl_ifc_nand_driver);
1137 
1138 MODULE_LICENSE("GPL");
1139 MODULE_AUTHOR("Freescale");
1140 MODULE_DESCRIPTION("Freescale Integrated Flash Controller MTD NAND driver");
1141