xref: /arm-trusted-firmware/drivers/nxp/ifc/nand/ifc.h (revision 91f16700b400a8c0651d24a598fc48ee2997a0d7)
1*91f16700Schasinglulu /*
2*91f16700Schasinglulu  * Copyright 2022 NXP
3*91f16700Schasinglulu  *
4*91f16700Schasinglulu  * SPDX-License-Identifier: BSD-3-Clause
5*91f16700Schasinglulu  */
6*91f16700Schasinglulu 
7*91f16700Schasinglulu #ifndef IFC_H
8*91f16700Schasinglulu #define IFC_H
9*91f16700Schasinglulu 
10*91f16700Schasinglulu #include <endian.h>
11*91f16700Schasinglulu 
12*91f16700Schasinglulu #include <mmio.h>
13*91f16700Schasinglulu 
14*91f16700Schasinglulu #define NXP_IFC_RUN_TIME_ADDR	U(0x1000)
15*91f16700Schasinglulu 
16*91f16700Schasinglulu /* CPSR - Chip Select Property Register Offset */
17*91f16700Schasinglulu #define EXT_CSPR(n)		(U(0x000C) + (n * 0xC))
18*91f16700Schasinglulu #define CSPR(n)			(U(0x0010) + (n * 0xC))
19*91f16700Schasinglulu #define CSOR(n)			(U(0x0130) + (n * 0xC))
20*91f16700Schasinglulu #define EXT_CSOR(n)		(U(0x0134) + (n * 0xC))
21*91f16700Schasinglulu #define IFC_AMASK_CS0		U(0x00A0)
22*91f16700Schasinglulu 
23*91f16700Schasinglulu /* NAND specific Registers Offset */
24*91f16700Schasinglulu #define NCFGR			(NXP_IFC_RUN_TIME_ADDR + U(0x0000))
25*91f16700Schasinglulu #define NAND_FCR0		(NXP_IFC_RUN_TIME_ADDR + U(0x0014))
26*91f16700Schasinglulu 
27*91f16700Schasinglulu #define ROW0			(NXP_IFC_RUN_TIME_ADDR + U(0x003C))
28*91f16700Schasinglulu #define ROW1			(NXP_IFC_RUN_TIME_ADDR + U(0x004C))
29*91f16700Schasinglulu #define COL0			(NXP_IFC_RUN_TIME_ADDR + U(0x0044))
30*91f16700Schasinglulu #define COL1			(NXP_IFC_RUN_TIME_ADDR + U(0x0054))
31*91f16700Schasinglulu 
32*91f16700Schasinglulu #define NAND_BC			(NXP_IFC_RUN_TIME_ADDR + U(0x0108))
33*91f16700Schasinglulu #define NAND_FIR0		(NXP_IFC_RUN_TIME_ADDR + U(0x0110))
34*91f16700Schasinglulu #define NAND_FIR1		(NXP_IFC_RUN_TIME_ADDR + U(0x0114))
35*91f16700Schasinglulu #define NAND_FIR2		(NXP_IFC_RUN_TIME_ADDR + U(0x0118))
36*91f16700Schasinglulu #define NAND_CSEL		(NXP_IFC_RUN_TIME_ADDR + U(0x015C))
37*91f16700Schasinglulu #define NANDSEQ_STRT		(NXP_IFC_RUN_TIME_ADDR + U(0x0164))
38*91f16700Schasinglulu #define NAND_EVTER_STAT		(NXP_IFC_RUN_TIME_ADDR + U(0x016C))
39*91f16700Schasinglulu #define NAND_AUTOBOOT_TRGR	(NXP_IFC_RUN_TIME_ADDR + U(0x0284))
40*91f16700Schasinglulu 
41*91f16700Schasinglulu /* Size of SRAM Buffer */
42*91f16700Schasinglulu #define CSPR_PS			U(0x00000180)
43*91f16700Schasinglulu #define CSPR_PS_SHIFT		7
44*91f16700Schasinglulu #define CSPR_PS_8		0x1 // Port Size 8 bit
45*91f16700Schasinglulu #define CSPR_PS_16		0x2 // Port Size 16 bit
46*91f16700Schasinglulu #define CSPR_PS_32		0x3 // Port Size 32 bit
47*91f16700Schasinglulu 
48*91f16700Schasinglulu /* Chip Select Option Register NAND Machine */
49*91f16700Schasinglulu #define CSOR_NAND_PGS		U(0x00380000)
50*91f16700Schasinglulu #define CSOR_NAND_PGS_SHIFT	19
51*91f16700Schasinglulu #define CSOR_NAND_PGS_512	U(0x00000000)
52*91f16700Schasinglulu #define CSOR_NAND_PGS_2K	U(0x00080000)
53*91f16700Schasinglulu #define CSOR_NAND_PGS_4K	U(0x00100000)
54*91f16700Schasinglulu #define CSOR_NAND_PGS_8K	U(0x00180000)
55*91f16700Schasinglulu #define CSOR_NAND_PGS_16K	U(0x00200000)
56*91f16700Schasinglulu 
57*91f16700Schasinglulu 
58*91f16700Schasinglulu #define CSOR_NAND_PB			U(0x00000700)
59*91f16700Schasinglulu #define CSOR_NAND_PB_32			U(0x00000000)
60*91f16700Schasinglulu #define CSOR_NAND_PB_64			U(0x00000100)
61*91f16700Schasinglulu #define CSOR_NAND_PB_128		U(0x00000200)
62*91f16700Schasinglulu #define CSOR_NAND_PB_256		U(0x00000300)
63*91f16700Schasinglulu #define CSOR_NAND_PB_512		U(0x00000400)
64*91f16700Schasinglulu #define CSOR_NAND_PB_1024		U(0x00000500)
65*91f16700Schasinglulu #define CSOR_NAND_PB_2048		U(0x00000600)
66*91f16700Schasinglulu #define CSOR_NAND_PPB_32		32
67*91f16700Schasinglulu #define CSOR_NAND_PPB_64		64
68*91f16700Schasinglulu #define CSOR_NAND_PPB_128		128
69*91f16700Schasinglulu #define CSOR_NAND_PPB_256		256
70*91f16700Schasinglulu #define CSOR_NAND_PPB_512		512
71*91f16700Schasinglulu #define CSOR_NAND_PPB_1024		1024
72*91f16700Schasinglulu #define CSOR_NAND_PPB_2048		2048
73*91f16700Schasinglulu 
74*91f16700Schasinglulu /* NAND Chip select register */
75*91f16700Schasinglulu #define NAND_CSEL_SHIFT			26
76*91f16700Schasinglulu #define NAND_COL_MS_SHIFT		31
77*91f16700Schasinglulu 
78*91f16700Schasinglulu /* FCR - Flash Command Register */
79*91f16700Schasinglulu #define FCR_CMD0			U(0xFF000000)
80*91f16700Schasinglulu #define FCR_CMD0_SHIFT			24
81*91f16700Schasinglulu #define FCR_CMD1			U(0x00FF0000)
82*91f16700Schasinglulu #define FCR_CMD1_SHIFT			16
83*91f16700Schasinglulu #define FCR_CMD2			U(0x0000FF00)
84*91f16700Schasinglulu #define FCR_CMD2_SHIFT			8
85*91f16700Schasinglulu #define FCR_CMD3			U(0x000000FF)
86*91f16700Schasinglulu #define FCR_CMD3_SHIFT			0
87*91f16700Schasinglulu 
88*91f16700Schasinglulu /* FIR - Flash Instruction Register Opcode */
89*91f16700Schasinglulu #define FIR_OP0				U(0xFC000000)
90*91f16700Schasinglulu #define FIR_OP0_SHIFT			26
91*91f16700Schasinglulu #define FIR_OP1				U(0x03F00000)
92*91f16700Schasinglulu #define FIR_OP1_SHIFT			20
93*91f16700Schasinglulu #define FIR_OP2				U(0x000FC000)
94*91f16700Schasinglulu #define FIR_OP2_SHIFT			14
95*91f16700Schasinglulu #define FIR_OP3				U(0x00003F00)
96*91f16700Schasinglulu #define FIR_OP3_SHIFT			8
97*91f16700Schasinglulu #define FIR_OP4				U(0x000000FC)
98*91f16700Schasinglulu #define FIR_OP4_SHIFT			2
99*91f16700Schasinglulu #define FIR_OP5				U(0xFC000000)
100*91f16700Schasinglulu #define FIR_OP5_SHIFT			26
101*91f16700Schasinglulu #define FIR_OP6				U(0x03F00000)
102*91f16700Schasinglulu #define FIR_OP6_SHIFT			20
103*91f16700Schasinglulu 
104*91f16700Schasinglulu /* Instruction Opcode - 6 bits */
105*91f16700Schasinglulu #define FIR_OP_NOP			0x00
106*91f16700Schasinglulu #define FIR_OP_CA0			0x01 /* Issue current column address */
107*91f16700Schasinglulu #define FIR_OP_CA1			0x02 /* Issue current column address */
108*91f16700Schasinglulu #define FIR_OP_RA0			0x05 /* Issue current column address */
109*91f16700Schasinglulu #define FIR_OP_RA1			0x06 /* Issue current column address */
110*91f16700Schasinglulu #define FIR_OP_CMD0			0x09 /* Issue command from FCR[CMD0] */
111*91f16700Schasinglulu #define FIR_OP_CMD1			0x0a /* Issue command from FCR[CMD1] */
112*91f16700Schasinglulu #define FIR_OP_CMD2			0x0b /* Issue command from FCR[CMD2] */
113*91f16700Schasinglulu #define FIR_OP_CMD3			0x0c /* Issue command from FCR[CMD3] */
114*91f16700Schasinglulu #define FIR_OP_CW0			0x11 /* Wait then issue FCR[CMD0] */
115*91f16700Schasinglulu #define FIR_OP_CW1			0x12 /* Wait then issue FCR[CMD1] */
116*91f16700Schasinglulu #define FIR_OP_CW2			0x13 /* Wait then issue FCR[CMD1] */
117*91f16700Schasinglulu #define FIR_OP_CW3			0x14 /* Wait then issue FCR[CMD1] */
118*91f16700Schasinglulu #define FIR_OP_WBCD			0x19 /* Wait then read FBCR bytes */
119*91f16700Schasinglulu #define FIR_OP_RBCD			0x1a /* Wait then read 1 or 2 bytes */
120*91f16700Schasinglulu #define FIR_OP_BTRD			0x1b /* Wait then read 1 or 2 bytes */
121*91f16700Schasinglulu #define FIR_OP_RDSTAT			0x1c /* Wait then read 1 or 2 bytes */
122*91f16700Schasinglulu #define FIR_OP_NWAIT			0x1d /* Wait then read 1 or 2 bytes */
123*91f16700Schasinglulu #define FIR_OP_WFR			0x1e /* Wait then read 1 or 2 bytes */
124*91f16700Schasinglulu 
125*91f16700Schasinglulu #define NAND_SEQ_STRT_FIR_STRT		U(0x80000000)
126*91f16700Schasinglulu #define NAND_SEQ_STRT_FIR_STRT_SHIFT	31
127*91f16700Schasinglulu 
128*91f16700Schasinglulu #define NAND_EVTER_STAT_FTOER		U(0x08000000)
129*91f16700Schasinglulu #define NAND_EVTER_STAT_WPER		U(0x04000000)
130*91f16700Schasinglulu #define NAND_EVTER_STAT_ECCER		U(0x02000000)
131*91f16700Schasinglulu #define NAND_EVTER_STAT_DQSER		U(0x01000000)
132*91f16700Schasinglulu #define NAND_EVTER_STAT_RCW_DN		U(0x00008000)
133*91f16700Schasinglulu #define NAND_EVTER_STAT_BOOT_DN		U(0x00004000)
134*91f16700Schasinglulu #define NAND_EVTER_STAT_RCW_DN		U(0x00008000)
135*91f16700Schasinglulu #define NAND_EVTER_STAT_OPC_DN		U(0x80000000)
136*91f16700Schasinglulu #define NAND_EVTER_STAT_BBI_SRCH_SEL	U(0x00000800)
137*91f16700Schasinglulu #define NCFGR_BOOT			U(0x80000000)
138*91f16700Schasinglulu #define NAND_AUTOBOOT_TRGR_RCW_LD	U(0x80000000)
139*91f16700Schasinglulu #define NAND_AUTOBOOT_TRGR_BOOT_LD	U(0x20000000)
140*91f16700Schasinglulu 
141*91f16700Schasinglulu /* ECC ERROR STATUS Registers */
142*91f16700Schasinglulu #define NAND_RCW_LD			U(0x80000000)
143*91f16700Schasinglulu #define NAND_BOOT_LD			U(0x20000000)
144*91f16700Schasinglulu 
145*91f16700Schasinglulu /*Other Temp Defines */
146*91f16700Schasinglulu /*256 bad Blocks supported */
147*91f16700Schasinglulu #define BBT_SIZE			256
148*91f16700Schasinglulu 
149*91f16700Schasinglulu /*Standard NAND flash commands */
150*91f16700Schasinglulu #define NAND_CMD_READ0			0
151*91f16700Schasinglulu #define NAND_CMD_READ1			1
152*91f16700Schasinglulu #define NAND_CMD_READOOB		0x50
153*91f16700Schasinglulu 
154*91f16700Schasinglulu /*Extended commands for large page devices */
155*91f16700Schasinglulu #define NAND_CMD_READSTART		0x30
156*91f16700Schasinglulu 
157*91f16700Schasinglulu #define NAND_TIMEOUT_MS			40
158*91f16700Schasinglulu 
159*91f16700Schasinglulu #define EMPTY_VAL_CHECK			U(0xFFFFFFFF)
160*91f16700Schasinglulu #define EMPTY_VAL			0xFF
161*91f16700Schasinglulu 
162*91f16700Schasinglulu 
163*91f16700Schasinglulu #define MAIN				0
164*91f16700Schasinglulu #define SPARE				1
165*91f16700Schasinglulu 
166*91f16700Schasinglulu #define GOOD_BLK			1
167*91f16700Schasinglulu #define BAD_BLK				0
168*91f16700Schasinglulu #define DIV_2				2
169*91f16700Schasinglulu 
170*91f16700Schasinglulu #define ATTRIBUTE_PGSZ			0xa
171*91f16700Schasinglulu #define ATTRIBUTE_PPB			0xb
172*91f16700Schasinglulu 
173*91f16700Schasinglulu #define CSPR_PORT_SIZE_8		(0x1 << 7)
174*91f16700Schasinglulu #define CSPR_PORT_SIZE_16		(0x2 << 7)
175*91f16700Schasinglulu #define CSPR_PORT_SIZE_32		(0x3 << 7)
176*91f16700Schasinglulu 
177*91f16700Schasinglulu /* NAND specific */
178*91f16700Schasinglulu #define RCW_SRC_NAND_PORT_MASK		U(0x00000080)
179*91f16700Schasinglulu 
180*91f16700Schasinglulu #define NAND_DEFAULT_CSPR		U(0x00000053)
181*91f16700Schasinglulu #define NAND_DEFAULT_CSOR		U(0x0180C00C)
182*91f16700Schasinglulu #define NAND_DEFAULT_EXT_CSPR		U(0x00000000)
183*91f16700Schasinglulu #define NAND_DEFAULT_EXT_CSOR		U(0x00000000)
184*91f16700Schasinglulu #define NAND_DEFAULT_FTIM0		U(0x181c0c10)
185*91f16700Schasinglulu #define NAND_DEFAULT_FTIM1		U(0x5454141e)
186*91f16700Schasinglulu #define NAND_DEFAULT_FTIM2		U(0x03808034)
187*91f16700Schasinglulu #define NAND_DEFAULT_FTIM3		U(0x2c000000)
188*91f16700Schasinglulu 
189*91f16700Schasinglulu #define NAND_CSOR_ECC_MODE_DISABLE	U(0x00000000)
190*91f16700Schasinglulu #define NAND_CSOR_ECC_MODE0		U(0x84000000)
191*91f16700Schasinglulu #define NAND_CSOR_ECC_MODE1		U(0x94000000)
192*91f16700Schasinglulu #define NAND_CSOR_ECC_MODE2		U(0xa4000000)
193*91f16700Schasinglulu #define NAND_CSOR_ECC_MODE3		U(0xb4000000)
194*91f16700Schasinglulu #define NAND_CSOR_PAGE_SIZE_2K		(0x1 << 19)
195*91f16700Schasinglulu #define NAND_CSOR_PAGE_SIZE_4K		(0x2 << 19)
196*91f16700Schasinglulu #define NAND_CSOR_PAGE_SIZE_8K		(0x3 << 19)
197*91f16700Schasinglulu #define NAND_CSOR_PAGE_SIZE_16K		(0x4 << 19)
198*91f16700Schasinglulu #define NAND_CSOR_PPB_64		(0x1 << 8)
199*91f16700Schasinglulu #define NAND_CSOR_PPB_128		(0x2 << 8)
200*91f16700Schasinglulu #define NAND_CSOR_PPB_256		(0x3 << 8)
201*91f16700Schasinglulu #define NAND_CSOR_PPB_512		(0x4 << 8)
202*91f16700Schasinglulu 
203*91f16700Schasinglulu /* BBI INDICATOR for NAND_2K(CFG_RCW_SRC[1]) for
204*91f16700Schasinglulu  * devices greater than 2K page size(CFG_RCW_SRC[3])
205*91f16700Schasinglulu  */
206*91f16700Schasinglulu #define RCW_SRC_NAND_BBI_MASK		U(0x00000008)
207*91f16700Schasinglulu #define RCW_SRC_NAND_BBI_MASK_NAND_2K	U(0x00000002)
208*91f16700Schasinglulu #define NAND_BBI_ONFI_2K		(0x1 << 1)
209*91f16700Schasinglulu #define NAND_BBI_ONFI			(0x1 << 3)
210*91f16700Schasinglulu 
211*91f16700Schasinglulu #define RCW_SRC_NAND_PAGE_MASK		U(0x00000070)
212*91f16700Schasinglulu #define RCW_SRC_NAND_PAGE_MASK_NAND_2K	U(0x0000000C)
213*91f16700Schasinglulu #define NAND_2K_XXX			0x00
214*91f16700Schasinglulu #define NAND_2K_64			0x04
215*91f16700Schasinglulu #define NAND_2K_128			0x08
216*91f16700Schasinglulu #define NAND_4K_128			0x10
217*91f16700Schasinglulu #define NAND_4K_256			0x20
218*91f16700Schasinglulu #define NAND_4K_512			0x30
219*91f16700Schasinglulu #define NAND_8K_128			0x40
220*91f16700Schasinglulu #define NAND_8K_256			0x50
221*91f16700Schasinglulu #define NAND_8K_512			0x60
222*91f16700Schasinglulu #define NAND_16K_512			0x70
223*91f16700Schasinglulu #define BLOCK_LEN_2K			2048
224*91f16700Schasinglulu 
225*91f16700Schasinglulu #define RCW_SRC_NAND_ECC_MASK		U(0x00000007)
226*91f16700Schasinglulu #define RCW_SRC_NAND_ECC_MASK_NAND_2K	U(0x00000001)
227*91f16700Schasinglulu #define NAND_ECC_DISABLE		0x0
228*91f16700Schasinglulu #define NAND_ECC_4_520			0x1
229*91f16700Schasinglulu #define NAND_ECC_8_528			0x5
230*91f16700Schasinglulu #define NAND_ECC_24_1K			0x6
231*91f16700Schasinglulu #define NAND_ECC_40_1K			0x7
232*91f16700Schasinglulu 
233*91f16700Schasinglulu #define NAND_SPARE_2K			U(0x00000040)
234*91f16700Schasinglulu #define NAND_SPARE_4K_ECC_M0		U(0x00000080)
235*91f16700Schasinglulu #define NAND_SPARE_4K_ECC_M1		U(0x000000D2)
236*91f16700Schasinglulu #define NAND_SPARE_4K_ECC_M2		U(0x000000B0)
237*91f16700Schasinglulu #define NAND_SPARE_4K_ECC_M3		U(0x00000120)
238*91f16700Schasinglulu #define NAND_SPARE_8K_ECC_M0		U(0x00000088)
239*91f16700Schasinglulu #define NAND_SPARE_8K_ECC_M1		U(0x00000108)
240*91f16700Schasinglulu #define NAND_SPARE_8K_ECC_M2		U(0x00000158)
241*91f16700Schasinglulu #define NAND_SPARE_8K_ECC_M3		U(0x00000238)
242*91f16700Schasinglulu #define NAND_SPARE_16K_ECC_M0		U(0x00000108)
243*91f16700Schasinglulu #define NAND_SPARE_16K_ECC_M1		U(0x00000208)
244*91f16700Schasinglulu #define NAND_SPARE_16K_ECC_M2		U(0x000002A8)
245*91f16700Schasinglulu #define NAND_SPARE_16K_ECC_M3		U(0x00000468)
246*91f16700Schasinglulu 
247*91f16700Schasinglulu struct nand_info {
248*91f16700Schasinglulu 	uintptr_t ifc_register_addr;
249*91f16700Schasinglulu 	uintptr_t ifc_region_addr;
250*91f16700Schasinglulu 	uint32_t page_size;
251*91f16700Schasinglulu 	uint32_t port_size;
252*91f16700Schasinglulu 	uint32_t blk_size;
253*91f16700Schasinglulu 	uint32_t ppb;
254*91f16700Schasinglulu 	uint32_t pi_width;	/* Bits Required to index a page in block */
255*91f16700Schasinglulu 	uint32_t ral;
256*91f16700Schasinglulu 	uint32_t ibr_flow;
257*91f16700Schasinglulu 	uint32_t bbt[BBT_SIZE];
258*91f16700Schasinglulu 	uint32_t lgb;		/* Last Good Block */
259*91f16700Schasinglulu 	uint32_t bbt_max;	/* Total entries in bbt */
260*91f16700Schasinglulu 	uint32_t bzero_good;
261*91f16700Schasinglulu 	uint8_t bbs;
262*91f16700Schasinglulu 	uint8_t bad_marker_loc;
263*91f16700Schasinglulu 	uint8_t onfi_dev_flag;
264*91f16700Schasinglulu 	uint8_t init_time_boot_flag;
265*91f16700Schasinglulu 	uint8_t *buf;
266*91f16700Schasinglulu };
267*91f16700Schasinglulu 
268*91f16700Schasinglulu struct ifc_regs {
269*91f16700Schasinglulu 	uint32_t ext_cspr;
270*91f16700Schasinglulu 	uint32_t cspr;
271*91f16700Schasinglulu 	uint32_t csor;
272*91f16700Schasinglulu 	uint32_t ext_csor;
273*91f16700Schasinglulu };
274*91f16700Schasinglulu 
275*91f16700Schasinglulu struct sec_nand_info {
276*91f16700Schasinglulu 	uint32_t cspr_port_size;
277*91f16700Schasinglulu 	uint32_t csor_ecc_mode;
278*91f16700Schasinglulu 	uint32_t csor_page_size;
279*91f16700Schasinglulu 	uint32_t csor_ppb;
280*91f16700Schasinglulu 	uint32_t ext_csor_spare_size;
281*91f16700Schasinglulu 	uint32_t onfi_flag;
282*91f16700Schasinglulu };
283*91f16700Schasinglulu 
284*91f16700Schasinglulu struct sec_nor_info {
285*91f16700Schasinglulu 	uint32_t cspr_port_size;
286*91f16700Schasinglulu 	uint32_t csor_nor_mode;
287*91f16700Schasinglulu 	uint32_t csor_adm_shift;
288*91f16700Schasinglulu 	uint32_t port_size;
289*91f16700Schasinglulu 	uint32_t addr_bits;
290*91f16700Schasinglulu };
291*91f16700Schasinglulu 
292*91f16700Schasinglulu enum ifc_chip_sel {
293*91f16700Schasinglulu 	IFC_CS0,
294*91f16700Schasinglulu 	IFC_CS1,
295*91f16700Schasinglulu 	IFC_CS2,
296*91f16700Schasinglulu 	IFC_CS3,
297*91f16700Schasinglulu 	IFC_CS4,
298*91f16700Schasinglulu 	IFC_CS5,
299*91f16700Schasinglulu 	IFC_CS6,
300*91f16700Schasinglulu 	IFC_CS7,
301*91f16700Schasinglulu };
302*91f16700Schasinglulu 
303*91f16700Schasinglulu enum ifc_ftims {
304*91f16700Schasinglulu 	IFC_FTIM0,
305*91f16700Schasinglulu 	IFC_FTIM1,
306*91f16700Schasinglulu 	IFC_FTIM2,
307*91f16700Schasinglulu 	IFC_FTIM3,
308*91f16700Schasinglulu };
309*91f16700Schasinglulu 
310*91f16700Schasinglulu #ifdef NXP_IFC_BE
311*91f16700Schasinglulu #define nand_in32(a)		bswap32(mmio_read_32((uintptr_t)a))
312*91f16700Schasinglulu #define nand_out32(a, v)	mmio_write_32((uintptr_t)a, bswap32(v))
313*91f16700Schasinglulu #else
314*91f16700Schasinglulu #define nand_in32(a)		mmio_read_32((uintptr_t)a)
315*91f16700Schasinglulu #define nand_out32(a, v)	mmio_write_32((uintptr_t)a, v)
316*91f16700Schasinglulu #endif
317*91f16700Schasinglulu 
318*91f16700Schasinglulu /* Read Write on IFC registers */
319*91f16700Schasinglulu static inline void write_reg(struct nand_info *nand, uint32_t reg, uint32_t val)
320*91f16700Schasinglulu {
321*91f16700Schasinglulu 	nand_out32(nand->ifc_register_addr + reg, val);
322*91f16700Schasinglulu }
323*91f16700Schasinglulu 
324*91f16700Schasinglulu static inline uint32_t read_reg(struct nand_info *nand, uint32_t reg)
325*91f16700Schasinglulu {
326*91f16700Schasinglulu 	return nand_in32(nand->ifc_register_addr + reg);
327*91f16700Schasinglulu }
328*91f16700Schasinglulu 
329*91f16700Schasinglulu #endif /* IFC_H */
330