mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-26 01:28:14 +00:00 
			
		
		
		
	This header was renamed to rawnand.h in Linux.
The following is the corresponding commit in Linux.
  commit d4092d76a4a4e57b65910899948a83cc8646c5a5
  Author: Boris Brezillon <boris.brezillon@free-electrons.com>
  Date:   Fri Aug 4 17:29:10 2017 +0200
      mtd: nand: Rename nand.h into rawnand.h
      We are planning to share more code between different NAND based
      devices (SPI NAND, OneNAND and raw NANDs), but before doing that
      we need to move the existing include/linux/mtd/nand.h file into
      include/linux/mtd/rawnand.h so we can later create a nand.h header
      containing all common structure and function prototypes.
Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
		
	
			
		
			
				
	
	
		
			101 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * NAND Flash Driver
 | |
|  *
 | |
|  * Copyright (C) 2006-2014 Texas Instruments.
 | |
|  *
 | |
|  * Based on Linux DaVinci NAND driver by TI.
 | |
|  */
 | |
| 
 | |
| #ifndef _DAVINCI_NAND_H_
 | |
| #define _DAVINCI_NAND_H_
 | |
| 
 | |
| #include <linux/mtd/rawnand.h>
 | |
| #include <asm/arch/hardware.h>
 | |
| 
 | |
| #define NAND_READ_START  	0x00
 | |
| #define NAND_READ_END    	0x30
 | |
| #define NAND_STATUS      	0x70
 | |
| 
 | |
| #define MASK_CLE		0x10
 | |
| #define MASK_ALE		0x08
 | |
| 
 | |
| #ifdef CONFIG_SYS_NAND_MASK_CLE
 | |
| #undef MASK_CLE
 | |
| #define MASK_CLE CONFIG_SYS_NAND_MASK_CLE
 | |
| #endif
 | |
| #ifdef CONFIG_SYS_NAND_MASK_ALE
 | |
| #undef MASK_ALE
 | |
| #define MASK_ALE CONFIG_SYS_NAND_MASK_ALE
 | |
| #endif
 | |
| 
 | |
| struct davinci_emif_regs {
 | |
| 	uint32_t	ercsr;
 | |
| 	uint32_t	awccr;
 | |
| 	uint32_t	sdbcr;
 | |
| 	uint32_t	sdrcr;
 | |
| 	union {
 | |
| 		uint32_t abncr[4];
 | |
| 		struct {
 | |
| 			uint32_t ab1cr;
 | |
| 			uint32_t ab2cr;
 | |
| 			uint32_t ab3cr;
 | |
| 			uint32_t ab4cr;
 | |
| 		};
 | |
| 	};
 | |
| 	uint32_t	sdtimr;
 | |
| 	uint32_t	ddrsr;
 | |
| 	uint32_t	ddrphycr;
 | |
| 	uint32_t	ddrphysr;
 | |
| 	uint32_t	totar;
 | |
| 	uint32_t	totactr;
 | |
| 	uint32_t	ddrphyid_rev;
 | |
| 	uint32_t	sdsretr;
 | |
| 	uint32_t	eirr;
 | |
| 	uint32_t	eimr;
 | |
| 	uint32_t	eimsr;
 | |
| 	uint32_t	eimcr;
 | |
| 	uint32_t	ioctrlr;
 | |
| 	uint32_t	iostatr;
 | |
| 	uint32_t	rsvd0;
 | |
| 	uint32_t	one_nand_cr;
 | |
| 	uint32_t	nandfcr;
 | |
| 	uint32_t	nandfsr;
 | |
| 	uint32_t	rsvd1[2];
 | |
| 	uint32_t	nandfecc[4];
 | |
| 	uint32_t	rsvd2[15];
 | |
| 	uint32_t	nand4biteccload;
 | |
| 	uint32_t	nand4bitecc[4];
 | |
| 	uint32_t	nanderradd1;
 | |
| 	uint32_t	nanderradd2;
 | |
| 	uint32_t	nanderrval1;
 | |
| 	uint32_t	nanderrval2;
 | |
| };
 | |
| 
 | |
| #define davinci_emif_regs \
 | |
| 	((struct davinci_emif_regs *)DAVINCI_ASYNC_EMIF_CNTRL_BASE)
 | |
| 
 | |
| #define DAVINCI_NANDFCR_NAND_ENABLE(n)			(1 << ((n) - 2))
 | |
| #define DAVINCI_NANDFCR_4BIT_ECC_SEL_MASK		(3 << 4)
 | |
| #define DAVINCI_NANDFCR_4BIT_ECC_SEL(n)			(((n) - 2) << 4)
 | |
| #define DAVINCI_NANDFCR_1BIT_ECC_START(n)		(1 << (8 + ((n) - 2)))
 | |
| #define DAVINCI_NANDFCR_4BIT_ECC_START			(1 << 12)
 | |
| #define DAVINCI_NANDFCR_4BIT_CALC_START			(1 << 13)
 | |
| #define DAVINCI_NANDFCR_CS2NAND				(1 << 0)
 | |
| 
 | |
| /* Chip Select setup */
 | |
| #define DAVINCI_ABCR_STROBE_SELECT			(1 << 31)
 | |
| #define DAVINCI_ABCR_EXT_WAIT				(1 << 30)
 | |
| #define DAVINCI_ABCR_WSETUP(n)				(n << 26)
 | |
| #define DAVINCI_ABCR_WSTROBE(n)				(n << 20)
 | |
| #define DAVINCI_ABCR_WHOLD(n)				(n << 17)
 | |
| #define DAVINCI_ABCR_RSETUP(n)				(n << 13)
 | |
| #define DAVINCI_ABCR_RSTROBE(n)				(n << 7)
 | |
| #define DAVINCI_ABCR_RHOLD(n)				(n << 4)
 | |
| #define DAVINCI_ABCR_TA(n)				(n << 2)
 | |
| #define DAVINCI_ABCR_ASIZE_16BIT			1
 | |
| #define DAVINCI_ABCR_ASIZE_8BIT				0
 | |
| 
 | |
| void davinci_nand_init(struct nand_chip *nand);
 | |
| 
 | |
| #endif
 |