1 /* SPDX-License-Identifier: GPL-2.0-only */
4 * This file is created based on MT8186 Functional Specification
9 #include <console/console.h>
11 #include <soc/mt6366.h>
12 #include <soc/pmic_wrap.h>
14 #include <soc/regulator.h>
17 static struct pmic_setting init_setting
[] = {
19 {0x22, 0x1F00, 0x1F00, 0},
22 {0x36, 0x8888, 0xFFFF, 0},
23 {0x3A, 0x8888, 0xFFFF, 0},
24 {0x3C, 0x8888, 0xFFFF, 0},
25 {0x3E, 0x888, 0xFFF, 0},
26 {0x94, 0x0, 0xFFFF, 0},
27 {0x10C, 0x18, 0x18, 0},
30 {0x12A, 0x100, 0x180, 0},
31 {0x134, 0x80, 0x2890, 0},
32 {0x14C, 0x20, 0x20, 0},
33 {0x198, 0x0, 0x1FF, 0},
34 {0x790, 0x280, 0x780, 0},
35 {0x7AC, 0x0, 0x2000, 0},
36 {0x98A, 0x1840, 0x1E40, 0},
38 {0xA24, 0x1E00, 0x1F00, 0},
39 {0xA38, 0x0, 0x100, 0},
40 {0xA3C, 0x81F2, 0x81F2, 0},
41 {0xA44, 0xFFFF, 0xFFFF, 0},
42 {0xA46, 0xFC00, 0xFC00, 0},
44 {0xF8C, 0xAAA, 0xAAA, 0},
45 {0x1188, 0x0, 0x8000, 0},
46 {0x119E, 0x6000, 0x7000, 0},
47 {0x11A2, 0x0, 0x3000, 0},
48 {0x11B0, 0x4000, 0x4000, 0},
49 {0x11B4, 0x0, 0x100, 0},
50 {0x123A, 0x8040, 0x83FF, 0},
51 {0x123E, 0x4, 0x4, 0},
52 {0x1242, 0x1, 0x1, 0},
53 {0x1260, 0x0, 0x154, 0},
54 {0x1312, 0x8, 0x8, 0},
55 {0x1334, 0x0, 0x100, 0},
56 {0x138A, 0x10, 0x7F, 0},
57 {0x138C, 0x15, 0x7F, 0},
58 {0x138E, 0x1030, 0x3030, 0},
59 {0x140A, 0x10, 0x7F, 0},
60 {0x140C, 0x15, 0x7F, 0},
61 {0x140E, 0x1030, 0x3030, 0},
62 {0x148A, 0x10, 0x7F, 0},
63 {0x148E, 0x1030, 0x3030, 0},
64 {0x14A2, 0x20, 0x20, 0},
65 {0x150A, 0x10, 0x7F, 0},
66 {0x150E, 0x1030, 0x3030, 0},
67 {0x158A, 0x8, 0x7F, 0},
68 {0x158C, 0x90C, 0x7F7F, 0},
69 {0x158E, 0x1030, 0x3030, 0},
70 {0x159C, 0x8, 0xC, 0},
71 {0x15A2, 0x20, 0x20, 0},
72 {0x168A, 0x50, 0x7F, 0},
73 {0x168C, 0x1964, 0x7F7F, 0},
74 {0x168E, 0x2020, 0x3030, 0},
75 {0x16A2, 0x20, 0x20, 0},
76 {0x16AA, 0x50, 0x7F, 0},
77 {0x170C, 0x1964, 0x7F7F, 0},
78 {0x170E, 0x2020, 0x3030, 0},
79 {0x172A, 0x44, 0x7F, 0},
80 {0x178C, 0x202, 0x7F7F, 0},
81 {0x178E, 0x70, 0x73, 0},
82 {0x1790, 0xC, 0xC, 0},
83 {0x1798, 0x2810, 0x3F3F, 0},
84 {0x179A, 0x800, 0x3F00, 0},
85 {0x179E, 0x1, 0x1, 0},
86 {0x1808, 0x2000, 0x3000, 0},
87 {0x180C, 0x60, 0x60, 0},
88 {0x1814, 0x3FF0, 0x7FFF, 0},
89 {0x1816, 0x3, 0x7, 0},
90 {0x181A, 0x6081, 0xFFBF, 0},
91 {0x181C, 0x503, 0x787, 0},
92 {0x181E, 0xA462, 0xFFFF, 0},
93 {0x1820, 0xA662, 0xFFFF, 0},
94 {0x1824, 0xDB6, 0xFFF, 0},
95 {0x1828, 0x160, 0x160, 0},
96 {0x1830, 0x3FF0, 0x7FFF, 0},
97 {0x1832, 0x3, 0x7, 0},
98 {0x1836, 0x6081, 0xFFBF, 0},
99 {0x1838, 0x503, 0x787, 0},
100 {0x183A, 0xA262, 0xFFFF, 0},
101 {0x183C, 0xA262, 0xFFFF, 0},
102 {0x1840, 0xDB6, 0xFFF, 0},
103 {0x1888, 0x420, 0xE7C, 0},
104 {0x188A, 0x801, 0x3C07, 0},
105 {0x188C, 0x1F, 0x3F, 0},
106 {0x188E, 0x129A, 0xFFFF, 0},
107 {0x1894, 0x58, 0x1F8, 0},
108 {0x1896, 0x1C, 0x7C, 0},
109 {0x1898, 0x1805, 0x3C07, 0},
110 {0x189A, 0xF, 0xF, 0},
111 {0x189C, 0x221A, 0xFFFF, 0},
112 {0x18A0, 0x2E, 0x3F, 0},
113 {0x18A2, 0x0, 0x40, 0},
114 {0x18A4, 0x2C06, 0x3C07, 0},
115 {0x18A6, 0xF, 0xF, 0},
116 {0x18A8, 0x221A, 0xFFFF, 0},
117 {0x18AC, 0x2E, 0x3F, 0},
118 {0x18AE, 0x0, 0x40, 0},
119 {0x18B0, 0x1805, 0x3C07, 0},
120 {0x18B2, 0xF, 0xF, 0},
121 {0x18B4, 0x221A, 0xFFFF, 0},
122 {0x18B8, 0x2E, 0x3F, 0},
123 {0x18BC, 0x50, 0x4F0, 0},
124 {0x18BE, 0x3C, 0xFC, 0},
125 {0x18C0, 0x0, 0x300, 0},
126 {0x18C2, 0x8886, 0xFFFF, 0},
127 {0x1A0E, 0x3, 0x3, 0},
128 {0x1A10, 0x1, 0x1, 0},
129 {0x1A12, 0x0, 0x1, 0},
130 {0x1A14, 0x0, 0x1, 0},
131 {0x1A16, 0x0, 0x1, 0},
132 {0x1A18, 0x0, 0x1, 0},
133 {0x1A1A, 0x0, 0x1, 0},
134 {0x1A1C, 0x0, 0x1, 0},
135 {0x1A1E, 0x0, 0x1, 0},
136 {0x1A20, 0x0, 0x1, 0},
137 {0x1A22, 0x0, 0x1, 0},
138 {0x1A24, 0x0, 0x1, 0},
139 {0x1A26, 0x0, 0x1, 0},
140 {0x1A2C, 0x0, 0x1, 0},
141 {0x1A2E, 0x0, 0x1, 0},
142 {0x1A30, 0x0, 0x1, 0},
143 {0x1A32, 0x0, 0x1, 0},
144 {0x1A34, 0x0, 0x1, 0},
145 {0x1A36, 0x0, 0x1, 0},
146 {0x1A38, 0x0, 0x1, 0},
147 {0x1A3A, 0x0, 0x1, 0},
148 {0x1A3C, 0x0, 0x1, 0},
149 {0x1A3E, 0x0, 0x1, 0},
150 {0x1A40, 0x0, 0x1, 0},
151 {0x1A42, 0x0, 0x1, 0},
152 {0x1A44, 0x0, 0x1, 0},
153 {0x1A46, 0x0, 0x1, 0},
154 {0x1A48, 0x0, 0x1, 0},
155 {0x1A4A, 0x0, 0x1, 0},
156 {0x1A4C, 0x0, 0x1, 0},
157 {0x1A4E, 0x0, 0x1, 0},
158 {0x1A50, 0xE7FF, 0xE7FF, 0},
159 {0x1A56, 0x7FFF, 0x7FFF, 0},
160 {0x1B48, 0x10, 0x7F, 0},
161 {0x1B4A, 0xF15, 0x7F7F, 0},
162 /* Enable HW Tracking */
163 {0x1B66, 0x10, 0x7F, 8},
164 {0x1B68, 0x38, 0x7F, 0},
165 {0x1B68, 0x63, 0x7F, 8},
166 {0x1B64, 0x6, 0x7, 0},
167 {0x1B6E, 0x10, 0x7F, 8},
168 {0x1B70, 0x38, 0x7F, 0},
169 {0x1B70, 0x63, 0x7F, 8},
170 {0x1B6C, 0x6, 0x7, 0},
171 {0x1B8A, 0x10, 0x7F, 0},
172 {0x1B8C, 0xF15, 0x7F7F, 0},
173 {0x1BA8, 0x10, 0x7F, 0},
174 {0x1BAA, 0xF15, 0x7F7F, 0},
175 {0x1BAC, 0x0, 0x3, 0},
176 {0x1BCA, 0x10, 0x7F, 0},
177 {0x1BCC, 0x70F, 0x7F7F, 0},
178 {0x1C9E, 0x38, 0x7F, 0},
179 {0x1CA0, 0x70F, 0x7F7F, 0},
180 /* VSRAM_CORE: set SW mode */
181 {0x1CA4, 0x1, 0xFFFF, 0},
182 /* VSRAM_CORE: SW set OFF */
183 {0x1C9C, 0x0, 0xFFFF, 0},
184 {0x1EA2, 0x1B, 0x1F, 0},
185 {0x1EA4, 0xC00, 0x1C00, 0},
186 {0x1EA6, 0xC00, 0x1C00, 0},
187 {0x1EA8, 0xC00, 0x1C00, 0},
190 static struct pmic_setting lp_setting
[] = {
192 /* [0:0]: RG_BUCK_VPROC11_SW_OP_EN */
193 {0x1390, 0x1, 0x1, 0},
194 /* [0:0]: RG_BUCK_VCORE_SW_OP_EN */
195 {0x1490, 0x1, 0x1, 0},
196 /* [0:0]: RG_BUCK_VGPU_SW_OP_EN */
197 {0x1510, 0x1, 0x1, 0},
198 /* [0:0]: RG_BUCK_VMODEM_SW_OP_EN */
199 {0x1590, 0x1, 0x1, 0},
200 /* [0:0]: RG_BUCK_VS1_SW_OP_EN */
201 {0x1690, 0x1, 0x1, 0},
202 /* [1:1]: RG_BUCK_VS2_HW0_OP_EN */
203 {0x1710, 0x1, 0x1, 1},
204 /* [1:1]: RG_BUCK_VS2_HW0_OP_CFG */
205 {0x1716, 0x1, 0x1, 1},
206 /* [1:1]: RG_BUCK_VDRAM1_HW0_OP_EN */
207 {0x1610, 0x1, 0x1, 1},
208 /* [1:1]: RG_BUCK_VDRAM1_HW0_OP_CFG */
209 {0x1616, 0x1, 0x1, 1},
210 /* [0:0]: RG_BUCK_VPROC12_SW_OP_EN */
211 {0x1410, 0x1, 0x1, 0},
212 /* [0:0]: RG_LDO_VSRAM_GPU_SW_OP_EN */
213 {0x1BD0, 0x1, 0x1, 0},
214 /* [1:1]: RG_LDO_VSRAM_OTHERS_HW0_OP_EN */
215 {0x1BAE, 0x1, 0x1, 1},
216 /* [1:1]: RG_LDO_VSRAM_OTHERS_HW0_OP_CFG */
217 {0x1BB4, 0x1, 0x1, 1},
218 /* [0:0]: RG_LDO_VSRAM_PROC11_SW_OP_EN */
219 {0x1B4E, 0x1, 0x1, 0},
220 /* [1:1]: RG_LDO_VXO22_HW0_OP_EN */
221 {0x1A8A, 0x1, 0x1, 1},
222 /* [1:1]: RG_LDO_VXO22_HW0_OP_CFG */
223 {0x1A90, 0x1, 0x1, 1},
224 /* [2:2]: RG_LDO_VRF18_HW1_OP_EN */
225 {0x1C1E, 0x1, 0x1, 2},
226 /* [2:2]: RG_LDO_VRF18_HW1_OP_CFG */
227 {0x1C24, 0x0, 0x1, 2},
228 /* [0:0]: RG_LDO_VEFUSE_SW_OP_EN */
229 {0x1C46, 0x1, 0x1, 0},
230 /* [0:0]: RG_LDO_VCN33_SW_OP_EN */
231 {0x1D1E, 0x1, 0x1, 0},
232 /* [0:0]: RG_LDO_VCN33_SW_OP_EN */
233 {0x1D1E, 0x1, 0x1, 0},
234 /* [0:0]: RG_LDO_VCN28_SW_OP_EN */
235 {0x1D8A, 0x1, 0x1, 0},
236 /* [0:0]: RG_LDO_VCN18_SW_OP_EN */
237 {0x1C5A, 0x1, 0x1, 0},
238 /* [0:0]: RG_LDO_VCAMA1_SW_OP_EN */
239 {0x1C6E, 0x1, 0x1, 0},
240 /* [0:0]: RG_LDO_VCAMD_SW_OP_EN */
241 {0x1C9E, 0x1, 0x1, 0},
242 /* [0:0]: RG_LDO_VCAMA2_SW_OP_EN */
243 {0x1C8A, 0x1, 0x1, 0},
244 /* [0:0]: RG_LDO_VSRAM_PROC12_SW_OP_EN */
245 {0x1B90, 0x1, 0x1, 0},
246 /* [0:0]: RG_LDO_VCAMIO_SW_OP_EN */
247 {0x1CB2, 0x1, 0x1, 0},
248 /* [0:0]: RG_LDO_VLDO28_SW_OP_EN */
249 {0x1D34, 0x1, 0x1, 0},
250 /* [0:0]: RG_LDO_VLDO28_SW_OP_EN */
251 {0x1D34, 0x1, 0x1, 0},
252 /* [1:1]: RG_LDO_VA12_HW0_OP_EN */
253 {0x1A9E, 0x1, 0x1, 1},
254 /* [1:1]: RG_LDO_VA12_HW0_OP_CFG */
255 {0x1AA4, 0x1, 0x1, 1},
256 /* [1:1]: RG_LDO_VAUX18_HW0_OP_EN */
257 {0x1AB2, 0x1, 0x1, 1},
258 /* [1:1]: RG_LDO_VAUX18_HW0_OP_CFG */
259 {0x1AB8, 0x1, 0x1, 1},
260 /* [1:1]: RG_LDO_VAUD28_HW0_OP_EN */
261 {0x1AC6, 0x1, 0x1, 1},
262 /* [1:1]: RG_LDO_VAUD28_HW0_OP_CFG */
263 {0x1ACC, 0x1, 0x1, 1},
264 /* [0:0]: RG_LDO_VIO28_SW_OP_EN */
265 {0x1ADA, 0x1, 0x1, 0},
266 /* [0:0]: RG_LDO_VIO18_SW_OP_EN */
267 {0x1AEE, 0x1, 0x1, 0},
268 /* [2:2]: RG_LDO_VFE28_HW1_OP_EN */
269 {0x1C0A, 0x1, 0x1, 2},
270 /* [2:2]: RG_LDO_VFE28_HW1_OP_CFG */
271 {0x1C10, 0x0, 0x1, 2},
272 /* [1:1]: RG_LDO_VDRAM2_HW0_OP_EN */
273 {0x1B0A, 0x1, 0x1, 1},
274 /* [1:1]: RG_LDO_VDRAM2_HW0_OP_CFG */
275 {0x1B10, 0x1, 0x1, 1},
276 /* [0:0]: RG_LDO_VMC_SW_OP_EN */
277 {0x1CC6, 0x1, 0x1, 0},
278 /* [0:0]: RG_LDO_VMCH_SW_OP_EN */
279 {0x1CDA, 0x1, 0x1, 0},
280 /* [0:0]: RG_LDO_VEMC_SW_OP_EN */
281 {0x1B1E, 0x1, 0x1, 0},
282 /* [0:0]: RG_LDO_VSIM1_SW_OP_EN */
283 {0x1D4A, 0x1, 0x1, 0},
284 /* [0:0]: RG_LDO_VSIM2_SW_OP_EN */
285 {0x1D5E, 0x1, 0x1, 0},
286 /* [0:0]: RG_LDO_VIBR_SW_OP_EN */
287 {0x1D0A, 0x1, 0x1, 0},
288 /* [1:1]: RG_LDO_VUSB_HW0_OP_EN */
289 {0x1B32, 0x1, 0x1, 1},
290 /* [1:1]: RG_LDO_VUSB_HW0_OP_CFG */
291 {0x1B38, 0x1, 0x1, 1},
292 /* [1:1]: RG_LDO_VUSB_HW0_OP_EN */
293 {0x1B32, 0x1, 0x1, 1},
294 /* [1:1]: RG_LDO_VUSB_HW0_OP_CFG */
295 {0x1B38, 0x1, 0x1, 1},
296 /* [1:1]: RG_LDO_VBIF28_HW0_OP_EN */
297 {0x1DA0, 0x1, 0x1, 1},
298 /* [1:1]: RG_LDO_VBIF28_HW0_OP_CFG */
299 {0x1DA6, 0x0, 0x1, 1},
301 /* Deep idle setting */
302 /* [0:0]: RG_BUCK_VPROC11_SW_OP_EN */
303 {0x1390, 0x1, 0x1, 0},
304 /* [0:0]: RG_BUCK_VCORE_SW_OP_EN */
305 {0x1490, 0x1, 0x1, 0},
306 /* [0:0]: RG_BUCK_VGPU_SW_OP_EN */
307 {0x1510, 0x1, 0x1, 0},
308 /* [0:0]: RG_BUCK_VMODEM_SW_OP_EN */
309 {0x1590, 0x1, 0x1, 0},
310 /* [0:0]: RG_BUCK_VS1_SW_OP_EN */
311 {0x1690, 0x1, 0x1, 0},
312 /* [3:3]: RG_BUCK_VS2_HW2_OP_EN */
313 {0x1710, 0x1, 0x1, 3},
314 /* [3:3]: RG_BUCK_VS2_HW2_OP_CFG */
315 {0x1716, 0x1, 0x1, 3},
316 /* [3:3]: RG_BUCK_VDRAM1_HW2_OP_EN */
317 {0x1610, 0x1, 0x1, 3},
318 /* [3:3]: RG_BUCK_VDRAM1_HW2_OP_CFG */
319 {0x1616, 0x1, 0x1, 3},
320 /* [0:0]: RG_BUCK_VPROC12_SW_OP_EN */
321 {0x1410, 0x1, 0x1, 0},
322 /* [0:0]: RG_LDO_VSRAM_GPU_SW_OP_EN */
323 {0x1BD0, 0x1, 0x1, 0},
324 /* [3:3]: RG_LDO_VSRAM_OTHERS_HW2_OP_EN */
325 {0x1BAE, 0x1, 0x1, 3},
326 /* [3:3]: RG_LDO_VSRAM_OTHERS_HW2_OP_CFG */
327 {0x1BB4, 0x1, 0x1, 3},
328 /* [0:0]: RG_LDO_VSRAM_PROC11_SW_OP_EN */
329 {0x1B4E, 0x1, 0x1, 0},
330 /* [3:3]: RG_LDO_VXO22_HW2_OP_EN */
331 {0x1A8A, 0x1, 0x1, 3},
332 /* [3:3]: RG_LDO_VXO22_HW2_OP_CFG */
333 {0x1A90, 0x1, 0x1, 3},
334 /* [2:2]: RG_LDO_VRF18_HW1_OP_EN */
335 {0x1C1E, 0x1, 0x1, 2},
336 /* [2:2]: RG_LDO_VRF18_HW1_OP_CFG */
337 {0x1C24, 0x0, 0x1, 2},
338 /* [0:0]: RG_LDO_VEFUSE_SW_OP_EN */
339 {0x1C46, 0x1, 0x1, 0},
340 /* [0:0]: RG_LDO_VCN33_SW_OP_EN */
341 {0x1D1E, 0x1, 0x1, 0},
342 /* [0:0]: RG_LDO_VCN33_SW_OP_EN */
343 {0x1D1E, 0x1, 0x1, 0},
344 /* [0:0]: RG_LDO_VCN28_SW_OP_EN */
345 {0x1D8A, 0x1, 0x1, 0},
346 /* [0:0]: RG_LDO_VCN18_SW_OP_EN */
347 {0x1C5A, 0x1, 0x1, 0},
348 /* [0:0]: RG_LDO_VCAMA1_SW_OP_EN */
349 {0x1C6E, 0x1, 0x1, 0},
350 /* [0:0]: RG_LDO_VCAMD_SW_OP_EN */
351 {0x1C9E, 0x1, 0x1, 0},
352 /* [0:0]: RG_LDO_VCAMA2_SW_OP_EN */
353 {0x1C8A, 0x1, 0x1, 0},
354 /* [0:0]: RG_LDO_VSRAM_PROC12_SW_OP_EN */
355 {0x1B90, 0x1, 0x1, 0},
356 /* [0:0]: RG_LDO_VCAMIO_SW_OP_EN */
357 {0x1CB2, 0x1, 0x1, 0},
358 /* [0:0]: RG_LDO_VLDO28_SW_OP_EN */
359 {0x1D34, 0x1, 0x1, 0},
360 /* [0:0]: RG_LDO_VLDO28_SW_OP_EN */
361 {0x1D34, 0x1, 0x1, 0},
362 /* [3:3]: RG_LDO_VA12_HW2_OP_EN */
363 {0x1A9E, 0x1, 0x1, 3},
364 /* [3:3]: RG_LDO_VA12_HW2_OP_CFG */
365 {0x1AA4, 0x1, 0x1, 3},
366 /* [3:3]: RG_LDO_VAUX18_HW2_OP_EN */
367 {0x1AB2, 0x1, 0x1, 3},
368 /* [3:3]: RG_LDO_VAUX18_HW2_OP_CFG */
369 {0x1AB8, 0x1, 0x1, 3},
370 /* [0:0]: RG_LDO_VAUD28_SW_OP_EN */
371 {0x1AC6, 0x1, 0x1, 0},
372 /* [0:0]: RG_LDO_VIO28_SW_OP_EN */
373 {0x1ADA, 0x1, 0x1, 0},
374 /* [0:0]: RG_LDO_VIO18_SW_OP_EN */
375 {0x1AEE, 0x1, 0x1, 0},
376 /* [2:2]: RG_LDO_VFE28_HW1_OP_EN */
377 {0x1C0A, 0x1, 0x1, 2},
378 /* [2:2]: RG_LDO_VFE28_HW1_OP_CFG */
379 {0x1C10, 0x0, 0x1, 2},
380 /* [3:3]: RG_LDO_VDRAM2_HW2_OP_EN */
381 {0x1B0A, 0x1, 0x1, 3},
382 /* [3:3]: RG_LDO_VDRAM2_HW2_OP_CFG */
383 {0x1B10, 0x1, 0x1, 3},
384 /* [0:0]: RG_LDO_VMC_SW_OP_EN */
385 {0x1CC6, 0x1, 0x1, 0},
386 /* [0:0]: RG_LDO_VMCH_SW_OP_EN */
387 {0x1CDA, 0x1, 0x1, 0},
388 /* [0:0]: RG_LDO_VEMC_SW_OP_EN */
389 {0x1B1E, 0x1, 0x1, 0},
390 /* [0:0]: RG_LDO_VSIM1_SW_OP_EN */
391 {0x1D4A, 0x1, 0x1, 0},
392 /* [0:0]: RG_LDO_VSIM2_SW_OP_EN */
393 {0x1D5E, 0x1, 0x1, 0},
394 /* [0:0]: RG_LDO_VIBR_SW_OP_EN */
395 {0x1D0A, 0x1, 0x1, 0},
396 /* [3:3]: RG_LDO_VUSB_HW2_OP_EN */
397 {0x1B32, 0x1, 0x1, 3},
398 /* [3:3]: RG_LDO_VUSB_HW2_OP_CFG */
399 {0x1B38, 0x1, 0x1, 3},
400 /* [3:3]: RG_LDO_VUSB_HW2_OP_EN */
401 {0x1B32, 0x1, 0x1, 3},
402 /* [3:3]: RG_LDO_VUSB_HW2_OP_CFG */
403 {0x1B38, 0x1, 0x1, 3},
404 /* [3:3]: RG_LDO_VBIF28_HW2_OP_EN */
405 {0x1DA0, 0x1, 0x1, 3},
406 /* [3:3]: RG_LDO_VBIF28_HW2_OP_CFG */
407 {0x1DA6, 0x0, 0x1, 3},
410 static struct pmic_setting scp_setting
[] = {
411 /* scp voltage initialization */
412 /* [6:0]: RG_BUCK_VCORE_SSHUB_VOSEL */
413 {0x14A6, 0x20, 0x7F, 0},
414 /* [14:8]: RG_BUCK_VCORE_SSHUB_VOSEL_SLEEP */
415 {0x14A6, 0x20, 0x7F, 8},
416 /* [0:0]: RG_BUCK_VCORE_SSHUB_EN */
417 {0x14A4, 0x1, 0x1, 0},
418 /* [1:1]: RG_BUCK_VCORE_SSHUB_SLEEP_VOSEL_EN */
419 {0x14A4, 0x0, 0x1, 1},
420 /* [6:0]: RG_LDO_VSRAM_OTHERS_SSHUB_VOSEL */
421 {0x1BC6, 0x40, 0x7F, 0},
422 /* [14:8]: RG_LDO_VSRAM_OTHERS_SSHUB_VOSEL_SLEEP */
423 {0x1BC6, 0x40, 0x7F, 8},
424 /* [0:0]: RG_LDO_VSRAM_OTHERS_SSHUB_EN */
425 {0x1BC4, 0x1, 0x1, 0},
426 /* [1:1]: RG_LDO_VSRAM_OTHERS_SSHUB_SLEEP_VOSEL_EN */
427 {0x1BC4, 0x0, 0x1, 1},
428 /* [4:4]: RG_SRCVOLTEN_LP_EN */
429 {0x134, 0x1, 0x1, 4},
432 static const int vddq_votrim
[] = {
433 0, -10000, -20000, -30000, -40000, -50000, -60000, -70000,
434 80000, 70000, 60000, 50000, 40000, 30000, 20000, 10000,
437 static void mt6366_protect_control(bool en_protect
)
439 /* Write a magic number 0x9CA7 to disable protection */
440 pwrap_write_field(PMIC_TOP_TMA_KEY
, en_protect
? 0 : 0x9CA7, 0xFFFF, 0);
443 static u32
pmic_read_efuse(int i
)
447 /* 1. Enable efuse ctrl engine clock */
448 pwrap_write_field(PMIC_TOP_CKHWEN_CON0_CLR
, 0x1, 0x1, 2);
449 pwrap_write_field(PMIC_TOP_CKPDN_CON0_CLR
, 0x1, 0x1, 4);
452 pwrap_write_field(PMIC_OTP_CON11
, 0x1, 0x1, 0);
454 /* 3. Set row to read */
455 pwrap_write_field(PMIC_OTP_CON0
, i
* 2, 0xFF, 0);
457 /* 4. Toggle RG_OTP_RD_TRIG */
458 if (pwrap_read_field(PMIC_OTP_CON8
, 0x1, 0) == 0)
459 pwrap_write_field(PMIC_OTP_CON8
, 0x1, 0x1, 0);
461 pwrap_write_field(PMIC_OTP_CON8
, 0, 0x1, 0);
463 /* 5. Polling RG_OTP_RD_BUSY = 0 */
465 while (pwrap_read_field(PMIC_OTP_CON13
, 0x1, 0) == 1)
468 /* 6. Read RG_OTP_DOUT_SW */
470 efuse_data
= pwrap_read_field(PMIC_OTP_CON12
, 0xFFFF, 0);
472 /* 7. Disable efuse ctrl engine clock */
473 pwrap_write_field(PMIC_TOP_CKHWEN_CON0_SET
, 0x1, 0x1, 2);
474 pwrap_write_field(PMIC_TOP_CKPDN_CON0_SET
, 0x1, 0x1, 4);
479 static int pmic_get_efuse_votrim(void)
481 const u32 cali_efuse
= pmic_read_efuse(106) & 0xF;
482 assert(cali_efuse
< ARRAY_SIZE(vddq_votrim
));
483 return vddq_votrim
[cali_efuse
];
486 static u32
pmic_get_vcore_vol(void)
490 vol_reg
= pwrap_read_field(PMIC_VCORE_DBG0
, 0x7F, 0);
491 return 500000 + vol_reg
* 6250;
494 static void pmic_set_vcore_vol(u32 vcore_uv
)
498 assert(vcore_uv
>= 500000);
499 assert(vcore_uv
<= 1100000);
501 vol_reg
= (vcore_uv
- 500000) / 6250;
503 pwrap_write_field(PMIC_VCORE_OP_EN
, 1, 0x7F, 0);
504 pwrap_write_field(PMIC_VCORE_VOSEL
, vol_reg
, 0x7F, 0);
508 static u32
pmic_get_vproc12_vol(void)
512 vol_reg
= pwrap_read_field(PMIC_VPROC12_DBG0
, 0x7F, 0);
513 return 500000 + vol_reg
* 6250;
516 static void pmic_set_vproc12_vol(u32 v_uv
)
520 assert(v_uv
>= 500000);
521 assert(v_uv
<= 1293750);
523 vol_reg
= (v_uv
- 500000) / 6250;
525 pwrap_write_field(PMIC_VPROC12_OP_EN
, 1, 0x7F, 0);
526 pwrap_write_field(PMIC_VPROC12_VOSEL
, vol_reg
, 0x7F, 0);
530 static u32
pmic_get_vsram_proc12_vol(void)
534 vol_reg
= pwrap_read_field(PMIC_VSRAM_PROC12_DBG0
, 0x7F, 0);
535 return 500000 + vol_reg
* 6250;
538 static void pmic_set_vsram_proc12_vol(u32 v_uv
)
542 assert(v_uv
>= 500000);
543 assert(v_uv
<= 1293750);
545 vol_reg
= (v_uv
- 500000) / 6250;
547 pwrap_write_field(PMIC_VSRAM_PROC12_OP_EN
, 1, 0x7F, 0);
548 pwrap_write_field(PMIC_VSRAM_PROC12_VOSEL
, vol_reg
, 0x7F, 0);
552 static u32
pmic_get_vdram1_vol(void)
556 vol_reg
= pwrap_read_field(PMIC_VDRAM1_DBG0
, 0x7F, 0);
557 return 500000 + vol_reg
* 12500;
560 static void pmic_set_vdram1_vol(u32 vdram_uv
)
564 assert(vdram_uv
>= 500000);
565 assert(vdram_uv
<= 1300000);
567 vol_reg
= (vdram_uv
- 500000) / 12500;
569 pwrap_write_field(PMIC_VDRAM1_OP_EN
, 1, 0x7F, 0);
570 pwrap_write_field(PMIC_VDRAM1_VOSEL
, vol_reg
, 0x7F, 0);
574 static u32
pmic_get_vddq_vol(void)
579 if (!pwrap_read_field(PMIC_VDDQ_OP_EN
, 0x1, 15))
582 efuse_votrim
= pmic_get_efuse_votrim();
583 cali_trim
= pwrap_read_field(PMIC_VDDQ_ELR_0
, 0xF, 0);
584 assert(cali_trim
< ARRAY_SIZE(vddq_votrim
));
585 return 600 * 1000 - efuse_votrim
+ vddq_votrim
[cali_trim
];
588 static void pmic_set_vddq_vol(u32 vddq_uv
)
590 int target_mv
, dram2_ori_mv
, cali_offset_uv
;
593 assert(vddq_uv
>= 530000);
594 assert(vddq_uv
<= 680000);
596 /* Round down to multiple of 10 */
597 target_mv
= (vddq_uv
/ 1000) / 10 * 10;
599 dram2_ori_mv
= 600 - pmic_get_efuse_votrim() / 1000;
600 cali_offset_uv
= 1000 * (target_mv
- dram2_ori_mv
);
602 if (cali_offset_uv
>= 80000)
604 else if (cali_offset_uv
<= -70000)
608 while (cali_trim
< ARRAY_SIZE(vddq_votrim
) &&
609 vddq_votrim
[cali_trim
] != cali_offset_uv
)
611 assert(cali_trim
< ARRAY_SIZE(vddq_votrim
));
614 mt6366_protect_control(false);
615 pwrap_write_field(PMIC_VDDQ_ELR_0
, cali_trim
, 0xF, 0);
616 mt6366_protect_control(true);
620 static u32
pmic_get_vmch_vol(void)
625 vol_reg
= pwrap_read_field(PMIC_VMCH_ANA_CON0
, 0x7, 8);
638 printk(BIOS_ERR
, "ERROR[%s] VMCH read fail: %d\n", __func__
, vol_reg
);
645 static void pmic_set_vmch_vol(u32 vmch_uv
)
660 die("ERROR[%s]: VMCH voltage %u is not support.\n", __func__
, vmch_uv
);
664 pwrap_write_field(PMIC_VMCH_ANA_CON0
, val
, 0x7, 8);
666 /* Force SW to turn on */
667 pwrap_write_field(PMIC_LDO_VMCH_OP_EN
, 1, 0xFF, 0);
668 pwrap_write_field(PMIC_LDO_VMCH_CON0
, 1, 0xFF, 0);
671 static u32
pmic_get_vmc_vol(void)
676 vol_reg
= pwrap_read_field(PMIC_VMC_ANA_CON0
, 0xF, 8);
692 printk(BIOS_ERR
, "ERROR[%s] VMC read fail: %d\n", __func__
, vol_reg
);
699 static void pmic_set_vmc_vol(u32 vmc_uv
)
717 die("ERROR[%s]: VMC voltage %u is not support.\n", __func__
, vmc_uv
);
721 pwrap_write_field(PMIC_VMC_ANA_CON0
, val
, 0xF, 8);
723 /* Force SW to turn on */
724 pwrap_write_field(PMIC_LDO_VMC_OP_EN
, 1, 0xFF, 0);
725 pwrap_write_field(PMIC_LDO_VMC_CON0
, 1, 0xFF, 0);
728 #define VRF12_VOLTAGE_UV 1200000
730 static u32
pmic_get_vrf12_vol(void)
732 return (pwrap_read_field(PMIC_LDO_VRF12_CON0
, 0x3, 0) &
733 pwrap_read_field(PMIC_LDO_VRF12_OP_EN
, 0x3, 0)) ? VRF12_VOLTAGE_UV
: 0;
736 static void pmic_set_vrf12_vol(u32 vrf12_uv
)
738 assert(vrf12_uv
== VRF12_VOLTAGE_UV
);
739 pwrap_write_field(PMIC_LDO_VRF12_CON0
, 1, 0x3, 0);
740 pwrap_write_field(PMIC_LDO_VRF12_OP_EN
, 1, 0x3, 0);
743 static u32
pmic_get_vcn33_vol(void)
748 vol_reg
= pwrap_read_field(PMIC_VCN33_ANA_CON0
, 0x3, 8);
761 printk(BIOS_ERR
, "ERROR[%s] VCN33 read fail: %d\n", __func__
, vol_reg
);
768 static void pmic_set_vcn33_vol(u32 vcn33_uv
)
783 die("ERROR[%s]: VCN33 voltage %u is not support.\n", __func__
, vcn33_uv
);
787 pwrap_write_field(PMIC_VCN33_ANA_CON0
, val
, 0x3, 8);
789 /* Force SW to turn on */
790 pwrap_write_field(PMIC_LDO_VCN33_CON0_0
, 1, 0x1, 0);
793 #define VIO18_VOLTAGE_UV 1800000
795 static u32
pmic_get_vio18_vol(void)
797 return pwrap_read_field(PMIC_LDO_VIO18_CON0
, 0x1, 0) ? VIO18_VOLTAGE_UV
: 0;
800 static void pmic_set_vio18_vol(u32 vio18_uv
)
802 assert(vio18_uv
== VIO18_VOLTAGE_UV
);
803 pwrap_write_field(PMIC_LDO_VIO18_CON0
, 1, 0x1, 0);
806 static void pmic_wdt_set(void)
808 /* [5]=1, RG_WDTRSTB_DEB */
809 pwrap_write_field(PMIC_TOP_RST_MISC_SET
, 0x0020, 0xFFFF, 0);
810 /* [1]=0, RG_WDTRSTB_MODE */
811 pwrap_write_field(PMIC_TOP_RST_MISC_CLR
, 0x0002, 0xFFFF, 0);
812 /* [0]=1, RG_WDTRSTB_EN */
813 pwrap_write_field(PMIC_TOP_RST_MISC_SET
, 0x0001, 0xFFFF, 0);
816 static void mt6366_init_setting(void)
818 mt6366_protect_control(false);
819 for (size_t i
= 0; i
< ARRAY_SIZE(init_setting
); i
++)
821 init_setting
[i
].addr
, init_setting
[i
].val
,
822 init_setting
[i
].mask
, init_setting
[i
].shift
);
823 mt6366_protect_control(true);
826 static void wk_sleep_voltage_by_ddr(void)
828 if (pwrap_read_field(PMIC_VM_MODE
, 0x3, 0) == 0x2)
829 pwrap_write_field(PMIC_VDRAM1_VOSEL_SLEEP
, 0x3A, 0x7F, 0);
832 static void wk_power_down_seq(void)
834 mt6366_protect_control(false);
835 /* Set VPROC12 power-down time slot to 0xF to avoid 20ms delay */
836 pwrap_write_field(PMIC_CPSDSA4
, 0xF, 0x1F, 0);
837 mt6366_protect_control(true);
840 static void mt6366_lp_setting(void)
842 for (size_t i
= 0; i
< ARRAY_SIZE(lp_setting
); i
++)
844 lp_setting
[i
].addr
, lp_setting
[i
].val
,
845 lp_setting
[i
].mask
, lp_setting
[i
].shift
);
848 static void pmic_check_hwcid(void)
850 printk(BIOS_INFO
, "%s: ID = %#x\n", __func__
,
851 pwrap_read_field(0x8, 0xFFFF, 0));
854 void mt6366_set_power_hold(bool enable
)
856 pwrap_write_field(PMIC_PWRHOLD
, (enable
) ? 1 : 0, 0x1, 0);
859 void mt6366_init_scp_voltage(void)
861 for (size_t i
= 0; i
< ARRAY_SIZE(scp_setting
); i
++)
863 scp_setting
[i
].addr
, scp_setting
[i
].val
,
864 scp_setting
[i
].mask
, scp_setting
[i
].shift
);
867 void mt6366_set_vsim2_cali_mv(u32 vsim2_mv
)
869 u16 vsim2_reg
, cali_mv
;
871 cali_mv
= vsim2_mv
% 100;
872 assert(cali_mv
% 10 == 0);
874 switch (vsim2_mv
- cali_mv
) {
891 printk(BIOS_ERR
, "%s: voltage %d is not supported\n", __func__
, vsim2_mv
);
895 /* [11:8]=0x8, RG_VSIM2_VOSEL */
896 pwrap_write_field(PMIC_VSIM2_ANA_CON0
, vsim2_reg
, 0xF, 8);
898 /* [3:0], RG_VSIM2_VOCAL */
899 pwrap_write_field(PMIC_VSIM2_ANA_CON0
, cali_mv
/ 10, 0xF, 0);
902 void mt6366_set_voltage(enum mt6366_regulator_id id
, u32 voltage_uv
)
906 pmic_set_vcore_vol(voltage_uv
);
909 pmic_set_vdram1_vol(voltage_uv
);
912 pmic_set_vddq_vol(voltage_uv
);
915 pmic_set_vmch_vol(voltage_uv
);
918 pmic_set_vmc_vol(voltage_uv
);
921 pmic_set_vproc12_vol(voltage_uv
);
923 case MT6366_VSRAM_PROC12
:
924 pmic_set_vsram_proc12_vol(voltage_uv
);
927 pmic_set_vrf12_vol(voltage_uv
);
930 pmic_set_vcn33_vol(voltage_uv
);
933 pmic_set_vio18_vol(voltage_uv
);
936 printk(BIOS_ERR
, "%s: PMIC %d is not supported\n", __func__
, id
);
941 u32
mt6366_get_voltage(enum mt6366_regulator_id id
)
945 return pmic_get_vcore_vol();
947 return pmic_get_vdram1_vol();
949 return pmic_get_vddq_vol();
951 return pmic_get_vmch_vol();
953 return pmic_get_vmc_vol();
955 return pmic_get_vproc12_vol();
956 case MT6366_VSRAM_PROC12
:
957 return pmic_get_vsram_proc12_vol();
959 return pmic_get_vrf12_vol();
961 return pmic_get_vcn33_vol();
963 return pmic_get_vio18_vol();
965 printk(BIOS_ERR
, "%s: PMIC %d is not supported\n", __func__
, id
);
971 void mt6366_init(void)
973 struct stopwatch voltage_settled
;
976 die("ERROR - Failed to initialize pmic wrap!");
979 mt6366_set_power_hold(true);
981 mt6366_init_setting();
982 stopwatch_init_usecs_expire(&voltage_settled
, 200);
983 wk_sleep_voltage_by_ddr();
986 pmif_spmi_set_lp_mode();
988 while (!stopwatch_expired(&voltage_settled
))
989 /* wait for voltages to settle */;