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