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

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

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ 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.5) and /include/linux/fsl_ifc.h (Version linux-2.6.0)


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