ARM: OMAP5: Enable ABB configuration for MM voltage domain
[platform/kernel/u-boot.git] / arch / arm / cpu / armv7 / omap5 / prcm-regs.c
1 /*
2  *
3  * HW regs data for OMAP5 Soc
4  *
5  * (C) Copyright 2013
6  * Texas Instruments, <www.ti.com>
7  *
8  * Sricharan R <r.sricharan@ti.com>
9  *
10  * SPDX-License-Identifier:     GPL-2.0+
11  */
12
13 #include <asm/omap_common.h>
14 #include <asm/io.h>
15
16 struct prcm_regs const omap5_es1_prcm = {
17         /* cm1.ckgen */
18         .cm_clksel_core = 0x4a004100,
19         .cm_clksel_abe = 0x4a004108,
20         .cm_dll_ctrl = 0x4a004110,
21         .cm_clkmode_dpll_core = 0x4a004120,
22         .cm_idlest_dpll_core = 0x4a004124,
23         .cm_autoidle_dpll_core = 0x4a004128,
24         .cm_clksel_dpll_core = 0x4a00412c,
25         .cm_div_m2_dpll_core = 0x4a004130,
26         .cm_div_m3_dpll_core = 0x4a004134,
27         .cm_div_h11_dpll_core = 0x4a004138,
28         .cm_div_h12_dpll_core = 0x4a00413c,
29         .cm_div_h13_dpll_core = 0x4a004140,
30         .cm_div_h14_dpll_core = 0x4a004144,
31         .cm_ssc_deltamstep_dpll_core = 0x4a004148,
32         .cm_ssc_modfreqdiv_dpll_core = 0x4a00414c,
33         .cm_emu_override_dpll_core = 0x4a004150,
34         .cm_div_h22_dpllcore = 0x4a004154,
35         .cm_div_h23_dpll_core = 0x4a004158,
36         .cm_clkmode_dpll_mpu = 0x4a004160,
37         .cm_idlest_dpll_mpu = 0x4a004164,
38         .cm_autoidle_dpll_mpu = 0x4a004168,
39         .cm_clksel_dpll_mpu = 0x4a00416c,
40         .cm_div_m2_dpll_mpu = 0x4a004170,
41         .cm_ssc_deltamstep_dpll_mpu = 0x4a004188,
42         .cm_ssc_modfreqdiv_dpll_mpu = 0x4a00418c,
43         .cm_bypclk_dpll_mpu = 0x4a00419c,
44         .cm_clkmode_dpll_iva = 0x4a0041a0,
45         .cm_idlest_dpll_iva = 0x4a0041a4,
46         .cm_autoidle_dpll_iva = 0x4a0041a8,
47         .cm_clksel_dpll_iva = 0x4a0041ac,
48         .cm_div_h11_dpll_iva = 0x4a0041b8,
49         .cm_div_h12_dpll_iva = 0x4a0041bc,
50         .cm_ssc_deltamstep_dpll_iva = 0x4a0041c8,
51         .cm_ssc_modfreqdiv_dpll_iva = 0x4a0041cc,
52         .cm_bypclk_dpll_iva = 0x4a0041dc,
53         .cm_clkmode_dpll_abe = 0x4a0041e0,
54         .cm_idlest_dpll_abe = 0x4a0041e4,
55         .cm_autoidle_dpll_abe = 0x4a0041e8,
56         .cm_clksel_dpll_abe = 0x4a0041ec,
57         .cm_div_m2_dpll_abe = 0x4a0041f0,
58         .cm_div_m3_dpll_abe = 0x4a0041f4,
59         .cm_ssc_deltamstep_dpll_abe = 0x4a004208,
60         .cm_ssc_modfreqdiv_dpll_abe = 0x4a00420c,
61         .cm_clkmode_dpll_ddrphy = 0x4a004220,
62         .cm_idlest_dpll_ddrphy = 0x4a004224,
63         .cm_autoidle_dpll_ddrphy = 0x4a004228,
64         .cm_clksel_dpll_ddrphy = 0x4a00422c,
65         .cm_div_m2_dpll_ddrphy = 0x4a004230,
66         .cm_div_h11_dpll_ddrphy = 0x4a004238,
67         .cm_div_h12_dpll_ddrphy = 0x4a00423c,
68         .cm_div_h13_dpll_ddrphy = 0x4a004240,
69         .cm_ssc_deltamstep_dpll_ddrphy = 0x4a004248,
70         .cm_shadow_freq_config1 = 0x4a004260,
71         .cm_mpu_mpu_clkctrl = 0x4a004320,
72
73         /* cm1.dsp */
74         .cm_dsp_clkstctrl = 0x4a004400,
75         .cm_dsp_dsp_clkctrl = 0x4a004420,
76
77         /* cm1.abe */
78         .cm1_abe_clkstctrl = 0x4a004500,
79         .cm1_abe_l4abe_clkctrl = 0x4a004520,
80         .cm1_abe_aess_clkctrl = 0x4a004528,
81         .cm1_abe_pdm_clkctrl = 0x4a004530,
82         .cm1_abe_dmic_clkctrl = 0x4a004538,
83         .cm1_abe_mcasp_clkctrl = 0x4a004540,
84         .cm1_abe_mcbsp1_clkctrl = 0x4a004548,
85         .cm1_abe_mcbsp2_clkctrl = 0x4a004550,
86         .cm1_abe_mcbsp3_clkctrl = 0x4a004558,
87         .cm1_abe_slimbus_clkctrl = 0x4a004560,
88         .cm1_abe_timer5_clkctrl = 0x4a004568,
89         .cm1_abe_timer6_clkctrl = 0x4a004570,
90         .cm1_abe_timer7_clkctrl = 0x4a004578,
91         .cm1_abe_timer8_clkctrl = 0x4a004580,
92         .cm1_abe_wdt3_clkctrl = 0x4a004588,
93
94         /* cm2.ckgen */
95         .cm_clksel_mpu_m3_iss_root = 0x4a008100,
96         .cm_clksel_usb_60mhz = 0x4a008104,
97         .cm_scale_fclk = 0x4a008108,
98         .cm_core_dvfs_perf1 = 0x4a008110,
99         .cm_core_dvfs_perf2 = 0x4a008114,
100         .cm_core_dvfs_perf3 = 0x4a008118,
101         .cm_core_dvfs_perf4 = 0x4a00811c,
102         .cm_core_dvfs_current = 0x4a008124,
103         .cm_iva_dvfs_perf_tesla = 0x4a008128,
104         .cm_iva_dvfs_perf_ivahd = 0x4a00812c,
105         .cm_iva_dvfs_perf_abe = 0x4a008130,
106         .cm_iva_dvfs_current = 0x4a008138,
107         .cm_clkmode_dpll_per = 0x4a008140,
108         .cm_idlest_dpll_per = 0x4a008144,
109         .cm_autoidle_dpll_per = 0x4a008148,
110         .cm_clksel_dpll_per = 0x4a00814c,
111         .cm_div_m2_dpll_per = 0x4a008150,
112         .cm_div_m3_dpll_per = 0x4a008154,
113         .cm_div_h11_dpll_per = 0x4a008158,
114         .cm_div_h12_dpll_per = 0x4a00815c,
115         .cm_div_h14_dpll_per = 0x4a008164,
116         .cm_ssc_deltamstep_dpll_per = 0x4a008168,
117         .cm_ssc_modfreqdiv_dpll_per = 0x4a00816c,
118         .cm_emu_override_dpll_per = 0x4a008170,
119         .cm_clkmode_dpll_usb = 0x4a008180,
120         .cm_idlest_dpll_usb = 0x4a008184,
121         .cm_autoidle_dpll_usb = 0x4a008188,
122         .cm_clksel_dpll_usb = 0x4a00818c,
123         .cm_div_m2_dpll_usb = 0x4a008190,
124         .cm_ssc_deltamstep_dpll_usb = 0x4a0081a8,
125         .cm_ssc_modfreqdiv_dpll_usb = 0x4a0081ac,
126         .cm_clkdcoldo_dpll_usb = 0x4a0081b4,
127         .cm_clkmode_dpll_unipro = 0x4a0081c0,
128         .cm_idlest_dpll_unipro = 0x4a0081c4,
129         .cm_autoidle_dpll_unipro = 0x4a0081c8,
130         .cm_clksel_dpll_unipro = 0x4a0081cc,
131         .cm_div_m2_dpll_unipro = 0x4a0081d0,
132         .cm_ssc_deltamstep_dpll_unipro = 0x4a0081e8,
133         .cm_ssc_modfreqdiv_dpll_unipro = 0x4a0081ec,
134
135         /* cm2.core */
136         .cm_coreaon_bandgap_clkctrl = 0x4a008648,
137         .cm_coreaon_io_srcomp_clkctrl = 0x4a008650,
138         .cm_l3_1_clkstctrl = 0x4a008700,
139         .cm_l3_1_dynamicdep = 0x4a008708,
140         .cm_l3_1_l3_1_clkctrl = 0x4a008720,
141         .cm_l3_2_clkstctrl = 0x4a008800,
142         .cm_l3_2_dynamicdep = 0x4a008808,
143         .cm_l3_2_l3_2_clkctrl = 0x4a008820,
144         .cm_l3_gpmc_clkctrl = 0x4a008828,
145         .cm_l3_2_ocmc_ram_clkctrl = 0x4a008830,
146         .cm_mpu_m3_clkstctrl = 0x4a008900,
147         .cm_mpu_m3_staticdep = 0x4a008904,
148         .cm_mpu_m3_dynamicdep = 0x4a008908,
149         .cm_mpu_m3_mpu_m3_clkctrl = 0x4a008920,
150         .cm_sdma_clkstctrl = 0x4a008a00,
151         .cm_sdma_staticdep = 0x4a008a04,
152         .cm_sdma_dynamicdep = 0x4a008a08,
153         .cm_sdma_sdma_clkctrl = 0x4a008a20,
154         .cm_memif_clkstctrl = 0x4a008b00,
155         .cm_memif_dmm_clkctrl = 0x4a008b20,
156         .cm_memif_emif_fw_clkctrl = 0x4a008b28,
157         .cm_memif_emif_1_clkctrl = 0x4a008b30,
158         .cm_memif_emif_2_clkctrl = 0x4a008b38,
159         .cm_memif_dll_clkctrl = 0x4a008b40,
160         .cm_memif_emif_h1_clkctrl = 0x4a008b50,
161         .cm_memif_emif_h2_clkctrl = 0x4a008b58,
162         .cm_memif_dll_h_clkctrl = 0x4a008b60,
163         .cm_c2c_clkstctrl = 0x4a008c00,
164         .cm_c2c_staticdep = 0x4a008c04,
165         .cm_c2c_dynamicdep = 0x4a008c08,
166         .cm_c2c_sad2d_clkctrl = 0x4a008c20,
167         .cm_c2c_modem_icr_clkctrl = 0x4a008c28,
168         .cm_c2c_sad2d_fw_clkctrl = 0x4a008c30,
169         .cm_l4cfg_clkstctrl = 0x4a008d00,
170         .cm_l4cfg_dynamicdep = 0x4a008d08,
171         .cm_l4cfg_l4_cfg_clkctrl = 0x4a008d20,
172         .cm_l4cfg_hw_sem_clkctrl = 0x4a008d28,
173         .cm_l4cfg_mailbox_clkctrl = 0x4a008d30,
174         .cm_l4cfg_sar_rom_clkctrl = 0x4a008d38,
175         .cm_l3instr_clkstctrl = 0x4a008e00,
176         .cm_l3instr_l3_3_clkctrl = 0x4a008e20,
177         .cm_l3instr_l3_instr_clkctrl = 0x4a008e28,
178         .cm_l3instr_intrconn_wp1_clkctrl = 0x4a008e40,
179
180         /* cm2.ivahd */
181         .cm_ivahd_clkstctrl = 0x4a008f00,
182         .cm_ivahd_ivahd_clkctrl = 0x4a008f20,
183         .cm_ivahd_sl2_clkctrl = 0x4a008f28,
184
185         /* cm2.cam */
186         .cm_cam_clkstctrl = 0x4a009000,
187         .cm_cam_iss_clkctrl = 0x4a009020,
188         .cm_cam_fdif_clkctrl = 0x4a009028,
189
190         /* cm2.dss */
191         .cm_dss_clkstctrl = 0x4a009100,
192         .cm_dss_dss_clkctrl = 0x4a009120,
193
194         /* cm2.sgx */
195         .cm_sgx_clkstctrl = 0x4a009200,
196         .cm_sgx_sgx_clkctrl = 0x4a009220,
197
198         /* cm2.l3init */
199         .cm_l3init_clkstctrl = 0x4a009300,
200         .cm_l3init_hsmmc1_clkctrl = 0x4a009328,
201         .cm_l3init_hsmmc2_clkctrl = 0x4a009330,
202         .cm_l3init_hsi_clkctrl = 0x4a009338,
203         .cm_l3init_hsusbhost_clkctrl = 0x4a009358,
204         .cm_l3init_hsusbotg_clkctrl = 0x4a009360,
205         .cm_l3init_hsusbtll_clkctrl = 0x4a009368,
206         .cm_l3init_p1500_clkctrl = 0x4a009378,
207         .cm_l3init_sata_clkctrl = 0x4a009388,
208         .cm_l3init_fsusb_clkctrl = 0x4a0093d0,
209         .cm_l3init_ocp2scp1_clkctrl = 0x4a0093e0,
210         .cm_l3init_ocp2scp3_clkctrl = 0x4a0093e8,
211
212         /* cm2.l4per */
213         .cm_l4per_clkstctrl = 0x4a009400,
214         .cm_l4per_dynamicdep = 0x4a009408,
215         .cm_l4per_adc_clkctrl = 0x4a009420,
216         .cm_l4per_gptimer10_clkctrl = 0x4a009428,
217         .cm_l4per_gptimer11_clkctrl = 0x4a009430,
218         .cm_l4per_gptimer2_clkctrl = 0x4a009438,
219         .cm_l4per_gptimer3_clkctrl = 0x4a009440,
220         .cm_l4per_gptimer4_clkctrl = 0x4a009448,
221         .cm_l4per_gptimer9_clkctrl = 0x4a009450,
222         .cm_l4per_elm_clkctrl = 0x4a009458,
223         .cm_l4per_gpio2_clkctrl = 0x4a009460,
224         .cm_l4per_gpio3_clkctrl = 0x4a009468,
225         .cm_l4per_gpio4_clkctrl = 0x4a009470,
226         .cm_l4per_gpio5_clkctrl = 0x4a009478,
227         .cm_l4per_gpio6_clkctrl = 0x4a009480,
228         .cm_l4per_hdq1w_clkctrl = 0x4a009488,
229         .cm_l4per_hecc1_clkctrl = 0x4a009490,
230         .cm_l4per_hecc2_clkctrl = 0x4a009498,
231         .cm_l4per_i2c1_clkctrl = 0x4a0094a0,
232         .cm_l4per_i2c2_clkctrl = 0x4a0094a8,
233         .cm_l4per_i2c3_clkctrl = 0x4a0094b0,
234         .cm_l4per_i2c4_clkctrl = 0x4a0094b8,
235         .cm_l4per_l4per_clkctrl = 0x4a0094c0,
236         .cm_l4per_mcasp2_clkctrl = 0x4a0094d0,
237         .cm_l4per_mcasp3_clkctrl = 0x4a0094d8,
238         .cm_l4per_mgate_clkctrl = 0x4a0094e8,
239         .cm_l4per_mcspi1_clkctrl = 0x4a0094f0,
240         .cm_l4per_mcspi2_clkctrl = 0x4a0094f8,
241         .cm_l4per_mcspi3_clkctrl = 0x4a009500,
242         .cm_l4per_mcspi4_clkctrl = 0x4a009508,
243         .cm_l4per_gpio7_clkctrl = 0x4a009510,
244         .cm_l4per_gpio8_clkctrl = 0x4a009518,
245         .cm_l4per_mmcsd3_clkctrl = 0x4a009520,
246         .cm_l4per_mmcsd4_clkctrl = 0x4a009528,
247         .cm_l4per_msprohg_clkctrl = 0x4a009530,
248         .cm_l4per_slimbus2_clkctrl = 0x4a009538,
249         .cm_l4per_uart1_clkctrl = 0x4a009540,
250         .cm_l4per_uart2_clkctrl = 0x4a009548,
251         .cm_l4per_uart3_clkctrl = 0x4a009550,
252         .cm_l4per_uart4_clkctrl = 0x4a009558,
253         .cm_l4per_mmcsd5_clkctrl = 0x4a009560,
254         .cm_l4per_i2c5_clkctrl = 0x4a009568,
255         .cm_l4per_uart5_clkctrl = 0x4a009570,
256         .cm_l4per_uart6_clkctrl = 0x4a009578,
257         .cm_l4sec_clkstctrl = 0x4a009580,
258         .cm_l4sec_staticdep = 0x4a009584,
259         .cm_l4sec_dynamicdep = 0x4a009588,
260         .cm_l4sec_aes1_clkctrl = 0x4a0095a0,
261         .cm_l4sec_aes2_clkctrl = 0x4a0095a8,
262         .cm_l4sec_des3des_clkctrl = 0x4a0095b0,
263         .cm_l4sec_pkaeip29_clkctrl = 0x4a0095b8,
264         .cm_l4sec_rng_clkctrl = 0x4a0095c0,
265         .cm_l4sec_sha2md51_clkctrl = 0x4a0095c8,
266         .cm_l4sec_cryptodma_clkctrl = 0x4a0095d8,
267
268         /* l4 wkup regs */
269         .cm_abe_pll_ref_clksel = 0x4ae0610c,
270         .cm_sys_clksel = 0x4ae06110,
271         .cm_wkup_clkstctrl = 0x4ae07800,
272         .cm_wkup_l4wkup_clkctrl = 0x4ae07820,
273         .cm_wkup_wdtimer1_clkctrl = 0x4ae07828,
274         .cm_wkup_wdtimer2_clkctrl = 0x4ae07830,
275         .cm_wkup_gpio1_clkctrl = 0x4ae07838,
276         .cm_wkup_gptimer1_clkctrl = 0x4ae07840,
277         .cm_wkup_gptimer12_clkctrl = 0x4ae07848,
278         .cm_wkup_synctimer_clkctrl = 0x4ae07850,
279         .cm_wkup_usim_clkctrl = 0x4ae07858,
280         .cm_wkup_sarram_clkctrl = 0x4ae07860,
281         .cm_wkup_keyboard_clkctrl = 0x4ae07878,
282         .cm_wkup_rtc_clkctrl = 0x4ae07880,
283         .cm_wkup_bandgap_clkctrl = 0x4ae07888,
284         .cm_wkupaon_scrm_clkctrl = 0x4ae07890,
285         .cm_wkupaon_io_srcomp_clkctrl = 0x4ae07898,
286         .prm_rstctrl = 0x4ae07b00,
287         .prm_rstst = 0x4ae07b04,
288         .prm_rsttime = 0x4ae07b08,
289         .prm_vc_val_bypass = 0x4ae07ba0,
290         .prm_vc_cfg_i2c_mode = 0x4ae07bb4,
291         .prm_vc_cfg_i2c_clk = 0x4ae07bb8,
292
293         /* SCRM stuff, used by some boards */
294         .scrm_auxclk0 = 0x4ae0a310,
295         .scrm_auxclk1 = 0x4ae0a314,
296 };
297
298 struct omap_sys_ctrl_regs const omap5_ctrl = {
299         .control_status                         = 0x4A002134,
300         .control_std_fuse_die_id_0              = 0x4A002200,
301         .control_std_fuse_die_id_1              = 0x4A002208,
302         .control_std_fuse_die_id_2              = 0x4A00220C,
303         .control_std_fuse_die_id_3              = 0x4A002210,
304         .control_phy_power_usb                  = 0x4A002370,
305         .control_phy_power_sata                 = 0x4A002374,
306         .control_padconf_core_base              = 0x4A002800,
307         .control_paconf_global                  = 0x4A002DA0,
308         .control_paconf_mode                    = 0x4A002DA4,
309         .control_smart1io_padconf_0             = 0x4A002DA8,
310         .control_smart1io_padconf_1             = 0x4A002DAC,
311         .control_smart1io_padconf_2             = 0x4A002DB0,
312         .control_smart2io_padconf_0             = 0x4A002DB4,
313         .control_smart2io_padconf_1             = 0x4A002DB8,
314         .control_smart2io_padconf_2             = 0x4A002DBC,
315         .control_smart3io_padconf_0             = 0x4A002DC0,
316         .control_smart3io_padconf_1             = 0x4A002DC4,
317         .control_pbias                          = 0x4A002E00,
318         .control_i2c_0                          = 0x4A002E04,
319         .control_camera_rx                      = 0x4A002E08,
320         .control_hdmi_tx_phy                    = 0x4A002E0C,
321         .control_uniportm                       = 0x4A002E10,
322         .control_dsiphy                         = 0x4A002E14,
323         .control_mcbsplp                        = 0x4A002E18,
324         .control_usb2phycore                    = 0x4A002E1C,
325         .control_hdmi_1                         = 0x4A002E20,
326         .control_hsi                            = 0x4A002E24,
327         .control_ddr3ch1_0                      = 0x4A002E30,
328         .control_ddr3ch2_0                      = 0x4A002E34,
329         .control_ddrch1_0                       = 0x4A002E38,
330         .control_ddrch1_1                       = 0x4A002E3C,
331         .control_ddrch2_0                       = 0x4A002E40,
332         .control_ddrch2_1                       = 0x4A002E44,
333         .control_lpddr2ch1_0                    = 0x4A002E48,
334         .control_lpddr2ch1_1                    = 0x4A002E4C,
335         .control_ddrio_0                        = 0x4A002E50,
336         .control_ddrio_1                        = 0x4A002E54,
337         .control_ddrio_2                        = 0x4A002E58,
338         .control_hyst_1                         = 0x4A002E5C,
339         .control_usbb_hsic_control              = 0x4A002E60,
340         .control_c2c                            = 0x4A002E64,
341         .control_core_control_spare_rw          = 0x4A002E68,
342         .control_core_control_spare_r           = 0x4A002E6C,
343         .control_core_control_spare_r_c0        = 0x4A002E70,
344         .control_srcomp_north_side              = 0x4A002E74,
345         .control_srcomp_south_side              = 0x4A002E78,
346         .control_srcomp_east_side               = 0x4A002E7C,
347         .control_srcomp_west_side               = 0x4A002E80,
348         .control_srcomp_code_latch              = 0x4A002E84,
349         .control_port_emif1_sdram_config        = 0x4AE0C110,
350         .control_port_emif1_lpddr2_nvm_config   = 0x4AE0C114,
351         .control_port_emif2_sdram_config        = 0x4AE0C118,
352         .control_emif1_sdram_config_ext         = 0x4AE0C144,
353         .control_emif2_sdram_config_ext         = 0x4AE0C148,
354         .control_wkup_ldovbb_mpu_voltage_ctrl   = 0x4AE0C318,
355         .control_wkup_ldovbb_mm_voltage_ctrl    = 0x4AE0C314,
356         .control_padconf_wkup_base              = 0x4AE0C800,
357         .control_smart1nopmio_padconf_0         = 0x4AE0CDA0,
358         .control_smart1nopmio_padconf_1         = 0x4AE0CDA4,
359         .control_padconf_mode                   = 0x4AE0CDA8,
360         .control_xtal_oscillator                = 0x4AE0CDAC,
361         .control_i2c_2                          = 0x4AE0CDB0,
362         .control_ckobuffer                      = 0x4AE0CDB4,
363         .control_wkup_control_spare_rw          = 0x4AE0CDB8,
364         .control_wkup_control_spare_r           = 0x4AE0CDBC,
365         .control_wkup_control_spare_r_c0        = 0x4AE0CDC0,
366         .control_srcomp_east_side_wkup          = 0x4AE0CDC4,
367         .control_efuse_1                        = 0x4AE0CDC8,
368         .control_efuse_2                        = 0x4AE0CDCC,
369         .control_efuse_3                        = 0x4AE0CDD0,
370         .control_efuse_4                        = 0x4AE0CDD4,
371         .control_efuse_5                        = 0x4AE0CDD8,
372         .control_efuse_6                        = 0x4AE0CDDC,
373         .control_efuse_7                        = 0x4AE0CDE0,
374         .control_efuse_8                        = 0x4AE0CDE4,
375         .control_efuse_9                        = 0x4AE0CDE8,
376         .control_efuse_10                       = 0x4AE0CDEC,
377         .control_efuse_11                       = 0x4AE0CDF0,
378         .control_efuse_12                       = 0x4AE0CDF4,
379         .control_efuse_13                       = 0x4AE0CDF8,
380 };
381
382 struct omap_sys_ctrl_regs const dra7xx_ctrl = {
383         .control_status                         = 0x4A002134,
384         .control_phy_power_usb                  = 0x4A002370,
385         .control_phy_power_sata                 = 0x4A002374,
386         .ctrl_core_sma_sw_0                     = 0x4A0023FC,
387         .ctrl_core_sma_sw_1                     = 0x4A002534,
388         .control_core_mac_id_0_lo               = 0x4A002514,
389         .control_core_mac_id_0_hi               = 0x4A002518,
390         .control_core_mac_id_1_lo               = 0x4A00251C,
391         .control_core_mac_id_1_hi               = 0x4A002520,
392         .control_core_mmr_lock1                 = 0x4A002540,
393         .control_core_mmr_lock2                 = 0x4A002544,
394         .control_core_mmr_lock3                 = 0x4A002548,
395         .control_core_mmr_lock4                 = 0x4A00254C,
396         .control_core_mmr_lock5                 = 0x4A002550,
397         .control_core_control_io1               = 0x4A002554,
398         .control_core_control_io2               = 0x4A002558,
399         .control_paconf_global                  = 0x4A002DA0,
400         .control_paconf_mode                    = 0x4A002DA4,
401         .control_smart1io_padconf_0             = 0x4A002DA8,
402         .control_smart1io_padconf_1             = 0x4A002DAC,
403         .control_smart1io_padconf_2             = 0x4A002DB0,
404         .control_smart2io_padconf_0             = 0x4A002DB4,
405         .control_smart2io_padconf_1             = 0x4A002DB8,
406         .control_smart2io_padconf_2             = 0x4A002DBC,
407         .control_smart3io_padconf_0             = 0x4A002DC0,
408         .control_smart3io_padconf_1             = 0x4A002DC4,
409         .control_pbias                          = 0x4A002E00,
410         .control_i2c_0                          = 0x4A002E04,
411         .control_camera_rx                      = 0x4A002E08,
412         .control_hdmi_tx_phy                    = 0x4A002E0C,
413         .control_uniportm                       = 0x4A002E10,
414         .control_dsiphy                         = 0x4A002E14,
415         .control_mcbsplp                        = 0x4A002E18,
416         .control_usb2phycore                    = 0x4A002E1C,
417         .control_hdmi_1                         = 0x4A002E20,
418         .control_hsi                            = 0x4A002E24,
419         .control_ddr3ch1_0                      = 0x4A002E30,
420         .control_ddr3ch2_0                      = 0x4A002E34,
421         .control_ddrch1_0                       = 0x4A002E38,
422         .control_ddrch1_1                       = 0x4A002E3C,
423         .control_ddrch2_0                       = 0x4A002E40,
424         .control_ddrch2_1                       = 0x4A002E44,
425         .control_lpddr2ch1_0                    = 0x4A002E48,
426         .control_lpddr2ch1_1                    = 0x4A002E4C,
427         .control_ddrio_0                        = 0x4A002E50,
428         .control_ddrio_1                        = 0x4A002E54,
429         .control_ddrio_2                        = 0x4A002E58,
430         .control_hyst_1                         = 0x4A002E5C,
431         .control_usbb_hsic_control              = 0x4A002E60,
432         .control_c2c                            = 0x4A002E64,
433         .control_core_control_spare_rw          = 0x4A002E68,
434         .control_core_control_spare_r           = 0x4A002E6C,
435         .control_core_control_spare_r_c0        = 0x4A002E70,
436         .control_srcomp_north_side              = 0x4A002E74,
437         .control_srcomp_south_side              = 0x4A002E78,
438         .control_srcomp_east_side               = 0x4A002E7C,
439         .control_srcomp_west_side               = 0x4A002E80,
440         .control_srcomp_code_latch              = 0x4A002E84,
441         .control_ddr_control_ext_0              = 0x4A002E88,
442         .control_padconf_core_base              = 0x4A003400,
443         .control_port_emif1_sdram_config        = 0x4AE0C110,
444         .control_port_emif1_lpddr2_nvm_config   = 0x4AE0C114,
445         .control_port_emif2_sdram_config        = 0x4AE0C118,
446         .control_emif1_sdram_config_ext         = 0x4AE0C144,
447         .control_emif2_sdram_config_ext         = 0x4AE0C148,
448         .control_wkup_ldovbb_mpu_voltage_ctrl   = 0x4AE0C158,
449         .control_std_fuse_die_id_0              = 0x4AE0C200,
450         .control_std_fuse_die_id_1              = 0x4AE0C208,
451         .control_std_fuse_die_id_2              = 0x4AE0C20C,
452         .control_std_fuse_die_id_3              = 0x4AE0C210,
453         .control_padconf_mode                   = 0x4AE0C5A0,
454         .control_xtal_oscillator                = 0x4AE0C5A4,
455         .control_i2c_2                          = 0x4AE0C5A8,
456         .control_ckobuffer                      = 0x4AE0C5AC,
457         .control_wkup_control_spare_rw          = 0x4AE0C5B0,
458         .control_wkup_control_spare_r           = 0x4AE0C5B4,
459         .control_wkup_control_spare_r_c0        = 0x4AE0C5B8,
460         .control_srcomp_east_side_wkup          = 0x4AE0C5BC,
461         .control_efuse_1                        = 0x4AE0C5C8,
462         .control_efuse_2                        = 0x4AE0C5CC,
463         .control_efuse_3                        = 0x4AE0C5D0,
464         .control_efuse_4                        = 0x4AE0C5D4,
465         .control_efuse_13                       = 0x4AE0C5F0,
466         .iodelay_config_base                    = 0x4844A000,
467 };
468
469 struct prcm_regs const omap5_es2_prcm = {
470         /* cm1.ckgen */
471         .cm_clksel_core = 0x4a004100,
472         .cm_clksel_abe = 0x4a004108,
473         .cm_dll_ctrl = 0x4a004110,
474         .cm_clkmode_dpll_core = 0x4a004120,
475         .cm_idlest_dpll_core = 0x4a004124,
476         .cm_autoidle_dpll_core = 0x4a004128,
477         .cm_clksel_dpll_core = 0x4a00412c,
478         .cm_div_m2_dpll_core = 0x4a004130,
479         .cm_div_m3_dpll_core = 0x4a004134,
480         .cm_div_h11_dpll_core = 0x4a004138,
481         .cm_div_h12_dpll_core = 0x4a00413c,
482         .cm_div_h13_dpll_core = 0x4a004140,
483         .cm_div_h14_dpll_core = 0x4a004144,
484         .cm_ssc_deltamstep_dpll_core = 0x4a004148,
485         .cm_ssc_modfreqdiv_dpll_core = 0x4a00414c,
486         .cm_div_h21_dpll_core = 0x4a004150,
487         .cm_div_h22_dpllcore = 0x4a004154,
488         .cm_div_h23_dpll_core = 0x4a004158,
489         .cm_div_h24_dpll_core = 0x4a00415c,
490         .cm_clkmode_dpll_mpu = 0x4a004160,
491         .cm_idlest_dpll_mpu = 0x4a004164,
492         .cm_autoidle_dpll_mpu = 0x4a004168,
493         .cm_clksel_dpll_mpu = 0x4a00416c,
494         .cm_div_m2_dpll_mpu = 0x4a004170,
495         .cm_ssc_deltamstep_dpll_mpu = 0x4a004188,
496         .cm_ssc_modfreqdiv_dpll_mpu = 0x4a00418c,
497         .cm_bypclk_dpll_mpu = 0x4a00419c,
498         .cm_clkmode_dpll_iva = 0x4a0041a0,
499         .cm_idlest_dpll_iva = 0x4a0041a4,
500         .cm_autoidle_dpll_iva = 0x4a0041a8,
501         .cm_clksel_dpll_iva = 0x4a0041ac,
502         .cm_div_h11_dpll_iva = 0x4a0041b8,
503         .cm_div_h12_dpll_iva = 0x4a0041bc,
504         .cm_ssc_deltamstep_dpll_iva = 0x4a0041c8,
505         .cm_ssc_modfreqdiv_dpll_iva = 0x4a0041cc,
506         .cm_bypclk_dpll_iva = 0x4a0041dc,
507         .cm_clkmode_dpll_abe = 0x4a0041e0,
508         .cm_idlest_dpll_abe = 0x4a0041e4,
509         .cm_autoidle_dpll_abe = 0x4a0041e8,
510         .cm_clksel_dpll_abe = 0x4a0041ec,
511         .cm_div_m2_dpll_abe = 0x4a0041f0,
512         .cm_div_m3_dpll_abe = 0x4a0041f4,
513         .cm_ssc_deltamstep_dpll_abe = 0x4a004208,
514         .cm_ssc_modfreqdiv_dpll_abe = 0x4a00420c,
515         .cm_clkmode_dpll_ddrphy = 0x4a004220,
516         .cm_idlest_dpll_ddrphy = 0x4a004224,
517         .cm_autoidle_dpll_ddrphy = 0x4a004228,
518         .cm_clksel_dpll_ddrphy = 0x4a00422c,
519         .cm_div_m2_dpll_ddrphy = 0x4a004230,
520         .cm_div_h11_dpll_ddrphy = 0x4a004238,
521         .cm_div_h12_dpll_ddrphy = 0x4a00423c,
522         .cm_div_h13_dpll_ddrphy = 0x4a004240,
523         .cm_ssc_deltamstep_dpll_ddrphy = 0x4a004248,
524         .cm_shadow_freq_config1 = 0x4a004260,
525         .cm_mpu_mpu_clkctrl = 0x4a004320,
526
527         /* cm1.dsp */
528         .cm_dsp_clkstctrl = 0x4a004400,
529         .cm_dsp_dsp_clkctrl = 0x4a004420,
530
531         /* cm1.abe */
532         .cm1_abe_clkstctrl = 0x4a004500,
533         .cm1_abe_l4abe_clkctrl = 0x4a004520,
534         .cm1_abe_aess_clkctrl = 0x4a004528,
535         .cm1_abe_pdm_clkctrl = 0x4a004530,
536         .cm1_abe_dmic_clkctrl = 0x4a004538,
537         .cm1_abe_mcasp_clkctrl = 0x4a004540,
538         .cm1_abe_mcbsp1_clkctrl = 0x4a004548,
539         .cm1_abe_mcbsp2_clkctrl = 0x4a004550,
540         .cm1_abe_mcbsp3_clkctrl = 0x4a004558,
541         .cm1_abe_slimbus_clkctrl = 0x4a004560,
542         .cm1_abe_timer5_clkctrl = 0x4a004568,
543         .cm1_abe_timer6_clkctrl = 0x4a004570,
544         .cm1_abe_timer7_clkctrl = 0x4a004578,
545         .cm1_abe_timer8_clkctrl = 0x4a004580,
546         .cm1_abe_wdt3_clkctrl = 0x4a004588,
547
548         /* cm2.ckgen */
549         .cm_clksel_mpu_m3_iss_root = 0x4a008100,
550         .cm_clksel_usb_60mhz = 0x4a008104,
551         .cm_scale_fclk = 0x4a008108,
552         .cm_core_dvfs_perf1 = 0x4a008110,
553         .cm_core_dvfs_perf2 = 0x4a008114,
554         .cm_core_dvfs_perf3 = 0x4a008118,
555         .cm_core_dvfs_perf4 = 0x4a00811c,
556         .cm_core_dvfs_current = 0x4a008124,
557         .cm_iva_dvfs_perf_tesla = 0x4a008128,
558         .cm_iva_dvfs_perf_ivahd = 0x4a00812c,
559         .cm_iva_dvfs_perf_abe = 0x4a008130,
560         .cm_iva_dvfs_current = 0x4a008138,
561         .cm_clkmode_dpll_per = 0x4a008140,
562         .cm_idlest_dpll_per = 0x4a008144,
563         .cm_autoidle_dpll_per = 0x4a008148,
564         .cm_clksel_dpll_per = 0x4a00814c,
565         .cm_div_m2_dpll_per = 0x4a008150,
566         .cm_div_m3_dpll_per = 0x4a008154,
567         .cm_div_h11_dpll_per = 0x4a008158,
568         .cm_div_h12_dpll_per = 0x4a00815c,
569         .cm_div_h13_dpll_per = 0x4a008160,
570         .cm_div_h14_dpll_per = 0x4a008164,
571         .cm_ssc_deltamstep_dpll_per = 0x4a008168,
572         .cm_ssc_modfreqdiv_dpll_per = 0x4a00816c,
573         .cm_emu_override_dpll_per = 0x4a008170,
574         .cm_clkmode_dpll_usb = 0x4a008180,
575         .cm_idlest_dpll_usb = 0x4a008184,
576         .cm_autoidle_dpll_usb = 0x4a008188,
577         .cm_clksel_dpll_usb = 0x4a00818c,
578         .cm_div_m2_dpll_usb = 0x4a008190,
579         .cm_ssc_deltamstep_dpll_usb = 0x4a0081a8,
580         .cm_ssc_modfreqdiv_dpll_usb = 0x4a0081ac,
581         .cm_clkdcoldo_dpll_usb = 0x4a0081b4,
582         .cm_clkmode_dpll_unipro = 0x4a0081c0,
583         .cm_idlest_dpll_unipro = 0x4a0081c4,
584         .cm_autoidle_dpll_unipro = 0x4a0081c8,
585         .cm_clksel_dpll_unipro = 0x4a0081cc,
586         .cm_div_m2_dpll_unipro = 0x4a0081d0,
587         .cm_ssc_deltamstep_dpll_unipro = 0x4a0081e8,
588         .cm_ssc_modfreqdiv_dpll_unipro = 0x4a0081ec,
589         .cm_coreaon_usb_phy1_core_clkctrl = 0x4A008640,
590         .cm_coreaon_bandgap_clkctrl = 0x4a008648,
591         .cm_coreaon_io_srcomp_clkctrl = 0x4a008650,
592
593         /* cm2.core */
594         .cm_l3_1_clkstctrl = 0x4a008700,
595         .cm_l3_1_dynamicdep = 0x4a008708,
596         .cm_l3_1_l3_1_clkctrl = 0x4a008720,
597         .cm_l3_2_clkstctrl = 0x4a008800,
598         .cm_l3_2_dynamicdep = 0x4a008808,
599         .cm_l3_2_l3_2_clkctrl = 0x4a008820,
600         .cm_l3_gpmc_clkctrl = 0x4a008828,
601         .cm_l3_2_ocmc_ram_clkctrl = 0x4a008830,
602         .cm_mpu_m3_clkstctrl = 0x4a008900,
603         .cm_mpu_m3_staticdep = 0x4a008904,
604         .cm_mpu_m3_dynamicdep = 0x4a008908,
605         .cm_mpu_m3_mpu_m3_clkctrl = 0x4a008920,
606         .cm_sdma_clkstctrl = 0x4a008a00,
607         .cm_sdma_staticdep = 0x4a008a04,
608         .cm_sdma_dynamicdep = 0x4a008a08,
609         .cm_sdma_sdma_clkctrl = 0x4a008a20,
610         .cm_memif_clkstctrl = 0x4a008b00,
611         .cm_memif_dmm_clkctrl = 0x4a008b20,
612         .cm_memif_emif_fw_clkctrl = 0x4a008b28,
613         .cm_memif_emif_1_clkctrl = 0x4a008b30,
614         .cm_memif_emif_2_clkctrl = 0x4a008b38,
615         .cm_memif_dll_clkctrl = 0x4a008b40,
616         .cm_memif_emif_h1_clkctrl = 0x4a008b50,
617         .cm_memif_emif_h2_clkctrl = 0x4a008b58,
618         .cm_memif_dll_h_clkctrl = 0x4a008b60,
619         .cm_c2c_clkstctrl = 0x4a008c00,
620         .cm_c2c_staticdep = 0x4a008c04,
621         .cm_c2c_dynamicdep = 0x4a008c08,
622         .cm_c2c_sad2d_clkctrl = 0x4a008c20,
623         .cm_c2c_modem_icr_clkctrl = 0x4a008c28,
624         .cm_c2c_sad2d_fw_clkctrl = 0x4a008c30,
625         .cm_l4cfg_clkstctrl = 0x4a008d00,
626         .cm_l4cfg_dynamicdep = 0x4a008d08,
627         .cm_l4cfg_l4_cfg_clkctrl = 0x4a008d20,
628         .cm_l4cfg_hw_sem_clkctrl = 0x4a008d28,
629         .cm_l4cfg_mailbox_clkctrl = 0x4a008d30,
630         .cm_l4cfg_sar_rom_clkctrl = 0x4a008d38,
631         .cm_l3instr_clkstctrl = 0x4a008e00,
632         .cm_l3instr_l3_3_clkctrl = 0x4a008e20,
633         .cm_l3instr_l3_instr_clkctrl = 0x4a008e28,
634         .cm_l3instr_intrconn_wp1_clkctrl = 0x4a008e40,
635         .cm_l4per_clkstctrl = 0x4a009000,
636         .cm_l4per_dynamicdep = 0x4a009008,
637         .cm_l4per_adc_clkctrl = 0x4a009020,
638         .cm_l4per_gptimer10_clkctrl = 0x4a009028,
639         .cm_l4per_gptimer11_clkctrl = 0x4a009030,
640         .cm_l4per_gptimer2_clkctrl = 0x4a009038,
641         .cm_l4per_gptimer3_clkctrl = 0x4a009040,
642         .cm_l4per_gptimer4_clkctrl = 0x4a009048,
643         .cm_l4per_gptimer9_clkctrl = 0x4a009050,
644         .cm_l4per_elm_clkctrl = 0x4a009058,
645         .cm_l4per_gpio2_clkctrl = 0x4a009060,
646         .cm_l4per_gpio3_clkctrl = 0x4a009068,
647         .cm_l4per_gpio4_clkctrl = 0x4a009070,
648         .cm_l4per_gpio5_clkctrl = 0x4a009078,
649         .cm_l4per_gpio6_clkctrl = 0x4a009080,
650         .cm_l4per_hdq1w_clkctrl = 0x4a009088,
651         .cm_l4per_hecc1_clkctrl = 0x4a009090,
652         .cm_l4per_hecc2_clkctrl = 0x4a009098,
653         .cm_l4per_i2c1_clkctrl = 0x4a0090a0,
654         .cm_l4per_i2c2_clkctrl = 0x4a0090a8,
655         .cm_l4per_i2c3_clkctrl = 0x4a0090b0,
656         .cm_l4per_i2c4_clkctrl = 0x4a0090b8,
657         .cm_l4per_l4per_clkctrl = 0x4a0090c0,
658         .cm_l4per_mcasp2_clkctrl = 0x4a0090d0,
659         .cm_l4per_mcasp3_clkctrl = 0x4a0090d8,
660         .cm_l4per_mgate_clkctrl = 0x4a0090e8,
661         .cm_l4per_mcspi1_clkctrl = 0x4a0090f0,
662         .cm_l4per_mcspi2_clkctrl = 0x4a0090f8,
663         .cm_l4per_mcspi3_clkctrl = 0x4a009100,
664         .cm_l4per_mcspi4_clkctrl = 0x4a009108,
665         .cm_l4per_gpio7_clkctrl = 0x4a009110,
666         .cm_l4per_gpio8_clkctrl = 0x4a009118,
667         .cm_l4per_mmcsd3_clkctrl = 0x4a009120,
668         .cm_l4per_mmcsd4_clkctrl = 0x4a009128,
669         .cm_l4per_msprohg_clkctrl = 0x4a009130,
670         .cm_l4per_slimbus2_clkctrl = 0x4a009138,
671         .cm_l4per_uart1_clkctrl = 0x4a009140,
672         .cm_l4per_uart2_clkctrl = 0x4a009148,
673         .cm_l4per_uart3_clkctrl = 0x4a009150,
674         .cm_l4per_uart4_clkctrl = 0x4a009158,
675         .cm_l4per_mmcsd5_clkctrl = 0x4a009160,
676         .cm_l4per_i2c5_clkctrl = 0x4a009168,
677         .cm_l4per_uart5_clkctrl = 0x4a009170,
678         .cm_l4per_uart6_clkctrl = 0x4a009178,
679         .cm_l4sec_clkstctrl = 0x4a009180,
680         .cm_l4sec_staticdep = 0x4a009184,
681         .cm_l4sec_dynamicdep = 0x4a009188,
682         .cm_l4sec_aes1_clkctrl = 0x4a0091a0,
683         .cm_l4sec_aes2_clkctrl = 0x4a0091a8,
684         .cm_l4sec_des3des_clkctrl = 0x4a0091b0,
685         .cm_l4sec_pkaeip29_clkctrl = 0x4a0091b8,
686         .cm_l4sec_rng_clkctrl = 0x4a0091c0,
687         .cm_l4sec_sha2md51_clkctrl = 0x4a0091c8,
688         .cm_l4sec_cryptodma_clkctrl = 0x4a0091d8,
689
690         /* cm2.ivahd */
691         .cm_ivahd_clkstctrl = 0x4a009200,
692         .cm_ivahd_ivahd_clkctrl = 0x4a009220,
693         .cm_ivahd_sl2_clkctrl = 0x4a009228,
694
695         /* cm2.cam */
696         .cm_cam_clkstctrl = 0x4a009300,
697         .cm_cam_iss_clkctrl = 0x4a009320,
698         .cm_cam_fdif_clkctrl = 0x4a009328,
699
700         /* cm2.dss */
701         .cm_dss_clkstctrl = 0x4a009400,
702         .cm_dss_dss_clkctrl = 0x4a009420,
703
704         /* cm2.sgx */
705         .cm_sgx_clkstctrl = 0x4a009500,
706         .cm_sgx_sgx_clkctrl = 0x4a009520,
707
708         /* cm2.l3init */
709         .cm_l3init_clkstctrl = 0x4a009600,
710
711         /* cm2.l3init */
712         .cm_l3init_hsmmc1_clkctrl = 0x4a009628,
713         .cm_l3init_hsmmc2_clkctrl = 0x4a009630,
714         .cm_l3init_hsi_clkctrl = 0x4a009638,
715         .cm_l3init_hsusbhost_clkctrl = 0x4a009658,
716         .cm_l3init_hsusbotg_clkctrl = 0x4a009660,
717         .cm_l3init_hsusbtll_clkctrl = 0x4a009668,
718         .cm_l3init_p1500_clkctrl = 0x4a009678,
719         .cm_l3init_sata_clkctrl = 0x4a009688,
720         .cm_l3init_fsusb_clkctrl = 0x4a0096d0,
721         .cm_l3init_ocp2scp1_clkctrl = 0x4a0096e0,
722         .cm_l3init_ocp2scp3_clkctrl = 0x4a0096e8,
723         .cm_l3init_usb_otg_ss1_clkctrl = 0x4a0096f0,
724
725         /* prm irqstatus regs */
726         .prm_irqstatus_mpu = 0x4ae06010,
727         .prm_irqstatus_mpu_2 = 0x4ae06014,
728
729         /* l4 wkup regs */
730         .cm_abe_pll_ref_clksel = 0x4ae0610c,
731         .cm_sys_clksel = 0x4ae06110,
732         .cm_wkup_clkstctrl = 0x4ae07900,
733         .cm_wkup_l4wkup_clkctrl = 0x4ae07920,
734         .cm_wkup_wdtimer1_clkctrl = 0x4ae07928,
735         .cm_wkup_wdtimer2_clkctrl = 0x4ae07930,
736         .cm_wkup_gpio1_clkctrl = 0x4ae07938,
737         .cm_wkup_gptimer1_clkctrl = 0x4ae07940,
738         .cm_wkup_gptimer12_clkctrl = 0x4ae07948,
739         .cm_wkup_synctimer_clkctrl = 0x4ae07950,
740         .cm_wkup_usim_clkctrl = 0x4ae07958,
741         .cm_wkup_sarram_clkctrl = 0x4ae07960,
742         .cm_wkup_keyboard_clkctrl = 0x4ae07978,
743         .cm_wkup_rtc_clkctrl = 0x4ae07980,
744         .cm_wkup_bandgap_clkctrl = 0x4ae07988,
745         .cm_wkupaon_scrm_clkctrl = 0x4ae07990,
746         .cm_wkupaon_io_srcomp_clkctrl = 0x4ae07998,
747         .prm_rstctrl = 0x4ae07c00,
748         .prm_rstst = 0x4ae07c04,
749         .prm_rsttime = 0x4ae07c08,
750         .prm_vc_val_bypass = 0x4ae07ca0,
751         .prm_vc_cfg_i2c_mode = 0x4ae07cb4,
752         .prm_vc_cfg_i2c_clk = 0x4ae07cb8,
753
754         .prm_abbldo_mpu_setup = 0x4ae07cdc,
755         .prm_abbldo_mpu_ctrl = 0x4ae07ce0,
756         .prm_abbldo_mm_setup = 0x4ae07ce4,
757         .prm_abbldo_mm_ctrl = 0x4ae07ce8,
758
759         /* SCRM stuff, used by some boards */
760         .scrm_auxclk0 = 0x4ae0a310,
761         .scrm_auxclk1 = 0x4ae0a314,
762 };
763
764 struct prcm_regs const dra7xx_prcm = {
765         /* cm1.ckgen */
766         .cm_clksel_core                         = 0x4a005100,
767         .cm_clksel_abe                          = 0x4a005108,
768         .cm_dll_ctrl                            = 0x4a005110,
769         .cm_clkmode_dpll_core                   = 0x4a005120,
770         .cm_idlest_dpll_core                    = 0x4a005124,
771         .cm_autoidle_dpll_core                  = 0x4a005128,
772         .cm_clksel_dpll_core                    = 0x4a00512c,
773         .cm_div_m2_dpll_core                    = 0x4a005130,
774         .cm_div_m3_dpll_core                    = 0x4a005134,
775         .cm_div_h11_dpll_core                   = 0x4a005138,
776         .cm_div_h12_dpll_core                   = 0x4a00513c,
777         .cm_div_h13_dpll_core                   = 0x4a005140,
778         .cm_div_h14_dpll_core                   = 0x4a005144,
779         .cm_ssc_deltamstep_dpll_core            = 0x4a005148,
780         .cm_ssc_modfreqdiv_dpll_core            = 0x4a00514c,
781         .cm_div_h21_dpll_core                   = 0x4a005150,
782         .cm_div_h22_dpllcore                    = 0x4a005154,
783         .cm_div_h23_dpll_core                   = 0x4a005158,
784         .cm_div_h24_dpll_core                   = 0x4a00515c,
785         .cm_clkmode_dpll_mpu                    = 0x4a005160,
786         .cm_idlest_dpll_mpu                     = 0x4a005164,
787         .cm_autoidle_dpll_mpu                   = 0x4a005168,
788         .cm_clksel_dpll_mpu                     = 0x4a00516c,
789         .cm_div_m2_dpll_mpu                     = 0x4a005170,
790         .cm_ssc_deltamstep_dpll_mpu             = 0x4a005188,
791         .cm_ssc_modfreqdiv_dpll_mpu             = 0x4a00518c,
792         .cm_bypclk_dpll_mpu                     = 0x4a00519c,
793         .cm_clkmode_dpll_iva                    = 0x4a0051a0,
794         .cm_idlest_dpll_iva                     = 0x4a0051a4,
795         .cm_autoidle_dpll_iva                   = 0x4a0051a8,
796         .cm_clksel_dpll_iva                     = 0x4a0051ac,
797         .cm_ssc_deltamstep_dpll_iva             = 0x4a0051c8,
798         .cm_ssc_modfreqdiv_dpll_iva             = 0x4a0051cc,
799         .cm_bypclk_dpll_iva                     = 0x4a0051dc,
800         .cm_clkmode_dpll_abe                    = 0x4a0051e0,
801         .cm_idlest_dpll_abe                     = 0x4a0051e4,
802         .cm_autoidle_dpll_abe                   = 0x4a0051e8,
803         .cm_clksel_dpll_abe                     = 0x4a0051ec,
804         .cm_div_m2_dpll_abe                     = 0x4a0051f0,
805         .cm_div_m3_dpll_abe                     = 0x4a0051f4,
806         .cm_ssc_deltamstep_dpll_abe             = 0x4a005208,
807         .cm_ssc_modfreqdiv_dpll_abe             = 0x4a00520c,
808         .cm_clkmode_dpll_ddrphy                 = 0x4a005210,
809         .cm_idlest_dpll_ddrphy                  = 0x4a005214,
810         .cm_autoidle_dpll_ddrphy                = 0x4a005218,
811         .cm_clksel_dpll_ddrphy                  = 0x4a00521c,
812         .cm_div_m2_dpll_ddrphy                  = 0x4a005220,
813         .cm_div_h11_dpll_ddrphy                 = 0x4a005228,
814         .cm_ssc_deltamstep_dpll_ddrphy          = 0x4a00522c,
815         .cm_clkmode_dpll_dsp                    = 0x4a005234,
816         .cm_shadow_freq_config1                 = 0x4a005260,
817         .cm_clkmode_dpll_gmac                   = 0x4a0052a8,
818         .cm_coreaon_usb_phy1_core_clkctrl       = 0x4a008640,
819         .cm_coreaon_usb_phy2_core_clkctrl       = 0x4a008688,
820         .cm_coreaon_l3init_60m_gfclk_clkctrl    = 0x4a0086c0,
821
822         /* cm1.mpu */
823         .cm_mpu_mpu_clkctrl                     = 0x4a005320,
824
825         /* cm1.dsp */
826         .cm_dsp_clkstctrl                       = 0x4a005400,
827         .cm_dsp_dsp_clkctrl                     = 0x4a005420,
828
829         /* cm IPU */
830         .cm_ipu_clkstctrl                       = 0x4a005540,
831         .cm_ipu_i2c5_clkctrl                    = 0x4a005578,
832
833         /* prm irqstatus regs */
834         .prm_irqstatus_mpu_2                    = 0x4ae06014,
835
836         /* cm2.ckgen */
837         .cm_clksel_usb_60mhz                    = 0x4a008104,
838         .cm_clkmode_dpll_per                    = 0x4a008140,
839         .cm_idlest_dpll_per                     = 0x4a008144,
840         .cm_autoidle_dpll_per                   = 0x4a008148,
841         .cm_clksel_dpll_per                     = 0x4a00814c,
842         .cm_div_m2_dpll_per                     = 0x4a008150,
843         .cm_div_m3_dpll_per                     = 0x4a008154,
844         .cm_div_h11_dpll_per                    = 0x4a008158,
845         .cm_div_h12_dpll_per                    = 0x4a00815c,
846         .cm_div_h13_dpll_per                    = 0x4a008160,
847         .cm_div_h14_dpll_per                    = 0x4a008164,
848         .cm_ssc_deltamstep_dpll_per             = 0x4a008168,
849         .cm_ssc_modfreqdiv_dpll_per             = 0x4a00816c,
850         .cm_clkmode_dpll_usb                    = 0x4a008180,
851         .cm_idlest_dpll_usb                     = 0x4a008184,
852         .cm_autoidle_dpll_usb                   = 0x4a008188,
853         .cm_clksel_dpll_usb                     = 0x4a00818c,
854         .cm_div_m2_dpll_usb                     = 0x4a008190,
855         .cm_ssc_deltamstep_dpll_usb             = 0x4a0081a8,
856         .cm_ssc_modfreqdiv_dpll_usb             = 0x4a0081ac,
857         .cm_clkdcoldo_dpll_usb                  = 0x4a0081b4,
858         .cm_clkmode_dpll_pcie_ref               = 0x4a008200,
859         .cm_clkmode_apll_pcie                   = 0x4a00821c,
860         .cm_idlest_apll_pcie                    = 0x4a008220,
861         .cm_div_m2_apll_pcie                    = 0x4a008224,
862         .cm_clkvcoldo_apll_pcie                 = 0x4a008228,
863
864         /* cm2.core */
865         .cm_l3_1_clkstctrl                      = 0x4a008700,
866         .cm_l3_1_dynamicdep                     = 0x4a008708,
867         .cm_l3_1_l3_1_clkctrl                   = 0x4a008720,
868         .cm_l3_gpmc_clkctrl                     = 0x4a008728,
869         .cm_mpu_m3_clkstctrl                    = 0x4a008900,
870         .cm_mpu_m3_staticdep                    = 0x4a008904,
871         .cm_mpu_m3_dynamicdep                   = 0x4a008908,
872         .cm_mpu_m3_mpu_m3_clkctrl               = 0x4a008920,
873         .cm_sdma_clkstctrl                      = 0x4a008a00,
874         .cm_sdma_staticdep                      = 0x4a008a04,
875         .cm_sdma_dynamicdep                     = 0x4a008a08,
876         .cm_sdma_sdma_clkctrl                   = 0x4a008a20,
877         .cm_memif_clkstctrl                     = 0x4a008b00,
878         .cm_memif_dmm_clkctrl                   = 0x4a008b20,
879         .cm_memif_emif_fw_clkctrl               = 0x4a008b28,
880         .cm_memif_emif_1_clkctrl                = 0x4a008b30,
881         .cm_memif_emif_2_clkctrl                = 0x4a008b38,
882         .cm_memif_dll_clkctrl                   = 0x4a008b40,
883         .cm_l4cfg_clkstctrl                     = 0x4a008d00,
884         .cm_l4cfg_dynamicdep                    = 0x4a008d08,
885         .cm_l4cfg_l4_cfg_clkctrl                = 0x4a008d20,
886         .cm_l4cfg_hw_sem_clkctrl                = 0x4a008d28,
887         .cm_l4cfg_mailbox_clkctrl               = 0x4a008d30,
888         .cm_l4cfg_sar_rom_clkctrl               = 0x4a008d38,
889         .cm_l3instr_clkstctrl                   = 0x4a008e00,
890         .cm_l3instr_l3_3_clkctrl                = 0x4a008e20,
891         .cm_l3instr_l3_instr_clkctrl            = 0x4a008e28,
892         .cm_l3instr_intrconn_wp1_clkctrl        = 0x4a008e40,
893
894         /* cm2.ivahd */
895         .cm_ivahd_clkstctrl                     = 0x4a008f00,
896         .cm_ivahd_ivahd_clkctrl                 = 0x4a008f20,
897         .cm_ivahd_sl2_clkctrl                   = 0x4a008f28,
898
899         /* cm2.cam */
900         .cm_cam_clkstctrl                       = 0x4a009000,
901         .cm_cam_vip1_clkctrl                    = 0x4a009020,
902         .cm_cam_vip2_clkctrl                    = 0x4a009028,
903         .cm_cam_vip3_clkctrl                    = 0x4a009030,
904         .cm_cam_lvdsrx_clkctrl                  = 0x4a009038,
905         .cm_cam_csi1_clkctrl                    = 0x4a009040,
906         .cm_cam_csi2_clkctrl                    = 0x4a009048,
907
908         /* cm2.dss */
909         .cm_dss_clkstctrl                       = 0x4a009100,
910         .cm_dss_dss_clkctrl                     = 0x4a009120,
911
912         /* cm2.sgx */
913         .cm_sgx_clkstctrl                       = 0x4a009200,
914         .cm_sgx_sgx_clkctrl                     = 0x4a009220,
915
916         /* cm2.l3init */
917         .cm_l3init_clkstctrl                    = 0x4a009300,
918
919         /* cm2.l3init */
920         .cm_l3init_hsmmc1_clkctrl               = 0x4a009328,
921         .cm_l3init_hsmmc2_clkctrl               = 0x4a009330,
922         .cm_l3init_hsusbhost_clkctrl            = 0x4a009340,
923         .cm_l3init_hsusbotg_clkctrl             = 0x4a009348,
924         .cm_l3init_hsusbtll_clkctrl             = 0x4a009350,
925         .cm_l3init_sata_clkctrl                 = 0x4a009388,
926         .cm_gmac_clkstctrl                      = 0x4a0093c0,
927         .cm_gmac_gmac_clkctrl                   = 0x4a0093d0,
928         .cm_l3init_ocp2scp1_clkctrl             = 0x4a0093e0,
929         .cm_l3init_ocp2scp3_clkctrl             = 0x4a0093e8,
930         .cm_l3init_usb_otg_ss1_clkctrl          = 0x4a0093f0,
931         .cm_l3init_usb_otg_ss2_clkctrl          = 0x4a009340,
932
933         /* cm2.l4per */
934         .cm_l4per_clkstctrl                     = 0x4a009700,
935         .cm_l4per_dynamicdep                    = 0x4a009708,
936         .cm_l4per_gptimer10_clkctrl             = 0x4a009728,
937         .cm_l4per_gptimer11_clkctrl             = 0x4a009730,
938         .cm_l4per_gptimer2_clkctrl              = 0x4a009738,
939         .cm_l4per_gptimer3_clkctrl              = 0x4a009740,
940         .cm_l4per_gptimer4_clkctrl              = 0x4a009748,
941         .cm_l4per_gptimer9_clkctrl              = 0x4a009750,
942         .cm_l4per_elm_clkctrl                   = 0x4a009758,
943         .cm_l4per_gpio2_clkctrl                 = 0x4a009760,
944         .cm_l4per_gpio3_clkctrl                 = 0x4a009768,
945         .cm_l4per_gpio4_clkctrl                 = 0x4a009770,
946         .cm_l4per_gpio5_clkctrl                 = 0x4a009778,
947         .cm_l4per_gpio6_clkctrl                 = 0x4a009780,
948         .cm_l4per_hdq1w_clkctrl                 = 0x4a009788,
949         .cm_l4per_i2c1_clkctrl                  = 0x4a0097a0,
950         .cm_l4per_i2c2_clkctrl                  = 0x4a0097a8,
951         .cm_l4per_i2c3_clkctrl                  = 0x4a0097b0,
952         .cm_l4per_i2c4_clkctrl                  = 0x4a0097b8,
953         .cm_l4per_l4per_clkctrl                 = 0x4a0097c0,
954         .cm_l4per_mcspi1_clkctrl                = 0x4a0097f0,
955         .cm_l4per_mcspi2_clkctrl                = 0x4a0097f8,
956         .cm_l4per_mcspi3_clkctrl                = 0x4a009800,
957         .cm_l4per_mcspi4_clkctrl                = 0x4a009808,
958         .cm_l4per_gpio7_clkctrl                 = 0x4a009810,
959         .cm_l4per_gpio8_clkctrl                 = 0x4a009818,
960         .cm_l4per_mmcsd3_clkctrl                = 0x4a009820,
961         .cm_l4per_mmcsd4_clkctrl                = 0x4a009828,
962         .cm_l4per_qspi_clkctrl                  = 0x4a009838,
963         .cm_l4per_uart1_clkctrl                 = 0x4a009840,
964         .cm_l4per_uart2_clkctrl                 = 0x4a009848,
965         .cm_l4per_uart3_clkctrl                 = 0x4a009850,
966         .cm_l4per_uart4_clkctrl                 = 0x4a009858,
967         .cm_l4per_uart5_clkctrl                 = 0x4a009870,
968         .cm_l4sec_clkstctrl                     = 0x4a009880,
969         .cm_l4sec_staticdep                     = 0x4a009884,
970         .cm_l4sec_dynamicdep                    = 0x4a009888,
971         .cm_l4sec_aes1_clkctrl                  = 0x4a0098a0,
972         .cm_l4sec_aes2_clkctrl                  = 0x4a0098a8,
973         .cm_l4sec_des3des_clkctrl               = 0x4a0098b0,
974         .cm_l4sec_rng_clkctrl                   = 0x4a0098c0,
975         .cm_l4sec_sha2md51_clkctrl              = 0x4a0098c8,
976         .cm_l4sec_cryptodma_clkctrl             = 0x4a0098d8,
977
978         /* l4 wkup regs */
979         .cm_abe_pll_ref_clksel                  = 0x4ae0610c,
980         .cm_sys_clksel                          = 0x4ae06110,
981         .cm_abe_pll_sys_clksel                  = 0x4ae06118,
982         .cm_wkup_clkstctrl                      = 0x4ae07800,
983         .cm_wkup_l4wkup_clkctrl                 = 0x4ae07820,
984         .cm_wkup_wdtimer1_clkctrl               = 0x4ae07828,
985         .cm_wkup_wdtimer2_clkctrl               = 0x4ae07830,
986         .cm_wkup_gpio1_clkctrl                  = 0x4ae07838,
987         .cm_wkup_gptimer1_clkctrl               = 0x4ae07840,
988         .cm_wkup_gptimer12_clkctrl              = 0x4ae07848,
989         .cm_wkup_sarram_clkctrl                 = 0x4ae07860,
990         .cm_wkup_keyboard_clkctrl               = 0x4ae07878,
991         .cm_wkupaon_scrm_clkctrl                = 0x4ae07890,
992         .prm_rstctrl                            = 0x4ae07d00,
993         .prm_rstst                              = 0x4ae07d04,
994         .prm_rsttime                            = 0x4ae07d08,
995         .prm_io_pmctrl                          = 0x4ae07d20,
996         .prm_vc_val_bypass                      = 0x4ae07da0,
997         .prm_vc_cfg_i2c_mode                    = 0x4ae07db4,
998         .prm_vc_cfg_i2c_clk                     = 0x4ae07db8,
999
1000         .prm_abbldo_mpu_setup                   = 0x4AE07DDC,
1001         .prm_abbldo_mpu_ctrl                    = 0x4AE07DE0,
1002
1003         /*l3main1 edma*/
1004         .cm_l3main1_tptc1_clkctrl               = 0x4a008778,
1005         .cm_l3main1_tptc2_clkctrl               = 0x4a008780,
1006 };
1007
1008 void clrset_spare_register(u8 spare_type, u32 clear_bits, u32 set_bits)
1009 {
1010         u32 reg = spare_type ? (*ctrl)->ctrl_core_sma_sw_1 :
1011                 (*ctrl)->ctrl_core_sma_sw_0;
1012         clrsetbits_le32(reg, clear_bits, set_bits);
1013 }