hc
2025-02-14 bbb9540dc49f70f6b703d1c8d1b85fa5f602d86e
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
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
/* SPDX-License-Identifier: (GPL-2.0-or-later OR BSD-3-Clause) */
/*
 * Copyright (C) 2020 STMicroelectronics - All Rights Reserved
 * Copyright (C) 2020 Ahmad Fatoum, Pengutronix
 */
 
#include "stm32mp15-pinctrl.dtsi"
 
#include <dt-bindings/mfd/st,stpmic1.h>
 
/ {
   reserved-memory {
       #address-cells = <1>;
       #size-cells = <1>;
       ranges;
 
       mcuram2: mcuram2@10000000 {
           compatible = "shared-dma-pool";
           reg = <0x10000000 0x40000>;
           no-map;
       };
 
       vdev0vring0: vdev0vring0@10040000 {
           compatible = "shared-dma-pool";
           reg = <0x10040000 0x1000>;
           no-map;
       };
 
       vdev0vring1: vdev0vring1@10041000 {
           compatible = "shared-dma-pool";
           reg = <0x10041000 0x1000>;
           no-map;
       };
 
       vdev0buffer: vdev0buffer@10042000 {
           compatible = "shared-dma-pool";
           reg = <0x10042000 0x4000>;
           no-map;
       };
 
       mcuram: mcuram@30000000 {
           compatible = "shared-dma-pool";
           reg = <0x30000000 0x40000>;
           no-map;
       };
 
       retram: retram@38000000 {
           compatible = "shared-dma-pool";
           reg = <0x38000000 0x10000>;
           no-map;
       };
   };
 
   reg_sip_eeprom: regulator_eeprom {
       compatible = "regulator-fixed";
       regulator-name = "sip_eeprom";
       regulator-always-on;
   };
};
 
&i2c4 {
   pinctrl-names = "default", "sleep";
   pinctrl-0 = <&i2c4_pins_a>;
   pinctrl-1 = <&i2c4_sleep_pins_a>;
   clock-frequency = <400000>;
   i2c-scl-rising-time-ns = <185>;
   i2c-scl-falling-time-ns = <20>;
   status = "okay";
 
   pmic: stpmic@33 {
       compatible = "st,stpmic1";
       reg = <0x33>;
       interrupts-extended = <&gpioa 0 IRQ_TYPE_EDGE_FALLING>;
       interrupt-controller;
       #interrupt-cells = <2>;
 
       regulators {
           compatible = "st,stpmic1-regulators";
 
           ldo1-supply = <&v3v3>;
           ldo6-supply = <&v3v3>;
           pwr_sw1-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 = <3300000>;
               regulator-max-microvolt = <3300000>;
               regulator-always-on;
               st,mask-reset;
               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>;
           };
 
           v1v8_audio: ldo1 {
               regulator-name = "v1v8_audio";
               regulator-min-microvolt = <1800000>;
               regulator-max-microvolt = <1800000>;
               regulator-always-on;
               interrupts = <IT_CURLIM_LDO1 0>;
 
           };
 
           v3v3_hdmi: ldo2 {
               regulator-name = "v3v3_hdmi";
               regulator-min-microvolt = <3300000>;
               regulator-max-microvolt = <3300000>;
               regulator-always-on;
               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>;
           };
 
           vdda: ldo5 {
               regulator-name = "vdda";
               regulator-min-microvolt = <2900000>;
               regulator-max-microvolt = <2900000>;
               interrupts = <IT_CURLIM_LDO5 0>;
               regulator-boot-on;
           };
 
           v1v2_hdmi: ldo6 {
               regulator-name = "v1v2_hdmi";
               regulator-min-microvolt = <1200000>;
               regulator-max-microvolt = <1200000>;
               regulator-always-on;
               interrupts = <IT_CURLIM_LDO6 0>;
 
           };
 
           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";
       };
 
       pmic_watchdog: watchdog {
           compatible = "st,stpmic1-wdt";
           status = "disabled";
       };
   };
 
   sip_eeprom: eeprom@50 {
       compatible = "atmel,24c32";
       vcc-supply = <&reg_sip_eeprom>;
       reg = <0x50>;
   };
};
 
&ipcc {
   status = "okay";
};
 
&m4_rproc {
   memory-region = <&retram>, <&mcuram>, <&mcuram2>, <&vdev0vring0>,
           <&vdev0vring1>, <&vdev0buffer>;
   mboxes = <&ipcc 0>, <&ipcc 1>, <&ipcc 2>;
   mbox-names = "vq0", "vq1", "shutdown";
   interrupt-parent = <&exti>;
   interrupts = <68 1>;
   status = "okay";
};
 
&rng1 {
   status = "okay";
};