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