xref: /openbmc/u-boot/drivers/mtd/nand/raw/sunxi_nand.c (revision 2a1eade825149647ffbe4da5dce0883d45d3a137)
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * Copyright (C) 2013 Boris BREZILLON <b.brezillon.dev@gmail.com>
4  * Copyright (C) 2015 Roy Spliet <r.spliet@ultimaker.com>
5  *
6  * Derived from:
7  *	https://github.com/yuq/sunxi-nfc-mtd
8  *	Copyright (C) 2013 Qiang Yu <yuq825@gmail.com>
9  *
10  *	https://github.com/hno/Allwinner-Info
11  *	Copyright (C) 2013 Henrik Nordström <Henrik Nordström>
12  *
13  *	Copyright (C) 2013 Dmitriy B. <rzk333@gmail.com>
14  *	Copyright (C) 2013 Sergey Lapin <slapin@ossfans.org>
15  *
16  * This program is free software; you can redistribute it and/or modify
17  * it under the terms of the GNU General Public License as published by
18  * the Free Software Foundation; either version 2 of the License, or
19  * (at your option) any later version.
20  *
21  * This program is distributed in the hope that it will be useful,
22  * but WITHOUT ANY WARRANTY; without even the implied warranty of
23  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
24  * GNU General Public License for more details.
25  */
26 
27 #include <common.h>
28 #include <fdtdec.h>
29 #include <memalign.h>
30 #include <nand.h>
31 
32 #include <linux/kernel.h>
33 #include <linux/mtd/mtd.h>
34 #include <linux/mtd/rawnand.h>
35 #include <linux/mtd/partitions.h>
36 #include <linux/io.h>
37 
38 #include <asm/gpio.h>
39 #include <asm/arch/clock.h>
40 
41 DECLARE_GLOBAL_DATA_PTR;
42 
43 #define NFC_REG_CTL		0x0000
44 #define NFC_REG_ST		0x0004
45 #define NFC_REG_INT		0x0008
46 #define NFC_REG_TIMING_CTL	0x000C
47 #define NFC_REG_TIMING_CFG	0x0010
48 #define NFC_REG_ADDR_LOW	0x0014
49 #define NFC_REG_ADDR_HIGH	0x0018
50 #define NFC_REG_SECTOR_NUM	0x001C
51 #define NFC_REG_CNT		0x0020
52 #define NFC_REG_CMD		0x0024
53 #define NFC_REG_RCMD_SET	0x0028
54 #define NFC_REG_WCMD_SET	0x002C
55 #define NFC_REG_IO_DATA		0x0030
56 #define NFC_REG_ECC_CTL		0x0034
57 #define NFC_REG_ECC_ST		0x0038
58 #define NFC_REG_DEBUG		0x003C
59 #define NFC_REG_ECC_ERR_CNT(x)	((0x0040 + (x)) & ~0x3)
60 #define NFC_REG_USER_DATA(x)	(0x0050 + ((x) * 4))
61 #define NFC_REG_SPARE_AREA	0x00A0
62 #define NFC_REG_PAT_ID		0x00A4
63 #define NFC_RAM0_BASE		0x0400
64 #define NFC_RAM1_BASE		0x0800
65 
66 /* define bit use in NFC_CTL */
67 #define NFC_EN			BIT(0)
68 #define NFC_RESET		BIT(1)
69 #define NFC_BUS_WIDTH_MSK	BIT(2)
70 #define NFC_BUS_WIDTH_8		(0 << 2)
71 #define NFC_BUS_WIDTH_16	(1 << 2)
72 #define NFC_RB_SEL_MSK		BIT(3)
73 #define NFC_RB_SEL(x)		((x) << 3)
74 #define NFC_CE_SEL_MSK		(0x7 << 24)
75 #define NFC_CE_SEL(x)		((x) << 24)
76 #define NFC_CE_CTL		BIT(6)
77 #define NFC_PAGE_SHIFT_MSK	(0xf << 8)
78 #define NFC_PAGE_SHIFT(x)	(((x) < 10 ? 0 : (x) - 10) << 8)
79 #define NFC_SAM			BIT(12)
80 #define NFC_RAM_METHOD		BIT(14)
81 #define NFC_DEBUG_CTL		BIT(31)
82 
83 /* define bit use in NFC_ST */
84 #define NFC_RB_B2R		BIT(0)
85 #define NFC_CMD_INT_FLAG	BIT(1)
86 #define NFC_DMA_INT_FLAG	BIT(2)
87 #define NFC_CMD_FIFO_STATUS	BIT(3)
88 #define NFC_STA			BIT(4)
89 #define NFC_NATCH_INT_FLAG	BIT(5)
90 #define NFC_RB_STATE(x)		BIT(x + 8)
91 
92 /* define bit use in NFC_INT */
93 #define NFC_B2R_INT_ENABLE	BIT(0)
94 #define NFC_CMD_INT_ENABLE	BIT(1)
95 #define NFC_DMA_INT_ENABLE	BIT(2)
96 #define NFC_INT_MASK		(NFC_B2R_INT_ENABLE | \
97 				 NFC_CMD_INT_ENABLE | \
98 				 NFC_DMA_INT_ENABLE)
99 
100 /* define bit use in NFC_TIMING_CTL */
101 #define NFC_TIMING_CTL_EDO	BIT(8)
102 
103 /* define NFC_TIMING_CFG register layout */
104 #define NFC_TIMING_CFG(tWB, tADL, tWHR, tRHW, tCAD)		\
105 	(((tWB) & 0x3) | (((tADL) & 0x3) << 2) |		\
106 	(((tWHR) & 0x3) << 4) | (((tRHW) & 0x3) << 6) |		\
107 	(((tCAD) & 0x7) << 8))
108 
109 /* define bit use in NFC_CMD */
110 #define NFC_CMD_LOW_BYTE_MSK	0xff
111 #define NFC_CMD_HIGH_BYTE_MSK	(0xff << 8)
112 #define NFC_CMD(x)		(x)
113 #define NFC_ADR_NUM_MSK		(0x7 << 16)
114 #define NFC_ADR_NUM(x)		(((x) - 1) << 16)
115 #define NFC_SEND_ADR		BIT(19)
116 #define NFC_ACCESS_DIR		BIT(20)
117 #define NFC_DATA_TRANS		BIT(21)
118 #define NFC_SEND_CMD1		BIT(22)
119 #define NFC_WAIT_FLAG		BIT(23)
120 #define NFC_SEND_CMD2		BIT(24)
121 #define NFC_SEQ			BIT(25)
122 #define NFC_DATA_SWAP_METHOD	BIT(26)
123 #define NFC_ROW_AUTO_INC	BIT(27)
124 #define NFC_SEND_CMD3		BIT(28)
125 #define NFC_SEND_CMD4		BIT(29)
126 #define NFC_CMD_TYPE_MSK	(0x3 << 30)
127 #define NFC_NORMAL_OP		(0 << 30)
128 #define NFC_ECC_OP		(1 << 30)
129 #define NFC_PAGE_OP		(2 << 30)
130 
131 /* define bit use in NFC_RCMD_SET */
132 #define NFC_READ_CMD_MSK	0xff
133 #define NFC_RND_READ_CMD0_MSK	(0xff << 8)
134 #define NFC_RND_READ_CMD1_MSK	(0xff << 16)
135 
136 /* define bit use in NFC_WCMD_SET */
137 #define NFC_PROGRAM_CMD_MSK	0xff
138 #define NFC_RND_WRITE_CMD_MSK	(0xff << 8)
139 #define NFC_READ_CMD0_MSK	(0xff << 16)
140 #define NFC_READ_CMD1_MSK	(0xff << 24)
141 
142 /* define bit use in NFC_ECC_CTL */
143 #define NFC_ECC_EN		BIT(0)
144 #define NFC_ECC_PIPELINE	BIT(3)
145 #define NFC_ECC_EXCEPTION	BIT(4)
146 #define NFC_ECC_BLOCK_SIZE_MSK	BIT(5)
147 #define NFC_ECC_BLOCK_512	(1 << 5)
148 #define NFC_RANDOM_EN		BIT(9)
149 #define NFC_RANDOM_DIRECTION	BIT(10)
150 #define NFC_ECC_MODE_MSK	(0xf << 12)
151 #define NFC_ECC_MODE(x)		((x) << 12)
152 #define NFC_RANDOM_SEED_MSK	(0x7fff << 16)
153 #define NFC_RANDOM_SEED(x)	((x) << 16)
154 
155 /* define bit use in NFC_ECC_ST */
156 #define NFC_ECC_ERR(x)		BIT(x)
157 #define NFC_ECC_PAT_FOUND(x)	BIT(x + 16)
158 #define NFC_ECC_ERR_CNT(b, x)	(((x) >> ((b) * 8)) & 0xff)
159 
160 #define NFC_DEFAULT_TIMEOUT_MS	1000
161 
162 #define NFC_SRAM_SIZE		1024
163 
164 #define NFC_MAX_CS		7
165 
166 /*
167  * Ready/Busy detection type: describes the Ready/Busy detection modes
168  *
169  * @RB_NONE:	no external detection available, rely on STATUS command
170  *		and software timeouts
171  * @RB_NATIVE:	use sunxi NAND controller Ready/Busy support. The Ready/Busy
172  *		pin of the NAND flash chip must be connected to one of the
173  *		native NAND R/B pins (those which can be muxed to the NAND
174  *		Controller)
175  * @RB_GPIO:	use a simple GPIO to handle Ready/Busy status. The Ready/Busy
176  *		pin of the NAND flash chip must be connected to a GPIO capable
177  *		pin.
178  */
179 enum sunxi_nand_rb_type {
180 	RB_NONE,
181 	RB_NATIVE,
182 	RB_GPIO,
183 };
184 
185 /*
186  * Ready/Busy structure: stores information related to Ready/Busy detection
187  *
188  * @type:	the Ready/Busy detection mode
189  * @info:	information related to the R/B detection mode. Either a gpio
190  *		id or a native R/B id (those supported by the NAND controller).
191  */
192 struct sunxi_nand_rb {
193 	enum sunxi_nand_rb_type type;
194 	union {
195 		struct gpio_desc gpio;
196 		int nativeid;
197 	} info;
198 };
199 
200 /*
201  * Chip Select structure: stores information related to NAND Chip Select
202  *
203  * @cs:		the NAND CS id used to communicate with a NAND Chip
204  * @rb:		the Ready/Busy description
205  */
206 struct sunxi_nand_chip_sel {
207 	u8 cs;
208 	struct sunxi_nand_rb rb;
209 };
210 
211 /*
212  * sunxi HW ECC infos: stores information related to HW ECC support
213  *
214  * @mode:	the sunxi ECC mode field deduced from ECC requirements
215  * @layout:	the OOB layout depending on the ECC requirements and the
216  *		selected ECC mode
217  */
218 struct sunxi_nand_hw_ecc {
219 	int mode;
220 	struct nand_ecclayout layout;
221 };
222 
223 /*
224  * NAND chip structure: stores NAND chip device related information
225  *
226  * @node:		used to store NAND chips into a list
227  * @nand:		base NAND chip structure
228  * @mtd:		base MTD structure
229  * @clk_rate:		clk_rate required for this NAND chip
230  * @timing_cfg		TIMING_CFG register value for this NAND chip
231  * @selected:		current active CS
232  * @nsels:		number of CS lines required by the NAND chip
233  * @sels:		array of CS lines descriptions
234  */
235 struct sunxi_nand_chip {
236 	struct list_head node;
237 	struct nand_chip nand;
238 	unsigned long clk_rate;
239 	u32 timing_cfg;
240 	u32 timing_ctl;
241 	int selected;
242 	int addr_cycles;
243 	u32 addr[2];
244 	int cmd_cycles;
245 	u8 cmd[2];
246 	int nsels;
247 	struct sunxi_nand_chip_sel sels[0];
248 };
249 
250 static inline struct sunxi_nand_chip *to_sunxi_nand(struct nand_chip *nand)
251 {
252 	return container_of(nand, struct sunxi_nand_chip, nand);
253 }
254 
255 /*
256  * NAND Controller structure: stores sunxi NAND controller information
257  *
258  * @controller:		base controller structure
259  * @dev:		parent device (used to print error messages)
260  * @regs:		NAND controller registers
261  * @ahb_clk:		NAND Controller AHB clock
262  * @mod_clk:		NAND Controller mod clock
263  * @assigned_cs:	bitmask describing already assigned CS lines
264  * @clk_rate:		NAND controller current clock rate
265  * @chips:		a list containing all the NAND chips attached to
266  *			this NAND controller
267  * @complete:		a completion object used to wait for NAND
268  *			controller events
269  */
270 struct sunxi_nfc {
271 	struct nand_hw_control controller;
272 	struct device *dev;
273 	void __iomem *regs;
274 	struct clk *ahb_clk;
275 	struct clk *mod_clk;
276 	unsigned long assigned_cs;
277 	unsigned long clk_rate;
278 	struct list_head chips;
279 };
280 
281 static inline struct sunxi_nfc *to_sunxi_nfc(struct nand_hw_control *ctrl)
282 {
283 	return container_of(ctrl, struct sunxi_nfc, controller);
284 }
285 
286 static void sunxi_nfc_set_clk_rate(unsigned long hz)
287 {
288 	struct sunxi_ccm_reg *const ccm =
289 	(struct sunxi_ccm_reg *)SUNXI_CCM_BASE;
290 	int div_m, div_n;
291 
292 	div_m = (clock_get_pll6() + hz - 1) / hz;
293 	for (div_n = 0; div_n < 3 && div_m > 16; div_n++) {
294 		if (div_m % 2)
295 			div_m++;
296 		div_m >>= 1;
297 	}
298 	if (div_m > 16)
299 		div_m = 16;
300 
301 	/* config mod clock */
302 	writel(CCM_NAND_CTRL_ENABLE | CCM_NAND_CTRL_PLL6 |
303 	       CCM_NAND_CTRL_N(div_n) | CCM_NAND_CTRL_M(div_m),
304 	       &ccm->nand0_clk_cfg);
305 
306 	/* gate on nand clock */
307 	setbits_le32(&ccm->ahb_gate0, (1 << AHB_GATE_OFFSET_NAND0));
308 #ifdef CONFIG_MACH_SUN9I
309 	setbits_le32(&ccm->ahb_gate1, (1 << AHB_GATE_OFFSET_DMA));
310 #else
311 	setbits_le32(&ccm->ahb_gate0, (1 << AHB_GATE_OFFSET_DMA));
312 #endif
313 }
314 
315 static int sunxi_nfc_wait_int(struct sunxi_nfc *nfc, u32 flags,
316 			      unsigned int timeout_ms)
317 {
318 	unsigned int timeout_ticks;
319 	u32 time_start, status;
320 	int ret = -ETIMEDOUT;
321 
322 	if (!timeout_ms)
323 		timeout_ms = NFC_DEFAULT_TIMEOUT_MS;
324 
325 	timeout_ticks = (timeout_ms * CONFIG_SYS_HZ) / 1000;
326 
327 	time_start = get_timer(0);
328 
329 	do {
330 		status = readl(nfc->regs + NFC_REG_ST);
331 		if ((status & flags) == flags) {
332 			ret = 0;
333 			break;
334 		}
335 
336 		udelay(1);
337 	} while (get_timer(time_start) < timeout_ticks);
338 
339 	writel(status & flags, nfc->regs + NFC_REG_ST);
340 
341 	return ret;
342 }
343 
344 static int sunxi_nfc_wait_cmd_fifo_empty(struct sunxi_nfc *nfc)
345 {
346 	unsigned long timeout = (CONFIG_SYS_HZ *
347 				 NFC_DEFAULT_TIMEOUT_MS) / 1000;
348 	u32 time_start;
349 
350 	time_start = get_timer(0);
351 	do {
352 		if (!(readl(nfc->regs + NFC_REG_ST) & NFC_CMD_FIFO_STATUS))
353 			return 0;
354 	} while (get_timer(time_start) < timeout);
355 
356 	dev_err(nfc->dev, "wait for empty cmd FIFO timedout\n");
357 	return -ETIMEDOUT;
358 }
359 
360 static int sunxi_nfc_rst(struct sunxi_nfc *nfc)
361 {
362 	unsigned long timeout = (CONFIG_SYS_HZ *
363 				 NFC_DEFAULT_TIMEOUT_MS) / 1000;
364 	u32 time_start;
365 
366 	writel(0, nfc->regs + NFC_REG_ECC_CTL);
367 	writel(NFC_RESET, nfc->regs + NFC_REG_CTL);
368 
369 	time_start = get_timer(0);
370 	do {
371 		if (!(readl(nfc->regs + NFC_REG_CTL) & NFC_RESET))
372 			return 0;
373 	} while (get_timer(time_start) < timeout);
374 
375 	dev_err(nfc->dev, "wait for NAND controller reset timedout\n");
376 	return -ETIMEDOUT;
377 }
378 
379 static int sunxi_nfc_dev_ready(struct mtd_info *mtd)
380 {
381 	struct nand_chip *nand = mtd_to_nand(mtd);
382 	struct sunxi_nand_chip *sunxi_nand = to_sunxi_nand(nand);
383 	struct sunxi_nfc *nfc = to_sunxi_nfc(sunxi_nand->nand.controller);
384 	struct sunxi_nand_rb *rb;
385 	unsigned long timeo = (sunxi_nand->nand.state == FL_ERASING ? 400 : 20);
386 	int ret;
387 
388 	if (sunxi_nand->selected < 0)
389 		return 0;
390 
391 	rb = &sunxi_nand->sels[sunxi_nand->selected].rb;
392 
393 	switch (rb->type) {
394 	case RB_NATIVE:
395 		ret = !!(readl(nfc->regs + NFC_REG_ST) &
396 			 NFC_RB_STATE(rb->info.nativeid));
397 		if (ret)
398 			break;
399 
400 		sunxi_nfc_wait_int(nfc, NFC_RB_B2R, timeo);
401 		ret = !!(readl(nfc->regs + NFC_REG_ST) &
402 			 NFC_RB_STATE(rb->info.nativeid));
403 		break;
404 	case RB_GPIO:
405 		ret = dm_gpio_get_value(&rb->info.gpio);
406 		break;
407 	case RB_NONE:
408 	default:
409 		ret = 0;
410 		dev_err(nfc->dev, "cannot check R/B NAND status!\n");
411 		break;
412 	}
413 
414 	return ret;
415 }
416 
417 static void sunxi_nfc_select_chip(struct mtd_info *mtd, int chip)
418 {
419 	struct nand_chip *nand = mtd_to_nand(mtd);
420 	struct sunxi_nand_chip *sunxi_nand = to_sunxi_nand(nand);
421 	struct sunxi_nfc *nfc = to_sunxi_nfc(sunxi_nand->nand.controller);
422 	struct sunxi_nand_chip_sel *sel;
423 	u32 ctl;
424 
425 	if (chip > 0 && chip >= sunxi_nand->nsels)
426 		return;
427 
428 	if (chip == sunxi_nand->selected)
429 		return;
430 
431 	ctl = readl(nfc->regs + NFC_REG_CTL) &
432 	      ~(NFC_PAGE_SHIFT_MSK | NFC_CE_SEL_MSK | NFC_RB_SEL_MSK | NFC_EN);
433 
434 	if (chip >= 0) {
435 		sel = &sunxi_nand->sels[chip];
436 
437 		ctl |= NFC_CE_SEL(sel->cs) | NFC_EN |
438 		       NFC_PAGE_SHIFT(nand->page_shift - 10);
439 		if (sel->rb.type == RB_NONE) {
440 			nand->dev_ready = NULL;
441 		} else {
442 			nand->dev_ready = sunxi_nfc_dev_ready;
443 			if (sel->rb.type == RB_NATIVE)
444 				ctl |= NFC_RB_SEL(sel->rb.info.nativeid);
445 		}
446 
447 		writel(mtd->writesize, nfc->regs + NFC_REG_SPARE_AREA);
448 
449 		if (nfc->clk_rate != sunxi_nand->clk_rate) {
450 			sunxi_nfc_set_clk_rate(sunxi_nand->clk_rate);
451 			nfc->clk_rate = sunxi_nand->clk_rate;
452 		}
453 	}
454 
455 	writel(sunxi_nand->timing_ctl, nfc->regs + NFC_REG_TIMING_CTL);
456 	writel(sunxi_nand->timing_cfg, nfc->regs + NFC_REG_TIMING_CFG);
457 	writel(ctl, nfc->regs + NFC_REG_CTL);
458 
459 	sunxi_nand->selected = chip;
460 }
461 
462 static void sunxi_nfc_read_buf(struct mtd_info *mtd, uint8_t *buf, int len)
463 {
464 	struct nand_chip *nand = mtd_to_nand(mtd);
465 	struct sunxi_nand_chip *sunxi_nand = to_sunxi_nand(nand);
466 	struct sunxi_nfc *nfc = to_sunxi_nfc(sunxi_nand->nand.controller);
467 	int ret;
468 	int cnt;
469 	int offs = 0;
470 	u32 tmp;
471 
472 	while (len > offs) {
473 		cnt = min(len - offs, NFC_SRAM_SIZE);
474 
475 		ret = sunxi_nfc_wait_cmd_fifo_empty(nfc);
476 		if (ret)
477 			break;
478 
479 		writel(cnt, nfc->regs + NFC_REG_CNT);
480 		tmp = NFC_DATA_TRANS | NFC_DATA_SWAP_METHOD;
481 		writel(tmp, nfc->regs + NFC_REG_CMD);
482 
483 		ret = sunxi_nfc_wait_int(nfc, NFC_CMD_INT_FLAG, 0);
484 		if (ret)
485 			break;
486 
487 		if (buf)
488 			memcpy_fromio(buf + offs, nfc->regs + NFC_RAM0_BASE,
489 				      cnt);
490 		offs += cnt;
491 	}
492 }
493 
494 static void sunxi_nfc_write_buf(struct mtd_info *mtd, const uint8_t *buf,
495 				int len)
496 {
497 	struct nand_chip *nand = mtd_to_nand(mtd);
498 	struct sunxi_nand_chip *sunxi_nand = to_sunxi_nand(nand);
499 	struct sunxi_nfc *nfc = to_sunxi_nfc(sunxi_nand->nand.controller);
500 	int ret;
501 	int cnt;
502 	int offs = 0;
503 	u32 tmp;
504 
505 	while (len > offs) {
506 		cnt = min(len - offs, NFC_SRAM_SIZE);
507 
508 		ret = sunxi_nfc_wait_cmd_fifo_empty(nfc);
509 		if (ret)
510 			break;
511 
512 		writel(cnt, nfc->regs + NFC_REG_CNT);
513 		memcpy_toio(nfc->regs + NFC_RAM0_BASE, buf + offs, cnt);
514 		tmp = NFC_DATA_TRANS | NFC_DATA_SWAP_METHOD |
515 		      NFC_ACCESS_DIR;
516 		writel(tmp, nfc->regs + NFC_REG_CMD);
517 
518 		ret = sunxi_nfc_wait_int(nfc, NFC_CMD_INT_FLAG, 0);
519 		if (ret)
520 			break;
521 
522 		offs += cnt;
523 	}
524 }
525 
526 static uint8_t sunxi_nfc_read_byte(struct mtd_info *mtd)
527 {
528 	uint8_t ret;
529 
530 	sunxi_nfc_read_buf(mtd, &ret, 1);
531 
532 	return ret;
533 }
534 
535 static void sunxi_nfc_cmd_ctrl(struct mtd_info *mtd, int dat,
536 			       unsigned int ctrl)
537 {
538 	struct nand_chip *nand = mtd_to_nand(mtd);
539 	struct sunxi_nand_chip *sunxi_nand = to_sunxi_nand(nand);
540 	struct sunxi_nfc *nfc = to_sunxi_nfc(sunxi_nand->nand.controller);
541 	int ret;
542 	u32 tmp;
543 
544 	ret = sunxi_nfc_wait_cmd_fifo_empty(nfc);
545 	if (ret)
546 		return;
547 
548 	if (ctrl & NAND_CTRL_CHANGE) {
549 		tmp = readl(nfc->regs + NFC_REG_CTL);
550 		if (ctrl & NAND_NCE)
551 			tmp |= NFC_CE_CTL;
552 		else
553 			tmp &= ~NFC_CE_CTL;
554 		writel(tmp, nfc->regs + NFC_REG_CTL);
555 	}
556 
557 	if (dat == NAND_CMD_NONE && (ctrl & NAND_NCE) &&
558 	    !(ctrl & (NAND_CLE | NAND_ALE))) {
559 		u32 cmd = 0;
560 
561 		if (!sunxi_nand->addr_cycles && !sunxi_nand->cmd_cycles)
562 			return;
563 
564 		if (sunxi_nand->cmd_cycles--)
565 			cmd |= NFC_SEND_CMD1 | sunxi_nand->cmd[0];
566 
567 		if (sunxi_nand->cmd_cycles--) {
568 			cmd |= NFC_SEND_CMD2;
569 			writel(sunxi_nand->cmd[1],
570 			       nfc->regs + NFC_REG_RCMD_SET);
571 		}
572 
573 		sunxi_nand->cmd_cycles = 0;
574 
575 		if (sunxi_nand->addr_cycles) {
576 			cmd |= NFC_SEND_ADR |
577 			       NFC_ADR_NUM(sunxi_nand->addr_cycles);
578 			writel(sunxi_nand->addr[0],
579 			       nfc->regs + NFC_REG_ADDR_LOW);
580 		}
581 
582 		if (sunxi_nand->addr_cycles > 4)
583 			writel(sunxi_nand->addr[1],
584 			       nfc->regs + NFC_REG_ADDR_HIGH);
585 
586 		writel(cmd, nfc->regs + NFC_REG_CMD);
587 		sunxi_nand->addr[0] = 0;
588 		sunxi_nand->addr[1] = 0;
589 		sunxi_nand->addr_cycles = 0;
590 		sunxi_nfc_wait_int(nfc, NFC_CMD_INT_FLAG, 0);
591 	}
592 
593 	if (ctrl & NAND_CLE) {
594 		sunxi_nand->cmd[sunxi_nand->cmd_cycles++] = dat;
595 	} else if (ctrl & NAND_ALE) {
596 		sunxi_nand->addr[sunxi_nand->addr_cycles / 4] |=
597 				dat << ((sunxi_nand->addr_cycles % 4) * 8);
598 		sunxi_nand->addr_cycles++;
599 	}
600 }
601 
602 /* These seed values have been extracted from Allwinner's BSP */
603 static const u16 sunxi_nfc_randomizer_page_seeds[] = {
604 	0x2b75, 0x0bd0, 0x5ca3, 0x62d1, 0x1c93, 0x07e9, 0x2162, 0x3a72,
605 	0x0d67, 0x67f9, 0x1be7, 0x077d, 0x032f, 0x0dac, 0x2716, 0x2436,
606 	0x7922, 0x1510, 0x3860, 0x5287, 0x480f, 0x4252, 0x1789, 0x5a2d,
607 	0x2a49, 0x5e10, 0x437f, 0x4b4e, 0x2f45, 0x216e, 0x5cb7, 0x7130,
608 	0x2a3f, 0x60e4, 0x4dc9, 0x0ef0, 0x0f52, 0x1bb9, 0x6211, 0x7a56,
609 	0x226d, 0x4ea7, 0x6f36, 0x3692, 0x38bf, 0x0c62, 0x05eb, 0x4c55,
610 	0x60f4, 0x728c, 0x3b6f, 0x2037, 0x7f69, 0x0936, 0x651a, 0x4ceb,
611 	0x6218, 0x79f3, 0x383f, 0x18d9, 0x4f05, 0x5c82, 0x2912, 0x6f17,
612 	0x6856, 0x5938, 0x1007, 0x61ab, 0x3e7f, 0x57c2, 0x542f, 0x4f62,
613 	0x7454, 0x2eac, 0x7739, 0x42d4, 0x2f90, 0x435a, 0x2e52, 0x2064,
614 	0x637c, 0x66ad, 0x2c90, 0x0bad, 0x759c, 0x0029, 0x0986, 0x7126,
615 	0x1ca7, 0x1605, 0x386a, 0x27f5, 0x1380, 0x6d75, 0x24c3, 0x0f8e,
616 	0x2b7a, 0x1418, 0x1fd1, 0x7dc1, 0x2d8e, 0x43af, 0x2267, 0x7da3,
617 	0x4e3d, 0x1338, 0x50db, 0x454d, 0x764d, 0x40a3, 0x42e6, 0x262b,
618 	0x2d2e, 0x1aea, 0x2e17, 0x173d, 0x3a6e, 0x71bf, 0x25f9, 0x0a5d,
619 	0x7c57, 0x0fbe, 0x46ce, 0x4939, 0x6b17, 0x37bb, 0x3e91, 0x76db,
620 };
621 
622 /*
623  * sunxi_nfc_randomizer_ecc512_seeds and sunxi_nfc_randomizer_ecc1024_seeds
624  * have been generated using
625  * sunxi_nfc_randomizer_step(seed, (step_size * 8) + 15), which is what
626  * the randomizer engine does internally before de/scrambling OOB data.
627  *
628  * Those tables are statically defined to avoid calculating randomizer state
629  * at runtime.
630  */
631 static const u16 sunxi_nfc_randomizer_ecc512_seeds[] = {
632 	0x3346, 0x367f, 0x1f18, 0x769a, 0x4f64, 0x068c, 0x2ef1, 0x6b64,
633 	0x28a9, 0x15d7, 0x30f8, 0x3659, 0x53db, 0x7c5f, 0x71d4, 0x4409,
634 	0x26eb, 0x03cc, 0x655d, 0x47d4, 0x4daa, 0x0877, 0x712d, 0x3617,
635 	0x3264, 0x49aa, 0x7f9e, 0x588e, 0x4fbc, 0x7176, 0x7f91, 0x6c6d,
636 	0x4b95, 0x5fb7, 0x3844, 0x4037, 0x0184, 0x081b, 0x0ee8, 0x5b91,
637 	0x293d, 0x1f71, 0x0e6f, 0x402b, 0x5122, 0x1e52, 0x22be, 0x3d2d,
638 	0x75bc, 0x7c60, 0x6291, 0x1a2f, 0x61d4, 0x74aa, 0x4140, 0x29ab,
639 	0x472d, 0x2852, 0x017e, 0x15e8, 0x5ec2, 0x17cf, 0x7d0f, 0x06b8,
640 	0x117a, 0x6b94, 0x789b, 0x3126, 0x6ac5, 0x5be7, 0x150f, 0x51f8,
641 	0x7889, 0x0aa5, 0x663d, 0x77e8, 0x0b87, 0x3dcb, 0x360d, 0x218b,
642 	0x512f, 0x7dc9, 0x6a4d, 0x630a, 0x3547, 0x1dd2, 0x5aea, 0x69a5,
643 	0x7bfa, 0x5e4f, 0x1519, 0x6430, 0x3a0e, 0x5eb3, 0x5425, 0x0c7a,
644 	0x5540, 0x3670, 0x63c1, 0x31e9, 0x5a39, 0x2de7, 0x5979, 0x2891,
645 	0x1562, 0x014b, 0x5b05, 0x2756, 0x5a34, 0x13aa, 0x6cb5, 0x2c36,
646 	0x5e72, 0x1306, 0x0861, 0x15ef, 0x1ee8, 0x5a37, 0x7ac4, 0x45dd,
647 	0x44c4, 0x7266, 0x2f41, 0x3ccc, 0x045e, 0x7d40, 0x7c66, 0x0fa0,
648 };
649 
650 static const u16 sunxi_nfc_randomizer_ecc1024_seeds[] = {
651 	0x2cf5, 0x35f1, 0x63a4, 0x5274, 0x2bd2, 0x778b, 0x7285, 0x32b6,
652 	0x6a5c, 0x70d6, 0x757d, 0x6769, 0x5375, 0x1e81, 0x0cf3, 0x3982,
653 	0x6787, 0x042a, 0x6c49, 0x1925, 0x56a8, 0x40a9, 0x063e, 0x7bd9,
654 	0x4dbf, 0x55ec, 0x672e, 0x7334, 0x5185, 0x4d00, 0x232a, 0x7e07,
655 	0x445d, 0x6b92, 0x528f, 0x4255, 0x53ba, 0x7d82, 0x2a2e, 0x3a4e,
656 	0x75eb, 0x450c, 0x6844, 0x1b5d, 0x581a, 0x4cc6, 0x0379, 0x37b2,
657 	0x419f, 0x0e92, 0x6b27, 0x5624, 0x01e3, 0x07c1, 0x44a5, 0x130c,
658 	0x13e8, 0x5910, 0x0876, 0x60c5, 0x54e3, 0x5b7f, 0x2269, 0x509f,
659 	0x7665, 0x36fd, 0x3e9a, 0x0579, 0x6295, 0x14ef, 0x0a81, 0x1bcc,
660 	0x4b16, 0x64db, 0x0514, 0x4f07, 0x0591, 0x3576, 0x6853, 0x0d9e,
661 	0x259f, 0x38b7, 0x64fb, 0x3094, 0x4693, 0x6ddd, 0x29bb, 0x0bc8,
662 	0x3f47, 0x490e, 0x0c0e, 0x7933, 0x3c9e, 0x5840, 0x398d, 0x3e68,
663 	0x4af1, 0x71f5, 0x57cf, 0x1121, 0x64eb, 0x3579, 0x15ac, 0x584d,
664 	0x5f2a, 0x47e2, 0x6528, 0x6eac, 0x196e, 0x6b96, 0x0450, 0x0179,
665 	0x609c, 0x06e1, 0x4626, 0x42c7, 0x273e, 0x486f, 0x0705, 0x1601,
666 	0x145b, 0x407e, 0x062b, 0x57a5, 0x53f9, 0x5659, 0x4410, 0x3ccd,
667 };
668 
669 static u16 sunxi_nfc_randomizer_step(u16 state, int count)
670 {
671 	state &= 0x7fff;
672 
673 	/*
674 	 * This loop is just a simple implementation of a Fibonacci LFSR using
675 	 * the x16 + x15 + 1 polynomial.
676 	 */
677 	while (count--)
678 		state = ((state >> 1) |
679 			 (((state ^ (state >> 1)) & 1) << 14)) & 0x7fff;
680 
681 	return state;
682 }
683 
684 static u16 sunxi_nfc_randomizer_state(struct mtd_info *mtd, int page, bool ecc)
685 {
686 	const u16 *seeds = sunxi_nfc_randomizer_page_seeds;
687 	int mod = mtd->erasesize / mtd->writesize;
688 
689 	if (mod > ARRAY_SIZE(sunxi_nfc_randomizer_page_seeds))
690 		mod = ARRAY_SIZE(sunxi_nfc_randomizer_page_seeds);
691 
692 	if (ecc) {
693 		if (mtd->ecc_step_size == 512)
694 			seeds = sunxi_nfc_randomizer_ecc512_seeds;
695 		else
696 			seeds = sunxi_nfc_randomizer_ecc1024_seeds;
697 	}
698 
699 	return seeds[page % mod];
700 }
701 
702 static void sunxi_nfc_randomizer_config(struct mtd_info *mtd,
703 					int page, bool ecc)
704 {
705 	struct nand_chip *nand = mtd_to_nand(mtd);
706 	struct sunxi_nfc *nfc = to_sunxi_nfc(nand->controller);
707 	u32 ecc_ctl = readl(nfc->regs + NFC_REG_ECC_CTL);
708 	u16 state;
709 
710 	if (!(nand->options & NAND_NEED_SCRAMBLING))
711 		return;
712 
713 	ecc_ctl = readl(nfc->regs + NFC_REG_ECC_CTL);
714 	state = sunxi_nfc_randomizer_state(mtd, page, ecc);
715 	ecc_ctl = readl(nfc->regs + NFC_REG_ECC_CTL) & ~NFC_RANDOM_SEED_MSK;
716 	writel(ecc_ctl | NFC_RANDOM_SEED(state), nfc->regs + NFC_REG_ECC_CTL);
717 }
718 
719 static void sunxi_nfc_randomizer_enable(struct mtd_info *mtd)
720 {
721 	struct nand_chip *nand = mtd_to_nand(mtd);
722 	struct sunxi_nfc *nfc = to_sunxi_nfc(nand->controller);
723 
724 	if (!(nand->options & NAND_NEED_SCRAMBLING))
725 		return;
726 
727 	writel(readl(nfc->regs + NFC_REG_ECC_CTL) | NFC_RANDOM_EN,
728 	       nfc->regs + NFC_REG_ECC_CTL);
729 }
730 
731 static void sunxi_nfc_randomizer_disable(struct mtd_info *mtd)
732 {
733 	struct nand_chip *nand = mtd_to_nand(mtd);
734 	struct sunxi_nfc *nfc = to_sunxi_nfc(nand->controller);
735 
736 	if (!(nand->options & NAND_NEED_SCRAMBLING))
737 		return;
738 
739 	writel(readl(nfc->regs + NFC_REG_ECC_CTL) & ~NFC_RANDOM_EN,
740 	       nfc->regs + NFC_REG_ECC_CTL);
741 }
742 
743 static void sunxi_nfc_randomize_bbm(struct mtd_info *mtd, int page, u8 *bbm)
744 {
745 	u16 state = sunxi_nfc_randomizer_state(mtd, page, true);
746 
747 	bbm[0] ^= state;
748 	bbm[1] ^= sunxi_nfc_randomizer_step(state, 8);
749 }
750 
751 static void sunxi_nfc_randomizer_write_buf(struct mtd_info *mtd,
752 					   const uint8_t *buf, int len,
753 					   bool ecc, int page)
754 {
755 	sunxi_nfc_randomizer_config(mtd, page, ecc);
756 	sunxi_nfc_randomizer_enable(mtd);
757 	sunxi_nfc_write_buf(mtd, buf, len);
758 	sunxi_nfc_randomizer_disable(mtd);
759 }
760 
761 static void sunxi_nfc_randomizer_read_buf(struct mtd_info *mtd, uint8_t *buf,
762 					  int len, bool ecc, int page)
763 {
764 	sunxi_nfc_randomizer_config(mtd, page, ecc);
765 	sunxi_nfc_randomizer_enable(mtd);
766 	sunxi_nfc_read_buf(mtd, buf, len);
767 	sunxi_nfc_randomizer_disable(mtd);
768 }
769 
770 static void sunxi_nfc_hw_ecc_enable(struct mtd_info *mtd)
771 {
772 	struct nand_chip *nand = mtd_to_nand(mtd);
773 	struct sunxi_nfc *nfc = to_sunxi_nfc(nand->controller);
774 	struct sunxi_nand_hw_ecc *data = nand->ecc.priv;
775 	u32 ecc_ctl;
776 
777 	ecc_ctl = readl(nfc->regs + NFC_REG_ECC_CTL);
778 	ecc_ctl &= ~(NFC_ECC_MODE_MSK | NFC_ECC_PIPELINE |
779 		     NFC_ECC_BLOCK_SIZE_MSK);
780 	ecc_ctl |= NFC_ECC_EN | NFC_ECC_MODE(data->mode) | NFC_ECC_EXCEPTION;
781 
782 	if (nand->ecc.size == 512)
783 		ecc_ctl |= NFC_ECC_BLOCK_512;
784 
785 	writel(ecc_ctl, nfc->regs + NFC_REG_ECC_CTL);
786 }
787 
788 static void sunxi_nfc_hw_ecc_disable(struct mtd_info *mtd)
789 {
790 	struct nand_chip *nand = mtd_to_nand(mtd);
791 	struct sunxi_nfc *nfc = to_sunxi_nfc(nand->controller);
792 
793 	writel(readl(nfc->regs + NFC_REG_ECC_CTL) & ~NFC_ECC_EN,
794 	       nfc->regs + NFC_REG_ECC_CTL);
795 }
796 
797 static inline void sunxi_nfc_user_data_to_buf(u32 user_data, u8 *buf)
798 {
799 	buf[0] = user_data;
800 	buf[1] = user_data >> 8;
801 	buf[2] = user_data >> 16;
802 	buf[3] = user_data >> 24;
803 }
804 
805 static int sunxi_nfc_hw_ecc_read_chunk(struct mtd_info *mtd,
806 				       u8 *data, int data_off,
807 				       u8 *oob, int oob_off,
808 				       int *cur_off,
809 				       unsigned int *max_bitflips,
810 				       bool bbm, int page)
811 {
812 	struct nand_chip *nand = mtd_to_nand(mtd);
813 	struct sunxi_nfc *nfc = to_sunxi_nfc(nand->controller);
814 	struct nand_ecc_ctrl *ecc = &nand->ecc;
815 	int raw_mode = 0;
816 	u32 status;
817 	int ret;
818 
819 	if (*cur_off != data_off)
820 		nand->cmdfunc(mtd, NAND_CMD_RNDOUT, data_off, -1);
821 
822 	sunxi_nfc_randomizer_read_buf(mtd, NULL, ecc->size, false, page);
823 
824 	if (data_off + ecc->size != oob_off)
825 		nand->cmdfunc(mtd, NAND_CMD_RNDOUT, oob_off, -1);
826 
827 	ret = sunxi_nfc_wait_cmd_fifo_empty(nfc);
828 	if (ret)
829 		return ret;
830 
831 	sunxi_nfc_randomizer_enable(mtd);
832 	writel(NFC_DATA_TRANS | NFC_DATA_SWAP_METHOD | NFC_ECC_OP,
833 	       nfc->regs + NFC_REG_CMD);
834 
835 	ret = sunxi_nfc_wait_int(nfc, NFC_CMD_INT_FLAG, 0);
836 	sunxi_nfc_randomizer_disable(mtd);
837 	if (ret)
838 		return ret;
839 
840 	*cur_off = oob_off + ecc->bytes + 4;
841 
842 	status = readl(nfc->regs + NFC_REG_ECC_ST);
843 	if (status & NFC_ECC_PAT_FOUND(0)) {
844 		u8 pattern = 0xff;
845 
846 		if (unlikely(!(readl(nfc->regs + NFC_REG_PAT_ID) & 0x1)))
847 			pattern = 0x0;
848 
849 		memset(data, pattern, ecc->size);
850 		memset(oob, pattern, ecc->bytes + 4);
851 
852 		return 1;
853 	}
854 
855 	ret = NFC_ECC_ERR_CNT(0, readl(nfc->regs + NFC_REG_ECC_ERR_CNT(0)));
856 
857 	memcpy_fromio(data, nfc->regs + NFC_RAM0_BASE, ecc->size);
858 
859 	nand->cmdfunc(mtd, NAND_CMD_RNDOUT, oob_off, -1);
860 	sunxi_nfc_randomizer_read_buf(mtd, oob, ecc->bytes + 4, true, page);
861 
862 	if (status & NFC_ECC_ERR(0)) {
863 		/*
864 		 * Re-read the data with the randomizer disabled to identify
865 		 * bitflips in erased pages.
866 		 */
867 		if (nand->options & NAND_NEED_SCRAMBLING) {
868 			nand->cmdfunc(mtd, NAND_CMD_RNDOUT, data_off, -1);
869 			nand->read_buf(mtd, data, ecc->size);
870 			nand->cmdfunc(mtd, NAND_CMD_RNDOUT, oob_off, -1);
871 			nand->read_buf(mtd, oob, ecc->bytes + 4);
872 		}
873 
874 		ret = nand_check_erased_ecc_chunk(data,	ecc->size,
875 						  oob, ecc->bytes + 4,
876 						  NULL, 0, ecc->strength);
877 		if (ret >= 0)
878 			raw_mode = 1;
879 	} else {
880 		/*
881 		 * The engine protects 4 bytes of OOB data per chunk.
882 		 * Retrieve the corrected OOB bytes.
883 		 */
884 		sunxi_nfc_user_data_to_buf(readl(nfc->regs +
885 						 NFC_REG_USER_DATA(0)),
886 					   oob);
887 
888 		/* De-randomize the Bad Block Marker. */
889 		if (bbm && nand->options & NAND_NEED_SCRAMBLING)
890 			sunxi_nfc_randomize_bbm(mtd, page, oob);
891 	}
892 
893 	if (ret < 0) {
894 		mtd->ecc_stats.failed++;
895 	} else {
896 		mtd->ecc_stats.corrected += ret;
897 		*max_bitflips = max_t(unsigned int, *max_bitflips, ret);
898 	}
899 
900 	return raw_mode;
901 }
902 
903 static void sunxi_nfc_hw_ecc_read_extra_oob(struct mtd_info *mtd,
904 					    u8 *oob, int *cur_off,
905 					    bool randomize, int page)
906 {
907 	struct nand_chip *nand = mtd_to_nand(mtd);
908 	struct nand_ecc_ctrl *ecc = &nand->ecc;
909 	int offset = ((ecc->bytes + 4) * ecc->steps);
910 	int len = mtd->oobsize - offset;
911 
912 	if (len <= 0)
913 		return;
914 
915 	if (*cur_off != offset)
916 		nand->cmdfunc(mtd, NAND_CMD_RNDOUT,
917 			      offset + mtd->writesize, -1);
918 
919 	if (!randomize)
920 		sunxi_nfc_read_buf(mtd, oob + offset, len);
921 	else
922 		sunxi_nfc_randomizer_read_buf(mtd, oob + offset, len,
923 					      false, page);
924 
925 	*cur_off = mtd->oobsize + mtd->writesize;
926 }
927 
928 static inline u32 sunxi_nfc_buf_to_user_data(const u8 *buf)
929 {
930 	return buf[0] | (buf[1] << 8) | (buf[2] << 16) | (buf[3] << 24);
931 }
932 
933 static int sunxi_nfc_hw_ecc_write_chunk(struct mtd_info *mtd,
934 					const u8 *data, int data_off,
935 					const u8 *oob, int oob_off,
936 					int *cur_off, bool bbm,
937 					int page)
938 {
939 	struct nand_chip *nand = mtd_to_nand(mtd);
940 	struct sunxi_nfc *nfc = to_sunxi_nfc(nand->controller);
941 	struct nand_ecc_ctrl *ecc = &nand->ecc;
942 	int ret;
943 
944 	if (data_off != *cur_off)
945 		nand->cmdfunc(mtd, NAND_CMD_RNDIN, data_off, -1);
946 
947 	sunxi_nfc_randomizer_write_buf(mtd, data, ecc->size, false, page);
948 
949 	/* Fill OOB data in */
950 	if ((nand->options & NAND_NEED_SCRAMBLING) && bbm) {
951 		u8 user_data[4];
952 
953 		memcpy(user_data, oob, 4);
954 		sunxi_nfc_randomize_bbm(mtd, page, user_data);
955 		writel(sunxi_nfc_buf_to_user_data(user_data),
956 		       nfc->regs + NFC_REG_USER_DATA(0));
957 	} else {
958 		writel(sunxi_nfc_buf_to_user_data(oob),
959 		       nfc->regs + NFC_REG_USER_DATA(0));
960 	}
961 
962 	if (data_off + ecc->size != oob_off)
963 		nand->cmdfunc(mtd, NAND_CMD_RNDIN, oob_off, -1);
964 
965 	ret = sunxi_nfc_wait_cmd_fifo_empty(nfc);
966 	if (ret)
967 		return ret;
968 
969 	sunxi_nfc_randomizer_enable(mtd);
970 	writel(NFC_DATA_TRANS | NFC_DATA_SWAP_METHOD |
971 	       NFC_ACCESS_DIR | NFC_ECC_OP,
972 	       nfc->regs + NFC_REG_CMD);
973 
974 	ret = sunxi_nfc_wait_int(nfc, NFC_CMD_INT_FLAG, 0);
975 	sunxi_nfc_randomizer_disable(mtd);
976 	if (ret)
977 		return ret;
978 
979 	*cur_off = oob_off + ecc->bytes + 4;
980 
981 	return 0;
982 }
983 
984 static void sunxi_nfc_hw_ecc_write_extra_oob(struct mtd_info *mtd,
985 					     u8 *oob, int *cur_off,
986 					     int page)
987 {
988 	struct nand_chip *nand = mtd_to_nand(mtd);
989 	struct nand_ecc_ctrl *ecc = &nand->ecc;
990 	int offset = ((ecc->bytes + 4) * ecc->steps);
991 	int len = mtd->oobsize - offset;
992 
993 	if (len <= 0)
994 		return;
995 
996 	if (*cur_off != offset)
997 		nand->cmdfunc(mtd, NAND_CMD_RNDIN,
998 			      offset + mtd->writesize, -1);
999 
1000 	sunxi_nfc_randomizer_write_buf(mtd, oob + offset, len, false, page);
1001 
1002 	*cur_off = mtd->oobsize + mtd->writesize;
1003 }
1004 
1005 static int sunxi_nfc_hw_ecc_read_page(struct mtd_info *mtd,
1006 				      struct nand_chip *chip, uint8_t *buf,
1007 				      int oob_required, int page)
1008 {
1009 	struct nand_ecc_ctrl *ecc = &chip->ecc;
1010 	unsigned int max_bitflips = 0;
1011 	int ret, i, cur_off = 0;
1012 	bool raw_mode = false;
1013 
1014 	sunxi_nfc_hw_ecc_enable(mtd);
1015 
1016 	for (i = 0; i < ecc->steps; i++) {
1017 		int data_off = i * ecc->size;
1018 		int oob_off = i * (ecc->bytes + 4);
1019 		u8 *data = buf + data_off;
1020 		u8 *oob = chip->oob_poi + oob_off;
1021 
1022 		ret = sunxi_nfc_hw_ecc_read_chunk(mtd, data, data_off, oob,
1023 						  oob_off + mtd->writesize,
1024 						  &cur_off, &max_bitflips,
1025 						  !i, page);
1026 		if (ret < 0)
1027 			return ret;
1028 		else if (ret)
1029 			raw_mode = true;
1030 	}
1031 
1032 	if (oob_required)
1033 		sunxi_nfc_hw_ecc_read_extra_oob(mtd, chip->oob_poi, &cur_off,
1034 						!raw_mode, page);
1035 
1036 	sunxi_nfc_hw_ecc_disable(mtd);
1037 
1038 	return max_bitflips;
1039 }
1040 
1041 static int sunxi_nfc_hw_ecc_read_subpage(struct mtd_info *mtd,
1042 					 struct nand_chip *chip,
1043 					 uint32_t data_offs, uint32_t readlen,
1044 					 uint8_t *bufpoi, int page)
1045 {
1046 	struct nand_ecc_ctrl *ecc = &chip->ecc;
1047 	int ret, i, cur_off = 0;
1048 	unsigned int max_bitflips = 0;
1049 
1050 	sunxi_nfc_hw_ecc_enable(mtd);
1051 
1052 	chip->cmdfunc(mtd, NAND_CMD_READ0, 0, page);
1053 	for (i = data_offs / ecc->size;
1054 	     i < DIV_ROUND_UP(data_offs + readlen, ecc->size); i++) {
1055 		int data_off = i * ecc->size;
1056 		int oob_off = i * (ecc->bytes + 4);
1057 		u8 *data = bufpoi + data_off;
1058 		u8 *oob = chip->oob_poi + oob_off;
1059 
1060 		ret = sunxi_nfc_hw_ecc_read_chunk(mtd, data, data_off,
1061 			oob, oob_off + mtd->writesize,
1062 			&cur_off, &max_bitflips, !i, page);
1063 		if (ret < 0)
1064 			return ret;
1065 	}
1066 
1067 	sunxi_nfc_hw_ecc_disable(mtd);
1068 
1069 	return max_bitflips;
1070 }
1071 
1072 static int sunxi_nfc_hw_ecc_write_page(struct mtd_info *mtd,
1073 				       struct nand_chip *chip,
1074 				       const uint8_t *buf, int oob_required,
1075 				       int page)
1076 {
1077 	struct nand_ecc_ctrl *ecc = &chip->ecc;
1078 	int ret, i, cur_off = 0;
1079 
1080 	sunxi_nfc_hw_ecc_enable(mtd);
1081 
1082 	for (i = 0; i < ecc->steps; i++) {
1083 		int data_off = i * ecc->size;
1084 		int oob_off = i * (ecc->bytes + 4);
1085 		const u8 *data = buf + data_off;
1086 		const u8 *oob = chip->oob_poi + oob_off;
1087 
1088 		ret = sunxi_nfc_hw_ecc_write_chunk(mtd, data, data_off, oob,
1089 						   oob_off + mtd->writesize,
1090 						   &cur_off, !i, page);
1091 		if (ret)
1092 			return ret;
1093 	}
1094 
1095 	if (oob_required || (chip->options & NAND_NEED_SCRAMBLING))
1096 		sunxi_nfc_hw_ecc_write_extra_oob(mtd, chip->oob_poi,
1097 						 &cur_off, page);
1098 
1099 	sunxi_nfc_hw_ecc_disable(mtd);
1100 
1101 	return 0;
1102 }
1103 
1104 static int sunxi_nfc_hw_ecc_write_subpage(struct mtd_info *mtd,
1105 					  struct nand_chip *chip,
1106 					  u32 data_offs, u32 data_len,
1107 					  const u8 *buf, int oob_required,
1108 					  int page)
1109 {
1110 	struct nand_ecc_ctrl *ecc = &chip->ecc;
1111 	int ret, i, cur_off = 0;
1112 
1113 	sunxi_nfc_hw_ecc_enable(mtd);
1114 
1115 	for (i = data_offs / ecc->size;
1116 	     i < DIV_ROUND_UP(data_offs + data_len, ecc->size); i++) {
1117 		int data_off = i * ecc->size;
1118 		int oob_off = i * (ecc->bytes + 4);
1119 		const u8 *data = buf + data_off;
1120 		const u8 *oob = chip->oob_poi + oob_off;
1121 
1122 		ret = sunxi_nfc_hw_ecc_write_chunk(mtd, data, data_off, oob,
1123 						   oob_off + mtd->writesize,
1124 						   &cur_off, !i, page);
1125 		if (ret)
1126 			return ret;
1127 	}
1128 
1129 	sunxi_nfc_hw_ecc_disable(mtd);
1130 
1131 	return 0;
1132 }
1133 
1134 static int sunxi_nfc_hw_syndrome_ecc_read_page(struct mtd_info *mtd,
1135 					       struct nand_chip *chip,
1136 					       uint8_t *buf, int oob_required,
1137 					       int page)
1138 {
1139 	struct nand_ecc_ctrl *ecc = &chip->ecc;
1140 	unsigned int max_bitflips = 0;
1141 	int ret, i, cur_off = 0;
1142 	bool raw_mode = false;
1143 
1144 	sunxi_nfc_hw_ecc_enable(mtd);
1145 
1146 	for (i = 0; i < ecc->steps; i++) {
1147 		int data_off = i * (ecc->size + ecc->bytes + 4);
1148 		int oob_off = data_off + ecc->size;
1149 		u8 *data = buf + (i * ecc->size);
1150 		u8 *oob = chip->oob_poi + (i * (ecc->bytes + 4));
1151 
1152 		ret = sunxi_nfc_hw_ecc_read_chunk(mtd, data, data_off, oob,
1153 						  oob_off, &cur_off,
1154 						  &max_bitflips, !i, page);
1155 		if (ret < 0)
1156 			return ret;
1157 		else if (ret)
1158 			raw_mode = true;
1159 	}
1160 
1161 	if (oob_required)
1162 		sunxi_nfc_hw_ecc_read_extra_oob(mtd, chip->oob_poi, &cur_off,
1163 						!raw_mode, page);
1164 
1165 	sunxi_nfc_hw_ecc_disable(mtd);
1166 
1167 	return max_bitflips;
1168 }
1169 
1170 static int sunxi_nfc_hw_syndrome_ecc_write_page(struct mtd_info *mtd,
1171 						struct nand_chip *chip,
1172 						const uint8_t *buf,
1173 						int oob_required, int page)
1174 {
1175 	struct nand_ecc_ctrl *ecc = &chip->ecc;
1176 	int ret, i, cur_off = 0;
1177 
1178 	sunxi_nfc_hw_ecc_enable(mtd);
1179 
1180 	for (i = 0; i < ecc->steps; i++) {
1181 		int data_off = i * (ecc->size + ecc->bytes + 4);
1182 		int oob_off = data_off + ecc->size;
1183 		const u8 *data = buf + (i * ecc->size);
1184 		const u8 *oob = chip->oob_poi + (i * (ecc->bytes + 4));
1185 
1186 		ret = sunxi_nfc_hw_ecc_write_chunk(mtd, data, data_off,
1187 						   oob, oob_off, &cur_off,
1188 						   false, page);
1189 		if (ret)
1190 			return ret;
1191 	}
1192 
1193 	if (oob_required || (chip->options & NAND_NEED_SCRAMBLING))
1194 		sunxi_nfc_hw_ecc_write_extra_oob(mtd, chip->oob_poi,
1195 						 &cur_off, page);
1196 
1197 	sunxi_nfc_hw_ecc_disable(mtd);
1198 
1199 	return 0;
1200 }
1201 
1202 static const s32 tWB_lut[] = {6, 12, 16, 20};
1203 static const s32 tRHW_lut[] = {4, 8, 12, 20};
1204 
1205 static int _sunxi_nand_lookup_timing(const s32 *lut, int lut_size, u32 duration,
1206 		u32 clk_period)
1207 {
1208 	u32 clk_cycles = DIV_ROUND_UP(duration, clk_period);
1209 	int i;
1210 
1211 	for (i = 0; i < lut_size; i++) {
1212 		if (clk_cycles <= lut[i])
1213 			return i;
1214 	}
1215 
1216 	/* Doesn't fit */
1217 	return -EINVAL;
1218 }
1219 
1220 #define sunxi_nand_lookup_timing(l, p, c) \
1221 			_sunxi_nand_lookup_timing(l, ARRAY_SIZE(l), p, c)
1222 
1223 static int sunxi_nand_chip_set_timings(struct sunxi_nand_chip *chip,
1224 				       const struct nand_sdr_timings *timings)
1225 {
1226 	u32 min_clk_period = 0;
1227 	s32 tWB, tADL, tWHR, tRHW, tCAD;
1228 
1229 	/* T1 <=> tCLS */
1230 	if (timings->tCLS_min > min_clk_period)
1231 		min_clk_period = timings->tCLS_min;
1232 
1233 	/* T2 <=> tCLH */
1234 	if (timings->tCLH_min > min_clk_period)
1235 		min_clk_period = timings->tCLH_min;
1236 
1237 	/* T3 <=> tCS */
1238 	if (timings->tCS_min > min_clk_period)
1239 		min_clk_period = timings->tCS_min;
1240 
1241 	/* T4 <=> tCH */
1242 	if (timings->tCH_min > min_clk_period)
1243 		min_clk_period = timings->tCH_min;
1244 
1245 	/* T5 <=> tWP */
1246 	if (timings->tWP_min > min_clk_period)
1247 		min_clk_period = timings->tWP_min;
1248 
1249 	/* T6 <=> tWH */
1250 	if (timings->tWH_min > min_clk_period)
1251 		min_clk_period = timings->tWH_min;
1252 
1253 	/* T7 <=> tALS */
1254 	if (timings->tALS_min > min_clk_period)
1255 		min_clk_period = timings->tALS_min;
1256 
1257 	/* T8 <=> tDS */
1258 	if (timings->tDS_min > min_clk_period)
1259 		min_clk_period = timings->tDS_min;
1260 
1261 	/* T9 <=> tDH */
1262 	if (timings->tDH_min > min_clk_period)
1263 		min_clk_period = timings->tDH_min;
1264 
1265 	/* T10 <=> tRR */
1266 	if (timings->tRR_min > (min_clk_period * 3))
1267 		min_clk_period = DIV_ROUND_UP(timings->tRR_min, 3);
1268 
1269 	/* T11 <=> tALH */
1270 	if (timings->tALH_min > min_clk_period)
1271 		min_clk_period = timings->tALH_min;
1272 
1273 	/* T12 <=> tRP */
1274 	if (timings->tRP_min > min_clk_period)
1275 		min_clk_period = timings->tRP_min;
1276 
1277 	/* T13 <=> tREH */
1278 	if (timings->tREH_min > min_clk_period)
1279 		min_clk_period = timings->tREH_min;
1280 
1281 	/* T14 <=> tRC */
1282 	if (timings->tRC_min > (min_clk_period * 2))
1283 		min_clk_period = DIV_ROUND_UP(timings->tRC_min, 2);
1284 
1285 	/* T15 <=> tWC */
1286 	if (timings->tWC_min > (min_clk_period * 2))
1287 		min_clk_period = DIV_ROUND_UP(timings->tWC_min, 2);
1288 
1289 	/* T16 - T19 + tCAD */
1290 	tWB  = sunxi_nand_lookup_timing(tWB_lut, timings->tWB_max,
1291 					min_clk_period);
1292 	if (tWB < 0) {
1293 		dev_err(nfc->dev, "unsupported tWB\n");
1294 		return tWB;
1295 	}
1296 
1297 	tADL = DIV_ROUND_UP(timings->tADL_min, min_clk_period) >> 3;
1298 	if (tADL > 3) {
1299 		dev_err(nfc->dev, "unsupported tADL\n");
1300 		return -EINVAL;
1301 	}
1302 
1303 	tWHR = DIV_ROUND_UP(timings->tWHR_min, min_clk_period) >> 3;
1304 	if (tWHR > 3) {
1305 		dev_err(nfc->dev, "unsupported tWHR\n");
1306 		return -EINVAL;
1307 	}
1308 
1309 	tRHW = sunxi_nand_lookup_timing(tRHW_lut, timings->tRHW_min,
1310 					min_clk_period);
1311 	if (tRHW < 0) {
1312 		dev_err(nfc->dev, "unsupported tRHW\n");
1313 		return tRHW;
1314 	}
1315 
1316 	/*
1317 	 * TODO: according to ONFI specs this value only applies for DDR NAND,
1318 	 * but Allwinner seems to set this to 0x7. Mimic them for now.
1319 	 */
1320 	tCAD = 0x7;
1321 
1322 	/* TODO: A83 has some more bits for CDQSS, CS, CLHZ, CCS, WC */
1323 	chip->timing_cfg = NFC_TIMING_CFG(tWB, tADL, tWHR, tRHW, tCAD);
1324 
1325 	/*
1326 	 * ONFI specification 3.1, paragraph 4.15.2 dictates that EDO data
1327 	 * output cycle timings shall be used if the host drives tRC less than
1328 	 * 30 ns.
1329 	 */
1330 	chip->timing_ctl = (timings->tRC_min < 30000) ? NFC_TIMING_CTL_EDO : 0;
1331 
1332 	/* Convert min_clk_period from picoseconds to nanoseconds */
1333 	min_clk_period = DIV_ROUND_UP(min_clk_period, 1000);
1334 
1335 	/*
1336 	 * Convert min_clk_period into a clk frequency, then get the
1337 	 * appropriate rate for the NAND controller IP given this formula
1338 	 * (specified in the datasheet):
1339 	 * nand clk_rate = min_clk_rate
1340 	 */
1341 	chip->clk_rate = 1000000000L / min_clk_period;
1342 
1343 	return 0;
1344 }
1345 
1346 static int sunxi_nand_chip_init_timings(struct sunxi_nand_chip *chip)
1347 {
1348 	struct mtd_info *mtd = nand_to_mtd(&chip->nand);
1349 	const struct nand_sdr_timings *timings;
1350 	int ret;
1351 	int mode;
1352 
1353 	mode = onfi_get_async_timing_mode(&chip->nand);
1354 	if (mode == ONFI_TIMING_MODE_UNKNOWN) {
1355 		mode = chip->nand.onfi_timing_mode_default;
1356 	} else {
1357 		uint8_t feature[ONFI_SUBFEATURE_PARAM_LEN] = {};
1358 		int i;
1359 
1360 		mode = fls(mode) - 1;
1361 		if (mode < 0)
1362 			mode = 0;
1363 
1364 		feature[0] = mode;
1365 		for (i = 0; i < chip->nsels; i++) {
1366 			chip->nand.select_chip(mtd, i);
1367 			ret = chip->nand.onfi_set_features(mtd,
1368 						&chip->nand,
1369 						ONFI_FEATURE_ADDR_TIMING_MODE,
1370 						feature);
1371 			chip->nand.select_chip(mtd, -1);
1372 			if (ret && ret != -ENOTSUPP)
1373 				return ret;
1374 		}
1375 	}
1376 
1377 	timings = onfi_async_timing_mode_to_sdr_timings(mode);
1378 	if (IS_ERR(timings))
1379 		return PTR_ERR(timings);
1380 
1381 	return sunxi_nand_chip_set_timings(chip, timings);
1382 }
1383 
1384 static int sunxi_nand_hw_common_ecc_ctrl_init(struct mtd_info *mtd,
1385 					      struct nand_ecc_ctrl *ecc)
1386 {
1387 	static const u8 strengths[] = { 16, 24, 28, 32, 40, 48, 56, 60, 64 };
1388 	struct sunxi_nand_hw_ecc *data;
1389 	struct nand_ecclayout *layout;
1390 	int nsectors;
1391 	int ret;
1392 	int i;
1393 
1394 	data = kzalloc(sizeof(*data), GFP_KERNEL);
1395 	if (!data)
1396 		return -ENOMEM;
1397 
1398 	if (ecc->size != 512 && ecc->size != 1024)
1399 		return -EINVAL;
1400 
1401 	/* Prefer 1k ECC chunk over 512 ones */
1402 	if (ecc->size == 512 && mtd->writesize > 512) {
1403 		ecc->size = 1024;
1404 		ecc->strength *= 2;
1405 	}
1406 
1407 	/* Add ECC info retrieval from DT */
1408 	for (i = 0; i < ARRAY_SIZE(strengths); i++) {
1409 		if (ecc->strength <= strengths[i]) {
1410 			/*
1411 			 * Update ecc->strength value with the actual strength
1412 			 * that will be used by the ECC engine.
1413 			 */
1414 			ecc->strength = strengths[i];
1415 			break;
1416 		}
1417 	}
1418 
1419 	if (i >= ARRAY_SIZE(strengths)) {
1420 		dev_err(nfc->dev, "unsupported strength\n");
1421 		ret = -ENOTSUPP;
1422 		goto err;
1423 	}
1424 
1425 	data->mode = i;
1426 
1427 	/* HW ECC always request ECC bytes for 1024 bytes blocks */
1428 	ecc->bytes = DIV_ROUND_UP(ecc->strength * fls(8 * 1024), 8);
1429 
1430 	/* HW ECC always work with even numbers of ECC bytes */
1431 	ecc->bytes = ALIGN(ecc->bytes, 2);
1432 
1433 	layout = &data->layout;
1434 	nsectors = mtd->writesize / ecc->size;
1435 
1436 	if (mtd->oobsize < ((ecc->bytes + 4) * nsectors)) {
1437 		ret = -EINVAL;
1438 		goto err;
1439 	}
1440 
1441 	layout->eccbytes = (ecc->bytes * nsectors);
1442 
1443 	ecc->layout = layout;
1444 	ecc->priv = data;
1445 
1446 	return 0;
1447 
1448 err:
1449 	kfree(data);
1450 
1451 	return ret;
1452 }
1453 
1454 #ifndef __UBOOT__
1455 static void sunxi_nand_hw_common_ecc_ctrl_cleanup(struct nand_ecc_ctrl *ecc)
1456 {
1457 	kfree(ecc->priv);
1458 }
1459 #endif /* __UBOOT__ */
1460 
1461 static int sunxi_nand_hw_ecc_ctrl_init(struct mtd_info *mtd,
1462 				       struct nand_ecc_ctrl *ecc)
1463 {
1464 	struct nand_ecclayout *layout;
1465 	int nsectors;
1466 	int i, j;
1467 	int ret;
1468 
1469 	ret = sunxi_nand_hw_common_ecc_ctrl_init(mtd, ecc);
1470 	if (ret)
1471 		return ret;
1472 
1473 	ecc->read_page = sunxi_nfc_hw_ecc_read_page;
1474 	ecc->write_page = sunxi_nfc_hw_ecc_write_page;
1475 	ecc->read_subpage = sunxi_nfc_hw_ecc_read_subpage;
1476 	ecc->write_subpage = sunxi_nfc_hw_ecc_write_subpage;
1477 	layout = ecc->layout;
1478 	nsectors = mtd->writesize / ecc->size;
1479 
1480 	for (i = 0; i < nsectors; i++) {
1481 		if (i) {
1482 			layout->oobfree[i].offset =
1483 				layout->oobfree[i - 1].offset +
1484 				layout->oobfree[i - 1].length +
1485 				ecc->bytes;
1486 			layout->oobfree[i].length = 4;
1487 		} else {
1488 			/*
1489 			 * The first 2 bytes are used for BB markers, hence we
1490 			 * only have 2 bytes available in the first user data
1491 			 * section.
1492 			 */
1493 			layout->oobfree[i].length = 2;
1494 			layout->oobfree[i].offset = 2;
1495 		}
1496 
1497 		for (j = 0; j < ecc->bytes; j++)
1498 			layout->eccpos[(ecc->bytes * i) + j] =
1499 					layout->oobfree[i].offset +
1500 					layout->oobfree[i].length + j;
1501 	}
1502 
1503 	if (mtd->oobsize > (ecc->bytes + 4) * nsectors) {
1504 		layout->oobfree[nsectors].offset =
1505 				layout->oobfree[nsectors - 1].offset +
1506 				layout->oobfree[nsectors - 1].length +
1507 				ecc->bytes;
1508 		layout->oobfree[nsectors].length = mtd->oobsize -
1509 				((ecc->bytes + 4) * nsectors);
1510 	}
1511 
1512 	return 0;
1513 }
1514 
1515 static int sunxi_nand_hw_syndrome_ecc_ctrl_init(struct mtd_info *mtd,
1516 						struct nand_ecc_ctrl *ecc)
1517 {
1518 	struct nand_ecclayout *layout;
1519 	int nsectors;
1520 	int i;
1521 	int ret;
1522 
1523 	ret = sunxi_nand_hw_common_ecc_ctrl_init(mtd, ecc);
1524 	if (ret)
1525 		return ret;
1526 
1527 	ecc->prepad = 4;
1528 	ecc->read_page = sunxi_nfc_hw_syndrome_ecc_read_page;
1529 	ecc->write_page = sunxi_nfc_hw_syndrome_ecc_write_page;
1530 
1531 	layout = ecc->layout;
1532 	nsectors = mtd->writesize / ecc->size;
1533 
1534 	for (i = 0; i < (ecc->bytes * nsectors); i++)
1535 		layout->eccpos[i] = i;
1536 
1537 	layout->oobfree[0].length = mtd->oobsize - i;
1538 	layout->oobfree[0].offset = i;
1539 
1540 	return 0;
1541 }
1542 
1543 #ifndef __UBOOT__
1544 static void sunxi_nand_ecc_cleanup(struct nand_ecc_ctrl *ecc)
1545 {
1546 	switch (ecc->mode) {
1547 	case NAND_ECC_HW:
1548 	case NAND_ECC_HW_SYNDROME:
1549 		sunxi_nand_hw_common_ecc_ctrl_cleanup(ecc);
1550 		break;
1551 	case NAND_ECC_NONE:
1552 		kfree(ecc->layout);
1553 	default:
1554 		break;
1555 	}
1556 }
1557 #endif /* __UBOOT__ */
1558 
1559 static int sunxi_nand_ecc_init(struct mtd_info *mtd, struct nand_ecc_ctrl *ecc)
1560 {
1561 	struct nand_chip *nand = mtd_to_nand(mtd);
1562 	int ret;
1563 
1564 	if (!ecc->size) {
1565 		ecc->size = nand->ecc_step_ds;
1566 		ecc->strength = nand->ecc_strength_ds;
1567 	}
1568 
1569 	if (!ecc->size || !ecc->strength)
1570 		return -EINVAL;
1571 
1572 	switch (ecc->mode) {
1573 	case NAND_ECC_SOFT_BCH:
1574 		break;
1575 	case NAND_ECC_HW:
1576 		ret = sunxi_nand_hw_ecc_ctrl_init(mtd, ecc);
1577 		if (ret)
1578 			return ret;
1579 		break;
1580 	case NAND_ECC_HW_SYNDROME:
1581 		ret = sunxi_nand_hw_syndrome_ecc_ctrl_init(mtd, ecc);
1582 		if (ret)
1583 			return ret;
1584 		break;
1585 	case NAND_ECC_NONE:
1586 		ecc->layout = kzalloc(sizeof(*ecc->layout), GFP_KERNEL);
1587 		if (!ecc->layout)
1588 			return -ENOMEM;
1589 		ecc->layout->oobfree[0].length = mtd->oobsize;
1590 	case NAND_ECC_SOFT:
1591 		break;
1592 	default:
1593 		return -EINVAL;
1594 	}
1595 
1596 	return 0;
1597 }
1598 
1599 static int sunxi_nand_chip_init(int node, struct sunxi_nfc *nfc, int devnum)
1600 {
1601 	const struct nand_sdr_timings *timings;
1602 	const void *blob = gd->fdt_blob;
1603 	struct sunxi_nand_chip *chip;
1604 	struct mtd_info *mtd;
1605 	struct nand_chip *nand;
1606 	int nsels;
1607 	int ret;
1608 	int i;
1609 	u32 cs[8], rb[8];
1610 
1611 	if (!fdt_getprop(blob, node, "reg", &nsels))
1612 		return -EINVAL;
1613 
1614 	nsels /= sizeof(u32);
1615 	if (!nsels || nsels > 8) {
1616 		dev_err(dev, "invalid reg property size\n");
1617 		return -EINVAL;
1618 	}
1619 
1620 	chip = kzalloc(sizeof(*chip) +
1621 		       (nsels * sizeof(struct sunxi_nand_chip_sel)),
1622 		       GFP_KERNEL);
1623 	if (!chip) {
1624 		dev_err(dev, "could not allocate chip\n");
1625 		return -ENOMEM;
1626 	}
1627 
1628 	chip->nsels = nsels;
1629 	chip->selected = -1;
1630 
1631 	for (i = 0; i < nsels; i++) {
1632 		cs[i] = -1;
1633 		rb[i] = -1;
1634 	}
1635 
1636 	ret = fdtdec_get_int_array(gd->fdt_blob, node, "reg", cs, nsels);
1637 	if (ret) {
1638 		dev_err(dev, "could not retrieve reg property: %d\n", ret);
1639 		return ret;
1640 	}
1641 
1642 	ret = fdtdec_get_int_array(gd->fdt_blob, node, "allwinner,rb", rb,
1643 				   nsels);
1644 	if (ret) {
1645 		dev_err(dev, "could not retrieve reg property: %d\n", ret);
1646 		return ret;
1647 	}
1648 
1649 	for (i = 0; i < nsels; i++) {
1650 		int tmp = cs[i];
1651 
1652 		if (tmp > NFC_MAX_CS) {
1653 			dev_err(dev,
1654 				"invalid reg value: %u (max CS = 7)\n",
1655 				tmp);
1656 			return -EINVAL;
1657 		}
1658 
1659 		if (test_and_set_bit(tmp, &nfc->assigned_cs)) {
1660 			dev_err(dev, "CS %d already assigned\n", tmp);
1661 			return -EINVAL;
1662 		}
1663 
1664 		chip->sels[i].cs = tmp;
1665 
1666 		tmp = rb[i];
1667 		if (tmp >= 0 && tmp < 2) {
1668 			chip->sels[i].rb.type = RB_NATIVE;
1669 			chip->sels[i].rb.info.nativeid = tmp;
1670 		} else {
1671 			ret = gpio_request_by_name_nodev(offset_to_ofnode(node),
1672 						"rb-gpios", i,
1673 						&chip->sels[i].rb.info.gpio,
1674 						GPIOD_IS_IN);
1675 			if (ret)
1676 				chip->sels[i].rb.type = RB_GPIO;
1677 			else
1678 				chip->sels[i].rb.type = RB_NONE;
1679 		}
1680 	}
1681 
1682 	timings = onfi_async_timing_mode_to_sdr_timings(0);
1683 	if (IS_ERR(timings)) {
1684 		ret = PTR_ERR(timings);
1685 		dev_err(dev,
1686 			"could not retrieve timings for ONFI mode 0: %d\n",
1687 			ret);
1688 		return ret;
1689 	}
1690 
1691 	ret = sunxi_nand_chip_set_timings(chip, timings);
1692 	if (ret) {
1693 		dev_err(dev, "could not configure chip timings: %d\n", ret);
1694 		return ret;
1695 	}
1696 
1697 	nand = &chip->nand;
1698 	/* Default tR value specified in the ONFI spec (chapter 4.15.1) */
1699 	nand->chip_delay = 200;
1700 	nand->controller = &nfc->controller;
1701 	/*
1702 	 * Set the ECC mode to the default value in case nothing is specified
1703 	 * in the DT.
1704 	 */
1705 	nand->ecc.mode = NAND_ECC_HW;
1706 	nand->flash_node = node;
1707 	nand->select_chip = sunxi_nfc_select_chip;
1708 	nand->cmd_ctrl = sunxi_nfc_cmd_ctrl;
1709 	nand->read_buf = sunxi_nfc_read_buf;
1710 	nand->write_buf = sunxi_nfc_write_buf;
1711 	nand->read_byte = sunxi_nfc_read_byte;
1712 
1713 	mtd = nand_to_mtd(nand);
1714 	ret = nand_scan_ident(mtd, nsels, NULL);
1715 	if (ret)
1716 		return ret;
1717 
1718 	if (nand->bbt_options & NAND_BBT_USE_FLASH)
1719 		nand->bbt_options |= NAND_BBT_NO_OOB;
1720 
1721 	if (nand->options & NAND_NEED_SCRAMBLING)
1722 		nand->options |= NAND_NO_SUBPAGE_WRITE;
1723 
1724 	nand->options |= NAND_SUBPAGE_READ;
1725 
1726 	ret = sunxi_nand_chip_init_timings(chip);
1727 	if (ret) {
1728 		dev_err(dev, "could not configure chip timings: %d\n", ret);
1729 		return ret;
1730 	}
1731 
1732 	ret = sunxi_nand_ecc_init(mtd, &nand->ecc);
1733 	if (ret) {
1734 		dev_err(dev, "ECC init failed: %d\n", ret);
1735 		return ret;
1736 	}
1737 
1738 	ret = nand_scan_tail(mtd);
1739 	if (ret) {
1740 		dev_err(dev, "nand_scan_tail failed: %d\n", ret);
1741 		return ret;
1742 	}
1743 
1744 	ret = nand_register(devnum, mtd);
1745 	if (ret) {
1746 		dev_err(dev, "failed to register mtd device: %d\n", ret);
1747 		return ret;
1748 	}
1749 
1750 	list_add_tail(&chip->node, &nfc->chips);
1751 
1752 	return 0;
1753 }
1754 
1755 static int sunxi_nand_chips_init(int node, struct sunxi_nfc *nfc)
1756 {
1757 	const void *blob = gd->fdt_blob;
1758 	int nand_node;
1759 	int ret, i = 0;
1760 
1761 	for (nand_node = fdt_first_subnode(blob, node); nand_node >= 0;
1762 	     nand_node = fdt_next_subnode(blob, nand_node))
1763 		i++;
1764 
1765 	if (i > 8) {
1766 		dev_err(dev, "too many NAND chips: %d (max = 8)\n", i);
1767 		return -EINVAL;
1768 	}
1769 
1770 	i = 0;
1771 	for (nand_node = fdt_first_subnode(blob, node); nand_node >= 0;
1772 	     nand_node = fdt_next_subnode(blob, nand_node)) {
1773 		ret = sunxi_nand_chip_init(nand_node, nfc, i++);
1774 		if (ret)
1775 			return ret;
1776 	}
1777 
1778 	return 0;
1779 }
1780 
1781 #ifndef __UBOOT__
1782 static void sunxi_nand_chips_cleanup(struct sunxi_nfc *nfc)
1783 {
1784 	struct sunxi_nand_chip *chip;
1785 
1786 	while (!list_empty(&nfc->chips)) {
1787 		chip = list_first_entry(&nfc->chips, struct sunxi_nand_chip,
1788 					node);
1789 		nand_release(&chip->mtd);
1790 		sunxi_nand_ecc_cleanup(&chip->nand.ecc);
1791 		list_del(&chip->node);
1792 		kfree(chip);
1793 	}
1794 }
1795 #endif /* __UBOOT__ */
1796 
1797 void sunxi_nand_init(void)
1798 {
1799 	const void *blob = gd->fdt_blob;
1800 	struct sunxi_nfc *nfc;
1801 	fdt_addr_t regs;
1802 	int node;
1803 	int ret;
1804 
1805 	nfc = kzalloc(sizeof(*nfc), GFP_KERNEL);
1806 	if (!nfc)
1807 		return;
1808 
1809 	spin_lock_init(&nfc->controller.lock);
1810 	init_waitqueue_head(&nfc->controller.wq);
1811 	INIT_LIST_HEAD(&nfc->chips);
1812 
1813 	node = fdtdec_next_compatible(blob, 0, COMPAT_SUNXI_NAND);
1814 	if (node < 0) {
1815 		pr_err("unable to find nfc node in device tree\n");
1816 		goto err;
1817 	}
1818 
1819 	if (!fdtdec_get_is_enabled(blob, node)) {
1820 		pr_err("nfc disabled in device tree\n");
1821 		goto err;
1822 	}
1823 
1824 	regs = fdtdec_get_addr(blob, node, "reg");
1825 	if (regs == FDT_ADDR_T_NONE) {
1826 		pr_err("unable to find nfc address in device tree\n");
1827 		goto err;
1828 	}
1829 
1830 	nfc->regs = (void *)regs;
1831 
1832 	ret = sunxi_nfc_rst(nfc);
1833 	if (ret)
1834 		goto err;
1835 
1836 	ret = sunxi_nand_chips_init(node, nfc);
1837 	if (ret) {
1838 		dev_err(dev, "failed to init nand chips\n");
1839 		goto err;
1840 	}
1841 
1842 	return;
1843 
1844 err:
1845 	kfree(nfc);
1846 }
1847 
1848 MODULE_LICENSE("GPL v2");
1849 MODULE_AUTHOR("Boris BREZILLON");
1850 MODULE_DESCRIPTION("Allwinner NAND Flash Controller driver");
1851