]> Git Repo - J-u-boot.git/blob - drivers/ram/stm32mp1/stm32mp1_ddr.c
Merge tag 'u-boot-imx-master-20250127' of https://gitlab.denx.de/u-boot/custodians...
[J-u-boot.git] / drivers / ram / stm32mp1 / stm32mp1_ddr.c
1 // SPDX-License-Identifier: GPL-2.0+ OR BSD-3-Clause
2 /*
3  * Copyright (C) 2018, STMicroelectronics - All Rights Reserved
4  */
5
6 #define LOG_CATEGORY UCLASS_RAM
7
8 #include <clk.h>
9 #include <log.h>
10 #include <ram.h>
11 #include <reset.h>
12 #include <timer.h>
13 #include <asm/io.h>
14 #include <asm/arch/ddr.h>
15 #include <linux/bitops.h>
16 #include <linux/delay.h>
17 #include <linux/iopoll.h>
18 #include <linux/printk.h>
19 #include "stm32mp1_ddr.h"
20 #include "stm32mp1_ddr_regs.h"
21
22 #define RCC_DDRITFCR            0xD8
23
24 #define RCC_DDRITFCR_DDRCAPBRST         (BIT(14))
25 #define RCC_DDRITFCR_DDRCAXIRST         (BIT(15))
26 #define RCC_DDRITFCR_DDRCORERST         (BIT(16))
27 #define RCC_DDRITFCR_DPHYAPBRST         (BIT(17))
28 #define RCC_DDRITFCR_DPHYRST            (BIT(18))
29 #define RCC_DDRITFCR_DPHYCTLRST         (BIT(19))
30 #define RCC_DDRITFCR_DDRCKMOD_MASK      GENMASK(22, 20)
31 #define RCC_DDRITFCR_DDRCKMOD_ASR       BIT(20)
32
33 struct reg_desc {
34         const char *name;
35         u16 offset;     /* offset for base address */
36         u8 par_offset;  /* offset for parameter array */
37 };
38
39 #define INVALID_OFFSET  0xFF
40
41 #define DDRCTL_REG(x, y) \
42         {#x,\
43          offsetof(struct stm32mp1_ddrctl, x),\
44          offsetof(struct y, x)}
45
46 #define DDRPHY_REG(x, y) \
47         {#x,\
48          offsetof(struct stm32mp1_ddrphy, x),\
49          offsetof(struct y, x)}
50
51 #define DDR_REG_DYN(x) \
52         {#x,\
53          offsetof(struct stm32mp1_ddrctl, x),\
54          INVALID_OFFSET}
55
56 #define DDRPHY_REG_DYN(x) \
57         {#x,\
58          offsetof(struct stm32mp1_ddrphy, x),\
59          INVALID_OFFSET}
60
61 /***********************************************************
62  * PARAMETERS: value get from device tree :
63  *             size / order need to be aligned with binding
64  *             modification NOT ALLOWED !!!
65  ***********************************************************/
66 #define DDRCTL_REG_REG_SIZE     25      /* st,ctl-reg */
67 #define DDRCTL_REG_TIMING_SIZE  12      /* st,ctl-timing */
68 #define DDRCTL_REG_MAP_SIZE     9       /* st,ctl-map */
69 #define DDRCTL_REG_PERF_SIZE    17      /* st,ctl-perf */
70
71 #define DDRPHY_REG_REG_SIZE     11      /* st,phy-reg */
72 #define DDRPHY_REG_TIMING_SIZE  10      /* st,phy-timing */
73
74 #define DDRCTL_REG_REG(x)       DDRCTL_REG(x, stm32mp1_ddrctrl_reg)
75 static const struct reg_desc ddr_reg[DDRCTL_REG_REG_SIZE] = {
76         DDRCTL_REG_REG(mstr),
77         DDRCTL_REG_REG(mrctrl0),
78         DDRCTL_REG_REG(mrctrl1),
79         DDRCTL_REG_REG(derateen),
80         DDRCTL_REG_REG(derateint),
81         DDRCTL_REG_REG(pwrctl),
82         DDRCTL_REG_REG(pwrtmg),
83         DDRCTL_REG_REG(hwlpctl),
84         DDRCTL_REG_REG(rfshctl0),
85         DDRCTL_REG_REG(rfshctl3),
86         DDRCTL_REG_REG(crcparctl0),
87         DDRCTL_REG_REG(zqctl0),
88         DDRCTL_REG_REG(dfitmg0),
89         DDRCTL_REG_REG(dfitmg1),
90         DDRCTL_REG_REG(dfilpcfg0),
91         DDRCTL_REG_REG(dfiupd0),
92         DDRCTL_REG_REG(dfiupd1),
93         DDRCTL_REG_REG(dfiupd2),
94         DDRCTL_REG_REG(dfiphymstr),
95         DDRCTL_REG_REG(odtmap),
96         DDRCTL_REG_REG(dbg0),
97         DDRCTL_REG_REG(dbg1),
98         DDRCTL_REG_REG(dbgcmd),
99         DDRCTL_REG_REG(poisoncfg),
100         DDRCTL_REG_REG(pccfg),
101 };
102
103 #define DDRCTL_REG_TIMING(x)    DDRCTL_REG(x, stm32mp1_ddrctrl_timing)
104 static const struct reg_desc ddr_timing[DDRCTL_REG_TIMING_SIZE] = {
105         DDRCTL_REG_TIMING(rfshtmg),
106         DDRCTL_REG_TIMING(dramtmg0),
107         DDRCTL_REG_TIMING(dramtmg1),
108         DDRCTL_REG_TIMING(dramtmg2),
109         DDRCTL_REG_TIMING(dramtmg3),
110         DDRCTL_REG_TIMING(dramtmg4),
111         DDRCTL_REG_TIMING(dramtmg5),
112         DDRCTL_REG_TIMING(dramtmg6),
113         DDRCTL_REG_TIMING(dramtmg7),
114         DDRCTL_REG_TIMING(dramtmg8),
115         DDRCTL_REG_TIMING(dramtmg14),
116         DDRCTL_REG_TIMING(odtcfg),
117 };
118
119 #define DDRCTL_REG_MAP(x)       DDRCTL_REG(x, stm32mp1_ddrctrl_map)
120 static const struct reg_desc ddr_map[DDRCTL_REG_MAP_SIZE] = {
121         DDRCTL_REG_MAP(addrmap1),
122         DDRCTL_REG_MAP(addrmap2),
123         DDRCTL_REG_MAP(addrmap3),
124         DDRCTL_REG_MAP(addrmap4),
125         DDRCTL_REG_MAP(addrmap5),
126         DDRCTL_REG_MAP(addrmap6),
127         DDRCTL_REG_MAP(addrmap9),
128         DDRCTL_REG_MAP(addrmap10),
129         DDRCTL_REG_MAP(addrmap11),
130 };
131
132 #define DDRCTL_REG_PERF(x)      DDRCTL_REG(x, stm32mp1_ddrctrl_perf)
133 static const struct reg_desc ddr_perf[DDRCTL_REG_PERF_SIZE] = {
134         DDRCTL_REG_PERF(sched),
135         DDRCTL_REG_PERF(sched1),
136         DDRCTL_REG_PERF(perfhpr1),
137         DDRCTL_REG_PERF(perflpr1),
138         DDRCTL_REG_PERF(perfwr1),
139         DDRCTL_REG_PERF(pcfgr_0),
140         DDRCTL_REG_PERF(pcfgw_0),
141         DDRCTL_REG_PERF(pcfgqos0_0),
142         DDRCTL_REG_PERF(pcfgqos1_0),
143         DDRCTL_REG_PERF(pcfgwqos0_0),
144         DDRCTL_REG_PERF(pcfgwqos1_0),
145         DDRCTL_REG_PERF(pcfgr_1),
146         DDRCTL_REG_PERF(pcfgw_1),
147         DDRCTL_REG_PERF(pcfgqos0_1),
148         DDRCTL_REG_PERF(pcfgqos1_1),
149         DDRCTL_REG_PERF(pcfgwqos0_1),
150         DDRCTL_REG_PERF(pcfgwqos1_1),
151 };
152
153 #define DDRPHY_REG_REG(x)       DDRPHY_REG(x, stm32mp1_ddrphy_reg)
154 static const struct reg_desc ddrphy_reg[DDRPHY_REG_REG_SIZE] = {
155         DDRPHY_REG_REG(pgcr),
156         DDRPHY_REG_REG(aciocr),
157         DDRPHY_REG_REG(dxccr),
158         DDRPHY_REG_REG(dsgcr),
159         DDRPHY_REG_REG(dcr),
160         DDRPHY_REG_REG(odtcr),
161         DDRPHY_REG_REG(zq0cr1),
162         DDRPHY_REG_REG(dx0gcr),
163         DDRPHY_REG_REG(dx1gcr),
164         DDRPHY_REG_REG(dx2gcr),
165         DDRPHY_REG_REG(dx3gcr),
166 };
167
168 #define DDRPHY_REG_TIMING(x)    DDRPHY_REG(x, stm32mp1_ddrphy_timing)
169 static const struct reg_desc ddrphy_timing[DDRPHY_REG_TIMING_SIZE] = {
170         DDRPHY_REG_TIMING(ptr0),
171         DDRPHY_REG_TIMING(ptr1),
172         DDRPHY_REG_TIMING(ptr2),
173         DDRPHY_REG_TIMING(dtpr0),
174         DDRPHY_REG_TIMING(dtpr1),
175         DDRPHY_REG_TIMING(dtpr2),
176         DDRPHY_REG_TIMING(mr0),
177         DDRPHY_REG_TIMING(mr1),
178         DDRPHY_REG_TIMING(mr2),
179         DDRPHY_REG_TIMING(mr3),
180 };
181
182 /**************************************************************
183  * DYNAMIC REGISTERS: only used for debug purpose (read/modify)
184  **************************************************************/
185 #ifdef CONFIG_STM32MP1_DDR_INTERACTIVE
186 static const struct reg_desc ddr_dyn[] = {
187         DDR_REG_DYN(stat),
188         DDR_REG_DYN(init0),
189         DDR_REG_DYN(dfimisc),
190         DDR_REG_DYN(dfistat),
191         DDR_REG_DYN(swctl),
192         DDR_REG_DYN(swstat),
193         DDR_REG_DYN(pctrl_0),
194         DDR_REG_DYN(pctrl_1),
195 };
196
197 #define DDR_REG_DYN_SIZE        ARRAY_SIZE(ddr_dyn)
198
199 static const struct reg_desc ddrphy_dyn[] = {
200         DDRPHY_REG_DYN(pir),
201         DDRPHY_REG_DYN(pgsr),
202         DDRPHY_REG_DYN(zq0sr0),
203         DDRPHY_REG_DYN(zq0sr1),
204         DDRPHY_REG_DYN(dx0gsr0),
205         DDRPHY_REG_DYN(dx0gsr1),
206         DDRPHY_REG_DYN(dx0dllcr),
207         DDRPHY_REG_DYN(dx0dqtr),
208         DDRPHY_REG_DYN(dx0dqstr),
209         DDRPHY_REG_DYN(dx1gsr0),
210         DDRPHY_REG_DYN(dx1gsr1),
211         DDRPHY_REG_DYN(dx1dllcr),
212         DDRPHY_REG_DYN(dx1dqtr),
213         DDRPHY_REG_DYN(dx1dqstr),
214         DDRPHY_REG_DYN(dx2gsr0),
215         DDRPHY_REG_DYN(dx2gsr1),
216         DDRPHY_REG_DYN(dx2dllcr),
217         DDRPHY_REG_DYN(dx2dqtr),
218         DDRPHY_REG_DYN(dx2dqstr),
219         DDRPHY_REG_DYN(dx3gsr0),
220         DDRPHY_REG_DYN(dx3gsr1),
221         DDRPHY_REG_DYN(dx3dllcr),
222         DDRPHY_REG_DYN(dx3dqtr),
223         DDRPHY_REG_DYN(dx3dqstr),
224 };
225
226 #define DDRPHY_REG_DYN_SIZE     ARRAY_SIZE(ddrphy_dyn)
227
228 #endif
229
230 /*****************************************************************
231  * REGISTERS ARRAY: used to parse device tree and interactive mode
232  *****************************************************************/
233 enum reg_type {
234         REG_REG,
235         REG_TIMING,
236         REG_PERF,
237         REG_MAP,
238         REGPHY_REG,
239         REGPHY_TIMING,
240 #ifdef CONFIG_STM32MP1_DDR_INTERACTIVE
241 /* dynamic registers => managed in driver or not changed,
242  * can be dumped in interactive mode
243  */
244         REG_DYN,
245         REGPHY_DYN,
246 #endif
247         REG_TYPE_NB
248 };
249
250 enum base_type {
251         DDR_BASE,
252         DDRPHY_BASE,
253         NONE_BASE
254 };
255
256 struct ddr_reg_info {
257         const char *name;
258         const struct reg_desc *desc;
259         u8 size;
260         enum base_type base;
261 };
262
263 const struct ddr_reg_info ddr_registers[REG_TYPE_NB] = {
264 [REG_REG] = {
265         "static", ddr_reg, DDRCTL_REG_REG_SIZE, DDR_BASE},
266 [REG_TIMING] = {
267         "timing", ddr_timing, DDRCTL_REG_TIMING_SIZE, DDR_BASE},
268 [REG_PERF] = {
269         "perf", ddr_perf, DDRCTL_REG_PERF_SIZE, DDR_BASE},
270 [REG_MAP] = {
271         "map", ddr_map, DDRCTL_REG_MAP_SIZE, DDR_BASE},
272 [REGPHY_REG] = {
273         "static", ddrphy_reg, DDRPHY_REG_REG_SIZE, DDRPHY_BASE},
274 [REGPHY_TIMING] = {
275         "timing", ddrphy_timing, DDRPHY_REG_TIMING_SIZE, DDRPHY_BASE},
276 #ifdef CONFIG_STM32MP1_DDR_INTERACTIVE
277 [REG_DYN] = {
278         "dyn", ddr_dyn, DDR_REG_DYN_SIZE, DDR_BASE},
279 [REGPHY_DYN] = {
280         "dyn", ddrphy_dyn, DDRPHY_REG_DYN_SIZE, DDRPHY_BASE},
281 #endif
282
283 };
284
285 const char *base_name[] = {
286         [DDR_BASE] = "ctl",
287         [DDRPHY_BASE] = "phy",
288 };
289
290 static u32 get_base_addr(const struct ddr_info *priv, enum base_type base)
291 {
292         if (base == DDRPHY_BASE)
293                 return (u32)priv->phy;
294         else
295                 return (u32)priv->ctl;
296 }
297
298 static void set_reg(const struct ddr_info *priv,
299                     enum reg_type type,
300                     const void *param)
301 {
302         unsigned int i;
303         unsigned int *ptr, value;
304         enum base_type base = ddr_registers[type].base;
305         u32 base_addr = get_base_addr(priv, base);
306         const struct reg_desc *desc = ddr_registers[type].desc;
307
308         log_debug("init %s\n", ddr_registers[type].name);
309         for (i = 0; i < ddr_registers[type].size; i++) {
310                 ptr = (unsigned int *)(base_addr + desc[i].offset);
311                 if (desc[i].par_offset == INVALID_OFFSET) {
312                         log_err("invalid parameter offset for %s", desc[i].name);
313                 } else {
314                         value = *((u32 *)((u32)param +
315                                                desc[i].par_offset));
316                         writel(value, ptr);
317                         log_debug("[0x%x] %s= 0x%08x\n",
318                                   (u32)ptr, desc[i].name, value);
319                 }
320         }
321 }
322
323 #ifdef CONFIG_STM32MP1_DDR_INTERACTIVE
324 static void stm32mp1_dump_reg_desc(u32 base_addr, const struct reg_desc *desc)
325 {
326         unsigned int *ptr;
327
328         ptr = (unsigned int *)(base_addr + desc->offset);
329         printf("%s= 0x%08x\n", desc->name, readl(ptr));
330 }
331
332 static void stm32mp1_dump_param_desc(u32 par_addr, const struct reg_desc *desc)
333 {
334         unsigned int *ptr;
335
336         ptr = (unsigned int *)(par_addr + desc->par_offset);
337         printf("%s= 0x%08x\n", desc->name, readl(ptr));
338 }
339
340 static const struct reg_desc *found_reg(const char *name, enum reg_type *type)
341 {
342         unsigned int i, j;
343         const struct reg_desc *desc;
344
345         for (i = 0; i < ARRAY_SIZE(ddr_registers); i++) {
346                 desc = ddr_registers[i].desc;
347                 for (j = 0; j < ddr_registers[i].size; j++) {
348                         if (strcmp(name, desc[j].name) == 0) {
349                                 *type = i;
350                                 return &desc[j];
351                         }
352                 }
353         }
354         *type = REG_TYPE_NB;
355         return NULL;
356 }
357
358 int stm32mp1_dump_reg(const struct ddr_info *priv,
359                       const char *name)
360 {
361         unsigned int i, j;
362         const struct reg_desc *desc;
363         u32 base_addr;
364         enum base_type p_base;
365         enum reg_type type;
366         const char *p_name;
367         enum base_type filter = NONE_BASE;
368         int result = -1;
369
370         if (name) {
371                 if (strcmp(name, base_name[DDR_BASE]) == 0)
372                         filter = DDR_BASE;
373                 else if (strcmp(name, base_name[DDRPHY_BASE]) == 0)
374                         filter = DDRPHY_BASE;
375         }
376
377         for (i = 0; i < ARRAY_SIZE(ddr_registers); i++) {
378                 p_base = ddr_registers[i].base;
379                 p_name = ddr_registers[i].name;
380                 if (!name || (filter == p_base || !strcmp(name, p_name))) {
381                         result = 0;
382                         desc = ddr_registers[i].desc;
383                         base_addr = get_base_addr(priv, p_base);
384                         printf("==%s.%s==\n", base_name[p_base], p_name);
385                         for (j = 0; j < ddr_registers[i].size; j++)
386                                 stm32mp1_dump_reg_desc(base_addr, &desc[j]);
387                 }
388         }
389         if (result) {
390                 desc = found_reg(name, &type);
391                 if (desc) {
392                         p_base = ddr_registers[type].base;
393                         base_addr = get_base_addr(priv, p_base);
394                         stm32mp1_dump_reg_desc(base_addr, desc);
395                         result = 0;
396                 }
397         }
398         return result;
399 }
400
401 void stm32mp1_edit_reg(const struct ddr_info *priv,
402                        char *name, char *string)
403 {
404         unsigned long *ptr, value;
405         enum reg_type type;
406         enum base_type base;
407         const struct reg_desc *desc;
408         u32 base_addr;
409
410         desc = found_reg(name, &type);
411
412         if (!desc) {
413                 printf("%s not found\n", name);
414                 return;
415         }
416         if (strict_strtoul(string, 16, &value) < 0) {
417                 printf("invalid value %s\n", string);
418                 return;
419         }
420         base = ddr_registers[type].base;
421         base_addr = get_base_addr(priv, base);
422         ptr = (unsigned long *)(base_addr + desc->offset);
423         writel(value, ptr);
424         printf("%s= 0x%08x\n", desc->name, readl(ptr));
425 }
426
427 static u32 get_par_addr(const struct stm32mp1_ddr_config *config,
428                         enum reg_type type)
429 {
430         u32 par_addr = 0x0;
431
432         switch (type) {
433         case REG_REG:
434                 par_addr = (u32)&config->c_reg;
435                 break;
436         case REG_TIMING:
437                 par_addr = (u32)&config->c_timing;
438                 break;
439         case REG_PERF:
440                 par_addr = (u32)&config->c_perf;
441                 break;
442         case REG_MAP:
443                 par_addr = (u32)&config->c_map;
444                 break;
445         case REGPHY_REG:
446                 par_addr = (u32)&config->p_reg;
447                 break;
448         case REGPHY_TIMING:
449                 par_addr = (u32)&config->p_timing;
450                 break;
451         case REG_DYN:
452         case REGPHY_DYN:
453         case REG_TYPE_NB:
454                 par_addr = (u32)NULL;
455                 break;
456         }
457
458         return par_addr;
459 }
460
461 int stm32mp1_dump_param(const struct stm32mp1_ddr_config *config,
462                         const char *name)
463 {
464         unsigned int i, j;
465         const struct reg_desc *desc;
466         u32 par_addr;
467         enum base_type p_base;
468         enum reg_type type;
469         const char *p_name;
470         enum base_type filter = NONE_BASE;
471         int result = -EINVAL;
472
473         if (name) {
474                 if (strcmp(name, base_name[DDR_BASE]) == 0)
475                         filter = DDR_BASE;
476                 else if (strcmp(name, base_name[DDRPHY_BASE]) == 0)
477                         filter = DDRPHY_BASE;
478         }
479
480         for (i = 0; i < ARRAY_SIZE(ddr_registers); i++) {
481                 par_addr = get_par_addr(config, i);
482                 if (!par_addr)
483                         continue;
484                 p_base = ddr_registers[i].base;
485                 p_name = ddr_registers[i].name;
486                 if (!name || (filter == p_base || !strcmp(name, p_name))) {
487                         result = 0;
488                         desc = ddr_registers[i].desc;
489                         printf("==%s.%s==\n", base_name[p_base], p_name);
490                         for (j = 0; j < ddr_registers[i].size; j++)
491                                 stm32mp1_dump_param_desc(par_addr, &desc[j]);
492                 }
493         }
494         if (result) {
495                 desc = found_reg(name, &type);
496                 if (desc) {
497                         par_addr = get_par_addr(config, type);
498                         if (par_addr) {
499                                 stm32mp1_dump_param_desc(par_addr, desc);
500                                 result = 0;
501                         }
502                 }
503         }
504         return result;
505 }
506
507 void stm32mp1_edit_param(const struct stm32mp1_ddr_config *config,
508                          char *name, char *string)
509 {
510         unsigned long *ptr, value;
511         enum reg_type type;
512         const struct reg_desc *desc;
513         u32 par_addr;
514
515         desc = found_reg(name, &type);
516         if (!desc) {
517                 printf("%s not found\n", name);
518                 return;
519         }
520         if (strict_strtoul(string, 16, &value) < 0) {
521                 printf("invalid value %s\n", string);
522                 return;
523         }
524         par_addr = get_par_addr(config, type);
525         if (!par_addr) {
526                 printf("no parameter %s\n", name);
527                 return;
528         }
529         ptr = (unsigned long *)(par_addr + desc->par_offset);
530         writel(value, ptr);
531         printf("%s= 0x%08x\n", desc->name, readl(ptr));
532 }
533 #endif
534
535 __weak bool stm32mp1_ddr_interactive(void *priv,
536                                      enum stm32mp1_ddr_interact_step step,
537                                      const struct stm32mp1_ddr_config *config)
538 {
539         return false;
540 }
541
542 #define INTERACTIVE(step)\
543         stm32mp1_ddr_interactive(priv, step, config)
544
545 static void ddrphy_idone_wait(struct stm32mp1_ddrphy *phy)
546 {
547         u32 pgsr;
548         int ret;
549
550         ret = readl_poll_timeout(&phy->pgsr, pgsr,
551                                  pgsr & (DDRPHYC_PGSR_IDONE |
552                                          DDRPHYC_PGSR_DTERR |
553                                          DDRPHYC_PGSR_DTIERR |
554                                          DDRPHYC_PGSR_DFTERR |
555                                          DDRPHYC_PGSR_RVERR |
556                                          DDRPHYC_PGSR_RVEIRR),
557                                 1000000);
558         log_debug("\n[0x%08x] pgsr = 0x%08x ret=%d\n",
559                   (u32)&phy->pgsr, pgsr, ret);
560 }
561
562 static void stm32mp1_ddrphy_init(struct stm32mp1_ddrphy *phy, u32 pir)
563 {
564         pir |= DDRPHYC_PIR_INIT;
565         writel(pir, &phy->pir);
566         log_debug("[0x%08x] pir = 0x%08x -> 0x%08x\n",
567                   (u32)&phy->pir, pir, readl(&phy->pir));
568
569         /* need to wait 10 configuration clock before start polling */
570         udelay(10);
571
572         /* Wait DRAM initialization and Gate Training Evaluation complete */
573         ddrphy_idone_wait(phy);
574 }
575
576 /* start quasi dynamic register update */
577 static void start_sw_done(struct stm32mp1_ddrctl *ctl)
578 {
579         clrbits_le32(&ctl->swctl, DDRCTRL_SWCTL_SW_DONE);
580 }
581
582 /* wait quasi dynamic register update */
583 static void wait_sw_done_ack(struct stm32mp1_ddrctl *ctl)
584 {
585         int ret;
586         u32 swstat;
587
588         setbits_le32(&ctl->swctl, DDRCTRL_SWCTL_SW_DONE);
589
590         ret = readl_poll_timeout(&ctl->swstat, swstat,
591                                  swstat & DDRCTRL_SWSTAT_SW_DONE_ACK,
592                                  1000000);
593         if (ret)
594                 panic("Timeout initialising DRAM : DDR->swstat = %x\n",
595                       swstat);
596
597         log_debug("[0x%08x] swstat = 0x%08x\n", (u32)&ctl->swstat, swstat);
598 }
599
600 /* wait quasi dynamic register update */
601 static void wait_operating_mode(struct ddr_info *priv, int mode)
602 {
603         u32 stat, val, mask, val2 = 0, mask2 = 0;
604         int ret;
605
606         mask = DDRCTRL_STAT_OPERATING_MODE_MASK;
607         val = mode;
608         /* self-refresh due to software => check also STAT.selfref_type */
609         if (mode == DDRCTRL_STAT_OPERATING_MODE_SR) {
610                 mask |= DDRCTRL_STAT_SELFREF_TYPE_MASK;
611                 val |= DDRCTRL_STAT_SELFREF_TYPE_SR;
612         } else if (mode == DDRCTRL_STAT_OPERATING_MODE_NORMAL) {
613                 /* normal mode: handle also automatic self refresh */
614                 mask2 = DDRCTRL_STAT_OPERATING_MODE_MASK |
615                         DDRCTRL_STAT_SELFREF_TYPE_MASK;
616                 val2 = DDRCTRL_STAT_OPERATING_MODE_SR |
617                        DDRCTRL_STAT_SELFREF_TYPE_ASR;
618         }
619
620         ret = readl_poll_timeout(&priv->ctl->stat, stat,
621                                  ((stat & mask) == val) ||
622                                  (mask2 && ((stat & mask2) == val2)),
623                                  1000000);
624
625         if (ret)
626                 panic("Timeout DRAM : DDR->stat = %x\n", stat);
627
628         log_debug("[0x%08x] stat = 0x%08x\n", (u32)&priv->ctl->stat, stat);
629 }
630
631 static void stm32mp1_refresh_disable(struct stm32mp1_ddrctl *ctl)
632 {
633         start_sw_done(ctl);
634         /* quasi-dynamic register update*/
635         setbits_le32(&ctl->rfshctl3, DDRCTRL_RFSHCTL3_DIS_AUTO_REFRESH);
636         clrbits_le32(&ctl->pwrctl, DDRCTRL_PWRCTL_POWERDOWN_EN |
637                                    DDRCTRL_PWRCTL_SELFREF_EN);
638         clrbits_le32(&ctl->dfimisc, DDRCTRL_DFIMISC_DFI_INIT_COMPLETE_EN);
639         wait_sw_done_ack(ctl);
640 }
641
642 static void stm32mp1_refresh_restore(struct stm32mp1_ddrctl *ctl,
643                                      u32 rfshctl3, u32 pwrctl)
644 {
645         start_sw_done(ctl);
646         if (!(rfshctl3 & DDRCTRL_RFSHCTL3_DIS_AUTO_REFRESH))
647                 clrbits_le32(&ctl->rfshctl3, DDRCTRL_RFSHCTL3_DIS_AUTO_REFRESH);
648         if (pwrctl & DDRCTRL_PWRCTL_POWERDOWN_EN)
649                 setbits_le32(&ctl->pwrctl, DDRCTRL_PWRCTL_POWERDOWN_EN);
650         if ((pwrctl & DDRCTRL_PWRCTL_SELFREF_EN))
651                 setbits_le32(&ctl->pwrctl, DDRCTRL_PWRCTL_SELFREF_EN);
652         setbits_le32(&ctl->dfimisc, DDRCTRL_DFIMISC_DFI_INIT_COMPLETE_EN);
653         wait_sw_done_ack(ctl);
654 }
655
656 static void stm32mp1_asr_enable(struct ddr_info *priv, const u32 pwrctl)
657 {
658         struct stm32mp1_ddrctl *ctl = priv->ctl;
659
660         /* SSR is the best we can do. */
661         if (!(pwrctl & DDRCTRL_PWRCTL_EN_DFI_DRAM_CLK_DISABLE))
662                 return;
663
664         clrsetbits_le32(priv->rcc + RCC_DDRITFCR, RCC_DDRITFCR_DDRCKMOD_MASK,
665                         RCC_DDRITFCR_DDRCKMOD_ASR);
666
667         start_sw_done(ctl);
668
669         setbits_le32(&ctl->hwlpctl, DDRCTRL_HWLPCTL_HW_LP_EN);
670         writel(DDRCTRL_PWRTMG_POWERDOWN_TO_X32(0x10) |
671                DDRCTRL_PWRTMG_SELFREF_TO_X32(0x01),
672                &ctl->pwrtmg);
673
674         /* HSR we can do. */
675         setbits_le32(&ctl->pwrctl, DDRCTRL_PWRCTL_EN_DFI_DRAM_CLK_DISABLE);
676
677         if (pwrctl & DDRCTRL_PWRCTL_SELFREF_EN) /* ASR we can do. */
678                 setbits_le32(&ctl->pwrctl, DDRCTRL_PWRCTL_SELFREF_EN);
679
680         setbits_le32(&ctl->dfimisc, DDRCTRL_DFIMISC_DFI_INIT_COMPLETE_EN);
681         wait_sw_done_ack(ctl);
682 }
683
684 /* board-specific DDR power initializations. */
685 __weak int board_ddr_power_init(enum ddr_type ddr_type)
686 {
687         return 0;
688 }
689
690 __maybe_unused
691 void stm32mp1_ddr_init(struct ddr_info *priv,
692                        const struct stm32mp1_ddr_config *config)
693 {
694         u32 pir;
695         int ret = -EINVAL;
696         char bus_width;
697
698         switch (config->c_reg.mstr & DDRCTRL_MSTR_DATA_BUS_WIDTH_MASK) {
699         case DDRCTRL_MSTR_DATA_BUS_WIDTH_QUARTER:
700                 bus_width = 8;
701                 break;
702         case DDRCTRL_MSTR_DATA_BUS_WIDTH_HALF:
703                 bus_width = 16;
704                 break;
705         default:
706                 bus_width = 32;
707                 break;
708         }
709
710         if (config->c_reg.mstr & DDRCTRL_MSTR_DDR3)
711                 ret = board_ddr_power_init(STM32MP_DDR3);
712         else if (config->c_reg.mstr & DDRCTRL_MSTR_LPDDR2) {
713                 if (bus_width == 32)
714                         ret = board_ddr_power_init(STM32MP_LPDDR2_32);
715                 else
716                         ret = board_ddr_power_init(STM32MP_LPDDR2_16);
717         } else if (config->c_reg.mstr & DDRCTRL_MSTR_LPDDR3) {
718                 if (bus_width == 32)
719                         ret = board_ddr_power_init(STM32MP_LPDDR3_32);
720                 else
721                         ret = board_ddr_power_init(STM32MP_LPDDR3_16);
722         }
723         if (ret)
724                 panic("ddr power init failed\n");
725
726 start:
727         log_debug("name = %s\n", config->info.name);
728         log_debug("speed = %d kHz\n", config->info.speed);
729         log_debug("size  = 0x%x\n", config->info.size);
730 /*
731  * 1. Program the DWC_ddr_umctl2 registers
732  * 1.1 RESETS: presetn, core_ddrc_rstn, aresetn
733  */
734         /* Assert All DDR part */
735         setbits_le32(priv->rcc + RCC_DDRITFCR, RCC_DDRITFCR_DDRCAPBRST);
736         setbits_le32(priv->rcc + RCC_DDRITFCR, RCC_DDRITFCR_DDRCAXIRST);
737         setbits_le32(priv->rcc + RCC_DDRITFCR, RCC_DDRITFCR_DDRCORERST);
738         setbits_le32(priv->rcc + RCC_DDRITFCR, RCC_DDRITFCR_DPHYAPBRST);
739         setbits_le32(priv->rcc + RCC_DDRITFCR, RCC_DDRITFCR_DPHYRST);
740         setbits_le32(priv->rcc + RCC_DDRITFCR, RCC_DDRITFCR_DPHYCTLRST);
741
742 /* 1.2. start CLOCK */
743         if (stm32mp1_ddr_clk_enable(priv, config->info.speed))
744                 panic("invalid DRAM clock : %d kHz\n",
745                       config->info.speed);
746
747 /* 1.3. deassert reset */
748         /* de-assert PHY rstn and ctl_rstn via DPHYRST and DPHYCTLRST */
749         clrbits_le32(priv->rcc + RCC_DDRITFCR, RCC_DDRITFCR_DPHYRST);
750         clrbits_le32(priv->rcc + RCC_DDRITFCR, RCC_DDRITFCR_DPHYCTLRST);
751         /* De-assert presetn once the clocks are active
752          * and stable via DDRCAPBRST bit
753          */
754         clrbits_le32(priv->rcc + RCC_DDRITFCR, RCC_DDRITFCR_DDRCAPBRST);
755
756 /* 1.4. wait 128 cycles to permit initialization of end logic */
757         udelay(2);
758         /* for PCLK = 133MHz => 1 us is enough, 2 to allow lower frequency */
759
760         if (INTERACTIVE(STEP_DDR_RESET))
761                 goto start;
762
763 /* 1.5. initialize registers ddr_umctl2 */
764         /* Stop uMCTL2 before PHY is ready */
765         clrbits_le32(&priv->ctl->dfimisc, DDRCTRL_DFIMISC_DFI_INIT_COMPLETE_EN);
766         log_debug("[0x%08x] dfimisc = 0x%08x\n",
767                   (u32)&priv->ctl->dfimisc, readl(&priv->ctl->dfimisc));
768
769         set_reg(priv, REG_REG, &config->c_reg);
770         set_reg(priv, REG_TIMING, &config->c_timing);
771         set_reg(priv, REG_MAP, &config->c_map);
772
773         /* skip CTRL init, SDRAM init is done by PHY PUBL */
774         clrsetbits_le32(&priv->ctl->init0,
775                         DDRCTRL_INIT0_SKIP_DRAM_INIT_MASK,
776                         DDRCTRL_INIT0_SKIP_DRAM_INIT_NORMAL);
777
778         set_reg(priv, REG_PERF, &config->c_perf);
779
780         if (INTERACTIVE(STEP_CTL_INIT))
781                 goto start;
782
783 /*  2. deassert reset signal core_ddrc_rstn, aresetn and presetn */
784         clrbits_le32(priv->rcc + RCC_DDRITFCR, RCC_DDRITFCR_DDRCORERST);
785         clrbits_le32(priv->rcc + RCC_DDRITFCR, RCC_DDRITFCR_DDRCAXIRST);
786         clrbits_le32(priv->rcc + RCC_DDRITFCR, RCC_DDRITFCR_DPHYAPBRST);
787
788 /*  3. start PHY init by accessing relevant PUBL registers
789  *    (DXGCR, DCR, PTR*, MR*, DTPR*)
790  */
791         set_reg(priv, REGPHY_REG, &config->p_reg);
792         set_reg(priv, REGPHY_TIMING, &config->p_timing);
793
794         if (INTERACTIVE(STEP_PHY_INIT))
795                 goto start;
796
797 /*  4. Monitor PHY init status by polling PUBL register PGSR.IDONE
798  *     Perform DDR PHY DRAM initialization and Gate Training Evaluation
799  */
800         ddrphy_idone_wait(priv->phy);
801
802 /*  5. Indicate to PUBL that controller performs SDRAM initialization
803  *     by setting PIR.INIT and PIR CTLDINIT and pool PGSR.IDONE
804  *     DRAM init is done by PHY, init0.skip_dram.init = 1
805  */
806         pir = DDRPHYC_PIR_DLLSRST | DDRPHYC_PIR_DLLLOCK | DDRPHYC_PIR_ZCAL |
807               DDRPHYC_PIR_ITMSRST | DDRPHYC_PIR_DRAMINIT | DDRPHYC_PIR_ICPC;
808
809         if (config->c_reg.mstr & DDRCTRL_MSTR_DDR3)
810                 pir |= DDRPHYC_PIR_DRAMRST; /* only for DDR3 */
811
812         stm32mp1_ddrphy_init(priv->phy, pir);
813
814 /*  6. SET DFIMISC.dfi_init_complete_en to 1 */
815         /* Enable quasi-dynamic register programming*/
816         start_sw_done(priv->ctl);
817         setbits_le32(&priv->ctl->dfimisc, DDRCTRL_DFIMISC_DFI_INIT_COMPLETE_EN);
818         wait_sw_done_ack(priv->ctl);
819
820 /*  7. Wait for DWC_ddr_umctl2 to move to normal operation mode
821  *     by monitoring STAT.operating_mode signal
822  */
823         /* wait uMCTL2 ready */
824
825         wait_operating_mode(priv, DDRCTRL_STAT_OPERATING_MODE_NORMAL);
826
827         log_debug("DDR DQS training : ");
828 /*  8. Disable Auto refresh and power down by setting
829  *    - RFSHCTL3.dis_au_refresh = 1
830  *    - PWRCTL.powerdown_en = 0
831  *    - DFIMISC.dfiinit_complete_en = 0
832  */
833         stm32mp1_refresh_disable(priv->ctl);
834
835 /*  9. Program PUBL PGCR to enable refresh during training and rank to train
836  *     not done => keep the programed value in PGCR
837  */
838
839 /* 10. configure PUBL PIR register to specify which training step to run */
840         /* RVTRN is excuted only on LPDDR2/LPDDR3 */
841         if (config->c_reg.mstr & DDRCTRL_MSTR_DDR3)
842                 pir = DDRPHYC_PIR_QSTRN;
843         else
844                 pir = DDRPHYC_PIR_QSTRN | DDRPHYC_PIR_RVTRN;
845         stm32mp1_ddrphy_init(priv->phy, pir);
846
847 /* 11. monitor PUB PGSR.IDONE to poll cpmpletion of training sequence */
848         ddrphy_idone_wait(priv->phy);
849
850 /* 12. set back registers in step 8 to the orginal values if desidered */
851         stm32mp1_refresh_restore(priv->ctl, config->c_reg.rfshctl3,
852                                  config->c_reg.pwrctl);
853
854 /* Enable auto-self-refresh, which saves a bit of power at runtime. */
855         stm32mp1_asr_enable(priv, config->c_reg.pwrctl);
856
857         /* enable uMCTL2 AXI port 0 and 1 */
858         setbits_le32(&priv->ctl->pctrl_0, DDRCTRL_PCTRL_N_PORT_EN);
859         setbits_le32(&priv->ctl->pctrl_1, DDRCTRL_PCTRL_N_PORT_EN);
860
861         if (INTERACTIVE(STEP_DDR_READY))
862                 goto start;
863 }
This page took 0.074796 seconds and 4 git commands to generate.