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