1/* SPDX-License-Identifier: GPL-2.0 */
2/*
3 * Copyright (c) 2021 MediaTek Inc.
4 */
5
6#ifndef __MFD_MT6359P_REGISTERS_H__
7#define __MFD_MT6359P_REGISTERS_H__
8
9#define MT6359P_CHIP_VER 0x5930
10
11/* PMIC Registers */
12#define MT6359P_HWCID 0x8
13#define MT6359P_TOP_TRAP 0x50
14#define MT6359P_TOP_TMA_KEY 0x3a8
15#define MT6359P_BUCK_VCORE_ELR_NUM 0x152a
16#define MT6359P_BUCK_VCORE_ELR0 0x152c
17#define MT6359P_BUCK_VGPU11_SSHUB_CON0 0x15aa
18#define MT6359P_BUCK_VGPU11_ELR0 0x15b4
19#define MT6359P_LDO_VSRAM_PROC1_ELR 0x1b44
20#define MT6359P_LDO_VSRAM_PROC2_ELR 0x1b46
21#define MT6359P_LDO_VSRAM_OTHERS_ELR 0x1b48
22#define MT6359P_LDO_VSRAM_MD_ELR 0x1b4a
23#define MT6359P_LDO_VEMC_ELR_0 0x1b4c
24#define MT6359P_LDO_VFE28_CON0 0x1b88
25#define MT6359P_LDO_VFE28_MON 0x1b8c
26#define MT6359P_LDO_VXO22_CON0 0x1b9a
27#define MT6359P_LDO_VXO22_MON 0x1b9e
28#define MT6359P_LDO_VRF18_CON0 0x1bac
29#define MT6359P_LDO_VRF18_MON 0x1bb0
30#define MT6359P_LDO_VRF12_CON0 0x1bbe
31#define MT6359P_LDO_VRF12_MON 0x1bc2
32#define MT6359P_LDO_VEFUSE_CON0 0x1bd0
33#define MT6359P_LDO_VEFUSE_MON 0x1bd4
34#define MT6359P_LDO_VCN33_1_CON0 0x1be2
35#define MT6359P_LDO_VCN33_1_MON 0x1be6
36#define MT6359P_LDO_VCN33_1_MULTI_SW 0x1bf4
37#define MT6359P_LDO_VCN33_2_CON0 0x1c08
38#define MT6359P_LDO_VCN33_2_MON 0x1c0c
39#define MT6359P_LDO_VCN33_2_MULTI_SW 0x1c1a
40#define MT6359P_LDO_VCN13_CON0 0x1c1c
41#define MT6359P_LDO_VCN13_MON 0x1c20
42#define MT6359P_LDO_VCN18_CON0 0x1c2e
43#define MT6359P_LDO_VCN18_MON 0x1c32
44#define MT6359P_LDO_VA09_CON0 0x1c40
45#define MT6359P_LDO_VA09_MON 0x1c44
46#define MT6359P_LDO_VCAMIO_CON0 0x1c52
47#define MT6359P_LDO_VCAMIO_MON 0x1c56
48#define MT6359P_LDO_VA12_CON0 0x1c64
49#define MT6359P_LDO_VA12_MON 0x1c68
50#define MT6359P_LDO_VAUX18_CON0 0x1c88
51#define MT6359P_LDO_VAUX18_MON 0x1c8c
52#define MT6359P_LDO_VAUD18_CON0 0x1c9a
53#define MT6359P_LDO_VAUD18_MON 0x1c9e
54#define MT6359P_LDO_VIO18_CON0 0x1cac
55#define MT6359P_LDO_VIO18_MON 0x1cb0
56#define MT6359P_LDO_VEMC_CON0 0x1cbe
57#define MT6359P_LDO_VEMC_MON 0x1cc2
58#define MT6359P_LDO_VSIM1_CON0 0x1cd0
59#define MT6359P_LDO_VSIM1_MON 0x1cd4
60#define MT6359P_LDO_VSIM2_CON0 0x1ce2
61#define MT6359P_LDO_VSIM2_MON 0x1ce6
62#define MT6359P_LDO_VUSB_CON0 0x1d08
63#define MT6359P_LDO_VUSB_MON 0x1d0c
64#define MT6359P_LDO_VUSB_MULTI_SW 0x1d1a
65#define MT6359P_LDO_VRFCK_CON0 0x1d1c
66#define MT6359P_LDO_VRFCK_MON 0x1d20
67#define MT6359P_LDO_VBBCK_CON0 0x1d2e
68#define MT6359P_LDO_VBBCK_MON 0x1d32
69#define MT6359P_LDO_VBIF28_CON0 0x1d40
70#define MT6359P_LDO_VBIF28_MON 0x1d44
71#define MT6359P_LDO_VIBR_CON0 0x1d52
72#define MT6359P_LDO_VIBR_MON 0x1d56
73#define MT6359P_LDO_VIO28_CON0 0x1d64
74#define MT6359P_LDO_VIO28_MON 0x1d68
75#define MT6359P_LDO_VM18_CON0 0x1d88
76#define MT6359P_LDO_VM18_MON 0x1d8c
77#define MT6359P_LDO_VUFS_CON0 0x1d9a
78#define MT6359P_LDO_VUFS_MON 0x1d9e
79#define MT6359P_LDO_VSRAM_PROC1_CON0 0x1e88
80#define MT6359P_LDO_VSRAM_PROC1_MON 0x1e8c
81#define MT6359P_LDO_VSRAM_PROC1_VOSEL1 0x1e90
82#define MT6359P_LDO_VSRAM_PROC2_CON0 0x1ea8
83#define MT6359P_LDO_VSRAM_PROC2_MON 0x1eac
84#define MT6359P_LDO_VSRAM_PROC2_VOSEL1 0x1eb0
85#define MT6359P_LDO_VSRAM_OTHERS_CON0 0x1f08
86#define MT6359P_LDO_VSRAM_OTHERS_MON 0x1f0c
87#define MT6359P_LDO_VSRAM_OTHERS_VOSEL1 0x1f10
88#define MT6359P_LDO_VSRAM_OTHERS_SSHUB 0x1f28
89#define MT6359P_LDO_VSRAM_MD_CON0 0x1f2e
90#define MT6359P_LDO_VSRAM_MD_MON 0x1f32
91#define MT6359P_LDO_VSRAM_MD_VOSEL1 0x1f36
92#define MT6359P_VFE28_ANA_CON0 0x1f88
93#define MT6359P_VAUX18_ANA_CON0 0x1f8c
94#define MT6359P_VUSB_ANA_CON0 0x1f90
95#define MT6359P_VBIF28_ANA_CON0 0x1f94
96#define MT6359P_VCN33_1_ANA_CON0 0x1f98
97#define MT6359P_VCN33_2_ANA_CON0 0x1f9c
98#define MT6359P_VEMC_ANA_CON0 0x1fa0
99#define MT6359P_VSIM1_ANA_CON0 0x1fa2
100#define MT6359P_VSIM2_ANA_CON0 0x1fa6
101#define MT6359P_VIO28_ANA_CON0 0x1faa
102#define MT6359P_VIBR_ANA_CON0 0x1fae
103#define MT6359P_VFE28_ELR_4 0x1fc0
104#define MT6359P_VRF18_ANA_CON0 0x2008
105#define MT6359P_VEFUSE_ANA_CON0 0x200c
106#define MT6359P_VCN18_ANA_CON0 0x2010
107#define MT6359P_VCAMIO_ANA_CON0 0x2014
108#define MT6359P_VAUD18_ANA_CON0 0x2018
109#define MT6359P_VIO18_ANA_CON0 0x201c
110#define MT6359P_VM18_ANA_CON0 0x2020
111#define MT6359P_VUFS_ANA_CON0 0x2024
112#define MT6359P_VRF12_ANA_CON0 0x202a
113#define MT6359P_VCN13_ANA_CON0 0x202e
114#define MT6359P_VA09_ANA_CON0 0x2032
115#define MT6359P_VRF18_ELR_3 0x204e
116#define MT6359P_VXO22_ANA_CON0 0x2088
117#define MT6359P_VRFCK_ANA_CON0 0x208c
118#define MT6359P_VBBCK_ANA_CON0 0x2096
119
120#define MT6359P_RG_BUCK_VCORE_VOSEL_ADDR MT6359P_BUCK_VCORE_ELR0
121#define MT6359P_RG_BUCK_VGPU11_SSHUB_EN_ADDR MT6359P_BUCK_VGPU11_SSHUB_CON0
122#define MT6359P_RG_BUCK_VGPU11_VOSEL_ADDR MT6359P_BUCK_VGPU11_ELR0
123#define MT6359P_RG_BUCK_VGPU11_SSHUB_VOSEL_ADDR MT6359P_BUCK_VGPU11_SSHUB_CON0
124#define MT6359P_RG_BUCK_VGPU11_SSHUB_VOSEL_MASK 0x7F
125#define MT6359P_RG_BUCK_VGPU11_SSHUB_VOSEL_SHIFT 4
126#define MT6359P_RG_LDO_VSRAM_PROC1_VOSEL_ADDR MT6359P_LDO_VSRAM_PROC1_ELR
127#define MT6359P_RG_LDO_VSRAM_PROC2_VOSEL_ADDR MT6359P_LDO_VSRAM_PROC2_ELR
128#define MT6359P_RG_LDO_VSRAM_OTHERS_VOSEL_ADDR MT6359P_LDO_VSRAM_OTHERS_ELR
129#define MT6359P_RG_LDO_VSRAM_MD_VOSEL_ADDR MT6359P_LDO_VSRAM_MD_ELR
130#define MT6359P_RG_LDO_VEMC_VOSEL_0_ADDR MT6359P_LDO_VEMC_ELR_0
131#define MT6359P_RG_LDO_VEMC_VOSEL_0_MASK 0xF
132#define MT6359P_RG_LDO_VEMC_VOSEL_0_SHIFT 0
133#define MT6359P_RG_LDO_VFE28_EN_ADDR MT6359P_LDO_VFE28_CON0
134#define MT6359P_DA_VFE28_B_EN_ADDR MT6359P_LDO_VFE28_MON
135#define MT6359P_RG_LDO_VXO22_EN_ADDR MT6359P_LDO_VXO22_CON0
136#define MT6359P_RG_LDO_VXO22_EN_SHIFT 0
137#define MT6359P_DA_VXO22_B_EN_ADDR MT6359P_LDO_VXO22_MON
138#define MT6359P_RG_LDO_VRF18_EN_ADDR MT6359P_LDO_VRF18_CON0
139#define MT6359P_RG_LDO_VRF18_EN_SHIFT 0
140#define MT6359P_DA_VRF18_B_EN_ADDR MT6359P_LDO_VRF18_MON
141#define MT6359P_RG_LDO_VRF12_EN_ADDR MT6359P_LDO_VRF12_CON0
142#define MT6359P_RG_LDO_VRF12_EN_SHIFT 0
143#define MT6359P_DA_VRF12_B_EN_ADDR MT6359P_LDO_VRF12_MON
144#define MT6359P_RG_LDO_VEFUSE_EN_ADDR MT6359P_LDO_VEFUSE_CON0
145#define MT6359P_RG_LDO_VEFUSE_EN_SHIFT 0
146#define MT6359P_DA_VEFUSE_B_EN_ADDR MT6359P_LDO_VEFUSE_MON
147#define MT6359P_RG_LDO_VCN33_1_EN_0_ADDR MT6359P_LDO_VCN33_1_CON0
148#define MT6359P_DA_VCN33_1_B_EN_ADDR MT6359P_LDO_VCN33_1_MON
149#define MT6359P_RG_LDO_VCN33_1_EN_1_ADDR MT6359P_LDO_VCN33_1_MULTI_SW
150#define MT6359P_RG_LDO_VCN33_1_EN_1_SHIFT 15
151#define MT6359P_RG_LDO_VCN33_2_EN_0_ADDR MT6359P_LDO_VCN33_2_CON0
152#define MT6359P_RG_LDO_VCN33_2_EN_0_SHIFT 0
153#define MT6359P_DA_VCN33_2_B_EN_ADDR MT6359P_LDO_VCN33_2_MON
154#define MT6359P_RG_LDO_VCN33_2_EN_1_ADDR MT6359P_LDO_VCN33_2_MULTI_SW
155#define MT6359P_RG_LDO_VCN13_EN_ADDR MT6359P_LDO_VCN13_CON0
156#define MT6359P_RG_LDO_VCN13_EN_SHIFT 0
157#define MT6359P_DA_VCN13_B_EN_ADDR MT6359P_LDO_VCN13_MON
158#define MT6359P_RG_LDO_VCN18_EN_ADDR MT6359P_LDO_VCN18_CON0
159#define MT6359P_DA_VCN18_B_EN_ADDR MT6359P_LDO_VCN18_MON
160#define MT6359P_RG_LDO_VA09_EN_ADDR MT6359P_LDO_VA09_CON0
161#define MT6359P_RG_LDO_VA09_EN_SHIFT 0
162#define MT6359P_DA_VA09_B_EN_ADDR MT6359P_LDO_VA09_MON
163#define MT6359P_RG_LDO_VCAMIO_EN_ADDR MT6359P_LDO_VCAMIO_CON0
164#define MT6359P_RG_LDO_VCAMIO_EN_SHIFT 0
165#define MT6359P_DA_VCAMIO_B_EN_ADDR MT6359P_LDO_VCAMIO_MON
166#define MT6359P_RG_LDO_VA12_EN_ADDR MT6359P_LDO_VA12_CON0
167#define MT6359P_RG_LDO_VA12_EN_SHIFT 0
168#define MT6359P_DA_VA12_B_EN_ADDR MT6359P_LDO_VA12_MON
169#define MT6359P_RG_LDO_VAUX18_EN_ADDR MT6359P_LDO_VAUX18_CON0
170#define MT6359P_DA_VAUX18_B_EN_ADDR MT6359P_LDO_VAUX18_MON
171#define MT6359P_RG_LDO_VAUD18_EN_ADDR MT6359P_LDO_VAUD18_CON0
172#define MT6359P_DA_VAUD18_B_EN_ADDR MT6359P_LDO_VAUD18_MON
173#define MT6359P_RG_LDO_VIO18_EN_ADDR MT6359P_LDO_VIO18_CON0
174#define MT6359P_RG_LDO_VIO18_EN_SHIFT 0
175#define MT6359P_DA_VIO18_B_EN_ADDR MT6359P_LDO_VIO18_MON
176#define MT6359P_RG_LDO_VEMC_EN_ADDR MT6359P_LDO_VEMC_CON0
177#define MT6359P_RG_LDO_VEMC_EN_SHIFT 0
178#define MT6359P_DA_VEMC_B_EN_ADDR MT6359P_LDO_VEMC_MON
179#define MT6359P_RG_LDO_VSIM1_EN_ADDR MT6359P_LDO_VSIM1_CON0
180#define MT6359P_RG_LDO_VSIM1_EN_SHIFT 0
181#define MT6359P_DA_VSIM1_B_EN_ADDR MT6359P_LDO_VSIM1_MON
182#define MT6359P_RG_LDO_VSIM2_EN_ADDR MT6359P_LDO_VSIM2_CON0
183#define MT6359P_RG_LDO_VSIM2_EN_SHIFT 0
184#define MT6359P_DA_VSIM2_B_EN_ADDR MT6359P_LDO_VSIM2_MON
185#define MT6359P_RG_LDO_VUSB_EN_0_ADDR MT6359P_LDO_VUSB_CON0
186#define MT6359P_DA_VUSB_B_EN_ADDR MT6359P_LDO_VUSB_MON
187#define MT6359P_RG_LDO_VUSB_EN_1_ADDR MT6359P_LDO_VUSB_MULTI_SW
188#define MT6359P_RG_LDO_VRFCK_EN_ADDR MT6359P_LDO_VRFCK_CON0
189#define MT6359P_RG_LDO_VRFCK_EN_SHIFT 0
190#define MT6359P_DA_VRFCK_B_EN_ADDR MT6359P_LDO_VRFCK_MON
191#define MT6359P_RG_LDO_VBBCK_EN_ADDR MT6359P_LDO_VBBCK_CON0
192#define MT6359P_RG_LDO_VBBCK_EN_SHIFT 0
193#define MT6359P_DA_VBBCK_B_EN_ADDR MT6359P_LDO_VBBCK_MON
194#define MT6359P_RG_LDO_VBIF28_EN_ADDR MT6359P_LDO_VBIF28_CON0
195#define MT6359P_DA_VBIF28_B_EN_ADDR MT6359P_LDO_VBIF28_MON
196#define MT6359P_RG_LDO_VIBR_EN_ADDR MT6359P_LDO_VIBR_CON0
197#define MT6359P_RG_LDO_VIBR_EN_SHIFT 0
198#define MT6359P_DA_VIBR_B_EN_ADDR MT6359P_LDO_VIBR_MON
199#define MT6359P_RG_LDO_VIO28_EN_ADDR MT6359P_LDO_VIO28_CON0
200#define MT6359P_RG_LDO_VIO28_EN_SHIFT 0
201#define MT6359P_DA_VIO28_B_EN_ADDR MT6359P_LDO_VIO28_MON
202#define MT6359P_RG_LDO_VM18_EN_ADDR MT6359P_LDO_VM18_CON0
203#define MT6359P_RG_LDO_VM18_EN_SHIFT 0
204#define MT6359P_DA_VM18_B_EN_ADDR MT6359P_LDO_VM18_MON
205#define MT6359P_RG_LDO_VUFS_EN_ADDR MT6359P_LDO_VUFS_CON0
206#define MT6359P_RG_LDO_VUFS_EN_SHIFT 0
207#define MT6359P_DA_VUFS_B_EN_ADDR MT6359P_LDO_VUFS_MON
208#define MT6359P_RG_LDO_VSRAM_PROC1_EN_ADDR MT6359P_LDO_VSRAM_PROC1_CON0
209#define MT6359P_DA_VSRAM_PROC1_B_EN_ADDR MT6359P_LDO_VSRAM_PROC1_MON
210#define MT6359P_DA_VSRAM_PROC1_VOSEL_ADDR MT6359P_LDO_VSRAM_PROC1_VOSEL1
211#define MT6359P_RG_LDO_VSRAM_PROC2_EN_ADDR MT6359P_LDO_VSRAM_PROC2_CON0
212#define MT6359P_DA_VSRAM_PROC2_B_EN_ADDR MT6359P_LDO_VSRAM_PROC2_MON
213#define MT6359P_DA_VSRAM_PROC2_VOSEL_ADDR MT6359P_LDO_VSRAM_PROC2_VOSEL1
214#define MT6359P_RG_LDO_VSRAM_OTHERS_EN_ADDR MT6359P_LDO_VSRAM_OTHERS_CON0
215#define MT6359P_DA_VSRAM_OTHERS_B_EN_ADDR MT6359P_LDO_VSRAM_OTHERS_MON
216#define MT6359P_DA_VSRAM_OTHERS_VOSEL_ADDR MT6359P_LDO_VSRAM_OTHERS_VOSEL1
217#define MT6359P_RG_LDO_VSRAM_OTHERS_SSHUB_EN_ADDR MT6359P_LDO_VSRAM_OTHERS_SSHUB
218#define MT6359P_RG_LDO_VSRAM_OTHERS_SSHUB_VOSEL_ADDR MT6359P_LDO_VSRAM_OTHERS_SSHUB
219#define MT6359P_RG_LDO_VSRAM_MD_EN_ADDR MT6359P_LDO_VSRAM_MD_CON0
220#define MT6359P_DA_VSRAM_MD_B_EN_ADDR MT6359P_LDO_VSRAM_MD_MON
221#define MT6359P_DA_VSRAM_MD_VOSEL_ADDR MT6359P_LDO_VSRAM_MD_VOSEL1
222#define MT6359P_RG_VCN33_1_VOSEL_ADDR MT6359P_VCN33_1_ANA_CON0
223#define MT6359P_RG_VCN33_2_VOSEL_ADDR MT6359P_VCN33_2_ANA_CON0
224#define MT6359P_RG_VEMC_VOSEL_ADDR MT6359P_VEMC_ANA_CON0
225#define MT6359P_RG_VSIM1_VOSEL_ADDR MT6359P_VSIM1_ANA_CON0
226#define MT6359P_RG_VSIM2_VOSEL_ADDR MT6359P_VSIM2_ANA_CON0
227#define MT6359P_RG_VIO28_VOSEL_ADDR MT6359P_VIO28_ANA_CON0
228#define MT6359P_RG_VIBR_VOSEL_ADDR MT6359P_VIBR_ANA_CON0
229#define MT6359P_RG_VRF18_VOSEL_ADDR MT6359P_VRF18_ANA_CON0
230#define MT6359P_RG_VEFUSE_VOSEL_ADDR MT6359P_VEFUSE_ANA_CON0
231#define MT6359P_RG_VCAMIO_VOSEL_ADDR MT6359P_VCAMIO_ANA_CON0
232#define MT6359P_RG_VIO18_VOSEL_ADDR MT6359P_VIO18_ANA_CON0
233#define MT6359P_RG_VM18_VOSEL_ADDR MT6359P_VM18_ANA_CON0
234#define MT6359P_RG_VUFS_VOSEL_ADDR MT6359P_VUFS_ANA_CON0
235#define MT6359P_RG_VRF12_VOSEL_ADDR MT6359P_VRF12_ANA_CON0
236#define MT6359P_RG_VCN13_VOSEL_ADDR MT6359P_VCN13_ANA_CON0
237#define MT6359P_RG_VA09_VOSEL_ADDR MT6359P_VRF18_ELR_3
238#define MT6359P_RG_VA12_VOSEL_ADDR MT6359P_VFE28_ELR_4
239#define MT6359P_RG_VXO22_VOSEL_ADDR MT6359P_VXO22_ANA_CON0
240#define MT6359P_RG_VRFCK_VOSEL_ADDR MT6359P_VRFCK_ANA_CON0
241#define MT6359P_RG_VBBCK_VOSEL_ADDR MT6359P_VBBCK_ANA_CON0
242#define MT6359P_RG_VBBCK_VOSEL_MASK 0xF
243#define MT6359P_RG_VBBCK_VOSEL_SHIFT 4
244#define MT6359P_VM_MODE_ADDR MT6359P_TOP_TRAP
245#define MT6359P_TMA_KEY_ADDR MT6359P_TOP_TMA_KEY
246
247#define TMA_KEY 0x9CA6
248
249#endif /* __MFD_MT6359P_REGISTERS_H__ */
250

source code of linux/include/linux/mfd/mt6359p/registers.h