blob: 67dfac3dad409a4421139b26b1f6f32b69142e5d [file] [log] [blame]
Yann Gautiercaf575b2018-07-24 17:18:19 +02001/*
Patrick Delaunaya0f6ff72021-04-30 17:31:52 +02002 * Copyright (C) 2018-2022, STMicroelectronics - All Rights Reserved
Yann Gautiercaf575b2018-07-24 17:18:19 +02003 *
4 * SPDX-License-Identifier: GPL-2.0+ OR BSD-3-Clause
5 */
6
Antonio Nino Diaz5eb88372018-11-08 10:20:19 +00007#ifndef STM32MP1_DDR_H
8#define STM32MP1_DDR_H
Yann Gautiercaf575b2018-07-24 17:18:19 +02009
10#include <stdbool.h>
Antonio Nino Diaz5eb88372018-11-08 10:20:19 +000011#include <stdint.h>
Yann Gautiercaf575b2018-07-24 17:18:19 +020012
13#define DT_DDR_COMPAT "st,stm32mp1-ddr"
14
15struct stm32mp1_ddr_size {
16 uint64_t base;
17 uint64_t size;
18};
19
20/**
21 * struct ddr_info
22 *
23 * @dev: pointer for the device
24 * @info: UCLASS RAM information
25 * @ctl: DDR controleur base address
26 * @phy: DDR PHY base address
27 * @syscfg: syscfg base address
28 */
29struct ddr_info {
30 struct stm32mp1_ddr_size info;
31 struct stm32mp1_ddrctl *ctl;
32 struct stm32mp1_ddrphy *phy;
33 uintptr_t pwr;
34 uintptr_t rcc;
35};
36
37struct stm32mp1_ddrctrl_reg {
38 uint32_t mstr;
39 uint32_t mrctrl0;
40 uint32_t mrctrl1;
41 uint32_t derateen;
42 uint32_t derateint;
43 uint32_t pwrctl;
44 uint32_t pwrtmg;
45 uint32_t hwlpctl;
46 uint32_t rfshctl0;
47 uint32_t rfshctl3;
48 uint32_t crcparctl0;
49 uint32_t zqctl0;
50 uint32_t dfitmg0;
51 uint32_t dfitmg1;
52 uint32_t dfilpcfg0;
53 uint32_t dfiupd0;
54 uint32_t dfiupd1;
55 uint32_t dfiupd2;
56 uint32_t dfiphymstr;
57 uint32_t odtmap;
58 uint32_t dbg0;
59 uint32_t dbg1;
60 uint32_t dbgcmd;
61 uint32_t poisoncfg;
62 uint32_t pccfg;
63};
64
65struct stm32mp1_ddrctrl_timing {
66 uint32_t rfshtmg;
67 uint32_t dramtmg0;
68 uint32_t dramtmg1;
69 uint32_t dramtmg2;
70 uint32_t dramtmg3;
71 uint32_t dramtmg4;
72 uint32_t dramtmg5;
73 uint32_t dramtmg6;
74 uint32_t dramtmg7;
75 uint32_t dramtmg8;
76 uint32_t dramtmg14;
77 uint32_t odtcfg;
78};
79
80struct stm32mp1_ddrctrl_map {
81 uint32_t addrmap1;
82 uint32_t addrmap2;
83 uint32_t addrmap3;
84 uint32_t addrmap4;
85 uint32_t addrmap5;
86 uint32_t addrmap6;
87 uint32_t addrmap9;
88 uint32_t addrmap10;
89 uint32_t addrmap11;
90};
91
92struct stm32mp1_ddrctrl_perf {
93 uint32_t sched;
94 uint32_t sched1;
95 uint32_t perfhpr1;
96 uint32_t perflpr1;
97 uint32_t perfwr1;
98 uint32_t pcfgr_0;
99 uint32_t pcfgw_0;
100 uint32_t pcfgqos0_0;
101 uint32_t pcfgqos1_0;
102 uint32_t pcfgwqos0_0;
103 uint32_t pcfgwqos1_0;
Yann Gautier6d8c2442020-09-17 12:42:46 +0200104#if STM32MP_DDR_DUAL_AXI_PORT
Yann Gautiercaf575b2018-07-24 17:18:19 +0200105 uint32_t pcfgr_1;
106 uint32_t pcfgw_1;
107 uint32_t pcfgqos0_1;
108 uint32_t pcfgqos1_1;
109 uint32_t pcfgwqos0_1;
110 uint32_t pcfgwqos1_1;
Yann Gautier6d8c2442020-09-17 12:42:46 +0200111#endif
Yann Gautiercaf575b2018-07-24 17:18:19 +0200112};
113
114struct stm32mp1_ddrphy_reg {
115 uint32_t pgcr;
116 uint32_t aciocr;
117 uint32_t dxccr;
118 uint32_t dsgcr;
119 uint32_t dcr;
120 uint32_t odtcr;
121 uint32_t zq0cr1;
122 uint32_t dx0gcr;
123 uint32_t dx1gcr;
Yann Gautier6d8c2442020-09-17 12:42:46 +0200124#if STM32MP_DDR_32BIT_INTERFACE
Yann Gautiercaf575b2018-07-24 17:18:19 +0200125 uint32_t dx2gcr;
126 uint32_t dx3gcr;
Yann Gautier6d8c2442020-09-17 12:42:46 +0200127#endif
Yann Gautiercaf575b2018-07-24 17:18:19 +0200128};
129
130struct stm32mp1_ddrphy_timing {
131 uint32_t ptr0;
132 uint32_t ptr1;
133 uint32_t ptr2;
134 uint32_t dtpr0;
135 uint32_t dtpr1;
136 uint32_t dtpr2;
137 uint32_t mr0;
138 uint32_t mr1;
139 uint32_t mr2;
140 uint32_t mr3;
141};
142
Yann Gautiercaf575b2018-07-24 17:18:19 +0200143struct stm32mp1_ddr_info {
144 const char *name;
Yann Gautier7b7e4bf2019-01-17 19:16:03 +0100145 uint32_t speed; /* in kHZ */
Yann Gautiercaf575b2018-07-24 17:18:19 +0200146 uint32_t size; /* Memory size in byte = col * row * width */
147};
148
149struct stm32mp1_ddr_config {
150 struct stm32mp1_ddr_info info;
151 struct stm32mp1_ddrctrl_reg c_reg;
152 struct stm32mp1_ddrctrl_timing c_timing;
153 struct stm32mp1_ddrctrl_map c_map;
154 struct stm32mp1_ddrctrl_perf c_perf;
155 struct stm32mp1_ddrphy_reg p_reg;
156 struct stm32mp1_ddrphy_timing p_timing;
Yann Gautiercaf575b2018-07-24 17:18:19 +0200157};
158
Yann Gautier7b7e4bf2019-01-17 19:16:03 +0100159int stm32mp1_ddr_clk_enable(struct ddr_info *priv, uint32_t mem_speed);
Yann Gautiercaf575b2018-07-24 17:18:19 +0200160void stm32mp1_ddr_init(struct ddr_info *priv,
161 struct stm32mp1_ddr_config *config);
Antonio Nino Diaz5eb88372018-11-08 10:20:19 +0000162#endif /* STM32MP1_DDR_H */