1277d6af5SYann Gautier// SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause) 2277d6af5SYann Gautier/* 3b8816d3cSYann Gautier * Copyright (c) 2019-2024, STMicroelectronics - All Rights Reserved 4277d6af5SYann Gautier * Author: Alexandre Torgue <alexandre.torgue@st.com> for STMicroelectronics. 5277d6af5SYann Gautier */ 6277d6af5SYann Gautier 7277d6af5SYann Gautier#include <dt-bindings/clock/stm32mp1-clksrc.h> 8277d6af5SYann Gautier#include "stm32mp15-ddr3-1x4Gb-1066-binG.dtsi" 9277d6af5SYann Gautier 10277d6af5SYann Gautier/ { 114c8e8ea7SYann Gautier aliases { 124c8e8ea7SYann Gautier serial0 = &uart4; 134c8e8ea7SYann Gautier serial1 = &usart3; 144c8e8ea7SYann Gautier serial2 = &uart7; 154c8e8ea7SYann Gautier }; 164c8e8ea7SYann Gautier 17277d6af5SYann Gautier memory@c0000000 { 18277d6af5SYann Gautier device_type = "memory"; 19277d6af5SYann Gautier reg = <0xc0000000 0x20000000>; 20277d6af5SYann Gautier }; 21277d6af5SYann Gautier 22277d6af5SYann Gautier vin: vin { 23277d6af5SYann Gautier compatible = "regulator-fixed"; 24277d6af5SYann Gautier regulator-name = "vin"; 25277d6af5SYann Gautier regulator-min-microvolt = <5000000>; 26277d6af5SYann Gautier regulator-max-microvolt = <5000000>; 27277d6af5SYann Gautier regulator-always-on; 28277d6af5SYann Gautier }; 29277d6af5SYann Gautier}; 30277d6af5SYann Gautier 31277d6af5SYann Gautier&bsec { 32b8816d3cSYann Gautier board_id: board-id@ec { 33277d6af5SYann Gautier reg = <0xec 0x4>; 34277d6af5SYann Gautier st,non-secure-otp; 35277d6af5SYann Gautier }; 36277d6af5SYann Gautier}; 37277d6af5SYann Gautier 38277d6af5SYann Gautier&clk_hse { 39277d6af5SYann Gautier st,digbypass; 40277d6af5SYann Gautier}; 41277d6af5SYann Gautier 42277d6af5SYann Gautier&cpu0 { 43277d6af5SYann Gautier cpu-supply = <&vddcore>; 44277d6af5SYann Gautier}; 45277d6af5SYann Gautier 46277d6af5SYann Gautier&cpu1 { 47277d6af5SYann Gautier cpu-supply = <&vddcore>; 48277d6af5SYann Gautier}; 49277d6af5SYann Gautier 50277d6af5SYann Gautier&hash1 { 51277d6af5SYann Gautier status = "okay"; 52277d6af5SYann Gautier}; 53277d6af5SYann Gautier 54277d6af5SYann Gautier&i2c4 { 55277d6af5SYann Gautier pinctrl-names = "default"; 56277d6af5SYann Gautier pinctrl-0 = <&i2c4_pins_a>; 57277d6af5SYann Gautier i2c-scl-rising-time-ns = <185>; 58277d6af5SYann Gautier i2c-scl-falling-time-ns = <20>; 59277d6af5SYann Gautier clock-frequency = <400000>; 60277d6af5SYann Gautier status = "okay"; 61277d6af5SYann Gautier 62277d6af5SYann Gautier pmic: stpmic@33 { 63277d6af5SYann Gautier compatible = "st,stpmic1"; 64277d6af5SYann Gautier reg = <0x33>; 65277d6af5SYann Gautier interrupts-extended = <&exti_pwr 55 IRQ_TYPE_EDGE_FALLING>; 66277d6af5SYann Gautier interrupt-controller; 67277d6af5SYann Gautier #interrupt-cells = <2>; 68277d6af5SYann Gautier status = "okay"; 69277d6af5SYann Gautier 70277d6af5SYann Gautier regulators { 71277d6af5SYann Gautier compatible = "st,stpmic1-regulators"; 72277d6af5SYann Gautier buck1-supply = <&vin>; 73277d6af5SYann Gautier buck2-supply = <&vin>; 74277d6af5SYann Gautier buck3-supply = <&vin>; 75277d6af5SYann Gautier buck4-supply = <&vin>; 76277d6af5SYann Gautier ldo1-supply = <&v3v3>; 77277d6af5SYann Gautier ldo2-supply = <&vin>; 78277d6af5SYann Gautier ldo3-supply = <&vdd_ddr>; 79277d6af5SYann Gautier ldo4-supply = <&vin>; 80277d6af5SYann Gautier ldo5-supply = <&vin>; 81277d6af5SYann Gautier ldo6-supply = <&v3v3>; 82277d6af5SYann Gautier vref_ddr-supply = <&vin>; 83277d6af5SYann Gautier boost-supply = <&vin>; 84277d6af5SYann Gautier pwr_sw1-supply = <&bst_out>; 85277d6af5SYann Gautier pwr_sw2-supply = <&bst_out>; 86277d6af5SYann Gautier 87277d6af5SYann Gautier vddcore: buck1 { 88277d6af5SYann Gautier regulator-name = "vddcore"; 89277d6af5SYann Gautier regulator-min-microvolt = <1200000>; 90277d6af5SYann Gautier regulator-max-microvolt = <1350000>; 91277d6af5SYann Gautier regulator-always-on; 92277d6af5SYann Gautier regulator-initial-mode = <0>; 93277d6af5SYann Gautier regulator-over-current-protection; 94277d6af5SYann Gautier }; 95277d6af5SYann Gautier 96277d6af5SYann Gautier vdd_ddr: buck2 { 97277d6af5SYann Gautier regulator-name = "vdd_ddr"; 98277d6af5SYann Gautier regulator-min-microvolt = <1350000>; 99277d6af5SYann Gautier regulator-max-microvolt = <1350000>; 100277d6af5SYann Gautier regulator-always-on; 101277d6af5SYann Gautier regulator-initial-mode = <0>; 102277d6af5SYann Gautier regulator-over-current-protection; 103277d6af5SYann Gautier }; 104277d6af5SYann Gautier 105277d6af5SYann Gautier vdd: buck3 { 106277d6af5SYann Gautier regulator-name = "vdd"; 107277d6af5SYann Gautier regulator-min-microvolt = <3300000>; 108277d6af5SYann Gautier regulator-max-microvolt = <3300000>; 109277d6af5SYann Gautier regulator-always-on; 110277d6af5SYann Gautier st,mask-reset; 111277d6af5SYann Gautier regulator-initial-mode = <0>; 112277d6af5SYann Gautier regulator-over-current-protection; 113277d6af5SYann Gautier }; 114277d6af5SYann Gautier 115277d6af5SYann Gautier v3v3: buck4 { 116277d6af5SYann Gautier regulator-name = "v3v3"; 117277d6af5SYann Gautier regulator-min-microvolt = <3300000>; 118277d6af5SYann Gautier regulator-max-microvolt = <3300000>; 119277d6af5SYann Gautier regulator-always-on; 120277d6af5SYann Gautier regulator-over-current-protection; 121277d6af5SYann Gautier regulator-initial-mode = <0>; 122277d6af5SYann Gautier }; 123277d6af5SYann Gautier 124277d6af5SYann Gautier v1v8_audio: ldo1 { 125277d6af5SYann Gautier regulator-name = "v1v8_audio"; 126277d6af5SYann Gautier regulator-min-microvolt = <1800000>; 127277d6af5SYann Gautier regulator-max-microvolt = <1800000>; 128277d6af5SYann Gautier regulator-always-on; 129277d6af5SYann Gautier }; 130277d6af5SYann Gautier 131277d6af5SYann Gautier v3v3_hdmi: ldo2 { 132277d6af5SYann Gautier regulator-name = "v3v3_hdmi"; 133277d6af5SYann Gautier regulator-min-microvolt = <3300000>; 134277d6af5SYann Gautier regulator-max-microvolt = <3300000>; 135277d6af5SYann Gautier regulator-always-on; 136277d6af5SYann Gautier }; 137277d6af5SYann Gautier 138277d6af5SYann Gautier vtt_ddr: ldo3 { 139277d6af5SYann Gautier regulator-name = "vtt_ddr"; 140277d6af5SYann Gautier regulator-always-on; 141277d6af5SYann Gautier regulator-over-current-protection; 14267d95409SPascal Paillet st,regulator-sink-source; 143277d6af5SYann Gautier }; 144277d6af5SYann Gautier 145277d6af5SYann Gautier vdd_usb: ldo4 { 146277d6af5SYann Gautier regulator-name = "vdd_usb"; 147277d6af5SYann Gautier regulator-min-microvolt = <3300000>; 148277d6af5SYann Gautier regulator-max-microvolt = <3300000>; 149277d6af5SYann Gautier }; 150277d6af5SYann Gautier 151277d6af5SYann Gautier vdda: ldo5 { 152277d6af5SYann Gautier regulator-name = "vdda"; 153277d6af5SYann Gautier regulator-min-microvolt = <2900000>; 154277d6af5SYann Gautier regulator-max-microvolt = <2900000>; 155277d6af5SYann Gautier regulator-boot-on; 156277d6af5SYann Gautier }; 157277d6af5SYann Gautier 158277d6af5SYann Gautier v1v2_hdmi: ldo6 { 159277d6af5SYann Gautier regulator-name = "v1v2_hdmi"; 160277d6af5SYann Gautier regulator-min-microvolt = <1200000>; 161277d6af5SYann Gautier regulator-max-microvolt = <1200000>; 162277d6af5SYann Gautier regulator-always-on; 163277d6af5SYann Gautier }; 164277d6af5SYann Gautier 165277d6af5SYann Gautier vref_ddr: vref_ddr { 166277d6af5SYann Gautier regulator-name = "vref_ddr"; 167277d6af5SYann Gautier regulator-always-on; 168277d6af5SYann Gautier }; 169277d6af5SYann Gautier 170277d6af5SYann Gautier bst_out: boost { 171277d6af5SYann Gautier regulator-name = "bst_out"; 172277d6af5SYann Gautier }; 173277d6af5SYann Gautier 174277d6af5SYann Gautier vbus_otg: pwr_sw1 { 175277d6af5SYann Gautier regulator-name = "vbus_otg"; 176277d6af5SYann Gautier }; 177277d6af5SYann Gautier 178277d6af5SYann Gautier vbus_sw: pwr_sw2 { 179277d6af5SYann Gautier regulator-name = "vbus_sw"; 180277d6af5SYann Gautier regulator-active-discharge = <1>; 181277d6af5SYann Gautier }; 182277d6af5SYann Gautier }; 183277d6af5SYann Gautier }; 184277d6af5SYann Gautier}; 185277d6af5SYann Gautier 186277d6af5SYann Gautier&iwdg2 { 187277d6af5SYann Gautier timeout-sec = <32>; 188277d6af5SYann Gautier status = "okay"; 189277d6af5SYann Gautier}; 190277d6af5SYann Gautier 191277d6af5SYann Gautier&pwr_regulators { 192277d6af5SYann Gautier vdd-supply = <&vdd>; 193277d6af5SYann Gautier vdd_3v3_usbfs-supply = <&vdd_usb>; 194277d6af5SYann Gautier}; 195277d6af5SYann Gautier 196277d6af5SYann Gautier&rcc { 197277d6af5SYann Gautier st,clksrc = < 198277d6af5SYann Gautier CLK_MPU_PLL1P 199277d6af5SYann Gautier CLK_AXI_PLL2P 200277d6af5SYann Gautier CLK_MCU_PLL3P 201*33573ea6SValentin Caron CLK_RTC_LSE 202277d6af5SYann Gautier CLK_MCO1_DISABLED 203277d6af5SYann Gautier CLK_MCO2_DISABLED 204277d6af5SYann Gautier CLK_CKPER_HSE 205277d6af5SYann Gautier CLK_FMC_ACLK 206277d6af5SYann Gautier CLK_QSPI_ACLK 2073e881a88SYann Gautier CLK_ETH_PLL4P 208277d6af5SYann Gautier CLK_SDMMC12_PLL4P 209277d6af5SYann Gautier CLK_DSI_DSIPLL 210277d6af5SYann Gautier CLK_STGEN_HSE 211277d6af5SYann Gautier CLK_USBPHY_HSE 212277d6af5SYann Gautier CLK_SPI2S1_PLL3Q 213277d6af5SYann Gautier CLK_SPI2S23_PLL3Q 214277d6af5SYann Gautier CLK_SPI45_HSI 215277d6af5SYann Gautier CLK_SPI6_HSI 216277d6af5SYann Gautier CLK_I2C46_HSI 217277d6af5SYann Gautier CLK_SDMMC3_PLL4P 218277d6af5SYann Gautier CLK_USBO_USBPHY 219277d6af5SYann Gautier CLK_ADC_CKPER 220277d6af5SYann Gautier CLK_CEC_LSE 221277d6af5SYann Gautier CLK_I2C12_HSI 222277d6af5SYann Gautier CLK_I2C35_HSI 223277d6af5SYann Gautier CLK_UART1_HSI 224277d6af5SYann Gautier CLK_UART24_HSI 225277d6af5SYann Gautier CLK_UART35_HSI 226277d6af5SYann Gautier CLK_UART6_HSI 227277d6af5SYann Gautier CLK_UART78_HSI 228277d6af5SYann Gautier CLK_SPDIF_PLL4P 229277d6af5SYann Gautier CLK_FDCAN_PLL4R 230277d6af5SYann Gautier CLK_SAI1_PLL3Q 231277d6af5SYann Gautier CLK_SAI2_PLL3Q 232277d6af5SYann Gautier CLK_SAI3_PLL3Q 233277d6af5SYann Gautier CLK_SAI4_PLL3Q 234d594239dSLionel Debieve CLK_RNG1_CSI 235277d6af5SYann Gautier CLK_RNG2_LSI 236277d6af5SYann Gautier CLK_LPTIM1_PCLK1 237277d6af5SYann Gautier CLK_LPTIM23_PCLK3 238277d6af5SYann Gautier CLK_LPTIM45_LSE 239277d6af5SYann Gautier >; 240277d6af5SYann Gautier 2414391e5edSGabriel Fernandez st,clkdiv = < 2424391e5edSGabriel Fernandez DIV(DIV_MPU, 1) 2434391e5edSGabriel Fernandez DIV(DIV_AXI, 0) 2444391e5edSGabriel Fernandez DIV(DIV_MCU, 0) 2454391e5edSGabriel Fernandez DIV(DIV_APB1, 1) 2464391e5edSGabriel Fernandez DIV(DIV_APB2, 1) 2474391e5edSGabriel Fernandez DIV(DIV_APB3, 1) 2484391e5edSGabriel Fernandez DIV(DIV_APB4, 1) 2494391e5edSGabriel Fernandez DIV(DIV_APB5, 2) 250*33573ea6SValentin Caron DIV(DIV_RTC, 23) 2514391e5edSGabriel Fernandez DIV(DIV_MCO1, 0) 2524391e5edSGabriel Fernandez DIV(DIV_MCO2, 0) 2534391e5edSGabriel Fernandez >; 2544391e5edSGabriel Fernandez 2554391e5edSGabriel Fernandez st,pll_vco { 2564391e5edSGabriel Fernandez pll2_vco_1066Mhz: pll2-vco-1066Mhz { 2574391e5edSGabriel Fernandez src = <CLK_PLL12_HSE>; 2584391e5edSGabriel Fernandez divmn = <2 65>; 2594391e5edSGabriel Fernandez frac = <0x1400>; 2604391e5edSGabriel Fernandez }; 2614391e5edSGabriel Fernandez 2624391e5edSGabriel Fernandez pll3_vco_417Mhz: pll3-vco-417Mhz { 2634391e5edSGabriel Fernandez src = <CLK_PLL3_HSE>; 2644391e5edSGabriel Fernandez divmn = <1 33>; 2654391e5edSGabriel Fernandez frac = <0x1a04>; 2664391e5edSGabriel Fernandez }; 2674391e5edSGabriel Fernandez 2684391e5edSGabriel Fernandez pll4_vco_594Mhz: pll4-vco-594Mhz { 2694391e5edSGabriel Fernandez src = <CLK_PLL4_HSE>; 2704391e5edSGabriel Fernandez divmn = <3 98>; 2714391e5edSGabriel Fernandez }; 2724391e5edSGabriel Fernandez }; 2734391e5edSGabriel Fernandez 274277d6af5SYann Gautier /* VCO = 1066.0 MHz => P = 266 (AXI), Q = 533 (GPU), R = 533 (DDR) */ 275277d6af5SYann Gautier pll2: st,pll@1 { 276277d6af5SYann Gautier compatible = "st,stm32mp1-pll"; 277277d6af5SYann Gautier reg = <1>; 2784391e5edSGabriel Fernandez 2794391e5edSGabriel Fernandez st,pll = <&pll2_cfg1>; 2804391e5edSGabriel Fernandez 2814391e5edSGabriel Fernandez pll2_cfg1: pll2_cfg1 { 2824391e5edSGabriel Fernandez st,pll_vco = <&pll2_vco_1066Mhz>; 2834391e5edSGabriel Fernandez st,pll_div_pqr = <1 0 0>; 2844391e5edSGabriel Fernandez }; 285277d6af5SYann Gautier }; 286277d6af5SYann Gautier 287277d6af5SYann Gautier /* VCO = 417.8 MHz => P = 209, Q = 24, R = 11 */ 288277d6af5SYann Gautier pll3: st,pll@2 { 289277d6af5SYann Gautier compatible = "st,stm32mp1-pll"; 290277d6af5SYann Gautier reg = <2>; 2914391e5edSGabriel Fernandez 2924391e5edSGabriel Fernandez st,pll = <&pll3_cfg1>; 2934391e5edSGabriel Fernandez 2944391e5edSGabriel Fernandez pll3_cfg1: pll3_cfg1 { 2954391e5edSGabriel Fernandez st,pll_vco = <&pll3_vco_417Mhz>; 2964391e5edSGabriel Fernandez st,pll_div_pqr = <1 16 36>; 2974391e5edSGabriel Fernandez }; 298277d6af5SYann Gautier }; 299277d6af5SYann Gautier 300277d6af5SYann Gautier /* VCO = 594.0 MHz => P = 99, Q = 74, R = 74 */ 301277d6af5SYann Gautier pll4: st,pll@3 { 302277d6af5SYann Gautier compatible = "st,stm32mp1-pll"; 303277d6af5SYann Gautier reg = <3>; 3044391e5edSGabriel Fernandez 3054391e5edSGabriel Fernandez st,pll = <&pll4_cfg1>; 3064391e5edSGabriel Fernandez 3074391e5edSGabriel Fernandez pll4_cfg1: pll4_cfg1 { 3084391e5edSGabriel Fernandez st,pll_vco = <&pll4_vco_594Mhz>; 3094391e5edSGabriel Fernandez st,pll_div_pqr = <5 7 7>; 3104391e5edSGabriel Fernandez }; 311277d6af5SYann Gautier }; 312277d6af5SYann Gautier}; 313277d6af5SYann Gautier 314277d6af5SYann Gautier&rng1 { 315277d6af5SYann Gautier status = "okay"; 316277d6af5SYann Gautier}; 317277d6af5SYann Gautier 318277d6af5SYann Gautier&rtc { 319277d6af5SYann Gautier status = "okay"; 320277d6af5SYann Gautier}; 321277d6af5SYann Gautier 322277d6af5SYann Gautier&sdmmc1 { 323277d6af5SYann Gautier pinctrl-names = "default"; 324277d6af5SYann Gautier pinctrl-0 = <&sdmmc1_b4_pins_a>; 325277d6af5SYann Gautier disable-wp; 326277d6af5SYann Gautier st,neg-edge; 327277d6af5SYann Gautier bus-width = <4>; 328277d6af5SYann Gautier vmmc-supply = <&v3v3>; 329277d6af5SYann Gautier status = "okay"; 330277d6af5SYann Gautier}; 331277d6af5SYann Gautier 332277d6af5SYann Gautier&uart4 { 333277d6af5SYann Gautier pinctrl-names = "default"; 334277d6af5SYann Gautier pinctrl-0 = <&uart4_pins_a>; 335277d6af5SYann Gautier status = "okay"; 336277d6af5SYann Gautier}; 337277d6af5SYann Gautier 338277d6af5SYann Gautier&uart7 { 339277d6af5SYann Gautier pinctrl-names = "default"; 340e8a953a9SYann Gautier pinctrl-0 = <&uart7_pins_c>; 341277d6af5SYann Gautier status = "disabled"; 342277d6af5SYann Gautier}; 343277d6af5SYann Gautier 344277d6af5SYann Gautier&usart3 { 345277d6af5SYann Gautier pinctrl-names = "default"; 346e8a953a9SYann Gautier pinctrl-0 = <&usart3_pins_c>; 347277d6af5SYann Gautier uart-has-rtscts; 348277d6af5SYann Gautier status = "disabled"; 349277d6af5SYann Gautier}; 350277d6af5SYann Gautier 351277d6af5SYann Gautier&usbotg_hs { 352277d6af5SYann Gautier phys = <&usbphyc_port1 0>; 353277d6af5SYann Gautier phy-names = "usb2-phy"; 354277d6af5SYann Gautier usb-role-switch; 355277d6af5SYann Gautier status = "okay"; 356277d6af5SYann Gautier}; 357277d6af5SYann Gautier 358277d6af5SYann Gautier&usbphyc { 359277d6af5SYann Gautier status = "okay"; 360277d6af5SYann Gautier}; 361277d6af5SYann Gautier 362277d6af5SYann Gautier&usbphyc_port0 { 363277d6af5SYann Gautier phy-supply = <&vdd_usb>; 364277d6af5SYann Gautier}; 365277d6af5SYann Gautier 366277d6af5SYann Gautier&usbphyc_port1 { 367277d6af5SYann Gautier phy-supply = <&vdd_usb>; 368277d6af5SYann Gautier}; 369