xref: /arm-trusted-firmware/include/drivers/nxp/ddr/regs.h (revision 91f16700b400a8c0651d24a598fc48ee2997a0d7)
1*91f16700Schasinglulu /*
2*91f16700Schasinglulu  * Copyright 2021 NXP
3*91f16700Schasinglulu  *
4*91f16700Schasinglulu  * SPDX-License-Identifier: BSD-3-Clause
5*91f16700Schasinglulu  *
6*91f16700Schasinglulu  */
7*91f16700Schasinglulu 
8*91f16700Schasinglulu #ifndef DDR_REG_H
9*91f16700Schasinglulu #define DDR_REG_H
10*91f16700Schasinglulu 
11*91f16700Schasinglulu #define SDRAM_CS_CONFIG_EN		0x80000000
12*91f16700Schasinglulu 
13*91f16700Schasinglulu /* DDR_SDRAM_CFG - DDR SDRAM Control Configuration
14*91f16700Schasinglulu  */
15*91f16700Schasinglulu #define SDRAM_CFG_MEM_EN		0x80000000
16*91f16700Schasinglulu #define SDRAM_CFG_SREN			0x40000000
17*91f16700Schasinglulu #define SDRAM_CFG_ECC_EN		0x20000000
18*91f16700Schasinglulu #define SDRAM_CFG_RD_EN			0x10000000
19*91f16700Schasinglulu #define SDRAM_CFG_SDRAM_TYPE_MASK	0x07000000
20*91f16700Schasinglulu #define SDRAM_CFG_SDRAM_TYPE_SHIFT	24
21*91f16700Schasinglulu #define SDRAM_CFG_DYN_PWR		0x00200000
22*91f16700Schasinglulu #define SDRAM_CFG_DBW_MASK		0x00180000
23*91f16700Schasinglulu #define SDRAM_CFG_DBW_SHIFT		19
24*91f16700Schasinglulu #define SDRAM_CFG_32_BW			0x00080000
25*91f16700Schasinglulu #define SDRAM_CFG_16_BW			0x00100000
26*91f16700Schasinglulu #define SDRAM_CFG_8_BW			0x00180000
27*91f16700Schasinglulu #define SDRAM_CFG_8_BE			0x00040000
28*91f16700Schasinglulu #define SDRAM_CFG_2T_EN			0x00008000
29*91f16700Schasinglulu #define SDRAM_CFG_MEM_HLT		0x00000002
30*91f16700Schasinglulu #define SDRAM_CFG_BI			0x00000001
31*91f16700Schasinglulu 
32*91f16700Schasinglulu #define SDRAM_CFG2_FRC_SR		0x80000000
33*91f16700Schasinglulu #define SDRAM_CFG2_FRC_SR_CLEAR		~(SDRAM_CFG2_FRC_SR)
34*91f16700Schasinglulu #define SDRAM_CFG2_D_INIT		0x00000010
35*91f16700Schasinglulu #define SDRAM_CFG2_AP_EN		0x00000020
36*91f16700Schasinglulu #define SDRAM_CFG2_ODT_ONLY_READ	2
37*91f16700Schasinglulu 
38*91f16700Schasinglulu #define SDRAM_CFG3_DDRC_RST		0x80000000
39*91f16700Schasinglulu 
40*91f16700Schasinglulu #define SDRAM_INTERVAL_REFINT	0xFFFF0000
41*91f16700Schasinglulu #define SDRAM_INTERVAL_REFINT_CLEAR	~(SDRAM_INTERVAL_REFINT)
42*91f16700Schasinglulu #define SDRAM_INTERVAL_BSTOPRE	0x3FFF
43*91f16700Schasinglulu 
44*91f16700Schasinglulu /* DDR_MD_CNTL */
45*91f16700Schasinglulu #define MD_CNTL_MD_EN		0x80000000
46*91f16700Schasinglulu #define MD_CNTL_CS_SEL(x)	(((x) & 0x7) << 28)
47*91f16700Schasinglulu #define MD_CNTL_MD_SEL(x)	(((x) & 0xf) << 24)
48*91f16700Schasinglulu #define MD_CNTL_CKE(x)		(((x) & 0x3) << 20)
49*91f16700Schasinglulu 
50*91f16700Schasinglulu /* DDR_CDR1 */
51*91f16700Schasinglulu #define DDR_CDR1_DHC_EN	0x80000000
52*91f16700Schasinglulu #define DDR_CDR1_ODT_SHIFT	17
53*91f16700Schasinglulu #define DDR_CDR1_ODT_MASK	0x6
54*91f16700Schasinglulu #define DDR_CDR2_ODT_MASK	0x1
55*91f16700Schasinglulu #define DDR_CDR1_ODT(x) ((x & DDR_CDR1_ODT_MASK) << DDR_CDR1_ODT_SHIFT)
56*91f16700Schasinglulu #define DDR_CDR2_ODT(x) (x & DDR_CDR2_ODT_MASK)
57*91f16700Schasinglulu #define DDR_CDR2_VREF_OVRD(x)	(0x00008080 | ((((x) - 37) & 0x3F) << 8))
58*91f16700Schasinglulu #define DDR_CDR2_VREF_TRAIN_EN	0x00000080
59*91f16700Schasinglulu #define DDR_CDR2_VREF_RANGE_2	0x00000040
60*91f16700Schasinglulu #define DDR_CDR_ODT_OFF		0x0
61*91f16700Schasinglulu #define DDR_CDR_ODT_100ohm	0x1
62*91f16700Schasinglulu #define DDR_CDR_ODT_120OHM	0x2
63*91f16700Schasinglulu #define DDR_CDR_ODT_80ohm	0x3
64*91f16700Schasinglulu #define DDR_CDR_ODT_60ohm	0x4
65*91f16700Schasinglulu #define DDR_CDR_ODT_40ohm	0x5
66*91f16700Schasinglulu #define DDR_CDR_ODT_50ohm	0x6
67*91f16700Schasinglulu #define DDR_CDR_ODT_30ohm	0x7
68*91f16700Schasinglulu 
69*91f16700Schasinglulu 
70*91f16700Schasinglulu /* DDR ERR_DISABLE */
71*91f16700Schasinglulu #define DDR_ERR_DISABLE_APED	(1 << 8)  /* Address parity error disable */
72*91f16700Schasinglulu #define DDR_ERR_DISABLE_SBED	(1 << 2)  /* Address parity error disable */
73*91f16700Schasinglulu #define DDR_ERR_DISABLE_MBED	(1 << 3)  /* Address parity error disable */
74*91f16700Schasinglulu 
75*91f16700Schasinglulu /* Mode Registers */
76*91f16700Schasinglulu #define DDR_MR5_CA_PARITY_LAT_4_CLK	0x1 /* for DDR4-1600/1866/2133 */
77*91f16700Schasinglulu #define DDR_MR5_CA_PARITY_LAT_5_CLK	0x2 /* for DDR4-2400 */
78*91f16700Schasinglulu 
79*91f16700Schasinglulu /* DDR DSR2  register */
80*91f16700Schasinglulu #define DDR_DSR_2_PHY_INIT_CMPLT	0x4
81*91f16700Schasinglulu 
82*91f16700Schasinglulu /* SDRAM TIMING_CFG_10 register */
83*91f16700Schasinglulu #define DDR_TIMING_CFG_10_T_STAB	0x7FFF
84*91f16700Schasinglulu 
85*91f16700Schasinglulu /* DEBUG 2 register */
86*91f16700Schasinglulu #define DDR_DBG_2_MEM_IDLE		0x00000002
87*91f16700Schasinglulu 
88*91f16700Schasinglulu /* DEBUG 26 register */
89*91f16700Schasinglulu #define DDR_DEBUG_26_BIT_6		(0x1 << 6)
90*91f16700Schasinglulu #define DDR_DEBUG_26_BIT_7		(0x1 << 7)
91*91f16700Schasinglulu #define DDR_DEBUG_26_BIT_12		(0x1 << 12)
92*91f16700Schasinglulu #define DDR_DEBUG_26_BIT_13		(0x1 << 13)
93*91f16700Schasinglulu #define DDR_DEBUG_26_BIT_14		(0x1 << 14)
94*91f16700Schasinglulu #define DDR_DEBUG_26_BIT_15		(0x1 << 15)
95*91f16700Schasinglulu #define DDR_DEBUG_26_BIT_16		(0x1 << 16)
96*91f16700Schasinglulu #define DDR_DEBUG_26_BIT_17		(0x1 << 17)
97*91f16700Schasinglulu #define DDR_DEBUG_26_BIT_18		(0x1 << 18)
98*91f16700Schasinglulu #define DDR_DEBUG_26_BIT_19		(0x1 << 19)
99*91f16700Schasinglulu #define DDR_DEBUG_26_BIT_24		(0x1 << 24)
100*91f16700Schasinglulu #define DDR_DEBUG_26_BIT_25		(0x1 << 25)
101*91f16700Schasinglulu 
102*91f16700Schasinglulu #define DDR_DEBUG_26_BIT_24_CLEAR	~(DDR_DEBUG_26_BIT_24)
103*91f16700Schasinglulu 
104*91f16700Schasinglulu /* DEBUG_29 register */
105*91f16700Schasinglulu #define DDR_TX_BD_DIS	(1 << 10) /* Transmit Bit Deskew Disable */
106*91f16700Schasinglulu 
107*91f16700Schasinglulu #define DDR_INIT_ADDR_EXT_UIA	(1 << 31)
108*91f16700Schasinglulu 
109*91f16700Schasinglulu #endif /* DDR_REG_H */
110