xref: /rk3399_rockchip-uboot/arch/arm/include/asm/ti-common/davinci_nand.h (revision 331c2375688d79920fb06b8f0c4c52a7df56fb29)
13e01ed00SKhoronzhuk, Ivan /*
23e01ed00SKhoronzhuk, Ivan  * NAND Flash Driver
33e01ed00SKhoronzhuk, Ivan  *
43e01ed00SKhoronzhuk, Ivan  * Copyright (C) 2006-2014 Texas Instruments.
53e01ed00SKhoronzhuk, Ivan  *
63e01ed00SKhoronzhuk, Ivan  * Based on Linux DaVinci NAND driver by TI.
73e01ed00SKhoronzhuk, Ivan  */
83e01ed00SKhoronzhuk, Ivan 
93e01ed00SKhoronzhuk, Ivan #ifndef _DAVINCI_NAND_H_
103e01ed00SKhoronzhuk, Ivan #define _DAVINCI_NAND_H_
113e01ed00SKhoronzhuk, Ivan 
12*331c2375SMasahiro Yamada #include <linux/mtd/rawnand.h>
133e01ed00SKhoronzhuk, Ivan #include <asm/arch/hardware.h>
143e01ed00SKhoronzhuk, Ivan 
153e01ed00SKhoronzhuk, Ivan #define NAND_READ_START  	0x00
163e01ed00SKhoronzhuk, Ivan #define NAND_READ_END    	0x30
173e01ed00SKhoronzhuk, Ivan #define NAND_STATUS      	0x70
183e01ed00SKhoronzhuk, Ivan 
193e01ed00SKhoronzhuk, Ivan #define MASK_CLE		0x10
203e01ed00SKhoronzhuk, Ivan #define MASK_ALE		0x08
213e01ed00SKhoronzhuk, Ivan 
223e01ed00SKhoronzhuk, Ivan #ifdef CONFIG_SYS_NAND_MASK_CLE
233e01ed00SKhoronzhuk, Ivan #undef MASK_CLE
243e01ed00SKhoronzhuk, Ivan #define MASK_CLE CONFIG_SYS_NAND_MASK_CLE
253e01ed00SKhoronzhuk, Ivan #endif
263e01ed00SKhoronzhuk, Ivan #ifdef CONFIG_SYS_NAND_MASK_ALE
273e01ed00SKhoronzhuk, Ivan #undef MASK_ALE
283e01ed00SKhoronzhuk, Ivan #define MASK_ALE CONFIG_SYS_NAND_MASK_ALE
293e01ed00SKhoronzhuk, Ivan #endif
303e01ed00SKhoronzhuk, Ivan 
313e01ed00SKhoronzhuk, Ivan struct davinci_emif_regs {
323e01ed00SKhoronzhuk, Ivan 	uint32_t	ercsr;
333e01ed00SKhoronzhuk, Ivan 	uint32_t	awccr;
343e01ed00SKhoronzhuk, Ivan 	uint32_t	sdbcr;
353e01ed00SKhoronzhuk, Ivan 	uint32_t	sdrcr;
363e01ed00SKhoronzhuk, Ivan 	union {
373e01ed00SKhoronzhuk, Ivan 		uint32_t abncr[4];
38c1659942SPeter Howard 		struct {
393e01ed00SKhoronzhuk, Ivan 			uint32_t ab1cr;
403e01ed00SKhoronzhuk, Ivan 			uint32_t ab2cr;
413e01ed00SKhoronzhuk, Ivan 			uint32_t ab3cr;
423e01ed00SKhoronzhuk, Ivan 			uint32_t ab4cr;
433e01ed00SKhoronzhuk, Ivan 		};
44c1659942SPeter Howard 	};
453e01ed00SKhoronzhuk, Ivan 	uint32_t	sdtimr;
463e01ed00SKhoronzhuk, Ivan 	uint32_t	ddrsr;
473e01ed00SKhoronzhuk, Ivan 	uint32_t	ddrphycr;
483e01ed00SKhoronzhuk, Ivan 	uint32_t	ddrphysr;
493e01ed00SKhoronzhuk, Ivan 	uint32_t	totar;
503e01ed00SKhoronzhuk, Ivan 	uint32_t	totactr;
513e01ed00SKhoronzhuk, Ivan 	uint32_t	ddrphyid_rev;
523e01ed00SKhoronzhuk, Ivan 	uint32_t	sdsretr;
533e01ed00SKhoronzhuk, Ivan 	uint32_t	eirr;
543e01ed00SKhoronzhuk, Ivan 	uint32_t	eimr;
553e01ed00SKhoronzhuk, Ivan 	uint32_t	eimsr;
563e01ed00SKhoronzhuk, Ivan 	uint32_t	eimcr;
573e01ed00SKhoronzhuk, Ivan 	uint32_t	ioctrlr;
583e01ed00SKhoronzhuk, Ivan 	uint32_t	iostatr;
593e01ed00SKhoronzhuk, Ivan 	uint32_t	rsvd0;
603e01ed00SKhoronzhuk, Ivan 	uint32_t	one_nand_cr;
613e01ed00SKhoronzhuk, Ivan 	uint32_t	nandfcr;
623e01ed00SKhoronzhuk, Ivan 	uint32_t	nandfsr;
633e01ed00SKhoronzhuk, Ivan 	uint32_t	rsvd1[2];
643e01ed00SKhoronzhuk, Ivan 	uint32_t	nandfecc[4];
653e01ed00SKhoronzhuk, Ivan 	uint32_t	rsvd2[15];
663e01ed00SKhoronzhuk, Ivan 	uint32_t	nand4biteccload;
673e01ed00SKhoronzhuk, Ivan 	uint32_t	nand4bitecc[4];
683e01ed00SKhoronzhuk, Ivan 	uint32_t	nanderradd1;
693e01ed00SKhoronzhuk, Ivan 	uint32_t	nanderradd2;
703e01ed00SKhoronzhuk, Ivan 	uint32_t	nanderrval1;
713e01ed00SKhoronzhuk, Ivan 	uint32_t	nanderrval2;
723e01ed00SKhoronzhuk, Ivan };
733e01ed00SKhoronzhuk, Ivan 
743e01ed00SKhoronzhuk, Ivan #define davinci_emif_regs \
753e01ed00SKhoronzhuk, Ivan 	((struct davinci_emif_regs *)DAVINCI_ASYNC_EMIF_CNTRL_BASE)
763e01ed00SKhoronzhuk, Ivan 
773e01ed00SKhoronzhuk, Ivan #define DAVINCI_NANDFCR_NAND_ENABLE(n)			(1 << ((n) - 2))
783e01ed00SKhoronzhuk, Ivan #define DAVINCI_NANDFCR_4BIT_ECC_SEL_MASK		(3 << 4)
793e01ed00SKhoronzhuk, Ivan #define DAVINCI_NANDFCR_4BIT_ECC_SEL(n)			(((n) - 2) << 4)
803e01ed00SKhoronzhuk, Ivan #define DAVINCI_NANDFCR_1BIT_ECC_START(n)		(1 << (8 + ((n) - 2)))
813e01ed00SKhoronzhuk, Ivan #define DAVINCI_NANDFCR_4BIT_ECC_START			(1 << 12)
823e01ed00SKhoronzhuk, Ivan #define DAVINCI_NANDFCR_4BIT_CALC_START			(1 << 13)
833e01ed00SKhoronzhuk, Ivan #define DAVINCI_NANDFCR_CS2NAND				(1 << 0)
843e01ed00SKhoronzhuk, Ivan 
853e01ed00SKhoronzhuk, Ivan /* Chip Select setup */
863e01ed00SKhoronzhuk, Ivan #define DAVINCI_ABCR_STROBE_SELECT			(1 << 31)
873e01ed00SKhoronzhuk, Ivan #define DAVINCI_ABCR_EXT_WAIT				(1 << 30)
883e01ed00SKhoronzhuk, Ivan #define DAVINCI_ABCR_WSETUP(n)				(n << 26)
893e01ed00SKhoronzhuk, Ivan #define DAVINCI_ABCR_WSTROBE(n)				(n << 20)
903e01ed00SKhoronzhuk, Ivan #define DAVINCI_ABCR_WHOLD(n)				(n << 17)
913e01ed00SKhoronzhuk, Ivan #define DAVINCI_ABCR_RSETUP(n)				(n << 13)
923e01ed00SKhoronzhuk, Ivan #define DAVINCI_ABCR_RSTROBE(n)				(n << 7)
933e01ed00SKhoronzhuk, Ivan #define DAVINCI_ABCR_RHOLD(n)				(n << 4)
943e01ed00SKhoronzhuk, Ivan #define DAVINCI_ABCR_TA(n)				(n << 2)
953e01ed00SKhoronzhuk, Ivan #define DAVINCI_ABCR_ASIZE_16BIT			1
963e01ed00SKhoronzhuk, Ivan #define DAVINCI_ABCR_ASIZE_8BIT				0
973e01ed00SKhoronzhuk, Ivan 
983e01ed00SKhoronzhuk, Ivan void davinci_nand_init(struct nand_chip *nand);
993e01ed00SKhoronzhuk, Ivan 
1003e01ed00SKhoronzhuk, Ivan #endif
101