blob: b4d0890f902bee438e406c25cd4743b9a7d804c4 [file] [log] [blame]
Gabriel Fernandez3db088a2022-11-24 11:36:04 +01001// SPDX-License-Identifier: GPL-2.0-or-later OR BSD-3-Clause
2/*
3 * Copyright (C) 2022, STMicroelectronics - All Rights Reserved
4 * Author: Gabriel Fernandez <gabriel.fernandez@foss.st.com> for STMicroelectronics.
5 */
Gabriel Fernandez3db088a2022-11-24 11:36:04 +01006#define LOG_CATEGORY UCLASS_CLK
7
8#include <clk-uclass.h>
Gabriel Fernandez3db088a2022-11-24 11:36:04 +01009#include <dm.h>
10#include <log.h>
11#include <asm/io.h>
12#include <dt-bindings/clock/stm32mp13-clks.h>
13#include <linux/clk-provider.h>
Marek Vasut0b44b9c2025-05-12 19:08:29 +020014#include <dt-bindings/clock/stm32mp13-clksrc.h>
15#include <asm/arch/sys_proto.h>
16#include <asm/global_data.h>
17#include <clk-uclass.h>
18#include <div64.h>
19#include <dm/device_compat.h>
20#include <init.h>
21#include <linux/bitops.h>
22#include <linux/io.h>
23#include <linux/iopoll.h>
24#include <regmap.h>
25#include <spl.h>
26#include <syscon.h>
27#include <time.h>
28#include <vsprintf.h>
29#include <asm/arch/sys_proto.h>
Gabriel Fernandez3db088a2022-11-24 11:36:04 +010030
31#include "clk-stm32-core.h"
32#include "stm32mp13_rcc.h"
33
34DECLARE_GLOBAL_DATA_PTR;
35
36static const char * const adc12_src[] = {
37 "pll4_r", "ck_per", "pll3_q"
38};
39
40static const char * const dcmipp_src[] = {
41 "ck_axi", "pll2_q", "pll4_p", "ck_per",
42};
43
44static const char * const eth12_src[] = {
45 "pll4_p", "pll3_q"
46};
47
48static const char * const fdcan_src[] = {
49 "ck_hse", "pll3_q", "pll4_q", "pll4_r"
50};
51
52static const char * const fmc_src[] = {
53 "ck_axi", "pll3_r", "pll4_p", "ck_per"
54};
55
56static const char * const i2c12_src[] = {
57 "pclk1", "pll4_r", "ck_hsi", "ck_csi"
58};
59
60static const char * const i2c345_src[] = {
61 "pclk6", "pll4_r", "ck_hsi", "ck_csi"
62};
63
64static const char * const lptim1_src[] = {
65 "pclk1", "pll4_p", "pll3_q", "ck_lse", "ck_lsi", "ck_per"
66};
67
68static const char * const lptim23_src[] = {
69 "pclk3", "pll4_q", "ck_per", "ck_lse", "ck_lsi"
70};
71
72static const char * const lptim45_src[] = {
73 "pclk3", "pll4_p", "pll3_q", "ck_lse", "ck_lsi", "ck_per"
74};
75
76static const char * const mco1_src[] = {
77 "ck_hsi", "ck_hse", "ck_csi", "ck_lsi", "ck_lse"
78};
79
80static const char * const mco2_src[] = {
81 "ck_mpu", "ck_axi", "ck_mlahb", "pll4_p", "ck_hse", "ck_hsi"
82};
83
84static const char * const qspi_src[] = {
85 "ck_axi", "pll3_r", "pll4_p", "ck_per"
86};
87
88static const char * const rng1_src[] = {
89 "ck_csi", "pll4_r", "reserved", "ck_lsi"
90};
91
92static const char * const saes_src[] = {
93 "ck_axi", "ck_per", "pll4_r", "ck_lsi"
94};
95
96static const char * const sai1_src[] = {
97 "pll4_q", "pll3_q", "i2s_ckin", "ck_per", "pll3_r"
98};
99
100static const char * const sai2_src[] = {
101 "pll4_q", "pll3_q", "i2s_ckin", "ck_per", "spdif_ck_symb", "pll3_r"
102};
103
104static const char * const sdmmc12_src[] = {
105 "ck_axi", "pll3_r", "pll4_p", "ck_hsi"
106};
107
108static const char * const spdif_src[] = {
109 "pll4_p", "pll3_q", "ck_hsi"
110};
111
112static const char * const spi123_src[] = {
113 "pll4_p", "pll3_q", "i2s_ckin", "ck_per", "pll3_r"
114};
115
116static const char * const spi4_src[] = {
117 "pclk6", "pll4_q", "ck_hsi", "ck_csi", "ck_hse", "i2s_ckin"
118};
119
120static const char * const spi5_src[] = {
121 "pclk6", "pll4_q", "ck_hsi", "ck_csi", "ck_hse"
122};
123
124static const char * const stgen_src[] = {
125 "ck_hsi", "ck_hse"
126};
127
128static const char * const usart12_src[] = {
129 "pclk6", "pll3_q", "ck_hsi", "ck_csi", "pll4_q", "ck_hse"
130};
131
132static const char * const usart34578_src[] = {
133 "pclk1", "pll4_q", "ck_hsi", "ck_csi", "ck_hse"
134};
135
136static const char * const usart6_src[] = {
137 "pclk2", "pll4_q", "ck_hsi", "ck_csi", "ck_hse"
138};
139
140static const char * const usbo_src[] = {
141 "pll4_r", "ck_usbo_48m"
142};
143
144static const char * const usbphy_src[] = {
145 "ck_hse", "pll4_r", "clk-hse-div2"
146};
147
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100148
149#define MUX_CFG(id, src, _offset, _shift, _witdh) \
150 [id] = { \
151 .num_parents = ARRAY_SIZE(src), \
152 .parent_names = (src), \
153 .reg_off = (_offset), \
154 .shift = (_shift), \
155 .width = (_witdh), \
156 }
157
158static const struct stm32_mux_cfg stm32mp13_muxes[] = {
159 MUX_CFG(MUX_I2C12, i2c12_src, RCC_I2C12CKSELR, 0, 3),
160 MUX_CFG(MUX_LPTIM45, lptim45_src, RCC_LPTIM45CKSELR, 0, 3),
161 MUX_CFG(MUX_SPI23, spi123_src, RCC_SPI2S23CKSELR, 0, 3),
162 MUX_CFG(MUX_UART35, usart34578_src, RCC_UART35CKSELR, 0, 3),
163 MUX_CFG(MUX_UART78, usart34578_src, RCC_UART78CKSELR, 0, 3),
164 MUX_CFG(MUX_ADC1, adc12_src, RCC_ADC12CKSELR, 0, 2),
165 MUX_CFG(MUX_ADC2, adc12_src, RCC_ADC12CKSELR, 2, 2),
166 MUX_CFG(MUX_DCMIPP, dcmipp_src, RCC_DCMIPPCKSELR, 0, 2),
167 MUX_CFG(MUX_ETH1, eth12_src, RCC_ETH12CKSELR, 0, 2),
168 MUX_CFG(MUX_ETH2, eth12_src, RCC_ETH12CKSELR, 8, 2),
169 MUX_CFG(MUX_FDCAN, fdcan_src, RCC_FDCANCKSELR, 0, 2),
170 MUX_CFG(MUX_FMC, fmc_src, RCC_FMCCKSELR, 0, 2),
171 MUX_CFG(MUX_I2C3, i2c345_src, RCC_I2C345CKSELR, 0, 3),
172 MUX_CFG(MUX_I2C4, i2c345_src, RCC_I2C345CKSELR, 3, 3),
173 MUX_CFG(MUX_I2C5, i2c345_src, RCC_I2C345CKSELR, 6, 3),
174 MUX_CFG(MUX_LPTIM1, lptim1_src, RCC_LPTIM1CKSELR, 0, 3),
175 MUX_CFG(MUX_LPTIM2, lptim23_src, RCC_LPTIM23CKSELR, 0, 3),
176 MUX_CFG(MUX_LPTIM3, lptim23_src, RCC_LPTIM23CKSELR, 3, 3),
177 MUX_CFG(MUX_MCO1, mco1_src, RCC_MCO1CFGR, 0, 3),
178 MUX_CFG(MUX_MCO2, mco2_src, RCC_MCO2CFGR, 0, 3),
179 MUX_CFG(MUX_QSPI, qspi_src, RCC_QSPICKSELR, 0, 2),
180 MUX_CFG(MUX_RNG1, rng1_src, RCC_RNG1CKSELR, 0, 2),
181 MUX_CFG(MUX_SAES, saes_src, RCC_SAESCKSELR, 0, 2),
182 MUX_CFG(MUX_SAI1, sai1_src, RCC_SAI1CKSELR, 0, 3),
183 MUX_CFG(MUX_SAI2, sai2_src, RCC_SAI2CKSELR, 0, 3),
184 MUX_CFG(MUX_SDMMC1, sdmmc12_src, RCC_SDMMC12CKSELR, 0, 3),
185 MUX_CFG(MUX_SDMMC2, sdmmc12_src, RCC_SDMMC12CKSELR, 3, 3),
186 MUX_CFG(MUX_SPDIF, spdif_src, RCC_SPDIFCKSELR, 0, 2),
187 MUX_CFG(MUX_SPI1, spi123_src, RCC_SPI2S1CKSELR, 0, 3),
188 MUX_CFG(MUX_SPI4, spi4_src, RCC_SPI45CKSELR, 0, 3),
189 MUX_CFG(MUX_SPI5, spi5_src, RCC_SPI45CKSELR, 3, 3),
190 MUX_CFG(MUX_STGEN, stgen_src, RCC_STGENCKSELR, 0, 2),
191 MUX_CFG(MUX_UART1, usart12_src, RCC_UART12CKSELR, 0, 3),
192 MUX_CFG(MUX_UART2, usart12_src, RCC_UART12CKSELR, 3, 3),
193 MUX_CFG(MUX_UART4, usart34578_src, RCC_UART4CKSELR, 0, 3),
194 MUX_CFG(MUX_UART6, usart6_src, RCC_UART6CKSELR, 0, 3),
195 MUX_CFG(MUX_USBO, usbo_src, RCC_USBCKSELR, 4, 1),
196 MUX_CFG(MUX_USBPHY, usbphy_src, RCC_USBCKSELR, 0, 2),
197};
198
199enum enum_gate_cfg {
200 GATE_ZERO, /* reserved for no gate */
201 GATE_MCO1,
202 GATE_MCO2,
203 GATE_DBGCK,
204 GATE_TRACECK,
205 GATE_DDRC1,
206 GATE_DDRC1LP,
207 GATE_DDRPHYC,
208 GATE_DDRPHYCLP,
209 GATE_DDRCAPB,
210 GATE_DDRCAPBLP,
211 GATE_AXIDCG,
212 GATE_DDRPHYCAPB,
213 GATE_DDRPHYCAPBLP,
214 GATE_TIM2,
215 GATE_TIM3,
216 GATE_TIM4,
217 GATE_TIM5,
218 GATE_TIM6,
219 GATE_TIM7,
220 GATE_LPTIM1,
221 GATE_SPI2,
222 GATE_SPI3,
223 GATE_USART3,
224 GATE_UART4,
225 GATE_UART5,
226 GATE_UART7,
227 GATE_UART8,
228 GATE_I2C1,
229 GATE_I2C2,
230 GATE_SPDIF,
231 GATE_TIM1,
232 GATE_TIM8,
233 GATE_SPI1,
234 GATE_USART6,
235 GATE_SAI1,
236 GATE_SAI2,
237 GATE_DFSDM,
238 GATE_ADFSDM,
239 GATE_FDCAN,
240 GATE_LPTIM2,
241 GATE_LPTIM3,
242 GATE_LPTIM4,
243 GATE_LPTIM5,
244 GATE_VREF,
245 GATE_DTS,
246 GATE_PMBCTRL,
247 GATE_HDP,
248 GATE_SYSCFG,
249 GATE_DCMIPP,
250 GATE_DDRPERFM,
251 GATE_IWDG2APB,
252 GATE_USBPHY,
253 GATE_STGENRO,
254 GATE_LTDC,
255 GATE_TZC,
256 GATE_ETZPC,
257 GATE_IWDG1APB,
258 GATE_BSEC,
259 GATE_STGENC,
260 GATE_USART1,
261 GATE_USART2,
262 GATE_SPI4,
263 GATE_SPI5,
264 GATE_I2C3,
265 GATE_I2C4,
266 GATE_I2C5,
267 GATE_TIM12,
268 GATE_TIM13,
269 GATE_TIM14,
270 GATE_TIM15,
271 GATE_TIM16,
272 GATE_TIM17,
273 GATE_DMA1,
274 GATE_DMA2,
275 GATE_DMAMUX1,
276 GATE_DMA3,
277 GATE_DMAMUX2,
278 GATE_ADC1,
279 GATE_ADC2,
280 GATE_USBO,
281 GATE_TSC,
282 GATE_GPIOA,
283 GATE_GPIOB,
284 GATE_GPIOC,
285 GATE_GPIOD,
286 GATE_GPIOE,
287 GATE_GPIOF,
288 GATE_GPIOG,
289 GATE_GPIOH,
290 GATE_GPIOI,
291 GATE_PKA,
292 GATE_SAES,
293 GATE_CRYP1,
294 GATE_HASH1,
295 GATE_RNG1,
296 GATE_BKPSRAM,
297 GATE_AXIMC,
298 GATE_MCE,
299 GATE_ETH1CK,
300 GATE_ETH1TX,
301 GATE_ETH1RX,
302 GATE_ETH1MAC,
303 GATE_FMC,
304 GATE_QSPI,
305 GATE_SDMMC1,
306 GATE_SDMMC2,
307 GATE_CRC1,
308 GATE_USBH,
309 GATE_ETH2CK,
310 GATE_ETH2TX,
311 GATE_ETH2RX,
312 GATE_ETH2MAC,
313 GATE_ETH1STP,
314 GATE_ETH2STP,
315 GATE_MDMA
316};
317
318#define GATE_CFG(id, _offset, _bit_idx, _offset_clr) \
319 [id] = { \
320 .reg_off = (_offset), \
321 .bit_idx = (_bit_idx), \
322 .set_clr = (_offset_clr), \
323 }
324
325static const struct stm32_gate_cfg stm32mp13_gates[] = {
326 GATE_CFG(GATE_MCO1, RCC_MCO1CFGR, 12, 0),
327 GATE_CFG(GATE_MCO2, RCC_MCO2CFGR, 12, 0),
328 GATE_CFG(GATE_DBGCK, RCC_DBGCFGR, 8, 0),
329 GATE_CFG(GATE_TRACECK, RCC_DBGCFGR, 9, 0),
330 GATE_CFG(GATE_DDRC1, RCC_DDRITFCR, 0, 0),
331 GATE_CFG(GATE_DDRC1LP, RCC_DDRITFCR, 1, 0),
332 GATE_CFG(GATE_DDRPHYC, RCC_DDRITFCR, 4, 0),
333 GATE_CFG(GATE_DDRPHYCLP, RCC_DDRITFCR, 5, 0),
334 GATE_CFG(GATE_DDRCAPB, RCC_DDRITFCR, 6, 0),
335 GATE_CFG(GATE_DDRCAPBLP, RCC_DDRITFCR, 7, 0),
336 GATE_CFG(GATE_AXIDCG, RCC_DDRITFCR, 8, 0),
337 GATE_CFG(GATE_DDRPHYCAPB, RCC_DDRITFCR, 9, 0),
338 GATE_CFG(GATE_DDRPHYCAPBLP, RCC_DDRITFCR, 10, 0),
339 GATE_CFG(GATE_TIM2, RCC_MP_APB1ENSETR, 0, 1),
340 GATE_CFG(GATE_TIM3, RCC_MP_APB1ENSETR, 1, 1),
341 GATE_CFG(GATE_TIM4, RCC_MP_APB1ENSETR, 2, 1),
342 GATE_CFG(GATE_TIM5, RCC_MP_APB1ENSETR, 3, 1),
343 GATE_CFG(GATE_TIM6, RCC_MP_APB1ENSETR, 4, 1),
344 GATE_CFG(GATE_TIM7, RCC_MP_APB1ENSETR, 5, 1),
345 GATE_CFG(GATE_LPTIM1, RCC_MP_APB1ENSETR, 9, 1),
346 GATE_CFG(GATE_SPI2, RCC_MP_APB1ENSETR, 11, 1),
347 GATE_CFG(GATE_SPI3, RCC_MP_APB1ENSETR, 12, 1),
348 GATE_CFG(GATE_USART3, RCC_MP_APB1ENSETR, 15, 1),
349 GATE_CFG(GATE_UART4, RCC_MP_APB1ENSETR, 16, 1),
350 GATE_CFG(GATE_UART5, RCC_MP_APB1ENSETR, 17, 1),
351 GATE_CFG(GATE_UART7, RCC_MP_APB1ENSETR, 18, 1),
352 GATE_CFG(GATE_UART8, RCC_MP_APB1ENSETR, 19, 1),
353 GATE_CFG(GATE_I2C1, RCC_MP_APB1ENSETR, 21, 1),
354 GATE_CFG(GATE_I2C2, RCC_MP_APB1ENSETR, 22, 1),
355 GATE_CFG(GATE_SPDIF, RCC_MP_APB1ENSETR, 26, 1),
356 GATE_CFG(GATE_TIM1, RCC_MP_APB2ENSETR, 0, 1),
357 GATE_CFG(GATE_TIM8, RCC_MP_APB2ENSETR, 1, 1),
358 GATE_CFG(GATE_SPI1, RCC_MP_APB2ENSETR, 8, 1),
359 GATE_CFG(GATE_USART6, RCC_MP_APB2ENSETR, 13, 1),
360 GATE_CFG(GATE_SAI1, RCC_MP_APB2ENSETR, 16, 1),
361 GATE_CFG(GATE_SAI2, RCC_MP_APB2ENSETR, 17, 1),
362 GATE_CFG(GATE_DFSDM, RCC_MP_APB2ENSETR, 20, 1),
363 GATE_CFG(GATE_ADFSDM, RCC_MP_APB2ENSETR, 21, 1),
364 GATE_CFG(GATE_FDCAN, RCC_MP_APB2ENSETR, 24, 1),
365 GATE_CFG(GATE_LPTIM2, RCC_MP_APB3ENSETR, 0, 1),
366 GATE_CFG(GATE_LPTIM3, RCC_MP_APB3ENSETR, 1, 1),
367 GATE_CFG(GATE_LPTIM4, RCC_MP_APB3ENSETR, 2, 1),
368 GATE_CFG(GATE_LPTIM5, RCC_MP_APB3ENSETR, 3, 1),
369 GATE_CFG(GATE_VREF, RCC_MP_APB3ENSETR, 13, 1),
370 GATE_CFG(GATE_DTS, RCC_MP_APB3ENSETR, 16, 1),
371 GATE_CFG(GATE_PMBCTRL, RCC_MP_APB3ENSETR, 17, 1),
372 GATE_CFG(GATE_HDP, RCC_MP_APB3ENSETR, 20, 1),
373 GATE_CFG(GATE_SYSCFG, RCC_MP_NS_APB3ENSETR, 0, 1),
374 GATE_CFG(GATE_DCMIPP, RCC_MP_APB4ENSETR, 1, 1),
375 GATE_CFG(GATE_DDRPERFM, RCC_MP_APB4ENSETR, 8, 1),
376 GATE_CFG(GATE_IWDG2APB, RCC_MP_APB4ENSETR, 15, 1),
377 GATE_CFG(GATE_USBPHY, RCC_MP_APB4ENSETR, 16, 1),
378 GATE_CFG(GATE_STGENRO, RCC_MP_APB4ENSETR, 20, 1),
379 GATE_CFG(GATE_LTDC, RCC_MP_NS_APB4ENSETR, 0, 1),
380 GATE_CFG(GATE_TZC, RCC_MP_APB5ENSETR, 11, 1),
381 GATE_CFG(GATE_ETZPC, RCC_MP_APB5ENSETR, 13, 1),
382 GATE_CFG(GATE_IWDG1APB, RCC_MP_APB5ENSETR, 15, 1),
383 GATE_CFG(GATE_BSEC, RCC_MP_APB5ENSETR, 16, 1),
384 GATE_CFG(GATE_STGENC, RCC_MP_APB5ENSETR, 20, 1),
385 GATE_CFG(GATE_USART1, RCC_MP_APB6ENSETR, 0, 1),
386 GATE_CFG(GATE_USART2, RCC_MP_APB6ENSETR, 1, 1),
387 GATE_CFG(GATE_SPI4, RCC_MP_APB6ENSETR, 2, 1),
388 GATE_CFG(GATE_SPI5, RCC_MP_APB6ENSETR, 3, 1),
389 GATE_CFG(GATE_I2C3, RCC_MP_APB6ENSETR, 4, 1),
390 GATE_CFG(GATE_I2C4, RCC_MP_APB6ENSETR, 5, 1),
391 GATE_CFG(GATE_I2C5, RCC_MP_APB6ENSETR, 6, 1),
392 GATE_CFG(GATE_TIM12, RCC_MP_APB6ENSETR, 7, 1),
393 GATE_CFG(GATE_TIM13, RCC_MP_APB6ENSETR, 8, 1),
394 GATE_CFG(GATE_TIM14, RCC_MP_APB6ENSETR, 9, 1),
395 GATE_CFG(GATE_TIM15, RCC_MP_APB6ENSETR, 10, 1),
396 GATE_CFG(GATE_TIM16, RCC_MP_APB6ENSETR, 11, 1),
397 GATE_CFG(GATE_TIM17, RCC_MP_APB6ENSETR, 12, 1),
398 GATE_CFG(GATE_DMA1, RCC_MP_AHB2ENSETR, 0, 1),
399 GATE_CFG(GATE_DMA2, RCC_MP_AHB2ENSETR, 1, 1),
400 GATE_CFG(GATE_DMAMUX1, RCC_MP_AHB2ENSETR, 2, 1),
401 GATE_CFG(GATE_DMA3, RCC_MP_AHB2ENSETR, 3, 1),
402 GATE_CFG(GATE_DMAMUX2, RCC_MP_AHB2ENSETR, 4, 1),
403 GATE_CFG(GATE_ADC1, RCC_MP_AHB2ENSETR, 5, 1),
404 GATE_CFG(GATE_ADC2, RCC_MP_AHB2ENSETR, 6, 1),
405 GATE_CFG(GATE_USBO, RCC_MP_AHB2ENSETR, 8, 1),
406 GATE_CFG(GATE_TSC, RCC_MP_AHB4ENSETR, 15, 1),
407 GATE_CFG(GATE_GPIOA, RCC_MP_NS_AHB4ENSETR, 0, 1),
408 GATE_CFG(GATE_GPIOB, RCC_MP_NS_AHB4ENSETR, 1, 1),
409 GATE_CFG(GATE_GPIOC, RCC_MP_NS_AHB4ENSETR, 2, 1),
410 GATE_CFG(GATE_GPIOD, RCC_MP_NS_AHB4ENSETR, 3, 1),
411 GATE_CFG(GATE_GPIOE, RCC_MP_NS_AHB4ENSETR, 4, 1),
412 GATE_CFG(GATE_GPIOF, RCC_MP_NS_AHB4ENSETR, 5, 1),
413 GATE_CFG(GATE_GPIOG, RCC_MP_NS_AHB4ENSETR, 6, 1),
414 GATE_CFG(GATE_GPIOH, RCC_MP_NS_AHB4ENSETR, 7, 1),
415 GATE_CFG(GATE_GPIOI, RCC_MP_NS_AHB4ENSETR, 8, 1),
416 GATE_CFG(GATE_PKA, RCC_MP_AHB5ENSETR, 2, 1),
417 GATE_CFG(GATE_SAES, RCC_MP_AHB5ENSETR, 3, 1),
418 GATE_CFG(GATE_CRYP1, RCC_MP_AHB5ENSETR, 4, 1),
419 GATE_CFG(GATE_HASH1, RCC_MP_AHB5ENSETR, 5, 1),
420 GATE_CFG(GATE_RNG1, RCC_MP_AHB5ENSETR, 6, 1),
421 GATE_CFG(GATE_BKPSRAM, RCC_MP_AHB5ENSETR, 8, 1),
422 GATE_CFG(GATE_AXIMC, RCC_MP_AHB5ENSETR, 16, 1),
423 GATE_CFG(GATE_MCE, RCC_MP_AHB6ENSETR, 1, 1),
424 GATE_CFG(GATE_ETH1CK, RCC_MP_AHB6ENSETR, 7, 1),
425 GATE_CFG(GATE_ETH1TX, RCC_MP_AHB6ENSETR, 8, 1),
426 GATE_CFG(GATE_ETH1RX, RCC_MP_AHB6ENSETR, 9, 1),
427 GATE_CFG(GATE_ETH1MAC, RCC_MP_AHB6ENSETR, 10, 1),
428 GATE_CFG(GATE_FMC, RCC_MP_AHB6ENSETR, 12, 1),
429 GATE_CFG(GATE_QSPI, RCC_MP_AHB6ENSETR, 14, 1),
430 GATE_CFG(GATE_SDMMC1, RCC_MP_AHB6ENSETR, 16, 1),
431 GATE_CFG(GATE_SDMMC2, RCC_MP_AHB6ENSETR, 17, 1),
432 GATE_CFG(GATE_CRC1, RCC_MP_AHB6ENSETR, 20, 1),
433 GATE_CFG(GATE_USBH, RCC_MP_AHB6ENSETR, 24, 1),
434 GATE_CFG(GATE_ETH2CK, RCC_MP_AHB6ENSETR, 27, 1),
435 GATE_CFG(GATE_ETH2TX, RCC_MP_AHB6ENSETR, 28, 1),
436 GATE_CFG(GATE_ETH2RX, RCC_MP_AHB6ENSETR, 29, 1),
437 GATE_CFG(GATE_ETH2MAC, RCC_MP_AHB6ENSETR, 30, 1),
438 GATE_CFG(GATE_ETH1STP, RCC_MP_AHB6LPENSETR, 11, 1),
439 GATE_CFG(GATE_ETH2STP, RCC_MP_AHB6LPENSETR, 31, 1),
440 GATE_CFG(GATE_MDMA, RCC_MP_NS_AHB6ENSETR, 0, 1),
441};
442
443static const struct clk_div_table ck_trace_div_table[] = {
444 { 0, 1 }, { 1, 2 }, { 2, 4 }, { 3, 8 },
445 { 4, 16 }, { 5, 16 }, { 6, 16 }, { 7, 16 },
446 { 0 },
447};
448
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100449#define DIV_CFG(id, _offset, _shift, _width, _flags, _table) \
450 [id] = { \
451 .reg_off = _offset, \
452 .shift = _shift, \
453 .width = _width, \
454 .div_flags = _flags, \
455 .table = _table, \
456 }
457
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200458static const struct stm32_div_cfg stm32mp13_dividers[] = {
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100459 DIV_CFG(DIV_MCO1, RCC_MCO1CFGR, 4, 4, 0, NULL),
460 DIV_CFG(DIV_MCO2, RCC_MCO2CFGR, 4, 4, 0, NULL),
461 DIV_CFG(DIV_TRACE, RCC_DBGCFGR, 0, 3, 0, ck_trace_div_table),
462 DIV_CFG(DIV_ETH1PTP, RCC_ETH12CKSELR, 4, 4, 0, NULL),
463 DIV_CFG(DIV_ETH2PTP, RCC_ETH12CKSELR, 12, 4, 0, NULL),
464};
465
Marek Vasutd20eb392025-05-12 18:51:33 +0200466struct clk_stm32_security {
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100467 u16 offset;
468 u8 bit_idx;
469};
470
471enum securit_clk {
472 SECF_NONE,
473 SECF_LPTIM2,
474 SECF_LPTIM3,
475 SECF_VREF,
476 SECF_DCMIPP,
477 SECF_USBPHY,
478 SECF_RTC,
479 SECF_TZC,
480 SECF_ETZPC,
481 SECF_IWDG1,
482 SECF_BSEC,
483 SECF_STGENC,
484 SECF_STGENRO,
485 SECF_USART1,
486 SECF_USART2,
487 SECF_SPI4,
488 SECF_SPI5,
489 SECF_I2C3,
490 SECF_I2C4,
491 SECF_I2C5,
492 SECF_TIM12,
493 SECF_TIM13,
494 SECF_TIM14,
495 SECF_TIM15,
496 SECF_TIM16,
497 SECF_TIM17,
498 SECF_DMA3,
499 SECF_DMAMUX2,
500 SECF_ADC1,
501 SECF_ADC2,
502 SECF_USBO,
503 SECF_TSC,
504 SECF_PKA,
505 SECF_SAES,
506 SECF_CRYP1,
507 SECF_HASH1,
508 SECF_RNG1,
509 SECF_BKPSRAM,
510 SECF_MCE,
511 SECF_FMC,
512 SECF_QSPI,
513 SECF_SDMMC1,
514 SECF_SDMMC2,
515 SECF_ETH1CK,
516 SECF_ETH1TX,
517 SECF_ETH1RX,
518 SECF_ETH1MAC,
519 SECF_ETH1STP,
520 SECF_ETH2CK,
521 SECF_ETH2TX,
522 SECF_ETH2RX,
523 SECF_ETH2MAC,
524 SECF_ETH2STP,
525 SECF_MCO1,
526 SECF_MCO2
527};
528
529#define SECF(_sec_id, _offset, _bit_idx) \
530 [_sec_id] = { \
531 .offset = _offset, \
532 .bit_idx = _bit_idx, \
533 }
534
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200535#ifdef CONFIG_TFABOOT
Marek Vasutd20eb392025-05-12 18:51:33 +0200536static const struct clk_stm32_security stm32mp13_security[] = {
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100537 SECF(SECF_LPTIM2, RCC_APB3SECSR, RCC_APB3SECSR_LPTIM2SECF),
538 SECF(SECF_LPTIM3, RCC_APB3SECSR, RCC_APB3SECSR_LPTIM3SECF),
539 SECF(SECF_VREF, RCC_APB3SECSR, RCC_APB3SECSR_VREFSECF),
540 SECF(SECF_DCMIPP, RCC_APB4SECSR, RCC_APB4SECSR_DCMIPPSECF),
541 SECF(SECF_USBPHY, RCC_APB4SECSR, RCC_APB4SECSR_USBPHYSECF),
542 SECF(SECF_RTC, RCC_APB5SECSR, RCC_APB5SECSR_RTCSECF),
543 SECF(SECF_TZC, RCC_APB5SECSR, RCC_APB5SECSR_TZCSECF),
544 SECF(SECF_ETZPC, RCC_APB5SECSR, RCC_APB5SECSR_ETZPCSECF),
545 SECF(SECF_IWDG1, RCC_APB5SECSR, RCC_APB5SECSR_IWDG1SECF),
546 SECF(SECF_BSEC, RCC_APB5SECSR, RCC_APB5SECSR_BSECSECF),
547 SECF(SECF_STGENC, RCC_APB5SECSR, RCC_APB5SECSR_STGENCSECF),
548 SECF(SECF_STGENRO, RCC_APB5SECSR, RCC_APB5SECSR_STGENROSECF),
549 SECF(SECF_USART1, RCC_APB6SECSR, RCC_APB6SECSR_USART1SECF),
550 SECF(SECF_USART2, RCC_APB6SECSR, RCC_APB6SECSR_USART2SECF),
551 SECF(SECF_SPI4, RCC_APB6SECSR, RCC_APB6SECSR_SPI4SECF),
552 SECF(SECF_SPI5, RCC_APB6SECSR, RCC_APB6SECSR_SPI5SECF),
553 SECF(SECF_I2C3, RCC_APB6SECSR, RCC_APB6SECSR_I2C3SECF),
554 SECF(SECF_I2C4, RCC_APB6SECSR, RCC_APB6SECSR_I2C4SECF),
555 SECF(SECF_I2C5, RCC_APB6SECSR, RCC_APB6SECSR_I2C5SECF),
556 SECF(SECF_TIM12, RCC_APB6SECSR, RCC_APB6SECSR_TIM12SECF),
557 SECF(SECF_TIM13, RCC_APB6SECSR, RCC_APB6SECSR_TIM13SECF),
558 SECF(SECF_TIM14, RCC_APB6SECSR, RCC_APB6SECSR_TIM14SECF),
559 SECF(SECF_TIM15, RCC_APB6SECSR, RCC_APB6SECSR_TIM15SECF),
560 SECF(SECF_TIM16, RCC_APB6SECSR, RCC_APB6SECSR_TIM16SECF),
561 SECF(SECF_TIM17, RCC_APB6SECSR, RCC_APB6SECSR_TIM17SECF),
562 SECF(SECF_DMA3, RCC_AHB2SECSR, RCC_AHB2SECSR_DMA3SECF),
563 SECF(SECF_DMAMUX2, RCC_AHB2SECSR, RCC_AHB2SECSR_DMAMUX2SECF),
564 SECF(SECF_ADC1, RCC_AHB2SECSR, RCC_AHB2SECSR_ADC1SECF),
565 SECF(SECF_ADC2, RCC_AHB2SECSR, RCC_AHB2SECSR_ADC2SECF),
566 SECF(SECF_USBO, RCC_AHB2SECSR, RCC_AHB2SECSR_USBOSECF),
567 SECF(SECF_TSC, RCC_AHB4SECSR, RCC_AHB4SECSR_TSCSECF),
568 SECF(SECF_PKA, RCC_AHB5SECSR, RCC_AHB5SECSR_PKASECF),
569 SECF(SECF_SAES, RCC_AHB5SECSR, RCC_AHB5SECSR_SAESSECF),
570 SECF(SECF_CRYP1, RCC_AHB5SECSR, RCC_AHB5SECSR_CRYP1SECF),
571 SECF(SECF_HASH1, RCC_AHB5SECSR, RCC_AHB5SECSR_HASH1SECF),
572 SECF(SECF_RNG1, RCC_AHB5SECSR, RCC_AHB5SECSR_RNG1SECF),
573 SECF(SECF_BKPSRAM, RCC_AHB5SECSR, RCC_AHB5SECSR_BKPSRAMSECF),
574 SECF(SECF_MCE, RCC_AHB6SECSR, RCC_AHB6SECSR_MCESECF),
575 SECF(SECF_FMC, RCC_AHB6SECSR, RCC_AHB6SECSR_FMCSECF),
576 SECF(SECF_QSPI, RCC_AHB6SECSR, RCC_AHB6SECSR_QSPISECF),
577 SECF(SECF_SDMMC1, RCC_AHB6SECSR, RCC_AHB6SECSR_SDMMC1SECF),
578 SECF(SECF_SDMMC2, RCC_AHB6SECSR, RCC_AHB6SECSR_SDMMC2SECF),
579 SECF(SECF_ETH1CK, RCC_AHB6SECSR, RCC_AHB6SECSR_ETH1CKSECF),
580 SECF(SECF_ETH1TX, RCC_AHB6SECSR, RCC_AHB6SECSR_ETH1TXSECF),
581 SECF(SECF_ETH1RX, RCC_AHB6SECSR, RCC_AHB6SECSR_ETH1RXSECF),
582 SECF(SECF_ETH1MAC, RCC_AHB6SECSR, RCC_AHB6SECSR_ETH1MACSECF),
583 SECF(SECF_ETH1STP, RCC_AHB6SECSR, RCC_AHB6SECSR_ETH1STPSECF),
584 SECF(SECF_ETH2CK, RCC_AHB6SECSR, RCC_AHB6SECSR_ETH2CKSECF),
585 SECF(SECF_ETH2TX, RCC_AHB6SECSR, RCC_AHB6SECSR_ETH2TXSECF),
586 SECF(SECF_ETH2RX, RCC_AHB6SECSR, RCC_AHB6SECSR_ETH2RXSECF),
587 SECF(SECF_ETH2MAC, RCC_AHB6SECSR, RCC_AHB6SECSR_ETH2MACSECF),
588 SECF(SECF_ETH2STP, RCC_AHB6SECSR, RCC_AHB6SECSR_ETH2STPSECF),
589 SECF(SECF_MCO1, RCC_SECCFGR, RCC_SECCFGR_MCO1SECF),
590 SECF(SECF_MCO2, RCC_SECCFGR, RCC_SECCFGR_MCO2SECF),
591};
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200592#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100593
594#define PCLK(_id, _name, _parent, _flags, _gate_id, _sec_id) \
595 STM32_GATE(_id, _name, _parent, _flags, _gate_id, _sec_id)
596
597#define TIMER(_id, _name, _parent, _flags, _gate_id, _sec_id) \
598 STM32_GATE(_id, _name, _parent, ((_flags) | CLK_SET_RATE_PARENT), \
599 _gate_id, _sec_id)
600
601#define KCLK(_id, _name, _flags, _gate_id, _mux_id, _sec_id) \
602 STM32_COMPOSITE(_id, _name, _flags, _sec_id, \
603 _gate_id, _mux_id, NO_STM32_DIV)
604
605static const struct clock_config stm32mp13_clock_cfg[] = {
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200606#ifndef CONFIG_XPL_BUILD
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100607 TIMER(TIM2_K, "tim2_k", "timg1_ck", 0, GATE_TIM2, SECF_NONE),
608 TIMER(TIM3_K, "tim3_k", "timg1_ck", 0, GATE_TIM3, SECF_NONE),
609 TIMER(TIM4_K, "tim4_k", "timg1_ck", 0, GATE_TIM4, SECF_NONE),
610 TIMER(TIM5_K, "tim5_k", "timg1_ck", 0, GATE_TIM5, SECF_NONE),
611 TIMER(TIM6_K, "tim6_k", "timg1_ck", 0, GATE_TIM6, SECF_NONE),
612 TIMER(TIM7_K, "tim7_k", "timg1_ck", 0, GATE_TIM7, SECF_NONE),
613 TIMER(TIM1_K, "tim1_k", "timg2_ck", 0, GATE_TIM1, SECF_NONE),
614 TIMER(TIM8_K, "tim8_k", "timg2_ck", 0, GATE_TIM8, SECF_NONE),
615 TIMER(TIM12_K, "tim12_k", "timg3_ck", 0, GATE_TIM12, SECF_TIM12),
616 TIMER(TIM13_K, "tim13_k", "timg3_ck", 0, GATE_TIM13, SECF_TIM13),
617 TIMER(TIM14_K, "tim14_k", "timg3_ck", 0, GATE_TIM14, SECF_TIM14),
618 TIMER(TIM15_K, "tim15_k", "timg3_ck", 0, GATE_TIM15, SECF_TIM15),
619 TIMER(TIM16_K, "tim16_k", "timg3_ck", 0, GATE_TIM16, SECF_TIM16),
620 TIMER(TIM17_K, "tim17_k", "timg3_ck", 0, GATE_TIM17, SECF_TIM17),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200621#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100622
623 /* Peripheral clocks */
624 PCLK(SYSCFG, "syscfg", "pclk3", 0, GATE_SYSCFG, SECF_NONE),
625 PCLK(VREF, "vref", "pclk3", 0, GATE_VREF, SECF_VREF),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200626#ifndef CONFIG_XPL_BUILD
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100627 PCLK(PMBCTRL, "pmbctrl", "pclk3", 0, GATE_PMBCTRL, SECF_NONE),
628 PCLK(HDP, "hdp", "pclk3", 0, GATE_HDP, SECF_NONE),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200629#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100630 PCLK(IWDG2, "iwdg2", "pclk4", 0, GATE_IWDG2APB, SECF_NONE),
631 PCLK(STGENRO, "stgenro", "pclk4", 0, GATE_STGENRO, SECF_STGENRO),
632 PCLK(TZPC, "tzpc", "pclk5", 0, GATE_TZC, SECF_TZC),
633 PCLK(IWDG1, "iwdg1", "pclk5", 0, GATE_IWDG1APB, SECF_IWDG1),
634 PCLK(BSEC, "bsec", "pclk5", 0, GATE_BSEC, SECF_BSEC),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200635#ifndef CONFIG_XPL_BUILD
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100636 PCLK(DMA1, "dma1", "ck_mlahb", 0, GATE_DMA1, SECF_NONE),
637 PCLK(DMA2, "dma2", "ck_mlahb", 0, GATE_DMA2, SECF_NONE),
638 PCLK(DMAMUX1, "dmamux1", "ck_mlahb", 0, GATE_DMAMUX1, SECF_NONE),
639 PCLK(DMAMUX2, "dmamux2", "ck_mlahb", 0, GATE_DMAMUX2, SECF_DMAMUX2),
640 PCLK(ADC1, "adc1", "ck_mlahb", 0, GATE_ADC1, SECF_ADC1),
641 PCLK(ADC2, "adc2", "ck_mlahb", 0, GATE_ADC2, SECF_ADC2),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200642#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100643 PCLK(GPIOA, "gpioa", "pclk4", 0, GATE_GPIOA, SECF_NONE),
644 PCLK(GPIOB, "gpiob", "pclk4", 0, GATE_GPIOB, SECF_NONE),
645 PCLK(GPIOC, "gpioc", "pclk4", 0, GATE_GPIOC, SECF_NONE),
646 PCLK(GPIOD, "gpiod", "pclk4", 0, GATE_GPIOD, SECF_NONE),
647 PCLK(GPIOE, "gpioe", "pclk4", 0, GATE_GPIOE, SECF_NONE),
648 PCLK(GPIOF, "gpiof", "pclk4", 0, GATE_GPIOF, SECF_NONE),
649 PCLK(GPIOG, "gpiog", "pclk4", 0, GATE_GPIOG, SECF_NONE),
650 PCLK(GPIOH, "gpioh", "pclk4", 0, GATE_GPIOH, SECF_NONE),
651 PCLK(GPIOI, "gpioi", "pclk4", 0, GATE_GPIOI, SECF_NONE),
652 PCLK(TSC, "tsc", "pclk4", 0, GATE_TSC, SECF_TZC),
653 PCLK(PKA, "pka", "ck_axi", 0, GATE_PKA, SECF_PKA),
654 PCLK(CRYP1, "cryp1", "ck_axi", 0, GATE_CRYP1, SECF_CRYP1),
655 PCLK(HASH1, "hash1", "ck_axi", 0, GATE_HASH1, SECF_HASH1),
656 PCLK(BKPSRAM, "bkpsram", "ck_axi", 0, GATE_BKPSRAM, SECF_BKPSRAM),
657 PCLK(MDMA, "mdma", "ck_axi", 0, GATE_MDMA, SECF_NONE),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200658#ifndef CONFIG_XPL_BUILD
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100659 PCLK(ETH1TX, "eth1tx", "ck_axi", 0, GATE_ETH1TX, SECF_ETH1TX),
660 PCLK(ETH1RX, "eth1rx", "ck_axi", 0, GATE_ETH1RX, SECF_ETH1RX),
661 PCLK(ETH1MAC, "eth1mac", "ck_axi", 0, GATE_ETH1MAC, SECF_ETH1MAC),
662 PCLK(ETH2TX, "eth2tx", "ck_axi", 0, GATE_ETH2TX, SECF_ETH2TX),
663 PCLK(ETH2RX, "eth2rx", "ck_axi", 0, GATE_ETH2RX, SECF_ETH2RX),
664 PCLK(ETH2MAC, "eth2mac", "ck_axi", 0, GATE_ETH2MAC, SECF_ETH2MAC),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200665#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100666 PCLK(CRC1, "crc1", "ck_axi", 0, GATE_CRC1, SECF_NONE),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200667#ifndef CONFIG_XPL_BUILD
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100668 PCLK(USBH, "usbh", "ck_axi", 0, GATE_USBH, SECF_NONE),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200669#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100670 PCLK(DDRPERFM, "ddrperfm", "pclk4", 0, GATE_DDRPERFM, SECF_NONE),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200671#ifndef CONFIG_XPL_BUILD
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100672 PCLK(ETH1STP, "eth1stp", "ck_axi", 0, GATE_ETH1STP, SECF_ETH1STP),
673 PCLK(ETH2STP, "eth2stp", "ck_axi", 0, GATE_ETH2STP, SECF_ETH2STP),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200674#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100675
676 /* Kernel clocks */
677 KCLK(SDMMC1_K, "sdmmc1_k", 0, GATE_SDMMC1, MUX_SDMMC1, SECF_SDMMC1),
678 KCLK(SDMMC2_K, "sdmmc2_k", 0, GATE_SDMMC2, MUX_SDMMC2, SECF_SDMMC2),
679 KCLK(FMC_K, "fmc_k", 0, GATE_FMC, MUX_FMC, SECF_FMC),
680 KCLK(QSPI_K, "qspi_k", 0, GATE_QSPI, MUX_QSPI, SECF_QSPI),
681 KCLK(SPI2_K, "spi2_k", 0, GATE_SPI2, MUX_SPI23, SECF_NONE),
682 KCLK(SPI3_K, "spi3_k", 0, GATE_SPI3, MUX_SPI23, SECF_NONE),
683 KCLK(I2C1_K, "i2c1_k", 0, GATE_I2C1, MUX_I2C12, SECF_NONE),
684 KCLK(I2C2_K, "i2c2_k", 0, GATE_I2C2, MUX_I2C12, SECF_NONE),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200685#ifndef CONFIG_XPL_BUILD
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100686 KCLK(LPTIM4_K, "lptim4_k", 0, GATE_LPTIM4, MUX_LPTIM45, SECF_NONE),
687 KCLK(LPTIM5_K, "lptim5_k", 0, GATE_LPTIM5, MUX_LPTIM45, SECF_NONE),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200688#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100689 KCLK(USART3_K, "usart3_k", 0, GATE_USART3, MUX_UART35, SECF_NONE),
690 KCLK(UART5_K, "uart5_k", 0, GATE_UART5, MUX_UART35, SECF_NONE),
691 KCLK(UART7_K, "uart7_k", 0, GATE_UART7, MUX_UART78, SECF_NONE),
692 KCLK(UART8_K, "uart8_k", 0, GATE_UART8, MUX_UART78, SECF_NONE),
693 KCLK(RNG1_K, "rng1_k", 0, GATE_RNG1, MUX_RNG1, SECF_RNG1),
694 KCLK(USBPHY_K, "usbphy_k", 0, GATE_USBPHY, MUX_USBPHY, SECF_USBPHY),
695 KCLK(STGEN_K, "stgen_k", 0, GATE_STGENC, MUX_STGEN, SECF_STGENC),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200696#ifndef CONFIG_XPL_BUILD
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100697 KCLK(SPDIF_K, "spdif_k", 0, GATE_SPDIF, MUX_SPDIF, SECF_NONE),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200698#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100699 KCLK(SPI1_K, "spi1_k", 0, GATE_SPI1, MUX_SPI1, SECF_NONE),
700 KCLK(SPI4_K, "spi4_k", 0, GATE_SPI4, MUX_SPI4, SECF_SPI4),
701 KCLK(SPI5_K, "spi5_k", 0, GATE_SPI5, MUX_SPI5, SECF_SPI5),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200702#ifdef CONFIG_TFABOOT
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100703 KCLK(I2C3_K, "i2c3_k", 0, GATE_I2C3, MUX_I2C3, SECF_I2C3),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200704#else
705 KCLK(I2C3_K, "i2c3_k", 0, GATE_I2C3, MUX_I2C3, SECF_NONE),
706#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100707 KCLK(I2C4_K, "i2c4_k", 0, GATE_I2C4, MUX_I2C4, SECF_I2C4),
708 KCLK(I2C5_K, "i2c5_k", 0, GATE_I2C5, MUX_I2C5, SECF_I2C5),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200709#ifndef CONFIG_XPL_BUILD
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100710 KCLK(LPTIM1_K, "lptim1_k", 0, GATE_LPTIM1, MUX_LPTIM1, SECF_NONE),
711 KCLK(LPTIM2_K, "lptim2_k", 0, GATE_LPTIM2, MUX_LPTIM2, SECF_LPTIM2),
712 KCLK(LPTIM3_K, "lptim3_k", 0, GATE_LPTIM3, MUX_LPTIM3, SECF_LPTIM3),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200713#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100714 KCLK(USART1_K, "usart1_k", 0, GATE_USART1, MUX_UART1, SECF_USART1),
715 KCLK(USART2_K, "usart2_k", 0, GATE_USART2, MUX_UART2, SECF_USART2),
716 KCLK(UART4_K, "uart4_k", 0, GATE_UART4, MUX_UART4, SECF_NONE),
717 KCLK(USART6_K, "uart6_k", 0, GATE_USART6, MUX_UART6, SECF_NONE),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200718#ifndef CONFIG_XPL_BUILD
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100719 KCLK(FDCAN_K, "fdcan_k", 0, GATE_FDCAN, MUX_FDCAN, SECF_NONE),
720 KCLK(SAI1_K, "sai1_k", 0, GATE_SAI1, MUX_SAI1, SECF_NONE),
721 KCLK(SAI2_K, "sai2_k", 0, GATE_SAI2, MUX_SAI2, SECF_NONE),
722 KCLK(ADC1_K, "adc1_k", 0, GATE_ADC1, MUX_ADC1, SECF_ADC1),
723 KCLK(ADC2_K, "adc2_k", 0, GATE_ADC2, MUX_ADC2, SECF_ADC2),
724 KCLK(DCMIPP_K, "dcmipp_k", 0, GATE_DCMIPP, MUX_DCMIPP, SECF_DCMIPP),
725 KCLK(ADFSDM_K, "adfsdm_k", 0, GATE_ADFSDM, MUX_SAI1, SECF_NONE),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200726#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100727 KCLK(USBO_K, "usbo_k", 0, GATE_USBO, MUX_USBO, SECF_USBO),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200728#ifndef CONFIG_XPL_BUILD
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100729 KCLK(ETH1CK_K, "eth1ck_k", 0, GATE_ETH1CK, MUX_ETH1, SECF_ETH1CK),
730 KCLK(ETH2CK_K, "eth2ck_k", 0, GATE_ETH2CK, MUX_ETH2, SECF_ETH2CK),
731 KCLK(SAES_K, "saes_k", 0, GATE_SAES, MUX_SAES, SECF_SAES),
732
733 STM32_GATE(DFSDM_K, "dfsdm_k", "ck_mlahb", 0, GATE_DFSDM, SECF_NONE),
734 STM32_GATE(LTDC_PX, "ltdc_px", "pll4_q", CLK_SET_RATE_PARENT,
735 GATE_LTDC, SECF_NONE),
736
737 STM32_GATE(DTS_K, "dts_k", "ck_lse", 0, GATE_DTS, SECF_NONE),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200738#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100739
740 STM32_COMPOSITE(ETH1PTP_K, "eth1ptp_k", CLK_OPS_PARENT_ENABLE |
741 CLK_SET_RATE_NO_REPARENT, SECF_ETH1CK,
742 NO_STM32_GATE, MUX_ETH1, DIV_ETH1PTP),
743
744 STM32_COMPOSITE(ETH2PTP_K, "eth2ptp_k", CLK_OPS_PARENT_ENABLE |
745 CLK_SET_RATE_NO_REPARENT, SECF_ETH2CK,
746 NO_STM32_GATE, MUX_ETH2, DIV_ETH2PTP),
747
748 /* MCO clocks */
749 STM32_COMPOSITE(CK_MCO1, "ck_mco1", CLK_OPS_PARENT_ENABLE |
750 CLK_SET_RATE_NO_REPARENT, SECF_MCO1,
751 GATE_MCO1, MUX_MCO1, DIV_MCO1),
752
753 STM32_COMPOSITE(CK_MCO2, "ck_mco2", CLK_OPS_PARENT_ENABLE |
754 CLK_SET_RATE_NO_REPARENT, SECF_MCO2,
755 GATE_MCO2, MUX_MCO2, DIV_MCO2),
756
757 /* Debug clocks */
758 STM32_GATE(CK_DBG, "ck_sys_dbg", "ck_axi", CLK_IGNORE_UNUSED,
759 GATE_DBGCK, SECF_NONE),
760
761 STM32_COMPOSITE_NOMUX(CK_TRACE, "ck_trace", "ck_axi",
762 CLK_OPS_PARENT_ENABLE, SECF_NONE,
763 GATE_TRACECK, DIV_TRACE),
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200764
765#ifdef CONFIG_XPL_BUILD
766 STM32_GATE(AXIDCG, "axidcg", "ck_axi", CLK_IGNORE_UNUSED,
767 GATE_AXIDCG, SECF_NONE),
768 STM32_GATE(DDRC1, "ddrc1", "ck_axi", CLK_IGNORE_UNUSED,
769 GATE_DDRC1, SECF_NONE),
770 STM32_GATE(DDRPHYC, "ddrphyc", "pll2_r", CLK_IGNORE_UNUSED,
771 GATE_DDRPHYC, SECF_NONE),
772 STM32_GATE(DDRCAPB, "ddrcapb", "pclk4", CLK_IGNORE_UNUSED,
773 GATE_DDRCAPB, SECF_NONE),
774 STM32_GATE(DDRPHYCAPB, "ddrphycapb", "pclk4", CLK_IGNORE_UNUSED,
775 GATE_DDRPHYCAPB, SECF_NONE),
776#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100777};
778
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200779#ifdef CONFIG_TFABOOT
Gabriel Fernandez299487c2025-05-27 15:27:45 +0200780static int stm32mp13_check_security(struct udevice *dev, void __iomem *base,
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100781 const struct clock_config *cfg)
782{
783 int sec_id = cfg->sec_id;
784 int secured = 0;
785
786 if (sec_id != SECF_NONE) {
Marek Vasutd20eb392025-05-12 18:51:33 +0200787 const struct clk_stm32_security *secf;
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100788
789 secf = &stm32mp13_security[sec_id];
790 secured = !!(readl(base + secf->offset) & BIT(secf->bit_idx));
791 }
792
793 return secured;
794}
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200795#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100796
797static const struct stm32_clock_match_data stm32mp13_data = {
798 .tab_clocks = stm32mp13_clock_cfg,
799 .num_clocks = ARRAY_SIZE(stm32mp13_clock_cfg),
800 .clock_data = &(const struct clk_stm32_clock_data) {
801 .num_gates = ARRAY_SIZE(stm32mp13_gates),
802 .gates = stm32mp13_gates,
803 .muxes = stm32mp13_muxes,
804 .dividers = stm32mp13_dividers,
805 },
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200806#ifdef CONFIG_TFABOOT
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100807 .check_security = stm32mp13_check_security,
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200808#endif
809};
810
811#ifndef CONFIG_TFABOOT
812
813enum stm32mp1_parent_id {
814/*
815 * _HSI, _HSE, _CSI, _LSI, _LSE should not be moved
816 * they are used as index in osc_clk[] as clock reference
817 */
818 _HSI,
819 _HSE,
820 _CSI,
821 _LSI,
822 _LSE,
823 _I2S_CKIN,
824 NB_OSC,
825
826/* other parent source */
827 _HSI_KER = NB_OSC,
828 _HSE_KER,
829 _HSE_KER_DIV2,
830 _CSI_KER,
831 _PLL1_P,
832 _PLL1_Q,
833 _PLL1_R,
834 _PLL2_P,
835 _PLL2_Q,
836 _PLL2_R,
837 _PLL3_P,
838 _PLL3_Q,
839 _PLL3_R,
840 _PLL4_P,
841 _PLL4_Q,
842 _PLL4_R,
843 _ACLK,
844 _PCLK1,
845 _PCLK2,
846 _PCLK3,
847 _PCLK4,
848 _PCLK5,
849 _HCLK6,
850 _HCLK2,
851 _CK_PER,
852 _CK_MPU,
853 _CK_MCU,
854 _DSI_PHY,
855 _USB_PHY_48,
856 _PARENT_NB,
857 _UNKNOWN_ID = 0xff,
Gabriel Fernandez3db088a2022-11-24 11:36:04 +0100858};
859
Marek Vasut0b44b9c2025-05-12 19:08:29 +0200860#if defined(CONFIG_XPL_BUILD)
861
862#define MAX_HSI_HZ 64000000
863
864/* TIMEOUT */
865#define TIMEOUT_200MS 200000
866#define TIMEOUT_1S 1000000
867
868/* STGEN registers */
869#define STGENC_CNTCR 0x00
870#define STGENC_CNTSR 0x04
871#define STGENC_CNTCVL 0x08
872#define STGENC_CNTCVU 0x0C
873#define STGENC_CNTFID0 0x20
874
875#define STGENC_CNTCR_EN BIT(0)
876
877enum stm32mp1_clksrc_id {
878 CLKSRC_MPU,
879 CLKSRC_AXI,
880 CLKSRC_MLAHB,
881 CLKSRC_PLL12,
882 CLKSRC_PLL3,
883 CLKSRC_PLL4,
884 CLKSRC_RTC,
885 CLKSRC_MCO1,
886 CLKSRC_MCO2,
887 CLKSRC_NB
888};
889
890enum stm32mp1_clkdiv_id {
891 CLKDIV_AXI,
892 CLKDIV_MLAHB,
893 CLKDIV_APB1,
894 CLKDIV_APB2,
895 CLKDIV_APB3,
896 CLKDIV_APB4,
897 CLKDIV_APB5,
898 CLKDIV_APB6,
899 CLKDIV_RTC,
900 CLKDIV_NB
901};
902
903enum stm32mp1_pll_id {
904 _PLL1,
905 _PLL2,
906 _PLL3,
907 _PLL4,
908 _PLL_NB
909};
910
911enum stm32mp1_div_id {
912 _DIV_P,
913 _DIV_Q,
914 _DIV_R,
915 _DIV_NB,
916};
917
918/* define characteristic of PLL according type */
919#define DIVM_MIN 1
920#define DIVM_MAX 63
921#define DIVN_MIN 24
922#define DIVP_MIN 0
923#define DIVP_MAX 127
924#define FRAC_MAX 8192
925
926#define PLL2000_VCO_MIN 992000000
927#define PLL2000_VCO_MAX 2000000000
928
929enum stm32mp1_pllcfg {
930 PLLCFG_M,
931 PLLCFG_N,
932 PLLCFG_P,
933 PLLCFG_Q,
934 PLLCFG_R,
935 PLLCFG_O,
936 PLLCFG_NB
937};
938
939enum stm32mp1_pllcsg {
940 PLLCSG_MOD_PER,
941 PLLCSG_INC_STEP,
942 PLLCSG_SSCG_MODE,
943 PLLCSG_NB
944};
945
946enum stm32mp1_plltype {
947 PLL_800,
948 PLL_1600,
949 PLL_2000,
950 PLL_TYPE_NB
951};
952
953struct stm32mp1_pll {
954 u8 refclk_min;
955 u8 refclk_max;
956 u8 divn_max;
957};
958
959#define REFCLK_SIZE 4
960struct stm32mp1_clk_pll {
961 enum stm32mp1_plltype plltype;
962 u16 rckxselr;
963 u16 pllxcfgr1;
964 u16 pllxcfgr2;
965 u16 pllxfracr;
966 u16 pllxcr;
967 u16 pllxcsgr;
968 u8 refclk[REFCLK_SIZE];
969};
970
971static const struct stm32mp1_pll stm32mp1_pll[PLL_TYPE_NB] = {
972 [PLL_800] = {
973 .refclk_min = 4,
974 .refclk_max = 16,
975 .divn_max = 99,
976 },
977 [PLL_1600] = {
978 .refclk_min = 8,
979 .refclk_max = 16,
980 .divn_max = 199,
981 },
982 [PLL_2000] = {
983 .refclk_min = 8,
984 .refclk_max = 16,
985 .divn_max = 99,
986 },
987};
988
989#define STM32MP1_CLK_PLL(idx, type, off1, off2, off3, off4, off5, off6,\
990 p1, p2, p3, p4) \
991 [(idx)] = { \
992 .plltype = (type), \
993 .rckxselr = (off1), \
994 .pllxcfgr1 = (off2), \
995 .pllxcfgr2 = (off3), \
996 .pllxfracr = (off4), \
997 .pllxcr = (off5), \
998 .pllxcsgr = (off6), \
999 .refclk[0] = (p1), \
1000 .refclk[1] = (p2), \
1001 .refclk[2] = (p3), \
1002 .refclk[3] = (p4), \
1003 }
1004
1005static const struct stm32mp1_clk_pll stm32mp1_clk_pll[_PLL_NB] = {
1006 STM32MP1_CLK_PLL(_PLL1, PLL_2000,
1007 RCC_RCK12SELR, RCC_PLL1CFGR1, RCC_PLL1CFGR2,
1008 RCC_PLL1FRACR, RCC_PLL1CR, RCC_PLL1CSGR,
1009 _HSI, _HSE, _UNKNOWN_ID, _UNKNOWN_ID),
1010 STM32MP1_CLK_PLL(_PLL2, PLL_1600,
1011 RCC_RCK12SELR, RCC_PLL2CFGR1, RCC_PLL2CFGR2,
1012 RCC_PLL2FRACR, RCC_PLL2CR, RCC_PLL2CSGR,
1013 _HSI, _HSE, _UNKNOWN_ID, _UNKNOWN_ID),
1014 STM32MP1_CLK_PLL(_PLL3, PLL_800,
1015 RCC_RCK3SELR, RCC_PLL3CFGR1, RCC_PLL3CFGR2,
1016 RCC_PLL3FRACR, RCC_PLL3CR, RCC_PLL3CSGR,
1017 _HSI, _HSE, _CSI, _UNKNOWN_ID),
1018 STM32MP1_CLK_PLL(_PLL4, PLL_800,
1019 RCC_RCK4SELR, RCC_PLL4CFGR1, RCC_PLL4CFGR2,
1020 RCC_PLL4FRACR, RCC_PLL4CR, RCC_PLL4CSGR,
1021 _HSI, _HSE, _CSI, _I2S_CKIN),
1022};
1023
1024static ulong stm32mp1_clk_get_fixed(struct stm32mp_rcc_priv *priv, int idx)
1025{
1026 if (idx >= NB_OSC) {
1027 log_debug("clk id %d not found\n", idx);
1028 return 0;
1029 }
1030
1031 return clk_get_rate(&priv->osc_clk[idx]);
1032}
1033
1034bool stm32mp1_supports_opp(u32 opp_id, u32 cpu_type)
1035{
1036 /* 650 MHz is always supported */
1037 if (opp_id == 1)
1038 return true;
1039
1040 /*
1041 * 1000 MHz is supported on STM32MP13xDxx and STM32MP13xFxx,
1042 * which all have bit 11 i.e. 0x800 set in CPU ID.
1043 */
1044 if (opp_id == 2)
1045 return !!(cpu_type & BIT(11));
1046
1047 /* Any other OPP is invalid. */
1048 return false;
1049}
1050
1051__weak void board_vddcore_init(u32 voltage_mv)
1052{
1053}
1054
1055/*
1056 * gets OPP parameters (frequency in KHz and voltage in mV) from
1057 * an OPP table subnode. Platform HW support capabilities are also checked.
1058 * Returns 0 on success and a negative FDT error code on failure.
1059 */
1060static int stm32mp1_get_opp(u32 cpu_type, ofnode subnode,
1061 u32 *freq_khz, u32 *voltage_mv)
1062{
1063 u32 opp_hw;
1064 u64 read_freq_64;
1065 u32 read_voltage_32;
1066
1067 *freq_khz = 0;
1068 *voltage_mv = 0;
1069
1070 opp_hw = ofnode_read_u32_default(subnode, "opp-supported-hw", 0);
1071 if (opp_hw)
1072 if (!stm32mp1_supports_opp(opp_hw, cpu_type))
1073 return -FDT_ERR_BADVALUE;
1074
1075 read_freq_64 = ofnode_read_u64_default(subnode, "opp-hz", 0) /
1076 1000ULL;
1077 read_voltage_32 = ofnode_read_u32_default(subnode, "opp-microvolt", 0) /
1078 1000U;
1079
1080 if (!read_voltage_32 || !read_freq_64)
1081 return -FDT_ERR_NOTFOUND;
1082
1083 /* Frequency value expressed in KHz must fit on 32 bits */
1084 if (read_freq_64 > U32_MAX)
1085 return -FDT_ERR_BADVALUE;
1086
1087 /* Millivolt value must fit on 16 bits */
1088 if (read_voltage_32 > U16_MAX)
1089 return -FDT_ERR_BADVALUE;
1090
1091 *freq_khz = (u32)read_freq_64;
1092 *voltage_mv = read_voltage_32;
1093
1094 return 0;
1095}
1096
1097/*
1098 * parses OPP table in DT and finds the parameters for the
1099 * highest frequency supported by the HW platform.
1100 * Returns 0 on success and a negative FDT error code on failure.
1101 */
1102int stm32mp1_get_max_opp_freq(struct stm32mp_rcc_priv *priv, u64 *freq_hz)
1103{
1104 ofnode node, subnode;
1105 int ret;
1106 u32 freq = 0U, voltage = 0U;
1107 u32 cpu_type = get_cpu_type();
1108
1109 node = ofnode_by_compatible(ofnode_null(), "operating-points-v2");
1110 if (!ofnode_valid(node))
1111 return -FDT_ERR_NOTFOUND;
1112
1113 ofnode_for_each_subnode(subnode, node) {
1114 unsigned int read_freq;
1115 unsigned int read_voltage;
1116
1117 ret = stm32mp1_get_opp(cpu_type, subnode,
1118 &read_freq, &read_voltage);
1119 if (ret)
1120 continue;
1121
1122 if (read_freq > freq) {
1123 freq = read_freq;
1124 voltage = read_voltage;
1125 }
1126 }
1127
1128 if (!freq || !voltage)
1129 return -FDT_ERR_NOTFOUND;
1130
1131 *freq_hz = (u64)1000U * freq;
1132 board_vddcore_init(voltage);
1133
1134 return 0;
1135}
1136
1137static int stm32mp1_pll1_opp(struct stm32mp_rcc_priv *priv, int clksrc,
1138 u32 *pllcfg, u32 *fracv)
1139{
1140 u32 post_divm;
1141 u32 input_freq;
1142 u64 output_freq;
1143 u64 freq;
1144 u64 vco;
1145 u32 divm, divn, divp, frac;
1146 int i, ret;
1147 u32 diff;
1148 u32 best_diff = U32_MAX;
1149
1150 /* PLL1 is 2000 */
1151 const u32 DIVN_MAX = stm32mp1_pll[PLL_2000].divn_max;
1152 const u32 POST_DIVM_MIN = stm32mp1_pll[PLL_2000].refclk_min * 1000000U;
1153 const u32 POST_DIVM_MAX = stm32mp1_pll[PLL_2000].refclk_max * 1000000U;
1154
1155 ret = stm32mp1_get_max_opp_freq(priv, &output_freq);
1156 if (ret) {
1157 log_debug("PLL1 OPP configuration not found (%d).\n", ret);
1158 return ret;
1159 }
1160
1161 switch (clksrc) {
1162 case CLK_PLL12_HSI:
1163 input_freq = stm32mp1_clk_get_fixed(priv, _HSI);
1164 break;
1165 case CLK_PLL12_HSE:
1166 input_freq = stm32mp1_clk_get_fixed(priv, _HSE);
1167 break;
1168 default:
1169 return -EINTR;
1170 }
1171
1172 /* Following parameters have always the same value */
1173 pllcfg[PLLCFG_Q] = 0;
1174 pllcfg[PLLCFG_R] = 0;
1175 pllcfg[PLLCFG_O] = PQR(1, 1, 1);
1176
1177 for (divm = DIVM_MAX; divm >= DIVM_MIN; divm--) {
1178 post_divm = (u32)(input_freq / (divm + 1));
1179 if (post_divm < POST_DIVM_MIN || post_divm > POST_DIVM_MAX)
1180 continue;
1181
1182 for (divp = DIVP_MIN; divp <= DIVP_MAX; divp++) {
1183 freq = output_freq * (divm + 1) * (divp + 1);
1184 divn = (u32)((freq / input_freq) - 1);
1185 if (divn < DIVN_MIN || divn > DIVN_MAX)
1186 continue;
1187
1188 frac = (u32)(((freq * FRAC_MAX) / input_freq) -
1189 ((divn + 1) * FRAC_MAX));
1190 /* 2 loops to refine the fractional part */
1191 for (i = 2; i != 0; i--) {
1192 if (frac > FRAC_MAX)
1193 break;
1194
1195 vco = (post_divm * (divn + 1)) +
1196 ((post_divm * (u64)frac) /
1197 FRAC_MAX);
1198 if (vco < (PLL2000_VCO_MIN / 2) ||
1199 vco > (PLL2000_VCO_MAX / 2)) {
1200 frac++;
1201 continue;
1202 }
1203 freq = vco / (divp + 1);
1204 if (output_freq < freq)
1205 diff = (u32)(freq - output_freq);
1206 else
1207 diff = (u32)(output_freq - freq);
1208 if (diff < best_diff) {
1209 pllcfg[PLLCFG_M] = divm;
1210 pllcfg[PLLCFG_N] = divn;
1211 pllcfg[PLLCFG_P] = divp;
1212 *fracv = frac;
1213
1214 if (diff == 0) {
1215 return 0;
1216 }
1217
1218 best_diff = diff;
1219 }
1220 frac++;
1221 }
1222 }
1223 }
1224
1225 if (best_diff == U32_MAX)
1226 return -1;
1227
1228 return 0;
1229}
1230
1231static void stm32mp1_ls_osc_set(int enable, fdt_addr_t rcc, u32 offset,
1232 u32 mask_on)
1233{
1234 u32 address = rcc + offset;
1235
1236 if (enable)
1237 setbits_le32(address, mask_on);
1238 else
1239 clrbits_le32(address, mask_on);
1240}
1241
1242static void stm32mp1_hs_ocs_set(int enable, fdt_addr_t rcc, u32 mask_on)
1243{
1244 writel(mask_on, rcc + (enable ? RCC_OCENSETR : RCC_OCENCLRR));
1245}
1246
1247static int stm32mp1_osc_wait(int enable, fdt_addr_t rcc, u32 offset,
1248 u32 mask_rdy)
1249{
1250 u32 mask_test = 0;
1251 u32 address = rcc + offset;
1252 u32 val;
1253 int ret;
1254
1255 if (enable)
1256 mask_test = mask_rdy;
1257
1258 ret = readl_poll_timeout(address, val,
1259 (val & mask_rdy) == mask_test,
1260 TIMEOUT_1S);
1261
1262 if (ret)
1263 log_err("OSC %x @ %x timeout for enable=%d : 0x%x\n",
1264 mask_rdy, address, enable, readl(address));
1265
1266 return ret;
1267}
1268
1269static void stm32mp1_lse_enable(fdt_addr_t rcc, int bypass, int digbyp,
1270 u32 lsedrv)
1271{
1272 u32 value;
1273
1274 if (digbyp)
1275 setbits_le32(rcc + RCC_BDCR, RCC_BDCR_DIGBYP);
1276
1277 if (bypass || digbyp)
1278 setbits_le32(rcc + RCC_BDCR, RCC_BDCR_LSEBYP);
1279
1280 /*
1281 * warning: not recommended to switch directly from "high drive"
1282 * to "medium low drive", and vice-versa.
1283 */
1284 value = (readl(rcc + RCC_BDCR) & RCC_BDCR_LSEDRV_MASK)
1285 >> RCC_BDCR_LSEDRV_SHIFT;
1286
1287 while (value != lsedrv) {
1288 if (value > lsedrv)
1289 value--;
1290 else
1291 value++;
1292
1293 clrsetbits_le32(rcc + RCC_BDCR,
1294 RCC_BDCR_LSEDRV_MASK,
1295 value << RCC_BDCR_LSEDRV_SHIFT);
1296 }
1297
1298 stm32mp1_ls_osc_set(1, rcc, RCC_BDCR, RCC_BDCR_LSEON);
1299}
1300
1301static void stm32mp1_lse_wait(fdt_addr_t rcc)
1302{
1303 stm32mp1_osc_wait(1, rcc, RCC_BDCR, RCC_BDCR_LSERDY);
1304}
1305
1306static void stm32mp1_lsi_set(fdt_addr_t rcc, int enable)
1307{
1308 stm32mp1_ls_osc_set(enable, rcc, RCC_RDLSICR, RCC_RDLSICR_LSION);
1309 stm32mp1_osc_wait(enable, rcc, RCC_RDLSICR, RCC_RDLSICR_LSIRDY);
1310}
1311
1312static void stm32mp1_hse_enable(fdt_addr_t rcc, int bypass, int digbyp, int css)
1313{
1314 if (digbyp)
1315 writel(RCC_OCENR_DIGBYP, rcc + RCC_OCENSETR);
1316 if (bypass || digbyp)
1317 writel(RCC_OCENR_HSEBYP, rcc + RCC_OCENSETR);
1318
1319 stm32mp1_hs_ocs_set(1, rcc, RCC_OCENR_HSEON);
1320 stm32mp1_osc_wait(1, rcc, RCC_OCRDYR, RCC_OCRDYR_HSERDY);
1321
1322 if (css)
1323 writel(RCC_OCENR_HSECSSON, rcc + RCC_OCENSETR);
1324}
1325
1326static void stm32mp1_csi_set(fdt_addr_t rcc, int enable)
1327{
1328 stm32mp1_hs_ocs_set(enable, rcc, RCC_OCENR_CSION);
1329 stm32mp1_osc_wait(enable, rcc, RCC_OCRDYR, RCC_OCRDYR_CSIRDY);
1330}
1331
1332static void stm32mp1_hsi_set(fdt_addr_t rcc, int enable)
1333{
1334 stm32mp1_hs_ocs_set(enable, rcc, RCC_OCENR_HSION);
1335 stm32mp1_osc_wait(enable, rcc, RCC_OCRDYR, RCC_OCRDYR_HSIRDY);
1336}
1337
1338static int stm32mp1_set_hsidiv(fdt_addr_t rcc, u8 hsidiv)
1339{
1340 u32 address = rcc + RCC_OCRDYR;
1341 u32 val;
1342 int ret;
1343
1344 clrsetbits_le32(rcc + RCC_HSICFGR,
1345 RCC_HSICFGR_HSIDIV_MASK,
1346 RCC_HSICFGR_HSIDIV_MASK & hsidiv);
1347
1348 ret = readl_poll_timeout(address, val,
1349 val & RCC_OCRDYR_HSIDIVRDY,
1350 TIMEOUT_200MS);
1351 if (ret)
1352 log_err("HSIDIV failed @ 0x%x: 0x%x\n",
1353 address, readl(address));
1354
1355 return ret;
1356}
1357
1358static int stm32mp1_hsidiv(fdt_addr_t rcc, ulong hsifreq)
1359{
1360 u8 hsidiv;
1361 u32 hsidivfreq = MAX_HSI_HZ;
1362
1363 for (hsidiv = 0; hsidiv < 4; hsidiv++,
1364 hsidivfreq = hsidivfreq / 2)
1365 if (hsidivfreq == hsifreq)
1366 break;
1367
1368 if (hsidiv == 4) {
1369 log_err("hsi frequency invalid");
1370 return -1;
1371 }
1372
1373 if (hsidiv > 0)
1374 return stm32mp1_set_hsidiv(rcc, hsidiv);
1375
1376 return 0;
1377}
1378
1379static void pll_start(struct stm32mp_rcc_priv *priv, int pll_id)
1380{
1381 clrsetbits_le32((u32)(priv->base) + stm32mp1_clk_pll[pll_id].pllxcr,
1382 RCC_PLLNCR_DIVPEN | RCC_PLLNCR_DIVQEN |
1383 RCC_PLLNCR_DIVREN,
1384 RCC_PLLNCR_PLLON);
1385}
1386
1387static int pll_output(struct stm32mp_rcc_priv *priv, int pll_id, int output)
1388{
1389 u32 pllxcr = (u32)(priv->base) + stm32mp1_clk_pll[pll_id].pllxcr;
1390 u32 val;
1391 int ret;
1392
1393 ret = readl_poll_timeout(pllxcr, val, val & RCC_PLLNCR_PLLRDY,
1394 TIMEOUT_200MS);
1395
1396 if (ret) {
1397 log_err("PLL%d start failed @ 0x%x: 0x%x\n",
1398 pll_id, pllxcr, readl(pllxcr));
1399 return ret;
1400 }
1401
1402 /* start the requested output */
1403 setbits_le32(pllxcr, output << RCC_PLLNCR_DIVEN_SHIFT);
1404
1405 return 0;
1406}
1407
1408static int pll_stop(struct stm32mp_rcc_priv *priv, int pll_id)
1409{
1410 u32 pllxcr = (u32)(priv->base) + stm32mp1_clk_pll[pll_id].pllxcr;
1411 u32 val;
1412
1413 /* stop all output */
1414 clrbits_le32(pllxcr,
1415 RCC_PLLNCR_DIVPEN | RCC_PLLNCR_DIVQEN | RCC_PLLNCR_DIVREN);
1416
1417 /* stop PLL */
1418 clrbits_le32(pllxcr, RCC_PLLNCR_PLLON);
1419
1420 /* wait PLL stopped */
1421 return readl_poll_timeout(pllxcr, val, (val & RCC_PLLNCR_PLLRDY) == 0,
1422 TIMEOUT_200MS);
1423}
1424
1425static void pll_config_output(struct stm32mp_rcc_priv *priv,
1426 int pll_id, u32 *pllcfg)
1427{
1428 fdt_addr_t rcc = (u32)(priv->base);
1429 u32 value;
1430
1431 value = (pllcfg[PLLCFG_P] << RCC_PLLNCFGR2_DIVP_SHIFT)
1432 & RCC_PLLNCFGR2_DIVP_MASK;
1433 value |= (pllcfg[PLLCFG_Q] << RCC_PLLNCFGR2_DIVQ_SHIFT)
1434 & RCC_PLLNCFGR2_DIVQ_MASK;
1435 value |= (pllcfg[PLLCFG_R] << RCC_PLLNCFGR2_DIVR_SHIFT)
1436 & RCC_PLLNCFGR2_DIVR_MASK;
1437 writel(value, rcc + stm32mp1_clk_pll[pll_id].pllxcfgr2);
1438}
1439
1440static int pll_config(struct stm32mp_rcc_priv *priv, int pll_id,
1441 u32 *pllcfg, u32 fracv)
1442{
1443 fdt_addr_t rcc = (u32)(priv->base);
1444 enum stm32mp1_plltype type = stm32mp1_clk_pll[pll_id].plltype;
1445 int src;
1446 ulong refclk;
1447 u8 ifrge = 0;
1448 u32 value;
1449
1450 src = readl((u32)(priv->base) + stm32mp1_clk_pll[pll_id].rckxselr) & RCC_SELR_SRC_MASK;
1451 refclk = stm32mp1_clk_get_fixed(priv, stm32mp1_clk_pll[pll_id].refclk[src]) /
1452 (pllcfg[PLLCFG_M] + 1);
1453
1454 if (refclk < (stm32mp1_pll[type].refclk_min * 1000000) ||
1455 refclk > (stm32mp1_pll[type].refclk_max * 1000000)) {
1456 log_err("invalid refclk = %x\n", (u32)refclk);
1457 return -EINVAL;
1458 }
1459
1460
1461 if (type == PLL_800 && refclk >= 8000000)
1462 ifrge = 1;
1463
1464 value = (pllcfg[PLLCFG_N] << RCC_PLLNCFGR1_DIVN_SHIFT)
1465 & RCC_PLLNCFGR1_DIVN_MASK;
1466 value |= (pllcfg[PLLCFG_M] << RCC_PLLNCFGR1_DIVM_SHIFT)
1467 & RCC_PLLNCFGR1_DIVM_MASK;
1468 value |= (ifrge << RCC_PLLNCFGR1_IFRGE_SHIFT)
1469 & RCC_PLLNCFGR1_IFRGE_MASK;
1470 writel(value, rcc + stm32mp1_clk_pll[pll_id].pllxcfgr1);
1471
1472 /* fractional configuration: load sigma-delta modulator (SDM) */
1473
1474 /* Write into FRACV the new fractional value , and FRACLE to 0 */
1475 writel(fracv << RCC_PLLNFRACR_FRACV_SHIFT,
1476 rcc + stm32mp1_clk_pll[pll_id].pllxfracr);
1477
1478 /* Write FRACLE to 1 : FRACV value is loaded into the SDM */
1479 setbits_le32(rcc + stm32mp1_clk_pll[pll_id].pllxfracr,
1480 RCC_PLLNFRACR_FRACLE);
1481
1482 pll_config_output(priv, pll_id, pllcfg);
1483
1484 return 0;
1485}
1486
1487static void pll_csg(struct stm32mp_rcc_priv *priv, int pll_id, u32 *csg)
1488{
1489 u32 pllxcsg;
1490
1491 pllxcsg = ((csg[PLLCSG_MOD_PER] << RCC_PLLNCSGR_MOD_PER_SHIFT) &
1492 RCC_PLLNCSGR_MOD_PER_MASK) |
1493 ((csg[PLLCSG_INC_STEP] << RCC_PLLNCSGR_INC_STEP_SHIFT) &
1494 RCC_PLLNCSGR_INC_STEP_MASK) |
1495 ((csg[PLLCSG_SSCG_MODE] << RCC_PLLNCSGR_SSCG_MODE_SHIFT) &
1496 RCC_PLLNCSGR_SSCG_MODE_MASK);
1497
1498 writel(pllxcsg, (u32)(priv->base) + stm32mp1_clk_pll[pll_id].pllxcsgr);
1499
1500 setbits_le32((u32)(priv->base) + stm32mp1_clk_pll[pll_id].pllxcr, RCC_PLLNCR_SSCG_CTRL);
1501}
1502
1503static ulong pll_get_fref_ck(struct stm32mp_rcc_priv *priv,
1504 int pll_id)
1505{
1506 u32 selr;
1507 int src;
1508
1509 /* Get current refclk */
1510 selr = readl(priv->base + stm32mp1_clk_pll[pll_id].rckxselr);
1511 src = selr & RCC_SELR_SRC_MASK;
1512
1513 return stm32mp1_clk_get_fixed(priv, stm32mp1_clk_pll[pll_id].refclk[src]);
1514}
1515
1516static __maybe_unused int pll_set_rate(struct udevice *dev,
1517 int pll_id,
1518 int div_id,
1519 unsigned long clk_rate)
1520{
1521 struct stm32mp_rcc_priv *priv = dev_get_priv(dev);
1522 unsigned int pllcfg[PLLCFG_NB];
1523 ofnode plloff;
1524 char name[12];
1525 enum stm32mp1_plltype type = stm32mp1_clk_pll[pll_id].plltype;
1526 int divm, divn, divy;
1527 int ret;
1528 ulong fck_ref;
1529 u32 fracv;
1530 u64 value;
1531
1532 if (div_id > _DIV_NB)
1533 return -EINVAL;
1534
1535 sprintf(name, "st,pll@%d", pll_id);
1536 plloff = dev_read_subnode(dev, name);
1537 if (!ofnode_valid(plloff))
1538 return -FDT_ERR_NOTFOUND;
1539
1540 ret = ofnode_read_u32_array(plloff, "cfg",
1541 pllcfg, PLLCFG_NB);
1542 if (ret < 0)
1543 return -FDT_ERR_NOTFOUND;
1544
1545 fck_ref = pll_get_fref_ck(priv, pll_id);
1546
1547 divm = pllcfg[PLLCFG_M];
1548 /* select output divider = 0: for _DIV_P, 1:_DIV_Q 2:_DIV_R */
1549 divy = pllcfg[PLLCFG_P + div_id];
1550
1551 /* For: PLL1 & PLL2 => VCO is * 2 but ck_pll_y is also / 2
1552 * So same final result than PLL2 et 4
1553 * with FRACV
1554 * Fck_pll_y = Fck_ref * ((DIVN + 1) + FRACV / 2^13)
1555 * / (DIVy + 1) * (DIVM + 1)
1556 * value = (DIVN + 1) * 2^13 + FRACV / 2^13
1557 * = Fck_pll_y (DIVy + 1) * (DIVM + 1) * 2^13 / Fck_ref
1558 */
1559 value = ((u64)clk_rate * (divy + 1) * (divm + 1)) << 13;
1560 value = lldiv(value, fck_ref);
1561
1562 divn = (value >> 13) - 1;
1563 if (divn < DIVN_MIN ||
1564 divn > stm32mp1_pll[type].divn_max) {
1565 dev_err(dev, "divn invalid = %d", divn);
1566 return -EINVAL;
1567 }
1568 fracv = value - ((divn + 1) << 13);
1569 pllcfg[PLLCFG_N] = divn;
1570
1571 /* reconfigure PLL */
1572 pll_stop(priv, pll_id);
1573 pll_config(priv, pll_id, pllcfg, fracv);
1574 pll_start(priv, pll_id);
1575 pll_output(priv, pll_id, pllcfg[PLLCFG_O]);
1576
1577 return 0;
1578}
1579
1580static int set_clksrc(struct stm32mp_rcc_priv *priv, unsigned int clksrc)
1581{
1582 u32 address = (u32)(priv->base);
1583 u32 mux = (clksrc & MUX_ID_MASK) >> MUX_ID_SHIFT;
1584 u32 val;
1585 int ret;
1586
1587 /* List of relevant muxes to keep the size down */
1588 if (mux == MUX_PLL12)
1589 address += RCC_RCK12SELR;
1590 else if (mux == MUX_PLL3)
1591 address += RCC_RCK3SELR;
1592 else if (mux == MUX_PLL4)
1593 address += RCC_RCK4SELR;
1594 else if (mux == MUX_MPU)
1595 address += RCC_MPCKSELR;
1596 else if (mux == MUX_AXI)
1597 address += RCC_ASSCKSELR;
1598 else if (mux == MUX_MLAHB)
1599 address += RCC_MSSCKSELR;
1600 else if (mux == MUX_CKPER)
1601 address += RCC_CPERCKSELR;
1602 else
1603 return -EINVAL;
1604
1605 clrsetbits_le32(address, RCC_SELR_SRC_MASK, clksrc & RCC_SELR_SRC_MASK);
1606 ret = readl_poll_timeout(address, val, val & RCC_SELR_SRCRDY,
1607 TIMEOUT_200MS);
1608 if (ret)
1609 log_err("CLKSRC %x start failed @ 0x%x: 0x%x\n",
1610 clksrc, address, readl(address));
1611
1612 return ret;
1613}
1614
1615static void stgen_config(struct stm32mp_rcc_priv *priv)
1616{
1617 u32 stgenc, cntfid0;
1618 ulong rate = clk_get_rate(&priv->osc_clk[_HSI]);
1619 stgenc = STM32_STGEN_BASE;
1620 cntfid0 = readl(stgenc + STGENC_CNTFID0);
1621
1622 if (cntfid0 != rate) {
1623 u64 counter;
1624
1625 log_debug("System Generic Counter (STGEN) update\n");
1626 clrbits_le32(stgenc + STGENC_CNTCR, STGENC_CNTCR_EN);
1627 counter = (u64)readl(stgenc + STGENC_CNTCVL);
1628 counter |= ((u64)(readl(stgenc + STGENC_CNTCVU))) << 32;
1629 counter = lldiv(counter * (u64)rate, cntfid0);
1630 writel((u32)counter, stgenc + STGENC_CNTCVL);
1631 writel((u32)(counter >> 32), stgenc + STGENC_CNTCVU);
1632 writel(rate, stgenc + STGENC_CNTFID0);
1633 setbits_le32(stgenc + STGENC_CNTCR, STGENC_CNTCR_EN);
1634
1635 __asm__ volatile("mcr p15, 0, %0, c14, c0, 0" : : "r" (rate));
1636
1637 /* need to update gd->arch.timer_rate_hz with new frequency */
1638 timer_init();
1639 }
1640}
1641
1642static int set_clkdiv(unsigned int clkdiv, u32 address)
1643{
1644 u32 val;
1645 int ret;
1646
1647
1648 clrsetbits_le32(address, RCC_DIVR_DIV_MASK, clkdiv & RCC_DIVR_DIV_MASK);
1649 ret = readl_poll_timeout(address, val, val & RCC_DIVR_DIVRDY,
1650 TIMEOUT_200MS);
1651 if (ret)
1652 log_err("CLKDIV %x start failed @ 0x%x: 0x%x\n",
1653 clkdiv, address, readl(address));
1654
1655 return ret;
1656}
1657
1658static void set_rtcsrc(struct stm32mp_rcc_priv *priv,
1659 unsigned int clksrc,
1660 int lse_css)
1661{
1662 u32 address = (u32)(priv->base) + RCC_BDCR;
1663
1664 if (readl(address) & RCC_BDCR_RTCCKEN)
1665 goto skip_rtc;
1666
1667 if (clksrc == CLK_RTC_DISABLED)
1668 goto skip_rtc;
1669
1670 clrsetbits_le32(address,
1671 RCC_BDCR_RTCSRC_MASK,
1672 clksrc << RCC_BDCR_RTCSRC_SHIFT);
1673
1674 setbits_le32(address, RCC_BDCR_RTCCKEN);
1675
1676skip_rtc:
1677 if (lse_css)
1678 setbits_le32(address, RCC_BDCR_LSECSSON);
1679}
1680
1681static void pkcs_config(struct stm32mp_rcc_priv *priv, u32 pkcs)
1682{
1683 u32 mux = (pkcs & MUX_ID_MASK) >> MUX_ID_SHIFT;
1684 u32 address = (u32)(priv->base) + stm32mp13_muxes[mux].reg_off;
1685 u32 mask = (BIT(stm32mp13_muxes[mux].width) - 1) << stm32mp13_muxes[mux].shift;
1686 u32 value = (pkcs << stm32mp13_muxes[mux].shift) & mask;
1687
1688 clrsetbits_le32(address, mask, value);
1689}
1690
1691static int stm32mp1_clktree(struct udevice *dev)
1692{
1693 struct stm32mp_rcc_priv *priv = dev_get_priv(dev);
1694 fdt_addr_t rcc = (u32)(priv->base);
1695 unsigned int clksrc[CLKSRC_NB];
1696 unsigned int clkdiv[CLKDIV_NB];
1697 unsigned int pllcfg[_PLL_NB][PLLCFG_NB];
1698 unsigned int pllfracv[_PLL_NB];
1699 unsigned int pllcsg[_PLL_NB][PLLCSG_NB];
1700 bool pllcfg_valid[_PLL_NB];
1701 bool pllcsg_set[_PLL_NB];
1702 int ret;
1703 int i, len;
1704 int lse_css = 0;
1705 const u32 *pkcs_cell;
1706
1707 /* check mandatory field */
1708 ret = dev_read_u32_array(dev, "st,clksrc", clksrc, CLKSRC_NB);
1709 if (ret < 0) {
1710 dev_dbg(dev, "field st,clksrc invalid: error %d\n", ret);
1711 return -FDT_ERR_NOTFOUND;
1712 }
1713
1714 ret = dev_read_u32_array(dev, "st,clkdiv", clkdiv, CLKDIV_NB);
1715 if (ret < 0) {
1716 dev_dbg(dev, "field st,clkdiv invalid: error %d\n", ret);
1717 return -FDT_ERR_NOTFOUND;
1718 }
1719
1720 /* check mandatory field in each pll */
1721 for (i = 0; i < _PLL_NB; i++) {
1722 char name[12];
1723 ofnode node;
1724
1725 sprintf(name, "st,pll@%d", i);
1726 node = dev_read_subnode(dev, name);
1727 pllcfg_valid[i] = ofnode_valid(node);
1728 pllcsg_set[i] = false;
1729 if (pllcfg_valid[i]) {
1730 dev_dbg(dev, "DT for PLL %d @ %s\n", i, name);
1731 ret = ofnode_read_u32_array(node, "cfg",
1732 pllcfg[i], PLLCFG_NB);
1733 if (ret < 0) {
1734 dev_dbg(dev, "field cfg invalid: error %d\n", ret);
1735 return -FDT_ERR_NOTFOUND;
1736 }
1737 pllfracv[i] = ofnode_read_u32_default(node, "frac", 0);
1738
1739 ret = ofnode_read_u32_array(node, "csg", pllcsg[i],
1740 PLLCSG_NB);
1741 if (!ret) {
1742 pllcsg_set[i] = true;
1743 } else if (ret != -FDT_ERR_NOTFOUND) {
1744 dev_dbg(dev, "invalid csg node for pll@%d res=%d\n",
1745 i, ret);
1746 return ret;
1747 }
1748 } else if (i == _PLL1) {
1749 /* use OPP for PLL1 for A7 CPU */
1750 dev_dbg(dev, "DT for PLL %d with OPP\n", i);
1751 ret = stm32mp1_pll1_opp(priv,
1752 clksrc[CLKSRC_PLL12],
1753 pllcfg[i],
1754 &pllfracv[i]);
1755 if (ret) {
1756 dev_dbg(dev, "PLL %d with OPP error = %d\n", i, ret);
1757 return ret;
1758 }
1759 pllcfg_valid[i] = true;
1760 }
1761 }
1762
1763 dev_dbg(dev, "switch ON osillator\n");
1764 /*
1765 * switch ON oscillator found in device-tree,
1766 * HSI already ON after bootrom
1767 */
1768 if (clk_valid(&priv->osc_clk[_LSI]))
1769 stm32mp1_lsi_set(rcc, 1);
1770
1771 if (clk_valid(&priv->osc_clk[_LSE])) {
1772 int bypass, digbyp;
1773 u32 lsedrv;
1774 struct udevice *dev = priv->osc_clk[_LSE].dev;
1775
1776 bypass = dev_read_bool(dev, "st,bypass");
1777 digbyp = dev_read_bool(dev, "st,digbypass");
1778 lse_css = dev_read_bool(dev, "st,css");
1779 lsedrv = dev_read_u32_default(dev, "st,drive",
1780 LSEDRV_MEDIUM_HIGH);
1781
1782 stm32mp1_lse_enable(rcc, bypass, digbyp, lsedrv);
1783 }
1784
1785
1786 if (clk_valid(&priv->osc_clk[_HSE])) {
1787 int bypass, digbyp, css;
1788 struct udevice *dev = priv->osc_clk[_HSE].dev;
1789
1790 bypass = dev_read_bool(dev, "st,bypass");
1791 digbyp = dev_read_bool(dev, "st,digbypass");
1792 css = dev_read_bool(dev, "st,css");
1793
1794 stm32mp1_hse_enable(rcc, bypass, digbyp, css);
1795 }
1796
1797 /* CSI is mandatory for automatic I/O compensation (SYSCFG_CMPCR)
1798 * => switch on CSI even if node is not present in device tree
1799 */
1800 stm32mp1_csi_set(rcc, 1);
1801
1802 /* come back to HSI */
1803 dev_dbg(dev, "come back to HSI\n");
1804 set_clksrc(priv, CLK_MPU_HSI);
1805 set_clksrc(priv, CLK_AXI_HSI);
1806 set_clksrc(priv, CLK_MLAHBS_HSI);
1807
1808 dev_dbg(dev, "pll stop\n");
1809 for (i = 0; i < _PLL_NB; i++)
1810 pll_stop(priv, i);
1811
1812 /* configure HSIDIV */
1813 dev_dbg(dev, "configure HSIDIV\n");
1814 if (clk_valid(&priv->osc_clk[_HSI])) {
1815 stm32mp1_hsidiv(rcc, clk_get_rate(&priv->osc_clk[_HSI]));
1816 stgen_config(priv);
1817 }
1818
1819 /* select DIV */
1820 dev_dbg(dev, "select DIV\n");
1821 /* no ready bit when MPUSRC != CLK_MPU_PLL1P_DIV, MPUDIV is disabled */
1822 set_clkdiv(clkdiv[CLKDIV_AXI], rcc + RCC_AXIDIVR);
1823 set_clkdiv(clkdiv[CLKDIV_APB4], rcc + RCC_APB4DIVR);
1824 set_clkdiv(clkdiv[CLKDIV_APB5], rcc + RCC_APB5DIVR);
1825 set_clkdiv(clkdiv[CLKDIV_APB6], rcc + RCC_APB6DIVR);
1826 set_clkdiv(clkdiv[CLKDIV_APB1], rcc + RCC_APB1DIVR);
1827 set_clkdiv(clkdiv[CLKDIV_APB2], rcc + RCC_APB2DIVR);
1828 set_clkdiv(clkdiv[CLKDIV_APB3], rcc + RCC_APB3DIVR);
1829
1830 /* no ready bit for RTC */
1831 writel(clkdiv[CLKDIV_RTC] & RCC_DIVR_DIV_MASK, rcc + RCC_RTCDIVR);
1832
1833 /* configure PLLs source */
1834 dev_dbg(dev, "configure PLLs source\n");
1835 set_clksrc(priv, clksrc[CLKSRC_PLL12]);
1836 set_clksrc(priv, clksrc[CLKSRC_PLL3]);
1837 set_clksrc(priv, clksrc[CLKSRC_PLL4]);
1838
1839 /* configure and start PLLs */
1840 dev_dbg(dev, "configure PLLs\n");
1841 for (i = 0; i < _PLL_NB; i++) {
1842 if (!pllcfg_valid[i])
1843 continue;
1844 dev_dbg(dev, "configure PLL %d\n", i);
1845 pll_config(priv, i, pllcfg[i], pllfracv[i]);
1846 if (pllcsg_set[i])
1847 pll_csg(priv, i, pllcsg[i]);
1848 pll_start(priv, i);
1849 }
1850
1851 /* wait and start PLLs ouptut when ready */
1852 for (i = 0; i < _PLL_NB; i++) {
1853 if (!pllcfg_valid[i])
1854 continue;
1855 dev_dbg(dev, "output PLL %d\n", i);
1856 pll_output(priv, i, pllcfg[i][PLLCFG_O]);
1857 }
1858
1859 /* wait LSE ready before to use it */
1860 if (clk_valid(&priv->osc_clk[_LSE]))
1861 stm32mp1_lse_wait(rcc);
1862
1863 /* configure with expected clock source */
1864 dev_dbg(dev, "CLKSRC\n");
1865 set_clksrc(priv, clksrc[CLKSRC_MPU]);
1866 set_clksrc(priv, clksrc[CLKSRC_AXI]);
1867 set_clksrc(priv, clksrc[CLKSRC_MLAHB]);
1868 set_rtcsrc(priv, clksrc[CLKSRC_RTC], lse_css);
1869
1870 /* configure PKCK */
1871 dev_dbg(dev, "PKCK\n");
1872 pkcs_cell = dev_read_prop(dev, "st,pkcs", &len);
1873 if (pkcs_cell) {
1874 bool ckper_disabled = false;
1875
1876 for (i = 0; i < len / sizeof(u32); i++) {
1877 u32 pkcs = (u32)fdt32_to_cpu(pkcs_cell[i]);
1878
1879 if (pkcs == CLK_CKPER_DISABLED) {
1880 ckper_disabled = true;
1881 continue;
1882 }
1883 pkcs_config(priv, pkcs);
1884 }
1885 /* CKPER is source for some peripheral clock
1886 * (FMC-NAND / QPSI-NOR) and switching source is allowed
1887 * only if previous clock is still ON
1888 * => deactivated CKPER only after switching clock
1889 */
1890 if (ckper_disabled)
1891 pkcs_config(priv, CLK_CKPER_DISABLED);
1892 }
1893
1894 /* STGEN clock source can change with CLK_STGEN_XXX */
1895 stgen_config(priv);
1896
1897 dev_dbg(dev, "oscillator off\n");
1898 /* switch OFF HSI if not found in device-tree */
1899 if (!clk_valid(&priv->osc_clk[_HSI]))
1900 stm32mp1_hsi_set(rcc, 0);
1901
1902 /* Software Self-Refresh mode (SSR) during DDR initilialization */
1903 clrsetbits_le32((u32)(priv->base) + RCC_DDRITFCR,
1904 RCC_DDRITFCR_DDRCKMOD_MASK,
1905 RCC_DDRITFCR_DDRCKMOD_SSR <<
1906 RCC_DDRITFCR_DDRCKMOD_SHIFT);
1907
1908 return 0;
1909}
1910#endif
1911
1912static int stm32mp1_osc_init(struct udevice *dev)
1913{
1914 struct stm32mp_rcc_priv *priv = dev_get_priv(dev);
1915 fdt_addr_t base = dev_read_addr(dev->parent);
1916 struct clk *ck;
1917 int i;
1918
1919 const char *name[NB_OSC] = {
1920 [_LSI] = "lsi",
1921 [_LSE] = "lse",
1922 [_HSI] = "hsi",
1923 [_HSE] = "hse",
1924 [_CSI] = "csi",
1925 [_I2S_CKIN] = "i2s_ckin",
1926 };
1927
1928 const struct {
1929 const char *name;
1930 const int rate;
1931 } fixed_clk[] = {
1932 { "bsec", 66625000 },
1933 { "ck_axi", 266500000 },
1934 { "ck_mlahb", 200000000 },
1935 { "ck_mpu", 1000000000 },
1936 { "ck_per", 24000000 },
1937 { "ck_rtc", 32768 },
1938 { "clk-hse-div2", 12000000 },
1939 { "pclk1", 100000000 },
1940 { "pclk2", 100000000 },
1941 { "pclk3", 100000000 },
1942 { "pclk4", 133250000 },
1943 { "pclk5", 66625000 },
1944 { "pclk6", 100000000 },
1945 { "pll2_q", 266500000 },
1946 { "pll2_r", 533000000 },
1947 { "pll3_p", 200000000 },
1948 { "pll3_q", 150000000 },
1949 { "pll3_r", 200000000 },
1950 { "pll4_p", 125000000 },
1951 { "pll4_q", 83333333 },
1952 { "pll4_r", 75000000 },
1953 { "rtcapb", 66625000 },
1954 { "timg1_ck", 200000000 },
1955 { "timg2_ck", 200000000 },
1956 { "timg3_ck", 200000000 },
1957 };
1958
1959 if (base == FDT_ADDR_T_NONE)
1960 return -EINVAL;
1961
1962 priv->base = (void __iomem *)base;
1963
1964 for (i = 0; i < NB_OSC; i++) {
1965 if (clk_get_by_name(dev, name[i], &priv->osc_clk[i]))
1966 dev_dbg(dev, "No source clock \"%s\"\n", name[i]);
1967 else
1968 dev_dbg(dev, "%s clock rate: %luHz\n",
1969 name[i], clk_get_rate(&priv->osc_clk[i]));
1970 }
1971
1972 for (i = 0; i < ARRAY_SIZE(fixed_clk); i++) {
1973 ck = clk_register_fixed_rate(NULL, fixed_clk[i].name, fixed_clk[i].rate);
1974 if (!ck)
1975 dev_dbg(dev, "Cannot register fixed clock \"%s\"\n", fixed_clk[i].name);
1976 }
1977
1978 return 0;
1979}
1980#endif
1981
Gabriel Fernandez3db088a2022-11-24 11:36:04 +01001982static int stm32mp1_clk_probe(struct udevice *dev)
1983{
Gabriel Fernandez3db088a2022-11-24 11:36:04 +01001984 int err;
1985
Marek Vasut0b44b9c2025-05-12 19:08:29 +02001986#ifdef CONFIG_TFABOOT
1987 struct udevice *scmi;
1988
Gabriel Fernandez3db088a2022-11-24 11:36:04 +01001989 /* force SCMI probe to register all SCMI clocks */
1990 uclass_get_device_by_driver(UCLASS_CLK, DM_DRIVER_GET(scmi_clock), &scmi);
Marek Vasut0b44b9c2025-05-12 19:08:29 +02001991#else
1992 err = stm32mp1_osc_init(dev);
1993 if (err)
1994 return err;
1995
1996#if defined(CONFIG_XPL_BUILD)
1997 /* clock tree init is done only one time, before relocation */
1998 if (!(gd->flags & GD_FLG_RELOC))
1999 err = stm32mp1_clktree(dev);
2000 if (err)
2001 dev_err(dev, "clock tree initialization failed (%d)\n", err);
2002#endif
2003#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +01002004
2005 err = stm32_rcc_init(dev, &stm32mp13_data);
2006 if (err)
2007 return err;
2008
2009 gd->cpu_clk = clk_stm32_get_rate_by_name("ck_mpu");
2010 gd->bus_clk = clk_stm32_get_rate_by_name("ck_axi");
2011
2012 /* DDRPHYC father */
2013 gd->mem_clk = clk_stm32_get_rate_by_name("pll2_r");
2014
Marek Vasut0b44b9c2025-05-12 19:08:29 +02002015#ifndef CONFIG_XPL_BUILD
Gabriel Fernandez3db088a2022-11-24 11:36:04 +01002016 if (IS_ENABLED(CONFIG_DISPLAY_CPUINFO)) {
2017 if (gd->flags & GD_FLG_RELOC) {
2018 char buf[32];
2019
2020 log_info("Clocks:\n");
2021 log_info("- MPU : %s MHz\n", strmhz(buf, gd->cpu_clk));
2022 log_info("- AXI : %s MHz\n", strmhz(buf, gd->bus_clk));
2023 log_info("- PER : %s MHz\n",
2024 strmhz(buf, clk_stm32_get_rate_by_name("ck_per")));
2025 log_info("- DDR : %s MHz\n", strmhz(buf, gd->mem_clk));
2026 }
2027 }
Marek Vasut0b44b9c2025-05-12 19:08:29 +02002028#endif
Gabriel Fernandez3db088a2022-11-24 11:36:04 +01002029
2030 return 0;
2031}
2032
2033U_BOOT_DRIVER(stm32mp1_clock) = {
2034 .name = "stm32mp13_clk",
2035 .id = UCLASS_CLK,
2036 .ops = &stm32_clk_ops,
2037 .priv_auto = sizeof(struct stm32mp_rcc_priv),
2038 .probe = stm32mp1_clk_probe,
2039};