Merge branch 'master' of git://git.denx.de/u-boot-tegra
[platform/kernel/u-boot.git] / arch / arm / include / asm / ti-common / davinci_nand.h
1 /*
2  * NAND Flash Driver
3  *
4  * Copyright (C) 2006-2014 Texas Instruments.
5  *
6  * Based on Linux DaVinci NAND driver by TI.
7  */
8
9 #ifndef _DAVINCI_NAND_H_
10 #define _DAVINCI_NAND_H_
11
12 #include <linux/mtd/nand.h>
13 #include <asm/arch/hardware.h>
14
15 #define NAND_READ_START         0x00
16 #define NAND_READ_END           0x30
17 #define NAND_STATUS             0x70
18
19 #define MASK_CLE                0x10
20 #define MASK_ALE                0x08
21
22 #ifdef CONFIG_SYS_NAND_MASK_CLE
23 #undef MASK_CLE
24 #define MASK_CLE CONFIG_SYS_NAND_MASK_CLE
25 #endif
26 #ifdef CONFIG_SYS_NAND_MASK_ALE
27 #undef MASK_ALE
28 #define MASK_ALE CONFIG_SYS_NAND_MASK_ALE
29 #endif
30
31 struct davinci_emif_regs {
32         uint32_t        ercsr;
33         uint32_t        awccr;
34         uint32_t        sdbcr;
35         uint32_t        sdrcr;
36         union {
37                 uint32_t abncr[4];
38                 uint32_t ab1cr;
39                 uint32_t ab2cr;
40                 uint32_t ab3cr;
41                 uint32_t ab4cr;
42         };
43         uint32_t        sdtimr;
44         uint32_t        ddrsr;
45         uint32_t        ddrphycr;
46         uint32_t        ddrphysr;
47         uint32_t        totar;
48         uint32_t        totactr;
49         uint32_t        ddrphyid_rev;
50         uint32_t        sdsretr;
51         uint32_t        eirr;
52         uint32_t        eimr;
53         uint32_t        eimsr;
54         uint32_t        eimcr;
55         uint32_t        ioctrlr;
56         uint32_t        iostatr;
57         uint32_t        rsvd0;
58         uint32_t        one_nand_cr;
59         uint32_t        nandfcr;
60         uint32_t        nandfsr;
61         uint32_t        rsvd1[2];
62         uint32_t        nandfecc[4];
63         uint32_t        rsvd2[15];
64         uint32_t        nand4biteccload;
65         uint32_t        nand4bitecc[4];
66         uint32_t        nanderradd1;
67         uint32_t        nanderradd2;
68         uint32_t        nanderrval1;
69         uint32_t        nanderrval2;
70 };
71
72 #define davinci_emif_regs \
73         ((struct davinci_emif_regs *)DAVINCI_ASYNC_EMIF_CNTRL_BASE)
74
75 #define DAVINCI_NANDFCR_NAND_ENABLE(n)                  (1 << ((n) - 2))
76 #define DAVINCI_NANDFCR_4BIT_ECC_SEL_MASK               (3 << 4)
77 #define DAVINCI_NANDFCR_4BIT_ECC_SEL(n)                 (((n) - 2) << 4)
78 #define DAVINCI_NANDFCR_1BIT_ECC_START(n)               (1 << (8 + ((n) - 2)))
79 #define DAVINCI_NANDFCR_4BIT_ECC_START                  (1 << 12)
80 #define DAVINCI_NANDFCR_4BIT_CALC_START                 (1 << 13)
81 #define DAVINCI_NANDFCR_CS2NAND                         (1 << 0)
82
83 /* Chip Select setup */
84 #define DAVINCI_ABCR_STROBE_SELECT                      (1 << 31)
85 #define DAVINCI_ABCR_EXT_WAIT                           (1 << 30)
86 #define DAVINCI_ABCR_WSETUP(n)                          (n << 26)
87 #define DAVINCI_ABCR_WSTROBE(n)                         (n << 20)
88 #define DAVINCI_ABCR_WHOLD(n)                           (n << 17)
89 #define DAVINCI_ABCR_RSETUP(n)                          (n << 13)
90 #define DAVINCI_ABCR_RSTROBE(n)                         (n << 7)
91 #define DAVINCI_ABCR_RHOLD(n)                           (n << 4)
92 #define DAVINCI_ABCR_TA(n)                              (n << 2)
93 #define DAVINCI_ABCR_ASIZE_16BIT                        1
94 #define DAVINCI_ABCR_ASIZE_8BIT                         0
95
96 void davinci_nand_init(struct nand_chip *nand);
97
98 #endif