xref: /rk3399_ARM-atf/include/drivers/nxp/ddr/immap.h (revision 87311b4c16730b884c7e4ff01e3faea83f2731be)
1*050a99a6SPankaj Gupta /*
2*050a99a6SPankaj Gupta  * Copyright 2021 NXP
3*050a99a6SPankaj Gupta  *
4*050a99a6SPankaj Gupta  * SPDX-License-Identifier: BSD-3-Clause
5*050a99a6SPankaj Gupta  *
6*050a99a6SPankaj Gupta  */
7*050a99a6SPankaj Gupta 
8*050a99a6SPankaj Gupta #ifndef DDR_IMMAP_H
9*050a99a6SPankaj Gupta #define DDR_IMMAP_H
10*050a99a6SPankaj Gupta 
11*050a99a6SPankaj Gupta #define	DDR_DBUS_64		0
12*050a99a6SPankaj Gupta #define	DDR_DBUS_32		1
13*050a99a6SPankaj Gupta #define	DDR_DBUS_16		2
14*050a99a6SPankaj Gupta 
15*050a99a6SPankaj Gupta /*
16*050a99a6SPankaj Gupta  * DDRC register file for DDRC 5.0 and above
17*050a99a6SPankaj Gupta  */
18*050a99a6SPankaj Gupta struct ccsr_ddr {
19*050a99a6SPankaj Gupta 	struct {
20*050a99a6SPankaj Gupta 		unsigned int a;		 /* 0x0, 0x8, 0x10, 0x18 */
21*050a99a6SPankaj Gupta 		unsigned int res;	 /* 0x4, 0xc, 0x14, 0x1c */
22*050a99a6SPankaj Gupta 	} bnds[4];
23*050a99a6SPankaj Gupta 	unsigned char	res_20[0x40 - 0x20];
24*050a99a6SPankaj Gupta 	unsigned int	dec[10];	 /* 0x40 */
25*050a99a6SPankaj Gupta 	unsigned char	res_68[0x80 - 0x68];
26*050a99a6SPankaj Gupta 	unsigned int	csn_cfg[4];	 /* 0x80, 0x84, 0x88, 0x8c */
27*050a99a6SPankaj Gupta 	unsigned char	res_90[48];
28*050a99a6SPankaj Gupta 	unsigned int	csn_cfg_2[4];	 /* 0xc0, 0xc4, 0xc8, 0xcc */
29*050a99a6SPankaj Gupta 	unsigned char	res_d0[48];
30*050a99a6SPankaj Gupta 	unsigned int	timing_cfg_3;	 /* SDRAM Timing Configuration 3 */
31*050a99a6SPankaj Gupta 	unsigned int	timing_cfg_0;	 /* SDRAM Timing Configuration 0 */
32*050a99a6SPankaj Gupta 	unsigned int	timing_cfg_1;	 /* SDRAM Timing Configuration 1 */
33*050a99a6SPankaj Gupta 	unsigned int	timing_cfg_2;	 /* SDRAM Timing Configuration 2 */
34*050a99a6SPankaj Gupta 	unsigned int	sdram_cfg;	 /* SDRAM Control Configuration */
35*050a99a6SPankaj Gupta 	unsigned int	sdram_cfg_2;	 /* SDRAM Control Configuration 2 */
36*050a99a6SPankaj Gupta 	unsigned int	sdram_mode;	 /* SDRAM Mode Configuration */
37*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_2;	 /* SDRAM Mode Configuration 2 */
38*050a99a6SPankaj Gupta 	unsigned int	sdram_md_cntl;	 /* SDRAM Mode Control */
39*050a99a6SPankaj Gupta 	unsigned int	sdram_interval;	 /* SDRAM Interval Configuration */
40*050a99a6SPankaj Gupta 	unsigned int	sdram_data_init; /* SDRAM Data initialization */
41*050a99a6SPankaj Gupta 	unsigned char	res_12c[4];
42*050a99a6SPankaj Gupta 	unsigned int	sdram_clk_cntl;	 /* SDRAM Clock Control */
43*050a99a6SPankaj Gupta 	unsigned char	res_134[20];
44*050a99a6SPankaj Gupta 	unsigned int	init_addr;	 /* training init addr */
45*050a99a6SPankaj Gupta 	unsigned int	init_ext_addr;	 /* training init extended addr */
46*050a99a6SPankaj Gupta 	unsigned char	res_150[16];
47*050a99a6SPankaj Gupta 	unsigned int	timing_cfg_4;	 /* SDRAM Timing Configuration 4 */
48*050a99a6SPankaj Gupta 	unsigned int	timing_cfg_5;	 /* SDRAM Timing Configuration 5 */
49*050a99a6SPankaj Gupta 	unsigned int	timing_cfg_6;	 /* SDRAM Timing Configuration 6 */
50*050a99a6SPankaj Gupta 	unsigned int	timing_cfg_7;	 /* SDRAM Timing Configuration 7 */
51*050a99a6SPankaj Gupta 	unsigned int	zq_cntl;	 /* ZQ calibration control*/
52*050a99a6SPankaj Gupta 	unsigned int	wrlvl_cntl;	 /* write leveling control*/
53*050a99a6SPankaj Gupta 	unsigned char	reg_178[4];
54*050a99a6SPankaj Gupta 	unsigned int	ddr_sr_cntr;	 /* self refresh counter */
55*050a99a6SPankaj Gupta 	unsigned int	ddr_sdram_rcw_1; /* Control Words 1 */
56*050a99a6SPankaj Gupta 	unsigned int	ddr_sdram_rcw_2; /* Control Words 2 */
57*050a99a6SPankaj Gupta 	unsigned char	reg_188[8];
58*050a99a6SPankaj Gupta 	unsigned int	ddr_wrlvl_cntl_2; /* write leveling control 2 */
59*050a99a6SPankaj Gupta 	unsigned int	ddr_wrlvl_cntl_3; /* write leveling control 3 */
60*050a99a6SPankaj Gupta 	unsigned char	res_198[0x1a0-0x198];
61*050a99a6SPankaj Gupta 	unsigned int	ddr_sdram_rcw_3;
62*050a99a6SPankaj Gupta 	unsigned int	ddr_sdram_rcw_4;
63*050a99a6SPankaj Gupta 	unsigned int	ddr_sdram_rcw_5;
64*050a99a6SPankaj Gupta 	unsigned int	ddr_sdram_rcw_6;
65*050a99a6SPankaj Gupta 	unsigned char	res_1b0[0x200-0x1b0];
66*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_3;	 /* SDRAM Mode Configuration 3 */
67*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_4;	 /* SDRAM Mode Configuration 4 */
68*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_5;	 /* SDRAM Mode Configuration 5 */
69*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_6;	 /* SDRAM Mode Configuration 6 */
70*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_7;	 /* SDRAM Mode Configuration 7 */
71*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_8;	 /* SDRAM Mode Configuration 8 */
72*050a99a6SPankaj Gupta 	unsigned char	res_218[0x220-0x218];
73*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_9;	 /* SDRAM Mode Configuration 9 */
74*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_10;	 /* SDRAM Mode Configuration 10 */
75*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_11;	 /* SDRAM Mode Configuration 11 */
76*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_12;	 /* SDRAM Mode Configuration 12 */
77*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_13;	 /* SDRAM Mode Configuration 13 */
78*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_14;	 /* SDRAM Mode Configuration 14 */
79*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_15;	 /* SDRAM Mode Configuration 15 */
80*050a99a6SPankaj Gupta 	unsigned int	sdram_mode_16;	 /* SDRAM Mode Configuration 16 */
81*050a99a6SPankaj Gupta 	unsigned char	res_240[0x250-0x240];
82*050a99a6SPankaj Gupta 	unsigned int	timing_cfg_8;	 /* SDRAM Timing Configuration 8 */
83*050a99a6SPankaj Gupta 	unsigned int	timing_cfg_9;	 /* SDRAM Timing Configuration 9 */
84*050a99a6SPankaj Gupta 	unsigned int	timing_cfg_10;	 /* SDRAM Timing COnfigurtion 10 */
85*050a99a6SPankaj Gupta 	unsigned char   res_258[0x260-0x25c];
86*050a99a6SPankaj Gupta 	unsigned int	sdram_cfg_3;
87*050a99a6SPankaj Gupta 	unsigned char	res_264[0x270-0x264];
88*050a99a6SPankaj Gupta 	unsigned int	sdram_md_cntl_2;
89*050a99a6SPankaj Gupta 	unsigned char	res_274[0x400-0x274];
90*050a99a6SPankaj Gupta 	unsigned int	dq_map[4];
91*050a99a6SPankaj Gupta 	unsigned char	res_410[0x800-0x410];
92*050a99a6SPankaj Gupta 	unsigned int	tx_cfg[4];
93*050a99a6SPankaj Gupta 	unsigned char	res_810[0xb20-0x810];
94*050a99a6SPankaj Gupta 	unsigned int	ddr_dsr1;	 /* Debug Status 1 */
95*050a99a6SPankaj Gupta 	unsigned int	ddr_dsr2;	 /* Debug Status 2 */
96*050a99a6SPankaj Gupta 	unsigned int	ddr_cdr1;	 /* Control Driver 1 */
97*050a99a6SPankaj Gupta 	unsigned int	ddr_cdr2;	 /* Control Driver 2 */
98*050a99a6SPankaj Gupta 	unsigned char	res_b30[200];
99*050a99a6SPankaj Gupta 	unsigned int	ip_rev1;	 /* IP Block Revision 1 */
100*050a99a6SPankaj Gupta 	unsigned int	ip_rev2;	 /* IP Block Revision 2 */
101*050a99a6SPankaj Gupta 	unsigned int	eor;		 /* Enhanced Optimization Register */
102*050a99a6SPankaj Gupta 	unsigned char	res_c04[252];
103*050a99a6SPankaj Gupta 	unsigned int	mtcr;		 /* Memory Test Control Register */
104*050a99a6SPankaj Gupta 	unsigned char	res_d04[28];
105*050a99a6SPankaj Gupta 	unsigned int	mtp[10];	 /* Memory Test Patterns */
106*050a99a6SPankaj Gupta 	unsigned char	res_d48[184];
107*050a99a6SPankaj Gupta 	unsigned int	data_err_inject_hi; /* Data Path Err Injection Mask Hi*/
108*050a99a6SPankaj Gupta 	unsigned int	data_err_inject_lo;/* Data Path Err Injection Mask Lo*/
109*050a99a6SPankaj Gupta 	unsigned int	ecc_err_inject;	 /* Data Path Err Injection Mask ECC */
110*050a99a6SPankaj Gupta 	unsigned char	res_e0c[20];
111*050a99a6SPankaj Gupta 	unsigned int	capture_data_hi; /* Data Path Read Capture High */
112*050a99a6SPankaj Gupta 	unsigned int	capture_data_lo; /* Data Path Read Capture Low */
113*050a99a6SPankaj Gupta 	unsigned int	capture_ecc;	 /* Data Path Read Capture ECC */
114*050a99a6SPankaj Gupta 	unsigned char	res_e2c[20];
115*050a99a6SPankaj Gupta 	unsigned int	err_detect;	 /* Error Detect */
116*050a99a6SPankaj Gupta 	unsigned int	err_disable;	 /* Error Disable */
117*050a99a6SPankaj Gupta 	unsigned int	err_int_en;
118*050a99a6SPankaj Gupta 	unsigned int	capture_attributes; /* Error Attrs Capture */
119*050a99a6SPankaj Gupta 	unsigned int	capture_address; /* Error Addr Capture */
120*050a99a6SPankaj Gupta 	unsigned int	capture_ext_address; /* Error Extended Addr Capture */
121*050a99a6SPankaj Gupta 	unsigned int	err_sbe;	 /* Single-Bit ECC Error Management */
122*050a99a6SPankaj Gupta 	unsigned char	res_e5c[164];
123*050a99a6SPankaj Gupta 	unsigned int	debug[64];	 /* debug_1 to debug_64 */
124*050a99a6SPankaj Gupta };
125*050a99a6SPankaj Gupta #endif /* DDR_IMMAP_H */
126