xref: /arm-trusted-firmware/include/drivers/st/stm32mp1_ddr_regs.h (revision 91f16700b400a8c0651d24a598fc48ee2997a0d7)
1*91f16700Schasinglulu /*
2*91f16700Schasinglulu  * Copyright (c) 2017-2022, STMicroelectronics - All Rights Reserved
3*91f16700Schasinglulu  *
4*91f16700Schasinglulu  * SPDX-License-Identifier: GPL-2.0+ OR BSD-3-Clause
5*91f16700Schasinglulu  */
6*91f16700Schasinglulu 
7*91f16700Schasinglulu #ifndef STM32MP1_DDR_REGS_H
8*91f16700Schasinglulu #define STM32MP1_DDR_REGS_H
9*91f16700Schasinglulu 
10*91f16700Schasinglulu #include <drivers/st/stm32mp_ddrctrl_regs.h>
11*91f16700Schasinglulu #include <lib/utils_def.h>
12*91f16700Schasinglulu 
13*91f16700Schasinglulu /* DDR Physical Interface Control (DDRPHYC) registers*/
14*91f16700Schasinglulu struct stm32mp_ddrphy {
15*91f16700Schasinglulu 	uint32_t ridr;		/* 0x00 R Revision Identification */
16*91f16700Schasinglulu 	uint32_t pir;		/* 0x04 R/W PHY Initialization */
17*91f16700Schasinglulu 	uint32_t pgcr;		/* 0x08 R/W PHY General Configuration */
18*91f16700Schasinglulu 	uint32_t pgsr;		/* 0x0C PHY General Status */
19*91f16700Schasinglulu 	uint32_t dllgcr;	/* 0x10 R/W DLL General Control */
20*91f16700Schasinglulu 	uint32_t acdllcr;	/* 0x14 R/W AC DLL Control */
21*91f16700Schasinglulu 	uint32_t ptr0;		/* 0x18 R/W PHY Timing 0 */
22*91f16700Schasinglulu 	uint32_t ptr1;		/* 0x1C R/W PHY Timing 1 */
23*91f16700Schasinglulu 	uint32_t ptr2;		/* 0x20 R/W PHY Timing 2 */
24*91f16700Schasinglulu 	uint32_t aciocr;	/* 0x24 AC I/O Configuration */
25*91f16700Schasinglulu 	uint32_t dxccr;		/* 0x28 DATX8 Common Configuration */
26*91f16700Schasinglulu 	uint32_t dsgcr;		/* 0x2C DDR System General Configuration */
27*91f16700Schasinglulu 	uint32_t dcr;		/* 0x30 DRAM Configuration */
28*91f16700Schasinglulu 	uint32_t dtpr0;		/* 0x34 DRAM Timing Parameters0 */
29*91f16700Schasinglulu 	uint32_t dtpr1;		/* 0x38 DRAM Timing Parameters1 */
30*91f16700Schasinglulu 	uint32_t dtpr2;		/* 0x3C DRAM Timing Parameters2 */
31*91f16700Schasinglulu 	uint32_t mr0;		/* 0x40 Mode 0 */
32*91f16700Schasinglulu 	uint32_t mr1;		/* 0x44 Mode 1 */
33*91f16700Schasinglulu 	uint32_t mr2;		/* 0x48 Mode 2 */
34*91f16700Schasinglulu 	uint32_t mr3;		/* 0x4C Mode 3 */
35*91f16700Schasinglulu 	uint32_t odtcr;		/* 0x50 ODT Configuration */
36*91f16700Schasinglulu 	uint32_t dtar;		/* 0x54 data training address */
37*91f16700Schasinglulu 	uint32_t dtdr0;		/* 0x58 */
38*91f16700Schasinglulu 	uint32_t dtdr1;		/* 0x5c */
39*91f16700Schasinglulu 	uint8_t res1[0x0c0 - 0x060];	/* 0x60 */
40*91f16700Schasinglulu 	uint32_t dcuar;		/* 0xc0 Address */
41*91f16700Schasinglulu 	uint32_t dcudr;		/* 0xc4 DCU Data */
42*91f16700Schasinglulu 	uint32_t dcurr;		/* 0xc8 DCU Run */
43*91f16700Schasinglulu 	uint32_t dculr;		/* 0xcc DCU Loop */
44*91f16700Schasinglulu 	uint32_t dcugcr;	/* 0xd0 DCU General Configuration */
45*91f16700Schasinglulu 	uint32_t dcutpr;	/* 0xd4 DCU Timing Parameters */
46*91f16700Schasinglulu 	uint32_t dcusr0;	/* 0xd8 DCU Status 0 */
47*91f16700Schasinglulu 	uint32_t dcusr1;	/* 0xdc DCU Status 1 */
48*91f16700Schasinglulu 	uint8_t res2[0x100 - 0xe0];	/* 0xe0 */
49*91f16700Schasinglulu 	uint32_t bistrr;	/* 0x100 BIST Run */
50*91f16700Schasinglulu 	uint32_t bistmskr0;	/* 0x104 BIST Mask 0 */
51*91f16700Schasinglulu 	uint32_t bistmskr1;	/* 0x108 BIST Mask 0 */
52*91f16700Schasinglulu 	uint32_t bistwcr;	/* 0x10c BIST Word Count */
53*91f16700Schasinglulu 	uint32_t bistlsr;	/* 0x110 BIST LFSR Seed */
54*91f16700Schasinglulu 	uint32_t bistar0;	/* 0x114 BIST Address 0 */
55*91f16700Schasinglulu 	uint32_t bistar1;	/* 0x118 BIST Address 1 */
56*91f16700Schasinglulu 	uint32_t bistar2;	/* 0x11c BIST Address 2 */
57*91f16700Schasinglulu 	uint32_t bistupdr;	/* 0x120 BIST User Data Pattern */
58*91f16700Schasinglulu 	uint32_t bistgsr;	/* 0x124 BIST General Status */
59*91f16700Schasinglulu 	uint32_t bistwer;	/* 0x128 BIST Word Error */
60*91f16700Schasinglulu 	uint32_t bistber0;	/* 0x12c BIST Bit Error 0 */
61*91f16700Schasinglulu 	uint32_t bistber1;	/* 0x130 BIST Bit Error 1 */
62*91f16700Schasinglulu 	uint32_t bistber2;	/* 0x134 BIST Bit Error 2 */
63*91f16700Schasinglulu 	uint32_t bistwcsr;	/* 0x138 BIST Word Count Status */
64*91f16700Schasinglulu 	uint32_t bistfwr0;	/* 0x13c BIST Fail Word 0 */
65*91f16700Schasinglulu 	uint32_t bistfwr1;	/* 0x140 BIST Fail Word 1 */
66*91f16700Schasinglulu 	uint8_t res3[0x178 - 0x144];	/* 0x144 */
67*91f16700Schasinglulu 	uint32_t gpr0;		/* 0x178 General Purpose 0 (GPR0) */
68*91f16700Schasinglulu 	uint32_t gpr1;		/* 0x17C General Purpose 1 (GPR1) */
69*91f16700Schasinglulu 	uint32_t zq0cr0;	/* 0x180 zq 0 control 0 */
70*91f16700Schasinglulu 	uint32_t zq0cr1;	/* 0x184 zq 0 control 1 */
71*91f16700Schasinglulu 	uint32_t zq0sr0;	/* 0x188 zq 0 status 0 */
72*91f16700Schasinglulu 	uint32_t zq0sr1;	/* 0x18C zq 0 status 1 */
73*91f16700Schasinglulu 	uint8_t res4[0x1C0 - 0x190];	/* 0x190 */
74*91f16700Schasinglulu 	uint32_t dx0gcr;	/* 0x1c0 Byte lane 0 General Configuration */
75*91f16700Schasinglulu 	uint32_t dx0gsr0;	/* 0x1c4 Byte lane 0 General Status 0 */
76*91f16700Schasinglulu 	uint32_t dx0gsr1;	/* 0x1c8 Byte lane 0 General Status 1 */
77*91f16700Schasinglulu 	uint32_t dx0dllcr;	/* 0x1cc Byte lane 0 DLL Control */
78*91f16700Schasinglulu 	uint32_t dx0dqtr;	/* 0x1d0 Byte lane 0 DQ Timing */
79*91f16700Schasinglulu 	uint32_t dx0dqstr;	/* 0x1d4 Byte lane 0 DQS Timing */
80*91f16700Schasinglulu 	uint8_t res5[0x200 - 0x1d8];	/* 0x1d8 */
81*91f16700Schasinglulu 	uint32_t dx1gcr;	/* 0x200 Byte lane 1 General Configuration */
82*91f16700Schasinglulu 	uint32_t dx1gsr0;	/* 0x204 Byte lane 1 General Status 0 */
83*91f16700Schasinglulu 	uint32_t dx1gsr1;	/* 0x208 Byte lane 1 General Status 1 */
84*91f16700Schasinglulu 	uint32_t dx1dllcr;	/* 0x20c Byte lane 1 DLL Control */
85*91f16700Schasinglulu 	uint32_t dx1dqtr;	/* 0x210 Byte lane 1 DQ Timing */
86*91f16700Schasinglulu 	uint32_t dx1dqstr;	/* 0x214 Byte lane 1 QS Timing */
87*91f16700Schasinglulu 	uint8_t res6[0x240 - 0x218];	/* 0x218 */
88*91f16700Schasinglulu #if STM32MP_DDR_32BIT_INTERFACE
89*91f16700Schasinglulu 	uint32_t dx2gcr;	/* 0x240 Byte lane 2 General Configuration */
90*91f16700Schasinglulu 	uint32_t dx2gsr0;	/* 0x244 Byte lane 2 General Status 0 */
91*91f16700Schasinglulu 	uint32_t dx2gsr1;	/* 0x248 Byte lane 2 General Status 1 */
92*91f16700Schasinglulu 	uint32_t dx2dllcr;	/* 0x24c Byte lane 2 DLL Control */
93*91f16700Schasinglulu 	uint32_t dx2dqtr;	/* 0x250 Byte lane 2 DQ Timing */
94*91f16700Schasinglulu 	uint32_t dx2dqstr;	/* 0x254 Byte lane 2 QS Timing */
95*91f16700Schasinglulu 	uint8_t res7[0x280 - 0x258];	/* 0x258 */
96*91f16700Schasinglulu 	uint32_t dx3gcr;	/* 0x280 Byte lane 3 General Configuration */
97*91f16700Schasinglulu 	uint32_t dx3gsr0;	/* 0x284 Byte lane 3 General Status 0 */
98*91f16700Schasinglulu 	uint32_t dx3gsr1;	/* 0x288 Byte lane 3 General Status 1 */
99*91f16700Schasinglulu 	uint32_t dx3dllcr;	/* 0x28c Byte lane 3 DLL Control */
100*91f16700Schasinglulu 	uint32_t dx3dqtr;	/* 0x290 Byte lane 3 DQ Timing */
101*91f16700Schasinglulu 	uint32_t dx3dqstr;	/* 0x294 Byte lane 3 QS Timing */
102*91f16700Schasinglulu #endif
103*91f16700Schasinglulu } __packed;
104*91f16700Schasinglulu 
105*91f16700Schasinglulu /* DDR PHY registers offsets */
106*91f16700Schasinglulu #define DDRPHYC_PIR				0x004
107*91f16700Schasinglulu #define DDRPHYC_PGCR				0x008
108*91f16700Schasinglulu #define DDRPHYC_PGSR				0x00C
109*91f16700Schasinglulu #define DDRPHYC_DLLGCR				0x010
110*91f16700Schasinglulu #define DDRPHYC_ACDLLCR				0x014
111*91f16700Schasinglulu #define DDRPHYC_PTR0				0x018
112*91f16700Schasinglulu #define DDRPHYC_ACIOCR				0x024
113*91f16700Schasinglulu #define DDRPHYC_DXCCR				0x028
114*91f16700Schasinglulu #define DDRPHYC_DSGCR				0x02C
115*91f16700Schasinglulu #define DDRPHYC_ZQ0CR0				0x180
116*91f16700Schasinglulu #define DDRPHYC_DX0GCR				0x1C0
117*91f16700Schasinglulu #define DDRPHYC_DX0DLLCR			0x1CC
118*91f16700Schasinglulu #define DDRPHYC_DX1GCR				0x200
119*91f16700Schasinglulu #define DDRPHYC_DX1DLLCR			0x20C
120*91f16700Schasinglulu #if STM32MP_DDR_32BIT_INTERFACE
121*91f16700Schasinglulu #define DDRPHYC_DX2GCR				0x240
122*91f16700Schasinglulu #define DDRPHYC_DX2DLLCR			0x24C
123*91f16700Schasinglulu #define DDRPHYC_DX3GCR				0x280
124*91f16700Schasinglulu #define DDRPHYC_DX3DLLCR			0x28C
125*91f16700Schasinglulu #endif
126*91f16700Schasinglulu 
127*91f16700Schasinglulu /* DDR PHY Register fields */
128*91f16700Schasinglulu #define DDRPHYC_PIR_INIT			BIT(0)
129*91f16700Schasinglulu #define DDRPHYC_PIR_DLLSRST			BIT(1)
130*91f16700Schasinglulu #define DDRPHYC_PIR_DLLLOCK			BIT(2)
131*91f16700Schasinglulu #define DDRPHYC_PIR_ZCAL			BIT(3)
132*91f16700Schasinglulu #define DDRPHYC_PIR_ITMSRST			BIT(4)
133*91f16700Schasinglulu #define DDRPHYC_PIR_DRAMRST			BIT(5)
134*91f16700Schasinglulu #define DDRPHYC_PIR_DRAMINIT			BIT(6)
135*91f16700Schasinglulu #define DDRPHYC_PIR_QSTRN			BIT(7)
136*91f16700Schasinglulu #define DDRPHYC_PIR_RVTRN			BIT(8)
137*91f16700Schasinglulu #define DDRPHYC_PIR_ICPC			BIT(16)
138*91f16700Schasinglulu #define DDRPHYC_PIR_ZCALBYP			BIT(30)
139*91f16700Schasinglulu #define DDRPHYC_PIR_INITSTEPS_MASK		GENMASK(31, 7)
140*91f16700Schasinglulu 
141*91f16700Schasinglulu #define DDRPHYC_PGCR_DFTCMP			BIT(2)
142*91f16700Schasinglulu #define DDRPHYC_PGCR_PDDISDX			BIT(24)
143*91f16700Schasinglulu #define DDRPHYC_PGCR_RFSHDT_MASK		GENMASK(28, 25)
144*91f16700Schasinglulu 
145*91f16700Schasinglulu #define DDRPHYC_PGSR_IDONE			BIT(0)
146*91f16700Schasinglulu #define DDRPHYC_PGSR_DTERR			BIT(5)
147*91f16700Schasinglulu #define DDRPHYC_PGSR_DTIERR			BIT(6)
148*91f16700Schasinglulu #define DDRPHYC_PGSR_DFTERR			BIT(7)
149*91f16700Schasinglulu #define DDRPHYC_PGSR_RVERR			BIT(8)
150*91f16700Schasinglulu #define DDRPHYC_PGSR_RVEIRR			BIT(9)
151*91f16700Schasinglulu 
152*91f16700Schasinglulu #define DDRPHYC_DLLGCR_BPS200			BIT(23)
153*91f16700Schasinglulu 
154*91f16700Schasinglulu #define DDRPHYC_ACDLLCR_DLLSRST			BIT(30)
155*91f16700Schasinglulu #define DDRPHYC_ACDLLCR_DLLDIS			BIT(31)
156*91f16700Schasinglulu 
157*91f16700Schasinglulu #define DDRPHYC_PTR0_TDLLSRST_OFFSET		0
158*91f16700Schasinglulu #define DDRPHYC_PTR0_TDLLSRST_MASK		GENMASK(5, 0)
159*91f16700Schasinglulu #define DDRPHYC_PTR0_TDLLLOCK_OFFSET		6
160*91f16700Schasinglulu #define DDRPHYC_PTR0_TDLLLOCK_MASK		GENMASK(17, 6)
161*91f16700Schasinglulu #define DDRPHYC_PTR0_TITMSRST_OFFSET		18
162*91f16700Schasinglulu #define DDRPHYC_PTR0_TITMSRST_MASK		GENMASK(21, 18)
163*91f16700Schasinglulu 
164*91f16700Schasinglulu #define DDRPHYC_ACIOCR_ACPDD			BIT(3)
165*91f16700Schasinglulu #define DDRPHYC_ACIOCR_ACPDR			BIT(4)
166*91f16700Schasinglulu #define DDRPHYC_ACIOCR_CKPDD_MASK		GENMASK(10, 8)
167*91f16700Schasinglulu #define DDRPHYC_ACIOCR_CKPDD_0			BIT(8)
168*91f16700Schasinglulu #define DDRPHYC_ACIOCR_CKPDR_MASK		GENMASK(13, 11)
169*91f16700Schasinglulu #define DDRPHYC_ACIOCR_CKPDR_0			BIT(11)
170*91f16700Schasinglulu #define DDRPHYC_ACIOCR_CSPDD_MASK		GENMASK(21, 18)
171*91f16700Schasinglulu #define DDRPHYC_ACIOCR_CSPDD_0			BIT(18)
172*91f16700Schasinglulu #define DDRPHYC_ACIOCR_RSTPDD			BIT(27)
173*91f16700Schasinglulu #define DDRPHYC_ACIOCR_RSTPDR			BIT(28)
174*91f16700Schasinglulu 
175*91f16700Schasinglulu #define DDRPHYC_DXCCR_DXPDD			BIT(2)
176*91f16700Schasinglulu #define DDRPHYC_DXCCR_DXPDR			BIT(3)
177*91f16700Schasinglulu 
178*91f16700Schasinglulu #define DDRPHYC_DSGCR_CKEPDD_MASK		GENMASK(19, 16)
179*91f16700Schasinglulu #define DDRPHYC_DSGCR_CKEPDD_0			BIT(16)
180*91f16700Schasinglulu #define DDRPHYC_DSGCR_ODTPDD_MASK		GENMASK(23, 20)
181*91f16700Schasinglulu #define DDRPHYC_DSGCR_ODTPDD_0			BIT(20)
182*91f16700Schasinglulu #define DDRPHYC_DSGCR_NL2PD			BIT(24)
183*91f16700Schasinglulu 
184*91f16700Schasinglulu #define DDRPHYC_ZQ0CRN_ZDATA_MASK		GENMASK(27, 0)
185*91f16700Schasinglulu #define DDRPHYC_ZQ0CRN_ZDATA_SHIFT		0
186*91f16700Schasinglulu #define DDRPHYC_ZQ0CRN_ZDEN			BIT(28)
187*91f16700Schasinglulu #define DDRPHYC_ZQ0CRN_ZQPD			BIT(31)
188*91f16700Schasinglulu 
189*91f16700Schasinglulu #define DDRPHYC_DXNGCR_DXEN			BIT(0)
190*91f16700Schasinglulu 
191*91f16700Schasinglulu #define DDRPHYC_DXNDLLCR_DLLSRST		BIT(30)
192*91f16700Schasinglulu #define DDRPHYC_DXNDLLCR_DLLDIS			BIT(31)
193*91f16700Schasinglulu #define DDRPHYC_DXNDLLCR_SDPHASE_MASK		GENMASK(17, 14)
194*91f16700Schasinglulu #define DDRPHYC_DXNDLLCR_SDPHASE_SHIFT		14
195*91f16700Schasinglulu 
196*91f16700Schasinglulu #endif /* STM32MP1_DDR_REGS_H */
197