blob: 94cf80dbededbefb1af62a4cd256204b133cff6d [file] [log] [blame]
Marek Vasut526c9512020-03-31 19:51:36 +02001// SPDX-License-Identifier: (GPL-2.0 OR BSD-3-Clause)
2/*
3 * Copyright (C) Linaro Ltd 2019 - All Rights Reserved
4 * Author: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
5 * Copyright (C) 2020 Marek Vasut <marex@denx.de>
6 */
7/dts-v1/;
8
9#include "stm32mp157.dtsi"
10#include "stm32mp15-pinctrl.dtsi"
11#include "stm32mp15xxac-pinctrl.dtsi"
12#include <dt-bindings/gpio/gpio.h>
13#include <dt-bindings/mfd/st,stpmic1.h>
14
15/ {
16 aliases {
17 spi0 = &qspi;
18 };
19
20 memory@c0000000 {
21 device_type = "memory";
22 reg = <0xc0000000 0x40000000>;
23 };
Marek Vasut526c9512020-03-31 19:51:36 +020024};
25
26&i2c4 {
27 pinctrl-names = "default";
28 pinctrl-0 = <&i2c4_pins_a>;
29 i2c-scl-rising-time-ns = <185>;
30 i2c-scl-falling-time-ns = <20>;
31 status = "okay";
32 /delete-property/dmas;
33 /delete-property/dma-names;
34
35 pmic: stpmic@33 {
36 compatible = "st,stpmic1";
37 reg = <0x33>;
38 interrupts-extended = <&exti 55 IRQ_TYPE_EDGE_FALLING>;
39 interrupt-controller;
40 #interrupt-cells = <2>;
41 status = "okay";
42
Marek Vasut526c9512020-03-31 19:51:36 +020043 regulators {
44 compatible = "st,stpmic1-regulators";
45
46 ldo1-supply = <&v3v3>;
47 ldo2-supply = <&v3v3>;
48 ldo3-supply = <&vdd_ddr>;
49 ldo5-supply = <&v3v3>;
50 ldo6-supply = <&v3v3>;
51 pwr_sw1-supply = <&bst_out>;
52 pwr_sw2-supply = <&bst_out>;
53
54 vddcore: buck1 {
55 regulator-name = "vddcore";
56 regulator-min-microvolt = <800000>;
57 regulator-max-microvolt = <1350000>;
58 regulator-always-on;
59 regulator-initial-mode = <0>;
60 regulator-over-current-protection;
61 };
62
63 vdd_ddr: buck2 {
64 regulator-name = "vdd_ddr";
65 regulator-min-microvolt = <1350000>;
66 regulator-max-microvolt = <1350000>;
67 regulator-always-on;
68 regulator-initial-mode = <0>;
69 regulator-over-current-protection;
70 };
71
72 vdd: buck3 {
73 regulator-name = "vdd";
74 regulator-min-microvolt = <2900000>;
75 regulator-max-microvolt = <2900000>;
76 regulator-always-on;
Marek Vasut526c9512020-03-31 19:51:36 +020077 regulator-initial-mode = <0>;
78 regulator-over-current-protection;
79 };
80
81 v3v3: buck4 {
82 regulator-name = "v3v3";
83 regulator-min-microvolt = <3300000>;
84 regulator-max-microvolt = <3300000>;
85 regulator-always-on;
86 regulator-over-current-protection;
87 regulator-initial-mode = <0>;
88 };
89
90 vdda: ldo1 {
91 regulator-name = "vdda";
92 regulator-min-microvolt = <2900000>;
93 regulator-max-microvolt = <2900000>;
94 interrupts = <IT_CURLIM_LDO1 0>;
95 interrupt-parent = <&pmic>;
96 };
97
98 v2v8: ldo2 {
99 regulator-name = "v2v8";
100 regulator-min-microvolt = <2800000>;
101 regulator-max-microvolt = <2800000>;
102 interrupts = <IT_CURLIM_LDO2 0>;
103 interrupt-parent = <&pmic>;
104 };
105
106 vtt_ddr: ldo3 {
107 regulator-name = "vtt_ddr";
108 regulator-min-microvolt = <500000>;
109 regulator-max-microvolt = <750000>;
110 regulator-always-on;
111 regulator-over-current-protection;
112 };
113
114 vdd_usb: ldo4 {
115 regulator-name = "vdd_usb";
Marek Vasut526c9512020-03-31 19:51:36 +0200116 interrupts = <IT_CURLIM_LDO4 0>;
117 interrupt-parent = <&pmic>;
118 };
119
120 vdd_sd: ldo5 {
121 regulator-name = "vdd_sd";
122 regulator-min-microvolt = <2900000>;
123 regulator-max-microvolt = <2900000>;
124 interrupts = <IT_CURLIM_LDO5 0>;
125 interrupt-parent = <&pmic>;
126 regulator-boot-on;
127 };
128
129 v1v8: ldo6 {
130 regulator-name = "v1v8";
131 regulator-min-microvolt = <1800000>;
132 regulator-max-microvolt = <1800000>;
133 interrupts = <IT_CURLIM_LDO6 0>;
134 interrupt-parent = <&pmic>;
135 regulator-enable-ramp-delay = <300000>;
136 };
137
138 vref_ddr: vref_ddr {
139 regulator-name = "vref_ddr";
140 regulator-always-on;
Marek Vasut526c9512020-03-31 19:51:36 +0200141 };
142
143 bst_out: boost {
144 regulator-name = "bst_out";
145 interrupts = <IT_OCP_BOOST 0>;
146 interrupt-parent = <&pmic>;
147 };
148
149 vbus_otg: pwr_sw1 {
150 regulator-name = "vbus_otg";
151 interrupts = <IT_OCP_OTG 0>;
152 interrupt-parent = <&pmic>;
153 regulator-active-discharge = <1>;
154 };
155
156 vbus_sw: pwr_sw2 {
157 regulator-name = "vbus_sw";
158 interrupts = <IT_OCP_SWOUT 0>;
159 interrupt-parent = <&pmic>;
160 regulator-active-discharge = <1>;
161 };
162 };
163
164 onkey {
165 compatible = "st,stpmic1-onkey";
166 interrupts = <IT_PONKEY_F 0>, <IT_PONKEY_R 1>;
167 interrupt-names = "onkey-falling", "onkey-rising";
168 status = "okay";
169 };
170
171 watchdog {
172 compatible = "st,stpmic1-wdt";
173 status = "disabled";
174 };
175 };
176};
177
178&iwdg2 {
179 timeout-sec = <32>;
180 status = "okay";
181};
182
183&pwr_regulators {
Marek Vasut954d1ea2020-04-27 13:16:02 +0200184 vdd-supply = <&vdd>;
Marek Vasut526c9512020-03-31 19:51:36 +0200185 vdd_3v3_usbfs-supply = <&vdd_usb>;
186};
187
188&qspi {
189 pinctrl-names = "default", "sleep";
190 pinctrl-0 = <&qspi_clk_pins_a &qspi_bk1_pins_a>;
191 pinctrl-1 = <&qspi_clk_sleep_pins_a &qspi_bk1_sleep_pins_a>;
192 reg = <0x58003000 0x1000>, <0x70000000 0x200000>;
193 #address-cells = <1>;
194 #size-cells = <0>;
195 status = "okay";
196
197 flash0: spi-flash@0 {
198 compatible = "jedec,spi-nor";
199 reg = <0>;
200 spi-rx-bus-width = <4>;
Marek Vasut4f35b502021-08-09 14:06:04 +0200201 spi-max-frequency = <50000000>;
Marek Vasut526c9512020-03-31 19:51:36 +0200202 #address-cells = <1>;
203 #size-cells = <1>;
204 };
205};
206
207&rng1 {
208 status = "okay";
209};
210
211&rtc {
212 status = "okay";
213};