1277d6af5SYann Gautier// SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause) 2277d6af5SYann Gautier/* 3*20544d66SYann Gautier * Copyright (c) 2019-2025, 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 20133573ea6SValentin Caron CLK_RTC_LSE 202277d6af5SYann Gautier CLK_CKPER_HSE 203277d6af5SYann Gautier CLK_SDMMC12_PLL4P 204277d6af5SYann Gautier CLK_STGEN_HSE 205277d6af5SYann Gautier CLK_I2C46_HSI 206277d6af5SYann Gautier CLK_UART24_HSI 207277d6af5SYann Gautier >; 208277d6af5SYann Gautier 2094391e5edSGabriel Fernandez st,clkdiv = < 2104391e5edSGabriel Fernandez DIV(DIV_MPU, 1) 2114391e5edSGabriel Fernandez DIV(DIV_AXI, 0) 2124391e5edSGabriel Fernandez DIV(DIV_MCU, 0) 2134391e5edSGabriel Fernandez DIV(DIV_APB1, 1) 2144391e5edSGabriel Fernandez DIV(DIV_APB2, 1) 2154391e5edSGabriel Fernandez DIV(DIV_APB3, 1) 2164391e5edSGabriel Fernandez DIV(DIV_APB4, 1) 2174391e5edSGabriel Fernandez DIV(DIV_APB5, 2) 21833573ea6SValentin Caron DIV(DIV_RTC, 23) 2194391e5edSGabriel Fernandez >; 2204391e5edSGabriel Fernandez 2214391e5edSGabriel Fernandez st,pll_vco { 2224391e5edSGabriel Fernandez pll2_vco_1066Mhz: pll2-vco-1066Mhz { 2234391e5edSGabriel Fernandez src = <CLK_PLL12_HSE>; 2244391e5edSGabriel Fernandez divmn = <2 65>; 2254391e5edSGabriel Fernandez frac = <0x1400>; 2264391e5edSGabriel Fernandez }; 2274391e5edSGabriel Fernandez 2284391e5edSGabriel Fernandez pll3_vco_417Mhz: pll3-vco-417Mhz { 2294391e5edSGabriel Fernandez src = <CLK_PLL3_HSE>; 2304391e5edSGabriel Fernandez divmn = <1 33>; 2314391e5edSGabriel Fernandez frac = <0x1a04>; 2324391e5edSGabriel Fernandez }; 2334391e5edSGabriel Fernandez 2344391e5edSGabriel Fernandez pll4_vco_594Mhz: pll4-vco-594Mhz { 2354391e5edSGabriel Fernandez src = <CLK_PLL4_HSE>; 2364391e5edSGabriel Fernandez divmn = <3 98>; 2374391e5edSGabriel Fernandez }; 2384391e5edSGabriel Fernandez }; 2394391e5edSGabriel Fernandez 240277d6af5SYann Gautier /* VCO = 1066.0 MHz => P = 266 (AXI), Q = 533 (GPU), R = 533 (DDR) */ 241277d6af5SYann Gautier pll2: st,pll@1 { 242277d6af5SYann Gautier compatible = "st,stm32mp1-pll"; 243277d6af5SYann Gautier reg = <1>; 2444391e5edSGabriel Fernandez 2454391e5edSGabriel Fernandez st,pll = <&pll2_cfg1>; 2464391e5edSGabriel Fernandez 2474391e5edSGabriel Fernandez pll2_cfg1: pll2_cfg1 { 2484391e5edSGabriel Fernandez st,pll_vco = <&pll2_vco_1066Mhz>; 2494391e5edSGabriel Fernandez st,pll_div_pqr = <1 0 0>; 2504391e5edSGabriel Fernandez }; 251277d6af5SYann Gautier }; 252277d6af5SYann Gautier 253277d6af5SYann Gautier /* VCO = 417.8 MHz => P = 209, Q = 24, R = 11 */ 254277d6af5SYann Gautier pll3: st,pll@2 { 255277d6af5SYann Gautier compatible = "st,stm32mp1-pll"; 256277d6af5SYann Gautier reg = <2>; 2574391e5edSGabriel Fernandez 2584391e5edSGabriel Fernandez st,pll = <&pll3_cfg1>; 2594391e5edSGabriel Fernandez 2604391e5edSGabriel Fernandez pll3_cfg1: pll3_cfg1 { 2614391e5edSGabriel Fernandez st,pll_vco = <&pll3_vco_417Mhz>; 2624391e5edSGabriel Fernandez st,pll_div_pqr = <1 16 36>; 2634391e5edSGabriel Fernandez }; 264277d6af5SYann Gautier }; 265277d6af5SYann Gautier 266277d6af5SYann Gautier /* VCO = 594.0 MHz => P = 99, Q = 74, R = 74 */ 267277d6af5SYann Gautier pll4: st,pll@3 { 268277d6af5SYann Gautier compatible = "st,stm32mp1-pll"; 269277d6af5SYann Gautier reg = <3>; 2704391e5edSGabriel Fernandez 2714391e5edSGabriel Fernandez st,pll = <&pll4_cfg1>; 2724391e5edSGabriel Fernandez 2734391e5edSGabriel Fernandez pll4_cfg1: pll4_cfg1 { 2744391e5edSGabriel Fernandez st,pll_vco = <&pll4_vco_594Mhz>; 2754391e5edSGabriel Fernandez st,pll_div_pqr = <5 7 7>; 2764391e5edSGabriel Fernandez }; 277277d6af5SYann Gautier }; 278277d6af5SYann Gautier}; 279277d6af5SYann Gautier 280277d6af5SYann Gautier&rng1 { 281277d6af5SYann Gautier status = "okay"; 282277d6af5SYann Gautier}; 283277d6af5SYann Gautier 284277d6af5SYann Gautier&rtc { 285277d6af5SYann Gautier status = "okay"; 286277d6af5SYann Gautier}; 287277d6af5SYann Gautier 288277d6af5SYann Gautier&sdmmc1 { 289277d6af5SYann Gautier pinctrl-names = "default"; 290277d6af5SYann Gautier pinctrl-0 = <&sdmmc1_b4_pins_a>; 291277d6af5SYann Gautier disable-wp; 292277d6af5SYann Gautier st,neg-edge; 293277d6af5SYann Gautier bus-width = <4>; 294277d6af5SYann Gautier vmmc-supply = <&v3v3>; 295277d6af5SYann Gautier status = "okay"; 296277d6af5SYann Gautier}; 297277d6af5SYann Gautier 298277d6af5SYann Gautier&uart4 { 299277d6af5SYann Gautier pinctrl-names = "default"; 300277d6af5SYann Gautier pinctrl-0 = <&uart4_pins_a>; 301277d6af5SYann Gautier status = "okay"; 302277d6af5SYann Gautier}; 303277d6af5SYann Gautier 304277d6af5SYann Gautier&uart7 { 305277d6af5SYann Gautier pinctrl-names = "default"; 306e8a953a9SYann Gautier pinctrl-0 = <&uart7_pins_c>; 307277d6af5SYann Gautier status = "disabled"; 308277d6af5SYann Gautier}; 309277d6af5SYann Gautier 310277d6af5SYann Gautier&usart3 { 311277d6af5SYann Gautier pinctrl-names = "default"; 312e8a953a9SYann Gautier pinctrl-0 = <&usart3_pins_c>; 313277d6af5SYann Gautier uart-has-rtscts; 314277d6af5SYann Gautier status = "disabled"; 315277d6af5SYann Gautier}; 316277d6af5SYann Gautier 317277d6af5SYann Gautier&usbotg_hs { 318277d6af5SYann Gautier phys = <&usbphyc_port1 0>; 319277d6af5SYann Gautier phy-names = "usb2-phy"; 320277d6af5SYann Gautier usb-role-switch; 321277d6af5SYann Gautier status = "okay"; 322277d6af5SYann Gautier}; 323277d6af5SYann Gautier 324277d6af5SYann Gautier&usbphyc { 325277d6af5SYann Gautier status = "okay"; 326277d6af5SYann Gautier}; 327277d6af5SYann Gautier 328277d6af5SYann Gautier&usbphyc_port0 { 329277d6af5SYann Gautier phy-supply = <&vdd_usb>; 330277d6af5SYann Gautier}; 331277d6af5SYann Gautier 332277d6af5SYann Gautier&usbphyc_port1 { 333277d6af5SYann Gautier phy-supply = <&vdd_usb>; 334277d6af5SYann Gautier}; 335