~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/include/linux/fsl_ifc.h

Version: ~ [ linux-6.11-rc3 ] ~ [ linux-6.10.4 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.45 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.104 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.164 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.223 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.281 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.319 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /include/linux/fsl_ifc.h (Version linux-6.11-rc3) and /include/linux/fsl_ifc.h (Version linux-5.18.19)


  1 /* SPDX-License-Identifier: GPL-2.0-or-later *      1 /* SPDX-License-Identifier: GPL-2.0-or-later */
  2 /* Freescale Integrated Flash Controller            2 /* Freescale Integrated Flash Controller
  3  *                                                  3  *
  4  * Copyright 2011 Freescale Semiconductor, Inc      4  * Copyright 2011 Freescale Semiconductor, Inc
  5  *                                                  5  *
  6  * Author: Dipen Dudhat <dipen.dudhat@freescal      6  * Author: Dipen Dudhat <dipen.dudhat@freescale.com>
  7  */                                                 7  */
  8                                                     8 
  9 #ifndef __ASM_FSL_IFC_H                             9 #ifndef __ASM_FSL_IFC_H
 10 #define __ASM_FSL_IFC_H                            10 #define __ASM_FSL_IFC_H
 11                                                    11 
 12 #include <linux/compiler.h>                        12 #include <linux/compiler.h>
 13 #include <linux/types.h>                           13 #include <linux/types.h>
 14 #include <linux/io.h>                              14 #include <linux/io.h>
 15                                                    15 
 16 #include <linux/of_platform.h>                     16 #include <linux/of_platform.h>
 17 #include <linux/interrupt.h>                       17 #include <linux/interrupt.h>
 18                                                    18 
 19 /*                                                 19 /*
 20  * The actual number of banks implemented depe     20  * The actual number of banks implemented depends on the IFC version
 21  *    - IFC version 1.0 implements 4 banks.        21  *    - IFC version 1.0 implements 4 banks.
 22  *    - IFC version 1.1 onward implements 8 ba     22  *    - IFC version 1.1 onward implements 8 banks.
 23  */                                                23  */
 24 #define FSL_IFC_BANK_COUNT 8                       24 #define FSL_IFC_BANK_COUNT 8
 25                                                    25 
 26 #define FSL_IFC_VERSION_MASK    0x0F0F0000         26 #define FSL_IFC_VERSION_MASK    0x0F0F0000
 27 #define FSL_IFC_VERSION_1_0_0   0x01000000         27 #define FSL_IFC_VERSION_1_0_0   0x01000000
 28 #define FSL_IFC_VERSION_1_1_0   0x01010000         28 #define FSL_IFC_VERSION_1_1_0   0x01010000
 29 #define FSL_IFC_VERSION_2_0_0   0x02000000         29 #define FSL_IFC_VERSION_2_0_0   0x02000000
 30                                                    30 
 31 #define PGOFFSET_64K    (64*1024)                  31 #define PGOFFSET_64K    (64*1024)
 32 #define PGOFFSET_4K     (4*1024)                   32 #define PGOFFSET_4K     (4*1024)
 33                                                    33 
 34 /*                                                 34 /*
 35  * CSPR - Chip Select Property Register            35  * CSPR - Chip Select Property Register
 36  */                                                36  */
 37 #define CSPR_BA                         0xFFFF     37 #define CSPR_BA                         0xFFFF0000
 38 #define CSPR_BA_SHIFT                   16         38 #define CSPR_BA_SHIFT                   16
 39 #define CSPR_PORT_SIZE                  0x0000     39 #define CSPR_PORT_SIZE                  0x00000180
 40 #define CSPR_PORT_SIZE_SHIFT            7          40 #define CSPR_PORT_SIZE_SHIFT            7
 41 /* Port Size 8 bit */                              41 /* Port Size 8 bit */
 42 #define CSPR_PORT_SIZE_8                0x0000     42 #define CSPR_PORT_SIZE_8                0x00000080
 43 /* Port Size 16 bit */                             43 /* Port Size 16 bit */
 44 #define CSPR_PORT_SIZE_16               0x0000     44 #define CSPR_PORT_SIZE_16               0x00000100
 45 /* Port Size 32 bit */                             45 /* Port Size 32 bit */
 46 #define CSPR_PORT_SIZE_32               0x0000     46 #define CSPR_PORT_SIZE_32               0x00000180
 47 /* Write Protect */                                47 /* Write Protect */
 48 #define CSPR_WP                         0x0000     48 #define CSPR_WP                         0x00000040
 49 #define CSPR_WP_SHIFT                   6          49 #define CSPR_WP_SHIFT                   6
 50 /* Machine Select */                               50 /* Machine Select */
 51 #define CSPR_MSEL                       0x0000     51 #define CSPR_MSEL                       0x00000006
 52 #define CSPR_MSEL_SHIFT                 1          52 #define CSPR_MSEL_SHIFT                 1
 53 /* NOR */                                          53 /* NOR */
 54 #define CSPR_MSEL_NOR                   0x0000     54 #define CSPR_MSEL_NOR                   0x00000000
 55 /* NAND */                                         55 /* NAND */
 56 #define CSPR_MSEL_NAND                  0x0000     56 #define CSPR_MSEL_NAND                  0x00000002
 57 /* GPCM */                                         57 /* GPCM */
 58 #define CSPR_MSEL_GPCM                  0x0000     58 #define CSPR_MSEL_GPCM                  0x00000004
 59 /* Bank Valid */                                   59 /* Bank Valid */
 60 #define CSPR_V                          0x0000     60 #define CSPR_V                          0x00000001
 61 #define CSPR_V_SHIFT                    0          61 #define CSPR_V_SHIFT                    0
 62                                                    62 
 63 /*                                                 63 /*
 64  * Address Mask Register                           64  * Address Mask Register
 65  */                                                65  */
 66 #define IFC_AMASK_MASK                  0xFFFF     66 #define IFC_AMASK_MASK                  0xFFFF0000
 67 #define IFC_AMASK_SHIFT                 16         67 #define IFC_AMASK_SHIFT                 16
 68 #define IFC_AMASK(n)                    (IFC_A     68 #define IFC_AMASK(n)                    (IFC_AMASK_MASK << \
 69                                         (__ilo     69                                         (__ilog2(n) - IFC_AMASK_SHIFT))
 70                                                    70 
 71 /*                                                 71 /*
 72  * Chip Select Option Register IFC_NAND Machin     72  * Chip Select Option Register IFC_NAND Machine
 73  */                                                73  */
 74 /* Enable ECC Encoder */                           74 /* Enable ECC Encoder */
 75 #define CSOR_NAND_ECC_ENC_EN            0x8000     75 #define CSOR_NAND_ECC_ENC_EN            0x80000000
 76 #define CSOR_NAND_ECC_MODE_MASK         0x3000     76 #define CSOR_NAND_ECC_MODE_MASK         0x30000000
 77 /* 4 bit correction per 520 Byte sector */         77 /* 4 bit correction per 520 Byte sector */
 78 #define CSOR_NAND_ECC_MODE_4            0x0000     78 #define CSOR_NAND_ECC_MODE_4            0x00000000
 79 /* 8 bit correction per 528 Byte sector */         79 /* 8 bit correction per 528 Byte sector */
 80 #define CSOR_NAND_ECC_MODE_8            0x1000     80 #define CSOR_NAND_ECC_MODE_8            0x10000000
 81 /* Enable ECC Decoder */                           81 /* Enable ECC Decoder */
 82 #define CSOR_NAND_ECC_DEC_EN            0x0400     82 #define CSOR_NAND_ECC_DEC_EN            0x04000000
 83 /* Row Address Length */                           83 /* Row Address Length */
 84 #define CSOR_NAND_RAL_MASK              0x0180     84 #define CSOR_NAND_RAL_MASK              0x01800000
 85 #define CSOR_NAND_RAL_SHIFT             20         85 #define CSOR_NAND_RAL_SHIFT             20
 86 #define CSOR_NAND_RAL_1                 0x0000     86 #define CSOR_NAND_RAL_1                 0x00000000
 87 #define CSOR_NAND_RAL_2                 0x0080     87 #define CSOR_NAND_RAL_2                 0x00800000
 88 #define CSOR_NAND_RAL_3                 0x0100     88 #define CSOR_NAND_RAL_3                 0x01000000
 89 #define CSOR_NAND_RAL_4                 0x0180     89 #define CSOR_NAND_RAL_4                 0x01800000
 90 /* Page Size 512b, 2k, 4k */                       90 /* Page Size 512b, 2k, 4k */
 91 #define CSOR_NAND_PGS_MASK              0x0018     91 #define CSOR_NAND_PGS_MASK              0x00180000
 92 #define CSOR_NAND_PGS_SHIFT             16         92 #define CSOR_NAND_PGS_SHIFT             16
 93 #define CSOR_NAND_PGS_512               0x0000     93 #define CSOR_NAND_PGS_512               0x00000000
 94 #define CSOR_NAND_PGS_2K                0x0008     94 #define CSOR_NAND_PGS_2K                0x00080000
 95 #define CSOR_NAND_PGS_4K                0x0010     95 #define CSOR_NAND_PGS_4K                0x00100000
 96 #define CSOR_NAND_PGS_8K                0x0018     96 #define CSOR_NAND_PGS_8K                0x00180000
 97 /* Spare region Size */                            97 /* Spare region Size */
 98 #define CSOR_NAND_SPRZ_MASK             0x0000     98 #define CSOR_NAND_SPRZ_MASK             0x0000E000
 99 #define CSOR_NAND_SPRZ_SHIFT            13         99 #define CSOR_NAND_SPRZ_SHIFT            13
100 #define CSOR_NAND_SPRZ_16               0x0000    100 #define CSOR_NAND_SPRZ_16               0x00000000
101 #define CSOR_NAND_SPRZ_64               0x0000    101 #define CSOR_NAND_SPRZ_64               0x00002000
102 #define CSOR_NAND_SPRZ_128              0x0000    102 #define CSOR_NAND_SPRZ_128              0x00004000
103 #define CSOR_NAND_SPRZ_210              0x0000    103 #define CSOR_NAND_SPRZ_210              0x00006000
104 #define CSOR_NAND_SPRZ_218              0x0000    104 #define CSOR_NAND_SPRZ_218              0x00008000
105 #define CSOR_NAND_SPRZ_224              0x0000    105 #define CSOR_NAND_SPRZ_224              0x0000A000
106 #define CSOR_NAND_SPRZ_CSOR_EXT         0x0000    106 #define CSOR_NAND_SPRZ_CSOR_EXT         0x0000C000
107 /* Pages Per Block */                             107 /* Pages Per Block */
108 #define CSOR_NAND_PB_MASK               0x0000    108 #define CSOR_NAND_PB_MASK               0x00000700
109 #define CSOR_NAND_PB_SHIFT              8         109 #define CSOR_NAND_PB_SHIFT              8
110 #define CSOR_NAND_PB(n)         ((__ilog2(n) -    110 #define CSOR_NAND_PB(n)         ((__ilog2(n) - 5) << CSOR_NAND_PB_SHIFT)
111 /* Time for Read Enable High to Output High Im    111 /* Time for Read Enable High to Output High Impedance */
112 #define CSOR_NAND_TRHZ_MASK             0x0000    112 #define CSOR_NAND_TRHZ_MASK             0x0000001C
113 #define CSOR_NAND_TRHZ_SHIFT            2         113 #define CSOR_NAND_TRHZ_SHIFT            2
114 #define CSOR_NAND_TRHZ_20               0x0000    114 #define CSOR_NAND_TRHZ_20               0x00000000
115 #define CSOR_NAND_TRHZ_40               0x0000    115 #define CSOR_NAND_TRHZ_40               0x00000004
116 #define CSOR_NAND_TRHZ_60               0x0000    116 #define CSOR_NAND_TRHZ_60               0x00000008
117 #define CSOR_NAND_TRHZ_80               0x0000    117 #define CSOR_NAND_TRHZ_80               0x0000000C
118 #define CSOR_NAND_TRHZ_100              0x0000    118 #define CSOR_NAND_TRHZ_100              0x00000010
119 /* Buffer control disable */                      119 /* Buffer control disable */
120 #define CSOR_NAND_BCTLD                 0x0000    120 #define CSOR_NAND_BCTLD                 0x00000001
121                                                   121 
122 /*                                                122 /*
123  * Chip Select Option Register - NOR Flash Mod    123  * Chip Select Option Register - NOR Flash Mode
124  */                                               124  */
125 /* Enable Address shift Mode */                   125 /* Enable Address shift Mode */
126 #define CSOR_NOR_ADM_SHFT_MODE_EN       0x8000    126 #define CSOR_NOR_ADM_SHFT_MODE_EN       0x80000000
127 /* Page Read Enable from NOR device */            127 /* Page Read Enable from NOR device */
128 #define CSOR_NOR_PGRD_EN                0x1000    128 #define CSOR_NOR_PGRD_EN                0x10000000
129 /* AVD Toggle Enable during Burst Program */      129 /* AVD Toggle Enable during Burst Program */
130 #define CSOR_NOR_AVD_TGL_PGM_EN         0x0100    130 #define CSOR_NOR_AVD_TGL_PGM_EN         0x01000000
131 /* Address Data Multiplexing Shift */             131 /* Address Data Multiplexing Shift */
132 #define CSOR_NOR_ADM_MASK               0x0003    132 #define CSOR_NOR_ADM_MASK               0x0003E000
133 #define CSOR_NOR_ADM_SHIFT_SHIFT        13        133 #define CSOR_NOR_ADM_SHIFT_SHIFT        13
134 #define CSOR_NOR_ADM_SHIFT(n)   ((n) << CSOR_N    134 #define CSOR_NOR_ADM_SHIFT(n)   ((n) << CSOR_NOR_ADM_SHIFT_SHIFT)
135 /* Type of the NOR device hooked */               135 /* Type of the NOR device hooked */
136 #define CSOR_NOR_NOR_MODE_AYSNC_NOR     0x0000    136 #define CSOR_NOR_NOR_MODE_AYSNC_NOR     0x00000000
137 #define CSOR_NOR_NOR_MODE_AVD_NOR       0x0000    137 #define CSOR_NOR_NOR_MODE_AVD_NOR       0x00000020
138 /* Time for Read Enable High to Output High Im    138 /* Time for Read Enable High to Output High Impedance */
139 #define CSOR_NOR_TRHZ_MASK              0x0000    139 #define CSOR_NOR_TRHZ_MASK              0x0000001C
140 #define CSOR_NOR_TRHZ_SHIFT             2         140 #define CSOR_NOR_TRHZ_SHIFT             2
141 #define CSOR_NOR_TRHZ_20                0x0000    141 #define CSOR_NOR_TRHZ_20                0x00000000
142 #define CSOR_NOR_TRHZ_40                0x0000    142 #define CSOR_NOR_TRHZ_40                0x00000004
143 #define CSOR_NOR_TRHZ_60                0x0000    143 #define CSOR_NOR_TRHZ_60                0x00000008
144 #define CSOR_NOR_TRHZ_80                0x0000    144 #define CSOR_NOR_TRHZ_80                0x0000000C
145 #define CSOR_NOR_TRHZ_100               0x0000    145 #define CSOR_NOR_TRHZ_100               0x00000010
146 /* Buffer control disable */                      146 /* Buffer control disable */
147 #define CSOR_NOR_BCTLD                  0x0000    147 #define CSOR_NOR_BCTLD                  0x00000001
148                                                   148 
149 /*                                                149 /*
150  * Chip Select Option Register - GPCM Mode        150  * Chip Select Option Register - GPCM Mode
151  */                                               151  */
152 /* GPCM Mode - Normal */                          152 /* GPCM Mode - Normal */
153 #define CSOR_GPCM_GPMODE_NORMAL         0x0000    153 #define CSOR_GPCM_GPMODE_NORMAL         0x00000000
154 /* GPCM Mode - GenericASIC */                     154 /* GPCM Mode - GenericASIC */
155 #define CSOR_GPCM_GPMODE_ASIC           0x8000    155 #define CSOR_GPCM_GPMODE_ASIC           0x80000000
156 /* Parity Mode odd/even */                        156 /* Parity Mode odd/even */
157 #define CSOR_GPCM_PARITY_EVEN           0x4000    157 #define CSOR_GPCM_PARITY_EVEN           0x40000000
158 /* Parity Checking enable/disable */              158 /* Parity Checking enable/disable */
159 #define CSOR_GPCM_PAR_EN                0x2000    159 #define CSOR_GPCM_PAR_EN                0x20000000
160 /* GPCM Timeout Count */                          160 /* GPCM Timeout Count */
161 #define CSOR_GPCM_GPTO_MASK             0x0F00    161 #define CSOR_GPCM_GPTO_MASK             0x0F000000
162 #define CSOR_GPCM_GPTO_SHIFT            24        162 #define CSOR_GPCM_GPTO_SHIFT            24
163 #define CSOR_GPCM_GPTO(n)       ((__ilog2(n) -    163 #define CSOR_GPCM_GPTO(n)       ((__ilog2(n) - 8) << CSOR_GPCM_GPTO_SHIFT)
164 /* GPCM External Access Termination mode for r    164 /* GPCM External Access Termination mode for read access */
165 #define CSOR_GPCM_RGETA_EXT             0x0008    165 #define CSOR_GPCM_RGETA_EXT             0x00080000
166 /* GPCM External Access Termination mode for w    166 /* GPCM External Access Termination mode for write access */
167 #define CSOR_GPCM_WGETA_EXT             0x0004    167 #define CSOR_GPCM_WGETA_EXT             0x00040000
168 /* Address Data Multiplexing Shift */             168 /* Address Data Multiplexing Shift */
169 #define CSOR_GPCM_ADM_MASK              0x0003    169 #define CSOR_GPCM_ADM_MASK              0x0003E000
170 #define CSOR_GPCM_ADM_SHIFT_SHIFT       13        170 #define CSOR_GPCM_ADM_SHIFT_SHIFT       13
171 #define CSOR_GPCM_ADM_SHIFT(n)  ((n) << CSOR_G    171 #define CSOR_GPCM_ADM_SHIFT(n)  ((n) << CSOR_GPCM_ADM_SHIFT_SHIFT)
172 /* Generic ASIC Parity error indication delay     172 /* Generic ASIC Parity error indication delay */
173 #define CSOR_GPCM_GAPERRD_MASK          0x0000    173 #define CSOR_GPCM_GAPERRD_MASK          0x00000180
174 #define CSOR_GPCM_GAPERRD_SHIFT         7         174 #define CSOR_GPCM_GAPERRD_SHIFT         7
175 #define CSOR_GPCM_GAPERRD(n)    (((n) - 1) <<     175 #define CSOR_GPCM_GAPERRD(n)    (((n) - 1) << CSOR_GPCM_GAPERRD_SHIFT)
176 /* Time for Read Enable High to Output High Im    176 /* Time for Read Enable High to Output High Impedance */
177 #define CSOR_GPCM_TRHZ_MASK             0x0000    177 #define CSOR_GPCM_TRHZ_MASK             0x0000001C
178 #define CSOR_GPCM_TRHZ_20               0x0000    178 #define CSOR_GPCM_TRHZ_20               0x00000000
179 #define CSOR_GPCM_TRHZ_40               0x0000    179 #define CSOR_GPCM_TRHZ_40               0x00000004
180 #define CSOR_GPCM_TRHZ_60               0x0000    180 #define CSOR_GPCM_TRHZ_60               0x00000008
181 #define CSOR_GPCM_TRHZ_80               0x0000    181 #define CSOR_GPCM_TRHZ_80               0x0000000C
182 #define CSOR_GPCM_TRHZ_100              0x0000    182 #define CSOR_GPCM_TRHZ_100              0x00000010
183 /* Buffer control disable */                      183 /* Buffer control disable */
184 #define CSOR_GPCM_BCTLD                 0x0000    184 #define CSOR_GPCM_BCTLD                 0x00000001
185                                                   185 
186 /*                                                186 /*
187  * Ready Busy Status Register (RB_STAT)           187  * Ready Busy Status Register (RB_STAT)
188  */                                               188  */
189 /* CSn is READY */                                189 /* CSn is READY */
190 #define IFC_RB_STAT_READY_CS0           0x8000    190 #define IFC_RB_STAT_READY_CS0           0x80000000
191 #define IFC_RB_STAT_READY_CS1           0x4000    191 #define IFC_RB_STAT_READY_CS1           0x40000000
192 #define IFC_RB_STAT_READY_CS2           0x2000    192 #define IFC_RB_STAT_READY_CS2           0x20000000
193 #define IFC_RB_STAT_READY_CS3           0x1000    193 #define IFC_RB_STAT_READY_CS3           0x10000000
194                                                   194 
195 /*                                                195 /*
196  * General Control Register (GCR)                 196  * General Control Register (GCR)
197  */                                               197  */
198 #define IFC_GCR_MASK                    0x8000    198 #define IFC_GCR_MASK                    0x8000F800
199 /* reset all IFC hardware */                      199 /* reset all IFC hardware */
200 #define IFC_GCR_SOFT_RST_ALL            0x8000    200 #define IFC_GCR_SOFT_RST_ALL            0x80000000
201 /* Turnaroud Time of external buffer */           201 /* Turnaroud Time of external buffer */
202 #define IFC_GCR_TBCTL_TRN_TIME          0x0000    202 #define IFC_GCR_TBCTL_TRN_TIME          0x0000F800
203 #define IFC_GCR_TBCTL_TRN_TIME_SHIFT    11        203 #define IFC_GCR_TBCTL_TRN_TIME_SHIFT    11
204                                                   204 
205 /*                                                205 /*
206  * Common Event and Error Status Register (CM_    206  * Common Event and Error Status Register (CM_EVTER_STAT)
207  */                                               207  */
208 /* Chip select error */                           208 /* Chip select error */
209 #define IFC_CM_EVTER_STAT_CSER          0x8000    209 #define IFC_CM_EVTER_STAT_CSER          0x80000000
210                                                   210 
211 /*                                                211 /*
212  * Common Event and Error Enable Register (CM_    212  * Common Event and Error Enable Register (CM_EVTER_EN)
213  */                                               213  */
214 /* Chip select error checking enable */           214 /* Chip select error checking enable */
215 #define IFC_CM_EVTER_EN_CSEREN          0x8000    215 #define IFC_CM_EVTER_EN_CSEREN          0x80000000
216                                                   216 
217 /*                                                217 /*
218  * Common Event and Error Interrupt Enable Reg    218  * Common Event and Error Interrupt Enable Register (CM_EVTER_INTR_EN)
219  */                                               219  */
220 /* Chip select error interrupt enable */          220 /* Chip select error interrupt enable */
221 #define IFC_CM_EVTER_INTR_EN_CSERIREN   0x8000    221 #define IFC_CM_EVTER_INTR_EN_CSERIREN   0x80000000
222                                                   222 
223 /*                                                223 /*
224  * Common Transfer Error Attribute Register-0     224  * Common Transfer Error Attribute Register-0 (CM_ERATTR0)
225  */                                               225  */
226 /* transaction type of error Read/Write */        226 /* transaction type of error Read/Write */
227 #define IFC_CM_ERATTR0_ERTYP_READ       0x8000    227 #define IFC_CM_ERATTR0_ERTYP_READ       0x80000000
228 #define IFC_CM_ERATTR0_ERAID            0x0FF0    228 #define IFC_CM_ERATTR0_ERAID            0x0FF00000
229 #define IFC_CM_ERATTR0_ERAID_SHIFT      20        229 #define IFC_CM_ERATTR0_ERAID_SHIFT      20
230 #define IFC_CM_ERATTR0_ESRCID           0x0000    230 #define IFC_CM_ERATTR0_ESRCID           0x0000FF00
231 #define IFC_CM_ERATTR0_ESRCID_SHIFT     8         231 #define IFC_CM_ERATTR0_ESRCID_SHIFT     8
232                                                   232 
233 /*                                                233 /*
234  * Clock Control Register (CCR)                   234  * Clock Control Register (CCR)
235  */                                               235  */
236 #define IFC_CCR_MASK                    0x0F0F    236 #define IFC_CCR_MASK                    0x0F0F8800
237 /* Clock division ratio */                        237 /* Clock division ratio */
238 #define IFC_CCR_CLK_DIV_MASK            0x0F00    238 #define IFC_CCR_CLK_DIV_MASK            0x0F000000
239 #define IFC_CCR_CLK_DIV_SHIFT           24        239 #define IFC_CCR_CLK_DIV_SHIFT           24
240 #define IFC_CCR_CLK_DIV(n)              ((n-1)    240 #define IFC_CCR_CLK_DIV(n)              ((n-1) << IFC_CCR_CLK_DIV_SHIFT)
241 /* IFC Clock Delay */                             241 /* IFC Clock Delay */
242 #define IFC_CCR_CLK_DLY_MASK            0x000F    242 #define IFC_CCR_CLK_DLY_MASK            0x000F0000
243 #define IFC_CCR_CLK_DLY_SHIFT           16        243 #define IFC_CCR_CLK_DLY_SHIFT           16
244 #define IFC_CCR_CLK_DLY(n)              ((n) <    244 #define IFC_CCR_CLK_DLY(n)              ((n) << IFC_CCR_CLK_DLY_SHIFT)
245 /* Invert IFC clock before sending out */         245 /* Invert IFC clock before sending out */
246 #define IFC_CCR_INV_CLK_EN              0x0000    246 #define IFC_CCR_INV_CLK_EN              0x00008000
247 /* Fedback IFC Clock */                           247 /* Fedback IFC Clock */
248 #define IFC_CCR_FB_IFC_CLK_SEL          0x0000    248 #define IFC_CCR_FB_IFC_CLK_SEL          0x00000800
249                                                   249 
250 /*                                                250 /*
251  * Clock Status Register (CSR)                    251  * Clock Status Register (CSR)
252  */                                               252  */
253 /* Clk is stable */                               253 /* Clk is stable */
254 #define IFC_CSR_CLK_STAT_STABLE         0x8000    254 #define IFC_CSR_CLK_STAT_STABLE         0x80000000
255                                                   255 
256 /*                                                256 /*
257  * IFC_NAND Machine Specific Registers            257  * IFC_NAND Machine Specific Registers
258  */                                               258  */
259 /*                                                259 /*
260  * NAND Configuration Register (NCFGR)            260  * NAND Configuration Register (NCFGR)
261  */                                               261  */
262 /* Auto Boot Mode */                              262 /* Auto Boot Mode */
263 #define IFC_NAND_NCFGR_BOOT             0x8000    263 #define IFC_NAND_NCFGR_BOOT             0x80000000
264 /* SRAM Initialization */                         264 /* SRAM Initialization */
265 #define IFC_NAND_NCFGR_SRAM_INIT_EN     0x2000    265 #define IFC_NAND_NCFGR_SRAM_INIT_EN     0x20000000
266 /* Addressing Mode-ROW0+n/COL0 */                 266 /* Addressing Mode-ROW0+n/COL0 */
267 #define IFC_NAND_NCFGR_ADDR_MODE_RC0    0x0000    267 #define IFC_NAND_NCFGR_ADDR_MODE_RC0    0x00000000
268 /* Addressing Mode-ROW0+n/COL0+n */               268 /* Addressing Mode-ROW0+n/COL0+n */
269 #define IFC_NAND_NCFGR_ADDR_MODE_RC1    0x0040    269 #define IFC_NAND_NCFGR_ADDR_MODE_RC1    0x00400000
270 /* Number of loop iterations of FIR sequences     270 /* Number of loop iterations of FIR sequences for multi page operations */
271 #define IFC_NAND_NCFGR_NUM_LOOP_MASK    0x0000    271 #define IFC_NAND_NCFGR_NUM_LOOP_MASK    0x0000F000
272 #define IFC_NAND_NCFGR_NUM_LOOP_SHIFT   12        272 #define IFC_NAND_NCFGR_NUM_LOOP_SHIFT   12
273 #define IFC_NAND_NCFGR_NUM_LOOP(n)      ((n) <    273 #define IFC_NAND_NCFGR_NUM_LOOP(n)      ((n) << IFC_NAND_NCFGR_NUM_LOOP_SHIFT)
274 /* Number of wait cycles */                       274 /* Number of wait cycles */
275 #define IFC_NAND_NCFGR_NUM_WAIT_MASK    0x0000    275 #define IFC_NAND_NCFGR_NUM_WAIT_MASK    0x000000FF
276 #define IFC_NAND_NCFGR_NUM_WAIT_SHIFT   0         276 #define IFC_NAND_NCFGR_NUM_WAIT_SHIFT   0
277                                                   277 
278 /*                                                278 /*
279  * NAND Flash Command Registers (NAND_FCR0/NAN    279  * NAND Flash Command Registers (NAND_FCR0/NAND_FCR1)
280  */                                               280  */
281 /* General purpose FCM flash command bytes CMD    281 /* General purpose FCM flash command bytes CMD0-CMD7 */
282 #define IFC_NAND_FCR0_CMD0              0xFF00    282 #define IFC_NAND_FCR0_CMD0              0xFF000000
283 #define IFC_NAND_FCR0_CMD0_SHIFT        24        283 #define IFC_NAND_FCR0_CMD0_SHIFT        24
284 #define IFC_NAND_FCR0_CMD1              0x00FF    284 #define IFC_NAND_FCR0_CMD1              0x00FF0000
285 #define IFC_NAND_FCR0_CMD1_SHIFT        16        285 #define IFC_NAND_FCR0_CMD1_SHIFT        16
286 #define IFC_NAND_FCR0_CMD2              0x0000    286 #define IFC_NAND_FCR0_CMD2              0x0000FF00
287 #define IFC_NAND_FCR0_CMD2_SHIFT        8         287 #define IFC_NAND_FCR0_CMD2_SHIFT        8
288 #define IFC_NAND_FCR0_CMD3              0x0000    288 #define IFC_NAND_FCR0_CMD3              0x000000FF
289 #define IFC_NAND_FCR0_CMD3_SHIFT        0         289 #define IFC_NAND_FCR0_CMD3_SHIFT        0
290 #define IFC_NAND_FCR1_CMD4              0xFF00    290 #define IFC_NAND_FCR1_CMD4              0xFF000000
291 #define IFC_NAND_FCR1_CMD4_SHIFT        24        291 #define IFC_NAND_FCR1_CMD4_SHIFT        24
292 #define IFC_NAND_FCR1_CMD5              0x00FF    292 #define IFC_NAND_FCR1_CMD5              0x00FF0000
293 #define IFC_NAND_FCR1_CMD5_SHIFT        16        293 #define IFC_NAND_FCR1_CMD5_SHIFT        16
294 #define IFC_NAND_FCR1_CMD6              0x0000    294 #define IFC_NAND_FCR1_CMD6              0x0000FF00
295 #define IFC_NAND_FCR1_CMD6_SHIFT        8         295 #define IFC_NAND_FCR1_CMD6_SHIFT        8
296 #define IFC_NAND_FCR1_CMD7              0x0000    296 #define IFC_NAND_FCR1_CMD7              0x000000FF
297 #define IFC_NAND_FCR1_CMD7_SHIFT        0         297 #define IFC_NAND_FCR1_CMD7_SHIFT        0
298                                                   298 
299 /*                                                299 /*
300  * Flash ROW and COL Address Register (ROWn, C    300  * Flash ROW and COL Address Register (ROWn, COLn)
301  */                                               301  */
302 /* Main/spare region locator */                   302 /* Main/spare region locator */
303 #define IFC_NAND_COL_MS                 0x8000    303 #define IFC_NAND_COL_MS                 0x80000000
304 /* Column Address */                              304 /* Column Address */
305 #define IFC_NAND_COL_CA_MASK            0x0000    305 #define IFC_NAND_COL_CA_MASK            0x00000FFF
306                                                   306 
307 /*                                                307 /*
308  * NAND Flash Byte Count Register (NAND_BC)       308  * NAND Flash Byte Count Register (NAND_BC)
309  */                                               309  */
310 /* Byte Count for read/Write */                   310 /* Byte Count for read/Write */
311 #define IFC_NAND_BC                     0x0000    311 #define IFC_NAND_BC                     0x000001FF
312                                                   312 
313 /*                                                313 /*
314  * NAND Flash Instruction Registers (NAND_FIR0    314  * NAND Flash Instruction Registers (NAND_FIR0/NAND_FIR1/NAND_FIR2)
315  */                                               315  */
316 /* NAND Machine specific opcodes OP0-OP14*/       316 /* NAND Machine specific opcodes OP0-OP14*/
317 #define IFC_NAND_FIR0_OP0               0xFC00    317 #define IFC_NAND_FIR0_OP0               0xFC000000
318 #define IFC_NAND_FIR0_OP0_SHIFT         26        318 #define IFC_NAND_FIR0_OP0_SHIFT         26
319 #define IFC_NAND_FIR0_OP1               0x03F0    319 #define IFC_NAND_FIR0_OP1               0x03F00000
320 #define IFC_NAND_FIR0_OP1_SHIFT         20        320 #define IFC_NAND_FIR0_OP1_SHIFT         20
321 #define IFC_NAND_FIR0_OP2               0x000F    321 #define IFC_NAND_FIR0_OP2               0x000FC000
322 #define IFC_NAND_FIR0_OP2_SHIFT         14        322 #define IFC_NAND_FIR0_OP2_SHIFT         14
323 #define IFC_NAND_FIR0_OP3               0x0000    323 #define IFC_NAND_FIR0_OP3               0x00003F00
324 #define IFC_NAND_FIR0_OP3_SHIFT         8         324 #define IFC_NAND_FIR0_OP3_SHIFT         8
325 #define IFC_NAND_FIR0_OP4               0x0000    325 #define IFC_NAND_FIR0_OP4               0x000000FC
326 #define IFC_NAND_FIR0_OP4_SHIFT         2         326 #define IFC_NAND_FIR0_OP4_SHIFT         2
327 #define IFC_NAND_FIR1_OP5               0xFC00    327 #define IFC_NAND_FIR1_OP5               0xFC000000
328 #define IFC_NAND_FIR1_OP5_SHIFT         26        328 #define IFC_NAND_FIR1_OP5_SHIFT         26
329 #define IFC_NAND_FIR1_OP6               0x03F0    329 #define IFC_NAND_FIR1_OP6               0x03F00000
330 #define IFC_NAND_FIR1_OP6_SHIFT         20        330 #define IFC_NAND_FIR1_OP6_SHIFT         20
331 #define IFC_NAND_FIR1_OP7               0x000F    331 #define IFC_NAND_FIR1_OP7               0x000FC000
332 #define IFC_NAND_FIR1_OP7_SHIFT         14        332 #define IFC_NAND_FIR1_OP7_SHIFT         14
333 #define IFC_NAND_FIR1_OP8               0x0000    333 #define IFC_NAND_FIR1_OP8               0x00003F00
334 #define IFC_NAND_FIR1_OP8_SHIFT         8         334 #define IFC_NAND_FIR1_OP8_SHIFT         8
335 #define IFC_NAND_FIR1_OP9               0x0000    335 #define IFC_NAND_FIR1_OP9               0x000000FC
336 #define IFC_NAND_FIR1_OP9_SHIFT         2         336 #define IFC_NAND_FIR1_OP9_SHIFT         2
337 #define IFC_NAND_FIR2_OP10              0xFC00    337 #define IFC_NAND_FIR2_OP10              0xFC000000
338 #define IFC_NAND_FIR2_OP10_SHIFT        26        338 #define IFC_NAND_FIR2_OP10_SHIFT        26
339 #define IFC_NAND_FIR2_OP11              0x03F0    339 #define IFC_NAND_FIR2_OP11              0x03F00000
340 #define IFC_NAND_FIR2_OP11_SHIFT        20        340 #define IFC_NAND_FIR2_OP11_SHIFT        20
341 #define IFC_NAND_FIR2_OP12              0x000F    341 #define IFC_NAND_FIR2_OP12              0x000FC000
342 #define IFC_NAND_FIR2_OP12_SHIFT        14        342 #define IFC_NAND_FIR2_OP12_SHIFT        14
343 #define IFC_NAND_FIR2_OP13              0x0000    343 #define IFC_NAND_FIR2_OP13              0x00003F00
344 #define IFC_NAND_FIR2_OP13_SHIFT        8         344 #define IFC_NAND_FIR2_OP13_SHIFT        8
345 #define IFC_NAND_FIR2_OP14              0x0000    345 #define IFC_NAND_FIR2_OP14              0x000000FC
346 #define IFC_NAND_FIR2_OP14_SHIFT        2         346 #define IFC_NAND_FIR2_OP14_SHIFT        2
347                                                   347 
348 /*                                                348 /*
349  * Instruction opcodes to be programmed           349  * Instruction opcodes to be programmed
350  * in FIR registers- 6bits                        350  * in FIR registers- 6bits
351  */                                               351  */
352 enum ifc_nand_fir_opcodes {                       352 enum ifc_nand_fir_opcodes {
353         IFC_FIR_OP_NOP,                           353         IFC_FIR_OP_NOP,
354         IFC_FIR_OP_CA0,                           354         IFC_FIR_OP_CA0,
355         IFC_FIR_OP_CA1,                           355         IFC_FIR_OP_CA1,
356         IFC_FIR_OP_CA2,                           356         IFC_FIR_OP_CA2,
357         IFC_FIR_OP_CA3,                           357         IFC_FIR_OP_CA3,
358         IFC_FIR_OP_RA0,                           358         IFC_FIR_OP_RA0,
359         IFC_FIR_OP_RA1,                           359         IFC_FIR_OP_RA1,
360         IFC_FIR_OP_RA2,                           360         IFC_FIR_OP_RA2,
361         IFC_FIR_OP_RA3,                           361         IFC_FIR_OP_RA3,
362         IFC_FIR_OP_CMD0,                          362         IFC_FIR_OP_CMD0,
363         IFC_FIR_OP_CMD1,                          363         IFC_FIR_OP_CMD1,
364         IFC_FIR_OP_CMD2,                          364         IFC_FIR_OP_CMD2,
365         IFC_FIR_OP_CMD3,                          365         IFC_FIR_OP_CMD3,
366         IFC_FIR_OP_CMD4,                          366         IFC_FIR_OP_CMD4,
367         IFC_FIR_OP_CMD5,                          367         IFC_FIR_OP_CMD5,
368         IFC_FIR_OP_CMD6,                          368         IFC_FIR_OP_CMD6,
369         IFC_FIR_OP_CMD7,                          369         IFC_FIR_OP_CMD7,
370         IFC_FIR_OP_CW0,                           370         IFC_FIR_OP_CW0,
371         IFC_FIR_OP_CW1,                           371         IFC_FIR_OP_CW1,
372         IFC_FIR_OP_CW2,                           372         IFC_FIR_OP_CW2,
373         IFC_FIR_OP_CW3,                           373         IFC_FIR_OP_CW3,
374         IFC_FIR_OP_CW4,                           374         IFC_FIR_OP_CW4,
375         IFC_FIR_OP_CW5,                           375         IFC_FIR_OP_CW5,
376         IFC_FIR_OP_CW6,                           376         IFC_FIR_OP_CW6,
377         IFC_FIR_OP_CW7,                           377         IFC_FIR_OP_CW7,
378         IFC_FIR_OP_WBCD,                          378         IFC_FIR_OP_WBCD,
379         IFC_FIR_OP_RBCD,                          379         IFC_FIR_OP_RBCD,
380         IFC_FIR_OP_BTRD,                          380         IFC_FIR_OP_BTRD,
381         IFC_FIR_OP_RDSTAT,                        381         IFC_FIR_OP_RDSTAT,
382         IFC_FIR_OP_NWAIT,                         382         IFC_FIR_OP_NWAIT,
383         IFC_FIR_OP_WFR,                           383         IFC_FIR_OP_WFR,
384         IFC_FIR_OP_SBRD,                          384         IFC_FIR_OP_SBRD,
385         IFC_FIR_OP_UA,                            385         IFC_FIR_OP_UA,
386         IFC_FIR_OP_RB,                            386         IFC_FIR_OP_RB,
387 };                                                387 };
388                                                   388 
389 /*                                                389 /*
390  * NAND Chip Select Register (NAND_CSEL)          390  * NAND Chip Select Register (NAND_CSEL)
391  */                                               391  */
392 #define IFC_NAND_CSEL                   0x0C00    392 #define IFC_NAND_CSEL                   0x0C000000
393 #define IFC_NAND_CSEL_SHIFT             26        393 #define IFC_NAND_CSEL_SHIFT             26
394 #define IFC_NAND_CSEL_CS0               0x0000    394 #define IFC_NAND_CSEL_CS0               0x00000000
395 #define IFC_NAND_CSEL_CS1               0x0400    395 #define IFC_NAND_CSEL_CS1               0x04000000
396 #define IFC_NAND_CSEL_CS2               0x0800    396 #define IFC_NAND_CSEL_CS2               0x08000000
397 #define IFC_NAND_CSEL_CS3               0x0C00    397 #define IFC_NAND_CSEL_CS3               0x0C000000
398                                                   398 
399 /*                                                399 /*
400  * NAND Operation Sequence Start (NANDSEQ_STRT    400  * NAND Operation Sequence Start (NANDSEQ_STRT)
401  */                                               401  */
402 /* NAND Flash Operation Start */                  402 /* NAND Flash Operation Start */
403 #define IFC_NAND_SEQ_STRT_FIR_STRT      0x8000    403 #define IFC_NAND_SEQ_STRT_FIR_STRT      0x80000000
404 /* Automatic Erase */                             404 /* Automatic Erase */
405 #define IFC_NAND_SEQ_STRT_AUTO_ERS      0x0080    405 #define IFC_NAND_SEQ_STRT_AUTO_ERS      0x00800000
406 /* Automatic Program */                           406 /* Automatic Program */
407 #define IFC_NAND_SEQ_STRT_AUTO_PGM      0x0010    407 #define IFC_NAND_SEQ_STRT_AUTO_PGM      0x00100000
408 /* Automatic Copyback */                          408 /* Automatic Copyback */
409 #define IFC_NAND_SEQ_STRT_AUTO_CPB      0x0002    409 #define IFC_NAND_SEQ_STRT_AUTO_CPB      0x00020000
410 /* Automatic Read Operation */                    410 /* Automatic Read Operation */
411 #define IFC_NAND_SEQ_STRT_AUTO_RD       0x0000    411 #define IFC_NAND_SEQ_STRT_AUTO_RD       0x00004000
412 /* Automatic Status Read */                       412 /* Automatic Status Read */
413 #define IFC_NAND_SEQ_STRT_AUTO_STAT_RD  0x0000    413 #define IFC_NAND_SEQ_STRT_AUTO_STAT_RD  0x00000800
414                                                   414 
415 /*                                                415 /*
416  * NAND Event and Error Status Register (NAND_    416  * NAND Event and Error Status Register (NAND_EVTER_STAT)
417  */                                               417  */
418 /* Operation Complete */                          418 /* Operation Complete */
419 #define IFC_NAND_EVTER_STAT_OPC         0x8000    419 #define IFC_NAND_EVTER_STAT_OPC         0x80000000
420 /* Flash Timeout Error */                         420 /* Flash Timeout Error */
421 #define IFC_NAND_EVTER_STAT_FTOER       0x0800    421 #define IFC_NAND_EVTER_STAT_FTOER       0x08000000
422 /* Write Protect Error */                         422 /* Write Protect Error */
423 #define IFC_NAND_EVTER_STAT_WPER        0x0400    423 #define IFC_NAND_EVTER_STAT_WPER        0x04000000
424 /* ECC Error */                                   424 /* ECC Error */
425 #define IFC_NAND_EVTER_STAT_ECCER       0x0200    425 #define IFC_NAND_EVTER_STAT_ECCER       0x02000000
426 /* RCW Load Done */                               426 /* RCW Load Done */
427 #define IFC_NAND_EVTER_STAT_RCW_DN      0x0000    427 #define IFC_NAND_EVTER_STAT_RCW_DN      0x00008000
428 /* Boot Loadr Done */                             428 /* Boot Loadr Done */
429 #define IFC_NAND_EVTER_STAT_BOOT_DN     0x0000    429 #define IFC_NAND_EVTER_STAT_BOOT_DN     0x00004000
430 /* Bad Block Indicator search select */           430 /* Bad Block Indicator search select */
431 #define IFC_NAND_EVTER_STAT_BBI_SRCH_SE 0x0000    431 #define IFC_NAND_EVTER_STAT_BBI_SRCH_SE 0x00000800
432                                                   432 
433 /*                                                433 /*
434  * NAND Flash Page Read Completion Event Statu    434  * NAND Flash Page Read Completion Event Status Register
435  * (PGRDCMPL_EVT_STAT)                            435  * (PGRDCMPL_EVT_STAT)
436  */                                               436  */
437 #define PGRDCMPL_EVT_STAT_MASK          0xFFFF    437 #define PGRDCMPL_EVT_STAT_MASK          0xFFFF0000
438 /* Small Page 0-15 Done */                        438 /* Small Page 0-15 Done */
439 #define PGRDCMPL_EVT_STAT_SECTION_SP(n) (1 <<     439 #define PGRDCMPL_EVT_STAT_SECTION_SP(n) (1 << (31 - (n)))
440 /* Large Page(2K) 0-3 Done */                     440 /* Large Page(2K) 0-3 Done */
441 #define PGRDCMPL_EVT_STAT_LP_2K(n)      (0xF <    441 #define PGRDCMPL_EVT_STAT_LP_2K(n)      (0xF << (28 - (n)*4))
442 /* Large Page(4K) 0-1 Done */                     442 /* Large Page(4K) 0-1 Done */
443 #define PGRDCMPL_EVT_STAT_LP_4K(n)      (0xFF     443 #define PGRDCMPL_EVT_STAT_LP_4K(n)      (0xFF << (24 - (n)*8))
444                                                   444 
445 /*                                                445 /*
446  * NAND Event and Error Enable Register (NAND_    446  * NAND Event and Error Enable Register (NAND_EVTER_EN)
447  */                                               447  */
448 /* Operation complete event enable */             448 /* Operation complete event enable */
449 #define IFC_NAND_EVTER_EN_OPC_EN        0x8000    449 #define IFC_NAND_EVTER_EN_OPC_EN        0x80000000
450 /* Page read complete event enable */             450 /* Page read complete event enable */
451 #define IFC_NAND_EVTER_EN_PGRDCMPL_EN   0x2000    451 #define IFC_NAND_EVTER_EN_PGRDCMPL_EN   0x20000000
452 /* Flash Timeout error enable */                  452 /* Flash Timeout error enable */
453 #define IFC_NAND_EVTER_EN_FTOER_EN      0x0800    453 #define IFC_NAND_EVTER_EN_FTOER_EN      0x08000000
454 /* Write Protect error enable */                  454 /* Write Protect error enable */
455 #define IFC_NAND_EVTER_EN_WPER_EN       0x0400    455 #define IFC_NAND_EVTER_EN_WPER_EN       0x04000000
456 /* ECC error logging enable */                    456 /* ECC error logging enable */
457 #define IFC_NAND_EVTER_EN_ECCER_EN      0x0200    457 #define IFC_NAND_EVTER_EN_ECCER_EN      0x02000000
458                                                   458 
459 /*                                                459 /*
460  * NAND Event and Error Interrupt Enable Regis    460  * NAND Event and Error Interrupt Enable Register (NAND_EVTER_INTR_EN)
461  */                                               461  */
462 /* Enable interrupt for operation complete */     462 /* Enable interrupt for operation complete */
463 #define IFC_NAND_EVTER_INTR_OPCIR_EN              463 #define IFC_NAND_EVTER_INTR_OPCIR_EN            0x80000000
464 /* Enable interrupt for Page read complete */     464 /* Enable interrupt for Page read complete */
465 #define IFC_NAND_EVTER_INTR_PGRDCMPLIR_EN         465 #define IFC_NAND_EVTER_INTR_PGRDCMPLIR_EN       0x20000000
466 /* Enable interrupt for Flash timeout error */    466 /* Enable interrupt for Flash timeout error */
467 #define IFC_NAND_EVTER_INTR_FTOERIR_EN            467 #define IFC_NAND_EVTER_INTR_FTOERIR_EN          0x08000000
468 /* Enable interrupt for Write protect error */    468 /* Enable interrupt for Write protect error */
469 #define IFC_NAND_EVTER_INTR_WPERIR_EN             469 #define IFC_NAND_EVTER_INTR_WPERIR_EN           0x04000000
470 /* Enable interrupt for ECC error*/               470 /* Enable interrupt for ECC error*/
471 #define IFC_NAND_EVTER_INTR_ECCERIR_EN            471 #define IFC_NAND_EVTER_INTR_ECCERIR_EN          0x02000000
472                                                   472 
473 /*                                                473 /*
474  * NAND Transfer Error Attribute Register-0 (N    474  * NAND Transfer Error Attribute Register-0 (NAND_ERATTR0)
475  */                                               475  */
476 #define IFC_NAND_ERATTR0_MASK           0x0C08    476 #define IFC_NAND_ERATTR0_MASK           0x0C080000
477 /* Error on CS0-3 for NAND */                     477 /* Error on CS0-3 for NAND */
478 #define IFC_NAND_ERATTR0_ERCS_CS0       0x0000    478 #define IFC_NAND_ERATTR0_ERCS_CS0       0x00000000
479 #define IFC_NAND_ERATTR0_ERCS_CS1       0x0400    479 #define IFC_NAND_ERATTR0_ERCS_CS1       0x04000000
480 #define IFC_NAND_ERATTR0_ERCS_CS2       0x0800    480 #define IFC_NAND_ERATTR0_ERCS_CS2       0x08000000
481 #define IFC_NAND_ERATTR0_ERCS_CS3       0x0C00    481 #define IFC_NAND_ERATTR0_ERCS_CS3       0x0C000000
482 /* Transaction type of error Read/Write */        482 /* Transaction type of error Read/Write */
483 #define IFC_NAND_ERATTR0_ERTTYPE_READ   0x0008    483 #define IFC_NAND_ERATTR0_ERTTYPE_READ   0x00080000
484                                                   484 
485 /*                                                485 /*
486  * NAND Flash Status Register (NAND_FSR)          486  * NAND Flash Status Register (NAND_FSR)
487  */                                               487  */
488 /* First byte of data read from read status op    488 /* First byte of data read from read status op */
489 #define IFC_NAND_NFSR_RS0               0xFF00    489 #define IFC_NAND_NFSR_RS0               0xFF000000
490 /* Second byte of data read from read status o    490 /* Second byte of data read from read status op */
491 #define IFC_NAND_NFSR_RS1               0x00FF    491 #define IFC_NAND_NFSR_RS1               0x00FF0000
492                                                   492 
493 /*                                                493 /*
494  * ECC Error Status Registers (ECCSTAT0-ECCSTA    494  * ECC Error Status Registers (ECCSTAT0-ECCSTAT3)
495  */                                               495  */
496 /* Number of ECC errors on sector n (n = 0-15)    496 /* Number of ECC errors on sector n (n = 0-15) */
497 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR0_MASK     497 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR0_MASK   0x0F000000
498 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR0_SHIFT    498 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR0_SHIFT  24
499 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR1_MASK     499 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR1_MASK   0x000F0000
500 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR1_SHIFT    500 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR1_SHIFT  16
501 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR2_MASK     501 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR2_MASK   0x00000F00
502 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR2_SHIFT    502 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR2_SHIFT  8
503 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR3_MASK     503 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR3_MASK   0x0000000F
504 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR3_SHIFT    504 #define IFC_NAND_ECCSTAT0_ERRCNT_SECTOR3_SHIFT  0
505 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR4_MASK     505 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR4_MASK   0x0F000000
506 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR4_SHIFT    506 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR4_SHIFT  24
507 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR5_MASK     507 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR5_MASK   0x000F0000
508 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR5_SHIFT    508 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR5_SHIFT  16
509 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR6_MASK     509 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR6_MASK   0x00000F00
510 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR6_SHIFT    510 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR6_SHIFT  8
511 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR7_MASK     511 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR7_MASK   0x0000000F
512 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR7_SHIFT    512 #define IFC_NAND_ECCSTAT1_ERRCNT_SECTOR7_SHIFT  0
513 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR8_MASK     513 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR8_MASK   0x0F000000
514 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR8_SHIFT    514 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR8_SHIFT  24
515 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR9_MASK     515 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR9_MASK   0x000F0000
516 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR9_SHIFT    516 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR9_SHIFT  16
517 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR10_MASK    517 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR10_MASK  0x00000F00
518 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR10_SHIF    518 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR10_SHIFT 8
519 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR11_MASK    519 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR11_MASK  0x0000000F
520 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR11_SHIF    520 #define IFC_NAND_ECCSTAT2_ERRCNT_SECTOR11_SHIFT 0
521 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR12_MASK    521 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR12_MASK  0x0F000000
522 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR12_SHIF    522 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR12_SHIFT 24
523 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR13_MASK    523 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR13_MASK  0x000F0000
524 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR13_SHIF    524 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR13_SHIFT 16
525 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR14_MASK    525 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR14_MASK  0x00000F00
526 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR14_SHIF    526 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR14_SHIFT 8
527 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR15_MASK    527 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR15_MASK  0x0000000F
528 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR15_SHIF    528 #define IFC_NAND_ECCSTAT3_ERRCNT_SECTOR15_SHIFT 0
529                                                   529 
530 /*                                                530 /*
531  * NAND Control Register (NANDCR)                 531  * NAND Control Register (NANDCR)
532  */                                               532  */
533 #define IFC_NAND_NCR_FTOCNT_MASK        0x1E00    533 #define IFC_NAND_NCR_FTOCNT_MASK        0x1E000000
534 #define IFC_NAND_NCR_FTOCNT_SHIFT       25        534 #define IFC_NAND_NCR_FTOCNT_SHIFT       25
535 #define IFC_NAND_NCR_FTOCNT(n)  ((_ilog2(n) -     535 #define IFC_NAND_NCR_FTOCNT(n)  ((_ilog2(n) - 8)  << IFC_NAND_NCR_FTOCNT_SHIFT)
536                                                   536 
537 /*                                                537 /*
538  * NAND_AUTOBOOT_TRGR                             538  * NAND_AUTOBOOT_TRGR
539  */                                               539  */
540 /* Trigger RCW load */                            540 /* Trigger RCW load */
541 #define IFC_NAND_AUTOBOOT_TRGR_RCW_LD   0x8000    541 #define IFC_NAND_AUTOBOOT_TRGR_RCW_LD   0x80000000
542 /* Trigget Auto Boot */                           542 /* Trigget Auto Boot */
543 #define IFC_NAND_AUTOBOOT_TRGR_BOOT_LD  0x2000    543 #define IFC_NAND_AUTOBOOT_TRGR_BOOT_LD  0x20000000
544                                                   544 
545 /*                                                545 /*
546  * NAND_MDR                                       546  * NAND_MDR
547  */                                               547  */
548 /* 1st read data byte when opcode SBRD */         548 /* 1st read data byte when opcode SBRD */
549 #define IFC_NAND_MDR_RDATA0             0xFF00    549 #define IFC_NAND_MDR_RDATA0             0xFF000000
550 /* 2nd read data byte when opcode SBRD */         550 /* 2nd read data byte when opcode SBRD */
551 #define IFC_NAND_MDR_RDATA1             0x00FF    551 #define IFC_NAND_MDR_RDATA1             0x00FF0000
552                                                   552 
553 /*                                                553 /*
554  * NOR Machine Specific Registers                 554  * NOR Machine Specific Registers
555  */                                               555  */
556 /*                                                556 /*
557  * NOR Event and Error Status Register (NOR_EV    557  * NOR Event and Error Status Register (NOR_EVTER_STAT)
558  */                                               558  */
559 /* NOR Command Sequence Operation Complete */     559 /* NOR Command Sequence Operation Complete */
560 #define IFC_NOR_EVTER_STAT_OPC_NOR      0x8000    560 #define IFC_NOR_EVTER_STAT_OPC_NOR      0x80000000
561 /* Write Protect Error */                         561 /* Write Protect Error */
562 #define IFC_NOR_EVTER_STAT_WPER         0x0400    562 #define IFC_NOR_EVTER_STAT_WPER         0x04000000
563 /* Command Sequence Timeout Error */              563 /* Command Sequence Timeout Error */
564 #define IFC_NOR_EVTER_STAT_STOER        0x0100    564 #define IFC_NOR_EVTER_STAT_STOER        0x01000000
565                                                   565 
566 /*                                                566 /*
567  * NOR Event and Error Enable Register (NOR_EV    567  * NOR Event and Error Enable Register (NOR_EVTER_EN)
568  */                                               568  */
569 /* NOR Command Seq complete event enable */       569 /* NOR Command Seq complete event enable */
570 #define IFC_NOR_EVTER_EN_OPCEN_NOR      0x8000    570 #define IFC_NOR_EVTER_EN_OPCEN_NOR      0x80000000
571 /* Write Protect Error Checking Enable */         571 /* Write Protect Error Checking Enable */
572 #define IFC_NOR_EVTER_EN_WPEREN         0x0400    572 #define IFC_NOR_EVTER_EN_WPEREN         0x04000000
573 /* Timeout Error Enable */                        573 /* Timeout Error Enable */
574 #define IFC_NOR_EVTER_EN_STOEREN        0x0100    574 #define IFC_NOR_EVTER_EN_STOEREN        0x01000000
575                                                   575 
576 /*                                                576 /*
577  * NOR Event and Error Interrupt Enable Regist    577  * NOR Event and Error Interrupt Enable Register (NOR_EVTER_INTR_EN)
578  */                                               578  */
579 /* Enable interrupt for OPC complete */           579 /* Enable interrupt for OPC complete */
580 #define IFC_NOR_EVTER_INTR_OPCEN_NOR    0x8000    580 #define IFC_NOR_EVTER_INTR_OPCEN_NOR    0x80000000
581 /* Enable interrupt for write protect error */    581 /* Enable interrupt for write protect error */
582 #define IFC_NOR_EVTER_INTR_WPEREN       0x0400    582 #define IFC_NOR_EVTER_INTR_WPEREN       0x04000000
583 /* Enable interrupt for timeout error */          583 /* Enable interrupt for timeout error */
584 #define IFC_NOR_EVTER_INTR_STOEREN      0x0100    584 #define IFC_NOR_EVTER_INTR_STOEREN      0x01000000
585                                                   585 
586 /*                                                586 /*
587  * NOR Transfer Error Attribute Register-0 (NO    587  * NOR Transfer Error Attribute Register-0 (NOR_ERATTR0)
588  */                                               588  */
589 /* Source ID for error transaction */             589 /* Source ID for error transaction */
590 #define IFC_NOR_ERATTR0_ERSRCID         0xFF00    590 #define IFC_NOR_ERATTR0_ERSRCID         0xFF000000
591 /* AXI ID for error transation */                 591 /* AXI ID for error transation */
592 #define IFC_NOR_ERATTR0_ERAID           0x000F    592 #define IFC_NOR_ERATTR0_ERAID           0x000FF000
593 /* Chip select corresponds to NOR error */        593 /* Chip select corresponds to NOR error */
594 #define IFC_NOR_ERATTR0_ERCS_CS0        0x0000    594 #define IFC_NOR_ERATTR0_ERCS_CS0        0x00000000
595 #define IFC_NOR_ERATTR0_ERCS_CS1        0x0000    595 #define IFC_NOR_ERATTR0_ERCS_CS1        0x00000010
596 #define IFC_NOR_ERATTR0_ERCS_CS2        0x0000    596 #define IFC_NOR_ERATTR0_ERCS_CS2        0x00000020
597 #define IFC_NOR_ERATTR0_ERCS_CS3        0x0000    597 #define IFC_NOR_ERATTR0_ERCS_CS3        0x00000030
598 /* Type of transaction read/write */              598 /* Type of transaction read/write */
599 #define IFC_NOR_ERATTR0_ERTYPE_READ     0x0000    599 #define IFC_NOR_ERATTR0_ERTYPE_READ     0x00000001
600                                                   600 
601 /*                                                601 /*
602  * NOR Transfer Error Attribute Register-2 (NO    602  * NOR Transfer Error Attribute Register-2 (NOR_ERATTR2)
603  */                                               603  */
604 #define IFC_NOR_ERATTR2_ER_NUM_PHASE_EXP          604 #define IFC_NOR_ERATTR2_ER_NUM_PHASE_EXP        0x000F0000
605 #define IFC_NOR_ERATTR2_ER_NUM_PHASE_PER          605 #define IFC_NOR_ERATTR2_ER_NUM_PHASE_PER        0x00000F00
606                                                   606 
607 /*                                                607 /*
608  * NOR Control Register (NORCR)                   608  * NOR Control Register (NORCR)
609  */                                               609  */
610 #define IFC_NORCR_MASK                  0x0F0F    610 #define IFC_NORCR_MASK                  0x0F0F0000
611 /* No. of Address/Data Phase */                   611 /* No. of Address/Data Phase */
612 #define IFC_NORCR_NUM_PHASE_MASK        0x0F00    612 #define IFC_NORCR_NUM_PHASE_MASK        0x0F000000
613 #define IFC_NORCR_NUM_PHASE_SHIFT       24        613 #define IFC_NORCR_NUM_PHASE_SHIFT       24
614 #define IFC_NORCR_NUM_PHASE(n)  ((n-1) << IFC_    614 #define IFC_NORCR_NUM_PHASE(n)  ((n-1) << IFC_NORCR_NUM_PHASE_SHIFT)
615 /* Sequence Timeout Count */                      615 /* Sequence Timeout Count */
616 #define IFC_NORCR_STOCNT_MASK           0x000F    616 #define IFC_NORCR_STOCNT_MASK           0x000F0000
617 #define IFC_NORCR_STOCNT_SHIFT          16        617 #define IFC_NORCR_STOCNT_SHIFT          16
618 #define IFC_NORCR_STOCNT(n)     ((__ilog2(n) -    618 #define IFC_NORCR_STOCNT(n)     ((__ilog2(n) - 8) << IFC_NORCR_STOCNT_SHIFT)
619                                                   619 
620 /*                                                620 /*
621  * GPCM Machine specific registers                621  * GPCM Machine specific registers
622  */                                               622  */
623 /*                                                623 /*
624  * GPCM Event and Error Status Register (GPCM_    624  * GPCM Event and Error Status Register (GPCM_EVTER_STAT)
625  */                                               625  */
626 /* Timeout error */                               626 /* Timeout error */
627 #define IFC_GPCM_EVTER_STAT_TOER        0x0400    627 #define IFC_GPCM_EVTER_STAT_TOER        0x04000000
628 /* Parity error */                                628 /* Parity error */
629 #define IFC_GPCM_EVTER_STAT_PER         0x0100    629 #define IFC_GPCM_EVTER_STAT_PER         0x01000000
630                                                   630 
631 /*                                                631 /*
632  * GPCM Event and Error Enable Register (GPCM_    632  * GPCM Event and Error Enable Register (GPCM_EVTER_EN)
633  */                                               633  */
634 /* Timeout error enable */                        634 /* Timeout error enable */
635 #define IFC_GPCM_EVTER_EN_TOER_EN       0x0400    635 #define IFC_GPCM_EVTER_EN_TOER_EN       0x04000000
636 /* Parity error enable */                         636 /* Parity error enable */
637 #define IFC_GPCM_EVTER_EN_PER_EN        0x0100    637 #define IFC_GPCM_EVTER_EN_PER_EN        0x01000000
638                                                   638 
639 /*                                                639 /*
640  * GPCM Event and Error Interrupt Enable Regis    640  * GPCM Event and Error Interrupt Enable Register (GPCM_EVTER_INTR_EN)
641  */                                               641  */
642 /* Enable Interrupt for timeout error */          642 /* Enable Interrupt for timeout error */
643 #define IFC_GPCM_EEIER_TOERIR_EN        0x0400    643 #define IFC_GPCM_EEIER_TOERIR_EN        0x04000000
644 /* Enable Interrupt for Parity error */           644 /* Enable Interrupt for Parity error */
645 #define IFC_GPCM_EEIER_PERIR_EN         0x0100    645 #define IFC_GPCM_EEIER_PERIR_EN         0x01000000
646                                                   646 
647 /*                                                647 /*
648  * GPCM Transfer Error Attribute Register-0 (G    648  * GPCM Transfer Error Attribute Register-0 (GPCM_ERATTR0)
649  */                                               649  */
650 /* Source ID for error transaction */             650 /* Source ID for error transaction */
651 #define IFC_GPCM_ERATTR0_ERSRCID        0xFF00    651 #define IFC_GPCM_ERATTR0_ERSRCID        0xFF000000
652 /* AXI ID for error transaction */                652 /* AXI ID for error transaction */
653 #define IFC_GPCM_ERATTR0_ERAID          0x000F    653 #define IFC_GPCM_ERATTR0_ERAID          0x000FF000
654 /* Chip select corresponds to GPCM error */       654 /* Chip select corresponds to GPCM error */
655 #define IFC_GPCM_ERATTR0_ERCS_CS0       0x0000    655 #define IFC_GPCM_ERATTR0_ERCS_CS0       0x00000000
656 #define IFC_GPCM_ERATTR0_ERCS_CS1       0x0000    656 #define IFC_GPCM_ERATTR0_ERCS_CS1       0x00000040
657 #define IFC_GPCM_ERATTR0_ERCS_CS2       0x0000    657 #define IFC_GPCM_ERATTR0_ERCS_CS2       0x00000080
658 #define IFC_GPCM_ERATTR0_ERCS_CS3       0x0000    658 #define IFC_GPCM_ERATTR0_ERCS_CS3       0x000000C0
659 /* Type of transaction read/Write */              659 /* Type of transaction read/Write */
660 #define IFC_GPCM_ERATTR0_ERTYPE_READ    0x0000    660 #define IFC_GPCM_ERATTR0_ERTYPE_READ    0x00000001
661                                                   661 
662 /*                                                662 /*
663  * GPCM Transfer Error Attribute Register-2 (G    663  * GPCM Transfer Error Attribute Register-2 (GPCM_ERATTR2)
664  */                                               664  */
665 /* On which beat of address/data parity error     665 /* On which beat of address/data parity error is observed */
666 #define IFC_GPCM_ERATTR2_PERR_BEAT                666 #define IFC_GPCM_ERATTR2_PERR_BEAT              0x00000C00
667 /* Parity Error on byte */                        667 /* Parity Error on byte */
668 #define IFC_GPCM_ERATTR2_PERR_BYTE                668 #define IFC_GPCM_ERATTR2_PERR_BYTE              0x000000F0
669 /* Parity Error reported in addr or data phase    669 /* Parity Error reported in addr or data phase */
670 #define IFC_GPCM_ERATTR2_PERR_DATA_PHASE          670 #define IFC_GPCM_ERATTR2_PERR_DATA_PHASE        0x00000001
671                                                   671 
672 /*                                                672 /*
673  * GPCM Status Register (GPCM_STAT)               673  * GPCM Status Register (GPCM_STAT)
674  */                                               674  */
675 #define IFC_GPCM_STAT_BSY               0x8000    675 #define IFC_GPCM_STAT_BSY               0x80000000  /* GPCM is busy */
676                                                   676 
677 /*                                                677 /*
678  * IFC Controller NAND Machine registers          678  * IFC Controller NAND Machine registers
679  */                                               679  */
680 struct fsl_ifc_nand {                             680 struct fsl_ifc_nand {
681         __be32 ncfgr;                             681         __be32 ncfgr;
682         u32 res1[0x4];                            682         u32 res1[0x4];
683         __be32 nand_fcr0;                         683         __be32 nand_fcr0;
684         __be32 nand_fcr1;                         684         __be32 nand_fcr1;
685         u32 res2[0x8];                            685         u32 res2[0x8];
686         __be32 row0;                              686         __be32 row0;
687         u32 res3;                                 687         u32 res3;
688         __be32 col0;                              688         __be32 col0;
689         u32 res4;                                 689         u32 res4;
690         __be32 row1;                              690         __be32 row1;
691         u32 res5;                                 691         u32 res5;
692         __be32 col1;                              692         __be32 col1;
693         u32 res6;                                 693         u32 res6;
694         __be32 row2;                              694         __be32 row2;
695         u32 res7;                                 695         u32 res7;
696         __be32 col2;                              696         __be32 col2;
697         u32 res8;                                 697         u32 res8;
698         __be32 row3;                              698         __be32 row3;
699         u32 res9;                                 699         u32 res9;
700         __be32 col3;                              700         __be32 col3;
701         u32 res10[0x24];                          701         u32 res10[0x24];
702         __be32 nand_fbcr;                         702         __be32 nand_fbcr;
703         u32 res11;                                703         u32 res11;
704         __be32 nand_fir0;                         704         __be32 nand_fir0;
705         __be32 nand_fir1;                         705         __be32 nand_fir1;
706         __be32 nand_fir2;                         706         __be32 nand_fir2;
707         u32 res12[0x10];                          707         u32 res12[0x10];
708         __be32 nand_csel;                         708         __be32 nand_csel;
709         u32 res13;                                709         u32 res13;
710         __be32 nandseq_strt;                      710         __be32 nandseq_strt;
711         u32 res14;                                711         u32 res14;
712         __be32 nand_evter_stat;                   712         __be32 nand_evter_stat;
713         u32 res15;                                713         u32 res15;
714         __be32 pgrdcmpl_evt_stat;                 714         __be32 pgrdcmpl_evt_stat;
715         u32 res16[0x2];                           715         u32 res16[0x2];
716         __be32 nand_evter_en;                     716         __be32 nand_evter_en;
717         u32 res17[0x2];                           717         u32 res17[0x2];
718         __be32 nand_evter_intr_en;                718         __be32 nand_evter_intr_en;
719         __be32 nand_vol_addr_stat;                719         __be32 nand_vol_addr_stat;
720         u32 res18;                                720         u32 res18;
721         __be32 nand_erattr0;                      721         __be32 nand_erattr0;
722         __be32 nand_erattr1;                      722         __be32 nand_erattr1;
723         u32 res19[0x10];                          723         u32 res19[0x10];
724         __be32 nand_fsr;                          724         __be32 nand_fsr;
725         u32 res20;                                725         u32 res20;
726         __be32 nand_eccstat[8];                   726         __be32 nand_eccstat[8];
727         u32 res21[0x1c];                          727         u32 res21[0x1c];
728         __be32 nanndcr;                           728         __be32 nanndcr;
729         u32 res22[0x2];                           729         u32 res22[0x2];
730         __be32 nand_autoboot_trgr;                730         __be32 nand_autoboot_trgr;
731         u32 res23;                                731         u32 res23;
732         __be32 nand_mdr;                          732         __be32 nand_mdr;
733         u32 res24[0x1C];                          733         u32 res24[0x1C];
734         __be32 nand_dll_lowcfg0;                  734         __be32 nand_dll_lowcfg0;
735         __be32 nand_dll_lowcfg1;                  735         __be32 nand_dll_lowcfg1;
736         u32 res25;                                736         u32 res25;
737         __be32 nand_dll_lowstat;                  737         __be32 nand_dll_lowstat;
738         u32 res26[0x3c];                          738         u32 res26[0x3c];
739 };                                                739 };
740                                                   740 
741 /*                                                741 /*
742  * IFC controller NOR Machine registers           742  * IFC controller NOR Machine registers
743  */                                               743  */
744 struct fsl_ifc_nor {                              744 struct fsl_ifc_nor {
745         __be32 nor_evter_stat;                    745         __be32 nor_evter_stat;
746         u32 res1[0x2];                            746         u32 res1[0x2];
747         __be32 nor_evter_en;                      747         __be32 nor_evter_en;
748         u32 res2[0x2];                            748         u32 res2[0x2];
749         __be32 nor_evter_intr_en;                 749         __be32 nor_evter_intr_en;
750         u32 res3[0x2];                            750         u32 res3[0x2];
751         __be32 nor_erattr0;                       751         __be32 nor_erattr0;
752         __be32 nor_erattr1;                       752         __be32 nor_erattr1;
753         __be32 nor_erattr2;                       753         __be32 nor_erattr2;
754         u32 res4[0x4];                            754         u32 res4[0x4];
755         __be32 norcr;                             755         __be32 norcr;
756         u32 res5[0xEF];                           756         u32 res5[0xEF];
757 };                                                757 };
758                                                   758 
759 /*                                                759 /*
760  * IFC controller GPCM Machine registers          760  * IFC controller GPCM Machine registers
761  */                                               761  */
762 struct fsl_ifc_gpcm {                             762 struct fsl_ifc_gpcm {
763         __be32 gpcm_evter_stat;                   763         __be32 gpcm_evter_stat;
764         u32 res1[0x2];                            764         u32 res1[0x2];
765         __be32 gpcm_evter_en;                     765         __be32 gpcm_evter_en;
766         u32 res2[0x2];                            766         u32 res2[0x2];
767         __be32 gpcm_evter_intr_en;                767         __be32 gpcm_evter_intr_en;
768         u32 res3[0x2];                            768         u32 res3[0x2];
769         __be32 gpcm_erattr0;                      769         __be32 gpcm_erattr0;
770         __be32 gpcm_erattr1;                      770         __be32 gpcm_erattr1;
771         __be32 gpcm_erattr2;                      771         __be32 gpcm_erattr2;
772         __be32 gpcm_stat;                         772         __be32 gpcm_stat;
773 };                                                773 };
774                                                   774 
775 /*                                                775 /*
776  * IFC Controller Registers                       776  * IFC Controller Registers
777  */                                               777  */
778 struct fsl_ifc_global {                           778 struct fsl_ifc_global {
779         __be32 ifc_rev;                           779         __be32 ifc_rev;
780         u32 res1[0x2];                            780         u32 res1[0x2];
781         struct {                                  781         struct {
782                 __be32 cspr_ext;                  782                 __be32 cspr_ext;
783                 __be32 cspr;                      783                 __be32 cspr;
784                 u32 res2;                         784                 u32 res2;
785         } cspr_cs[FSL_IFC_BANK_COUNT];            785         } cspr_cs[FSL_IFC_BANK_COUNT];
786         u32 res3[0xd];                            786         u32 res3[0xd];
787         struct {                                  787         struct {
788                 __be32 amask;                     788                 __be32 amask;
789                 u32 res4[0x2];                    789                 u32 res4[0x2];
790         } amask_cs[FSL_IFC_BANK_COUNT];           790         } amask_cs[FSL_IFC_BANK_COUNT];
791         u32 res5[0xc];                            791         u32 res5[0xc];
792         struct {                                  792         struct {
793                 __be32 csor;                      793                 __be32 csor;
794                 __be32 csor_ext;                  794                 __be32 csor_ext;
795                 u32 res6;                         795                 u32 res6;
796         } csor_cs[FSL_IFC_BANK_COUNT];            796         } csor_cs[FSL_IFC_BANK_COUNT];
797         u32 res7[0xc];                            797         u32 res7[0xc];
798         struct {                                  798         struct {
799                 __be32 ftim[4];                   799                 __be32 ftim[4];
800                 u32 res8[0x8];                    800                 u32 res8[0x8];
801         } ftim_cs[FSL_IFC_BANK_COUNT];            801         } ftim_cs[FSL_IFC_BANK_COUNT];
802         u32 res9[0x30];                           802         u32 res9[0x30];
803         __be32 rb_stat;                           803         __be32 rb_stat;
804         __be32 rb_map;                            804         __be32 rb_map;
805         __be32 wb_map;                            805         __be32 wb_map;
806         __be32 ifc_gcr;                           806         __be32 ifc_gcr;
807         u32 res10[0x2];                           807         u32 res10[0x2];
808         __be32 cm_evter_stat;                     808         __be32 cm_evter_stat;
809         u32 res11[0x2];                           809         u32 res11[0x2];
810         __be32 cm_evter_en;                       810         __be32 cm_evter_en;
811         u32 res12[0x2];                           811         u32 res12[0x2];
812         __be32 cm_evter_intr_en;                  812         __be32 cm_evter_intr_en;
813         u32 res13[0x2];                           813         u32 res13[0x2];
814         __be32 cm_erattr0;                        814         __be32 cm_erattr0;
815         __be32 cm_erattr1;                        815         __be32 cm_erattr1;
816         u32 res14[0x2];                           816         u32 res14[0x2];
817         __be32 ifc_ccr;                           817         __be32 ifc_ccr;
818         __be32 ifc_csr;                           818         __be32 ifc_csr;
819         __be32 ddr_ccr_low;                       819         __be32 ddr_ccr_low;
820 };                                                820 };
821                                                   821 
822                                                   822 
823 struct fsl_ifc_runtime {                          823 struct fsl_ifc_runtime {
824         struct fsl_ifc_nand ifc_nand;             824         struct fsl_ifc_nand ifc_nand;
825         struct fsl_ifc_nor ifc_nor;               825         struct fsl_ifc_nor ifc_nor;
826         struct fsl_ifc_gpcm ifc_gpcm;             826         struct fsl_ifc_gpcm ifc_gpcm;
827 };                                                827 };
828                                                   828 
829 extern unsigned int convert_ifc_address(phys_a    829 extern unsigned int convert_ifc_address(phys_addr_t addr_base);
830 extern int fsl_ifc_find(phys_addr_t addr_base)    830 extern int fsl_ifc_find(phys_addr_t addr_base);
831                                                   831 
832 /* overview of the fsl ifc controller */          832 /* overview of the fsl ifc controller */
833                                                   833 
834 struct fsl_ifc_ctrl {                             834 struct fsl_ifc_ctrl {
835         /* device info */                         835         /* device info */
836         struct device                   *dev;     836         struct device                   *dev;
837         struct fsl_ifc_global __iomem   *gregs    837         struct fsl_ifc_global __iomem   *gregs;
838         struct fsl_ifc_runtime __iomem  *rregs    838         struct fsl_ifc_runtime __iomem  *rregs;
839         int                             irq;      839         int                             irq;
840         int                             nand_i    840         int                             nand_irq;
841         spinlock_t                      lock;     841         spinlock_t                      lock;
842         void                            *nand;    842         void                            *nand;
843         int                             versio    843         int                             version;
844         int                             banks;    844         int                             banks;
845                                                   845 
846         u32 nand_stat;                            846         u32 nand_stat;
847         wait_queue_head_t nand_wait;              847         wait_queue_head_t nand_wait;
848         bool little_endian;                       848         bool little_endian;
849 };                                                849 };
850                                                   850 
851 extern struct fsl_ifc_ctrl *fsl_ifc_ctrl_dev;     851 extern struct fsl_ifc_ctrl *fsl_ifc_ctrl_dev;
852                                                   852 
853 static inline u32 ifc_in32(void __iomem *addr)    853 static inline u32 ifc_in32(void __iomem *addr)
854 {                                                 854 {
855         u32 val;                                  855         u32 val;
856                                                   856 
857         if (fsl_ifc_ctrl_dev->little_endian)      857         if (fsl_ifc_ctrl_dev->little_endian)
858                 val = ioread32(addr);             858                 val = ioread32(addr);
859         else                                      859         else
860                 val = ioread32be(addr);           860                 val = ioread32be(addr);
861                                                   861 
862         return val;                               862         return val;
863 }                                                 863 }
864                                                   864 
865 static inline u16 ifc_in16(void __iomem *addr)    865 static inline u16 ifc_in16(void __iomem *addr)
866 {                                                 866 {
867         u16 val;                                  867         u16 val;
868                                                   868 
869         if (fsl_ifc_ctrl_dev->little_endian)      869         if (fsl_ifc_ctrl_dev->little_endian)
870                 val = ioread16(addr);             870                 val = ioread16(addr);
871         else                                      871         else
872                 val = ioread16be(addr);           872                 val = ioread16be(addr);
873                                                   873 
874         return val;                               874         return val;
875 }                                                 875 }
876                                                   876 
877 static inline u8 ifc_in8(void __iomem *addr)      877 static inline u8 ifc_in8(void __iomem *addr)
878 {                                                 878 {
879         return ioread8(addr);                     879         return ioread8(addr);
880 }                                                 880 }
881                                                   881 
882 static inline void ifc_out32(u32 val, void __i    882 static inline void ifc_out32(u32 val, void __iomem *addr)
883 {                                                 883 {
884         if (fsl_ifc_ctrl_dev->little_endian)      884         if (fsl_ifc_ctrl_dev->little_endian)
885                 iowrite32(val, addr);             885                 iowrite32(val, addr);
886         else                                      886         else
887                 iowrite32be(val, addr);           887                 iowrite32be(val, addr);
888 }                                                 888 }
889                                                   889 
890 static inline void ifc_out16(u16 val, void __i    890 static inline void ifc_out16(u16 val, void __iomem *addr)
891 {                                                 891 {
892         if (fsl_ifc_ctrl_dev->little_endian)      892         if (fsl_ifc_ctrl_dev->little_endian)
893                 iowrite16(val, addr);             893                 iowrite16(val, addr);
894         else                                      894         else
895                 iowrite16be(val, addr);           895                 iowrite16be(val, addr);
896 }                                                 896 }
897                                                   897 
898 static inline void ifc_out8(u8 val, void __iom    898 static inline void ifc_out8(u8 val, void __iomem *addr)
899 {                                                 899 {
900         iowrite8(val, addr);                      900         iowrite8(val, addr);
901 }                                                 901 }
902                                                   902 
903 #endif /* __ASM_FSL_IFC_H */                      903 #endif /* __ASM_FSL_IFC_H */
904                                                   904 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php