1*4882a593Smuzhiyun // SPDX-License-Identifier: GPL-2.0-only 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * DRA7 Clock init 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Copyright (C) 2013 Texas Instruments, Inc. 6*4882a593Smuzhiyun * 7*4882a593Smuzhiyun * Tero Kristo (t-kristo@ti.com) 8*4882a593Smuzhiyun */ 9*4882a593Smuzhiyun 10*4882a593Smuzhiyun #include <linux/kernel.h> 11*4882a593Smuzhiyun #include <linux/list.h> 12*4882a593Smuzhiyun #include <linux/clk.h> 13*4882a593Smuzhiyun #include <linux/clkdev.h> 14*4882a593Smuzhiyun #include <linux/clk/ti.h> 15*4882a593Smuzhiyun #include <dt-bindings/clock/dra7.h> 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun #include "clock.h" 18*4882a593Smuzhiyun 19*4882a593Smuzhiyun #define DRA7_DPLL_GMAC_DEFFREQ 1000000000 20*4882a593Smuzhiyun #define DRA7_DPLL_USB_DEFFREQ 960000000 21*4882a593Smuzhiyun 22*4882a593Smuzhiyun static const struct omap_clkctrl_reg_data dra7_mpu_clkctrl_regs[] __initconst = { 23*4882a593Smuzhiyun { DRA7_MPU_CLKCTRL, NULL, 0, "dpll_mpu_m2_ck" }, 24*4882a593Smuzhiyun { 0 }, 25*4882a593Smuzhiyun }; 26*4882a593Smuzhiyun 27*4882a593Smuzhiyun static const char * const dra7_mcasp1_aux_gfclk_mux_parents[] __initconst = { 28*4882a593Smuzhiyun "per_abe_x1_gfclk2_div", 29*4882a593Smuzhiyun "video1_clk2_div", 30*4882a593Smuzhiyun "video2_clk2_div", 31*4882a593Smuzhiyun "hdmi_clk2_div", 32*4882a593Smuzhiyun NULL, 33*4882a593Smuzhiyun }; 34*4882a593Smuzhiyun 35*4882a593Smuzhiyun static const char * const dra7_mcasp1_ahclkx_mux_parents[] __initconst = { 36*4882a593Smuzhiyun "abe_24m_fclk", 37*4882a593Smuzhiyun "abe_sys_clk_div", 38*4882a593Smuzhiyun "func_24m_clk", 39*4882a593Smuzhiyun "atl_clkin3_ck", 40*4882a593Smuzhiyun "atl_clkin2_ck", 41*4882a593Smuzhiyun "atl_clkin1_ck", 42*4882a593Smuzhiyun "atl_clkin0_ck", 43*4882a593Smuzhiyun "sys_clkin2", 44*4882a593Smuzhiyun "ref_clkin0_ck", 45*4882a593Smuzhiyun "ref_clkin1_ck", 46*4882a593Smuzhiyun "ref_clkin2_ck", 47*4882a593Smuzhiyun "ref_clkin3_ck", 48*4882a593Smuzhiyun "mlb_clk", 49*4882a593Smuzhiyun "mlbp_clk", 50*4882a593Smuzhiyun NULL, 51*4882a593Smuzhiyun }; 52*4882a593Smuzhiyun 53*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_mcasp1_bit_data[] __initconst = { 54*4882a593Smuzhiyun { 22, TI_CLK_MUX, dra7_mcasp1_aux_gfclk_mux_parents, NULL }, 55*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_mcasp1_ahclkx_mux_parents, NULL }, 56*4882a593Smuzhiyun { 28, TI_CLK_MUX, dra7_mcasp1_ahclkx_mux_parents, NULL }, 57*4882a593Smuzhiyun { 0 }, 58*4882a593Smuzhiyun }; 59*4882a593Smuzhiyun 60*4882a593Smuzhiyun static const char * const dra7_timer5_gfclk_mux_parents[] __initconst = { 61*4882a593Smuzhiyun "timer_sys_clk_div", 62*4882a593Smuzhiyun "sys_32k_ck", 63*4882a593Smuzhiyun "sys_clkin2", 64*4882a593Smuzhiyun "ref_clkin0_ck", 65*4882a593Smuzhiyun "ref_clkin1_ck", 66*4882a593Smuzhiyun "ref_clkin2_ck", 67*4882a593Smuzhiyun "ref_clkin3_ck", 68*4882a593Smuzhiyun "abe_giclk_div", 69*4882a593Smuzhiyun "video1_div_clk", 70*4882a593Smuzhiyun "video2_div_clk", 71*4882a593Smuzhiyun "hdmi_div_clk", 72*4882a593Smuzhiyun "clkoutmux0_clk_mux", 73*4882a593Smuzhiyun NULL, 74*4882a593Smuzhiyun }; 75*4882a593Smuzhiyun 76*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer5_bit_data[] __initconst = { 77*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer5_gfclk_mux_parents, NULL }, 78*4882a593Smuzhiyun { 0 }, 79*4882a593Smuzhiyun }; 80*4882a593Smuzhiyun 81*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer6_bit_data[] __initconst = { 82*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer5_gfclk_mux_parents, NULL }, 83*4882a593Smuzhiyun { 0 }, 84*4882a593Smuzhiyun }; 85*4882a593Smuzhiyun 86*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer7_bit_data[] __initconst = { 87*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer5_gfclk_mux_parents, NULL }, 88*4882a593Smuzhiyun { 0 }, 89*4882a593Smuzhiyun }; 90*4882a593Smuzhiyun 91*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer8_bit_data[] __initconst = { 92*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer5_gfclk_mux_parents, NULL }, 93*4882a593Smuzhiyun { 0 }, 94*4882a593Smuzhiyun }; 95*4882a593Smuzhiyun 96*4882a593Smuzhiyun static const char * const dra7_uart6_gfclk_mux_parents[] __initconst = { 97*4882a593Smuzhiyun "func_48m_fclk", 98*4882a593Smuzhiyun "dpll_per_m2x2_ck", 99*4882a593Smuzhiyun NULL, 100*4882a593Smuzhiyun }; 101*4882a593Smuzhiyun 102*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_uart6_bit_data[] __initconst = { 103*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_uart6_gfclk_mux_parents, NULL }, 104*4882a593Smuzhiyun { 0 }, 105*4882a593Smuzhiyun }; 106*4882a593Smuzhiyun 107*4882a593Smuzhiyun static const struct omap_clkctrl_reg_data dra7_ipu_clkctrl_regs[] __initconst = { 108*4882a593Smuzhiyun { DRA7_MCASP1_CLKCTRL, dra7_mcasp1_bit_data, CLKF_SW_SUP, "ipu_cm:clk:0010:22" }, 109*4882a593Smuzhiyun { DRA7_TIMER5_CLKCTRL, dra7_timer5_bit_data, CLKF_SW_SUP, "ipu_cm:clk:0018:24" }, 110*4882a593Smuzhiyun { DRA7_TIMER6_CLKCTRL, dra7_timer6_bit_data, CLKF_SW_SUP, "ipu_cm:clk:0020:24" }, 111*4882a593Smuzhiyun { DRA7_TIMER7_CLKCTRL, dra7_timer7_bit_data, CLKF_SW_SUP, "ipu_cm:clk:0028:24" }, 112*4882a593Smuzhiyun { DRA7_TIMER8_CLKCTRL, dra7_timer8_bit_data, CLKF_SW_SUP, "ipu_cm:clk:0030:24" }, 113*4882a593Smuzhiyun { DRA7_I2C5_CLKCTRL, NULL, CLKF_SW_SUP, "func_96m_fclk" }, 114*4882a593Smuzhiyun { DRA7_UART6_CLKCTRL, dra7_uart6_bit_data, CLKF_SW_SUP, "ipu_cm:clk:0040:24" }, 115*4882a593Smuzhiyun { 0 }, 116*4882a593Smuzhiyun }; 117*4882a593Smuzhiyun 118*4882a593Smuzhiyun static const struct omap_clkctrl_reg_data dra7_rtc_clkctrl_regs[] __initconst = { 119*4882a593Smuzhiyun { DRA7_RTCSS_CLKCTRL, NULL, CLKF_SW_SUP, "sys_32k_ck" }, 120*4882a593Smuzhiyun { 0 }, 121*4882a593Smuzhiyun }; 122*4882a593Smuzhiyun 123*4882a593Smuzhiyun static const struct omap_clkctrl_reg_data dra7_coreaon_clkctrl_regs[] __initconst = { 124*4882a593Smuzhiyun { DRA7_SMARTREFLEX_MPU_CLKCTRL, NULL, CLKF_SW_SUP, "wkupaon_iclk_mux" }, 125*4882a593Smuzhiyun { DRA7_SMARTREFLEX_CORE_CLKCTRL, NULL, CLKF_SW_SUP, "wkupaon_iclk_mux" }, 126*4882a593Smuzhiyun { 0 }, 127*4882a593Smuzhiyun }; 128*4882a593Smuzhiyun 129*4882a593Smuzhiyun static const struct omap_clkctrl_reg_data dra7_l3main1_clkctrl_regs[] __initconst = { 130*4882a593Smuzhiyun { DRA7_L3_MAIN_1_CLKCTRL, NULL, 0, "l3_iclk_div" }, 131*4882a593Smuzhiyun { DRA7_GPMC_CLKCTRL, NULL, CLKF_HW_SUP, "l3_iclk_div" }, 132*4882a593Smuzhiyun { DRA7_TPCC_CLKCTRL, NULL, 0, "l3_iclk_div" }, 133*4882a593Smuzhiyun { DRA7_TPTC0_CLKCTRL, NULL, CLKF_HW_SUP, "l3_iclk_div" }, 134*4882a593Smuzhiyun { DRA7_TPTC1_CLKCTRL, NULL, CLKF_HW_SUP, "l3_iclk_div" }, 135*4882a593Smuzhiyun { DRA7_VCP1_CLKCTRL, NULL, 0, "l3_iclk_div" }, 136*4882a593Smuzhiyun { DRA7_VCP2_CLKCTRL, NULL, 0, "l3_iclk_div" }, 137*4882a593Smuzhiyun { 0 }, 138*4882a593Smuzhiyun }; 139*4882a593Smuzhiyun 140*4882a593Smuzhiyun static const struct omap_clkctrl_reg_data dra7_dma_clkctrl_regs[] __initconst = { 141*4882a593Smuzhiyun { DRA7_DMA_SYSTEM_CLKCTRL, NULL, 0, "l3_iclk_div" }, 142*4882a593Smuzhiyun { 0 }, 143*4882a593Smuzhiyun }; 144*4882a593Smuzhiyun 145*4882a593Smuzhiyun static const struct omap_clkctrl_reg_data dra7_emif_clkctrl_regs[] __initconst = { 146*4882a593Smuzhiyun { DRA7_DMM_CLKCTRL, NULL, 0, "l3_iclk_div" }, 147*4882a593Smuzhiyun { 0 }, 148*4882a593Smuzhiyun }; 149*4882a593Smuzhiyun 150*4882a593Smuzhiyun static const char * const dra7_atl_dpll_clk_mux_parents[] __initconst = { 151*4882a593Smuzhiyun "sys_32k_ck", 152*4882a593Smuzhiyun "video1_clkin_ck", 153*4882a593Smuzhiyun "video2_clkin_ck", 154*4882a593Smuzhiyun "hdmi_clkin_ck", 155*4882a593Smuzhiyun NULL, 156*4882a593Smuzhiyun }; 157*4882a593Smuzhiyun 158*4882a593Smuzhiyun static const char * const dra7_atl_gfclk_mux_parents[] __initconst = { 159*4882a593Smuzhiyun "l3_iclk_div", 160*4882a593Smuzhiyun "dpll_abe_m2_ck", 161*4882a593Smuzhiyun "atl_cm:clk:0000:24", 162*4882a593Smuzhiyun NULL, 163*4882a593Smuzhiyun }; 164*4882a593Smuzhiyun 165*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_atl_bit_data[] __initconst = { 166*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_atl_dpll_clk_mux_parents, NULL }, 167*4882a593Smuzhiyun { 26, TI_CLK_MUX, dra7_atl_gfclk_mux_parents, NULL }, 168*4882a593Smuzhiyun { 0 }, 169*4882a593Smuzhiyun }; 170*4882a593Smuzhiyun 171*4882a593Smuzhiyun static const struct omap_clkctrl_reg_data dra7_atl_clkctrl_regs[] __initconst = { 172*4882a593Smuzhiyun { DRA7_ATL_CLKCTRL, dra7_atl_bit_data, CLKF_SW_SUP, "atl_cm:clk:0000:26" }, 173*4882a593Smuzhiyun { 0 }, 174*4882a593Smuzhiyun }; 175*4882a593Smuzhiyun 176*4882a593Smuzhiyun static const struct omap_clkctrl_reg_data dra7_l4cfg_clkctrl_regs[] __initconst = { 177*4882a593Smuzhiyun { DRA7_L4_CFG_CLKCTRL, NULL, 0, "l3_iclk_div" }, 178*4882a593Smuzhiyun { DRA7_SPINLOCK_CLKCTRL, NULL, 0, "l3_iclk_div" }, 179*4882a593Smuzhiyun { DRA7_MAILBOX1_CLKCTRL, NULL, 0, "l3_iclk_div" }, 180*4882a593Smuzhiyun { DRA7_MAILBOX2_CLKCTRL, NULL, 0, "l3_iclk_div" }, 181*4882a593Smuzhiyun { DRA7_MAILBOX3_CLKCTRL, NULL, 0, "l3_iclk_div" }, 182*4882a593Smuzhiyun { DRA7_MAILBOX4_CLKCTRL, NULL, 0, "l3_iclk_div" }, 183*4882a593Smuzhiyun { DRA7_MAILBOX5_CLKCTRL, NULL, 0, "l3_iclk_div" }, 184*4882a593Smuzhiyun { DRA7_MAILBOX6_CLKCTRL, NULL, 0, "l3_iclk_div" }, 185*4882a593Smuzhiyun { DRA7_MAILBOX7_CLKCTRL, NULL, 0, "l3_iclk_div" }, 186*4882a593Smuzhiyun { DRA7_MAILBOX8_CLKCTRL, NULL, 0, "l3_iclk_div" }, 187*4882a593Smuzhiyun { DRA7_MAILBOX9_CLKCTRL, NULL, 0, "l3_iclk_div" }, 188*4882a593Smuzhiyun { DRA7_MAILBOX10_CLKCTRL, NULL, 0, "l3_iclk_div" }, 189*4882a593Smuzhiyun { DRA7_MAILBOX11_CLKCTRL, NULL, 0, "l3_iclk_div" }, 190*4882a593Smuzhiyun { DRA7_MAILBOX12_CLKCTRL, NULL, 0, "l3_iclk_div" }, 191*4882a593Smuzhiyun { DRA7_MAILBOX13_CLKCTRL, NULL, 0, "l3_iclk_div" }, 192*4882a593Smuzhiyun { 0 }, 193*4882a593Smuzhiyun }; 194*4882a593Smuzhiyun 195*4882a593Smuzhiyun static const struct omap_clkctrl_reg_data dra7_l3instr_clkctrl_regs[] __initconst = { 196*4882a593Smuzhiyun { DRA7_L3_MAIN_2_CLKCTRL, NULL, CLKF_HW_SUP, "l3_iclk_div" }, 197*4882a593Smuzhiyun { DRA7_L3_INSTR_CLKCTRL, NULL, CLKF_HW_SUP, "l3_iclk_div" }, 198*4882a593Smuzhiyun { 0 }, 199*4882a593Smuzhiyun }; 200*4882a593Smuzhiyun 201*4882a593Smuzhiyun static const char * const dra7_dss_dss_clk_parents[] __initconst = { 202*4882a593Smuzhiyun "dpll_per_h12x2_ck", 203*4882a593Smuzhiyun NULL, 204*4882a593Smuzhiyun }; 205*4882a593Smuzhiyun 206*4882a593Smuzhiyun static const char * const dra7_dss_48mhz_clk_parents[] __initconst = { 207*4882a593Smuzhiyun "func_48m_fclk", 208*4882a593Smuzhiyun NULL, 209*4882a593Smuzhiyun }; 210*4882a593Smuzhiyun 211*4882a593Smuzhiyun static const char * const dra7_dss_hdmi_clk_parents[] __initconst = { 212*4882a593Smuzhiyun "hdmi_dpll_clk_mux", 213*4882a593Smuzhiyun NULL, 214*4882a593Smuzhiyun }; 215*4882a593Smuzhiyun 216*4882a593Smuzhiyun static const char * const dra7_dss_32khz_clk_parents[] __initconst = { 217*4882a593Smuzhiyun "sys_32k_ck", 218*4882a593Smuzhiyun NULL, 219*4882a593Smuzhiyun }; 220*4882a593Smuzhiyun 221*4882a593Smuzhiyun static const char * const dra7_dss_video1_clk_parents[] __initconst = { 222*4882a593Smuzhiyun "video1_dpll_clk_mux", 223*4882a593Smuzhiyun NULL, 224*4882a593Smuzhiyun }; 225*4882a593Smuzhiyun 226*4882a593Smuzhiyun static const char * const dra7_dss_video2_clk_parents[] __initconst = { 227*4882a593Smuzhiyun "video2_dpll_clk_mux", 228*4882a593Smuzhiyun NULL, 229*4882a593Smuzhiyun }; 230*4882a593Smuzhiyun 231*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_dss_core_bit_data[] __initconst = { 232*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_dss_clk_parents, NULL }, 233*4882a593Smuzhiyun { 9, TI_CLK_GATE, dra7_dss_48mhz_clk_parents, NULL }, 234*4882a593Smuzhiyun { 10, TI_CLK_GATE, dra7_dss_hdmi_clk_parents, NULL }, 235*4882a593Smuzhiyun { 11, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 236*4882a593Smuzhiyun { 12, TI_CLK_GATE, dra7_dss_video1_clk_parents, NULL }, 237*4882a593Smuzhiyun { 13, TI_CLK_GATE, dra7_dss_video2_clk_parents, NULL }, 238*4882a593Smuzhiyun { 0 }, 239*4882a593Smuzhiyun }; 240*4882a593Smuzhiyun 241*4882a593Smuzhiyun static const struct omap_clkctrl_reg_data dra7_dss_clkctrl_regs[] __initconst = { 242*4882a593Smuzhiyun { DRA7_DSS_CORE_CLKCTRL, dra7_dss_core_bit_data, CLKF_SW_SUP, "dss_cm:clk:0000:8" }, 243*4882a593Smuzhiyun { DRA7_BB2D_CLKCTRL, NULL, CLKF_SW_SUP, "dpll_core_h24x2_ck" }, 244*4882a593Smuzhiyun { 0 }, 245*4882a593Smuzhiyun }; 246*4882a593Smuzhiyun 247*4882a593Smuzhiyun static const char * const dra7_mmc1_fclk_mux_parents[] __initconst = { 248*4882a593Smuzhiyun "func_128m_clk", 249*4882a593Smuzhiyun "dpll_per_m2x2_ck", 250*4882a593Smuzhiyun NULL, 251*4882a593Smuzhiyun }; 252*4882a593Smuzhiyun 253*4882a593Smuzhiyun static const char * const dra7_mmc1_fclk_div_parents[] __initconst = { 254*4882a593Smuzhiyun "l3init_cm:clk:0008:24", 255*4882a593Smuzhiyun NULL, 256*4882a593Smuzhiyun }; 257*4882a593Smuzhiyun 258*4882a593Smuzhiyun static const struct omap_clkctrl_div_data dra7_mmc1_fclk_div_data __initconst = { 259*4882a593Smuzhiyun .max_div = 4, 260*4882a593Smuzhiyun .flags = CLK_DIVIDER_POWER_OF_TWO, 261*4882a593Smuzhiyun }; 262*4882a593Smuzhiyun 263*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_mmc1_bit_data[] __initconst = { 264*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 265*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_mmc1_fclk_mux_parents, NULL }, 266*4882a593Smuzhiyun { 25, TI_CLK_DIVIDER, dra7_mmc1_fclk_div_parents, &dra7_mmc1_fclk_div_data }, 267*4882a593Smuzhiyun { 0 }, 268*4882a593Smuzhiyun }; 269*4882a593Smuzhiyun 270*4882a593Smuzhiyun static const char * const dra7_mmc2_fclk_div_parents[] __initconst = { 271*4882a593Smuzhiyun "l3init_cm:clk:0010:24", 272*4882a593Smuzhiyun NULL, 273*4882a593Smuzhiyun }; 274*4882a593Smuzhiyun 275*4882a593Smuzhiyun static const struct omap_clkctrl_div_data dra7_mmc2_fclk_div_data __initconst = { 276*4882a593Smuzhiyun .max_div = 4, 277*4882a593Smuzhiyun .flags = CLK_DIVIDER_POWER_OF_TWO, 278*4882a593Smuzhiyun }; 279*4882a593Smuzhiyun 280*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_mmc2_bit_data[] __initconst = { 281*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 282*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_mmc1_fclk_mux_parents, NULL }, 283*4882a593Smuzhiyun { 25, TI_CLK_DIVIDER, dra7_mmc2_fclk_div_parents, &dra7_mmc2_fclk_div_data }, 284*4882a593Smuzhiyun { 0 }, 285*4882a593Smuzhiyun }; 286*4882a593Smuzhiyun 287*4882a593Smuzhiyun static const char * const dra7_usb_otg_ss2_refclk960m_parents[] __initconst = { 288*4882a593Smuzhiyun "l3init_960m_gfclk", 289*4882a593Smuzhiyun NULL, 290*4882a593Smuzhiyun }; 291*4882a593Smuzhiyun 292*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_usb_otg_ss2_bit_data[] __initconst = { 293*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_usb_otg_ss2_refclk960m_parents, NULL }, 294*4882a593Smuzhiyun { 0 }, 295*4882a593Smuzhiyun }; 296*4882a593Smuzhiyun 297*4882a593Smuzhiyun static const char * const dra7_sata_ref_clk_parents[] __initconst = { 298*4882a593Smuzhiyun "sys_clkin1", 299*4882a593Smuzhiyun NULL, 300*4882a593Smuzhiyun }; 301*4882a593Smuzhiyun 302*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_sata_bit_data[] __initconst = { 303*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_sata_ref_clk_parents, NULL }, 304*4882a593Smuzhiyun { 0 }, 305*4882a593Smuzhiyun }; 306*4882a593Smuzhiyun 307*4882a593Smuzhiyun static const char * const dra7_optfclk_pciephy1_clk_parents[] __initconst = { 308*4882a593Smuzhiyun "apll_pcie_ck", 309*4882a593Smuzhiyun NULL, 310*4882a593Smuzhiyun }; 311*4882a593Smuzhiyun 312*4882a593Smuzhiyun static const char * const dra7_optfclk_pciephy1_div_clk_parents[] __initconst = { 313*4882a593Smuzhiyun "optfclk_pciephy_div", 314*4882a593Smuzhiyun NULL, 315*4882a593Smuzhiyun }; 316*4882a593Smuzhiyun 317*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_pcie1_bit_data[] __initconst = { 318*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 319*4882a593Smuzhiyun { 9, TI_CLK_GATE, dra7_optfclk_pciephy1_clk_parents, NULL }, 320*4882a593Smuzhiyun { 10, TI_CLK_GATE, dra7_optfclk_pciephy1_div_clk_parents, NULL }, 321*4882a593Smuzhiyun { 0 }, 322*4882a593Smuzhiyun }; 323*4882a593Smuzhiyun 324*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_pcie2_bit_data[] __initconst = { 325*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 326*4882a593Smuzhiyun { 9, TI_CLK_GATE, dra7_optfclk_pciephy1_clk_parents, NULL }, 327*4882a593Smuzhiyun { 10, TI_CLK_GATE, dra7_optfclk_pciephy1_div_clk_parents, NULL }, 328*4882a593Smuzhiyun { 0 }, 329*4882a593Smuzhiyun }; 330*4882a593Smuzhiyun 331*4882a593Smuzhiyun static const char * const dra7_rmii_50mhz_clk_mux_parents[] __initconst = { 332*4882a593Smuzhiyun "dpll_gmac_h11x2_ck", 333*4882a593Smuzhiyun "rmii_clk_ck", 334*4882a593Smuzhiyun NULL, 335*4882a593Smuzhiyun }; 336*4882a593Smuzhiyun 337*4882a593Smuzhiyun static const char * const dra7_gmac_rft_clk_mux_parents[] __initconst = { 338*4882a593Smuzhiyun "video1_clkin_ck", 339*4882a593Smuzhiyun "video2_clkin_ck", 340*4882a593Smuzhiyun "dpll_abe_m2_ck", 341*4882a593Smuzhiyun "hdmi_clkin_ck", 342*4882a593Smuzhiyun "l3_iclk_div", 343*4882a593Smuzhiyun NULL, 344*4882a593Smuzhiyun }; 345*4882a593Smuzhiyun 346*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_gmac_bit_data[] __initconst = { 347*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_rmii_50mhz_clk_mux_parents, NULL }, 348*4882a593Smuzhiyun { 25, TI_CLK_MUX, dra7_gmac_rft_clk_mux_parents, NULL }, 349*4882a593Smuzhiyun { 0 }, 350*4882a593Smuzhiyun }; 351*4882a593Smuzhiyun 352*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_usb_otg_ss1_bit_data[] __initconst = { 353*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_usb_otg_ss2_refclk960m_parents, NULL }, 354*4882a593Smuzhiyun { 0 }, 355*4882a593Smuzhiyun }; 356*4882a593Smuzhiyun 357*4882a593Smuzhiyun static const struct omap_clkctrl_reg_data dra7_l3init_clkctrl_regs[] __initconst = { 358*4882a593Smuzhiyun { DRA7_MMC1_CLKCTRL, dra7_mmc1_bit_data, CLKF_SW_SUP, "l3init_cm:clk:0008:25" }, 359*4882a593Smuzhiyun { DRA7_MMC2_CLKCTRL, dra7_mmc2_bit_data, CLKF_SW_SUP, "l3init_cm:clk:0010:25" }, 360*4882a593Smuzhiyun { DRA7_USB_OTG_SS2_CLKCTRL, dra7_usb_otg_ss2_bit_data, CLKF_HW_SUP, "dpll_core_h13x2_ck" }, 361*4882a593Smuzhiyun { DRA7_USB_OTG_SS3_CLKCTRL, NULL, CLKF_HW_SUP, "dpll_core_h13x2_ck" }, 362*4882a593Smuzhiyun { DRA7_USB_OTG_SS4_CLKCTRL, NULL, CLKF_HW_SUP | CLKF_SOC_DRA74 | CLKF_SOC_DRA76, "dpll_core_h13x2_ck" }, 363*4882a593Smuzhiyun { DRA7_SATA_CLKCTRL, dra7_sata_bit_data, CLKF_SW_SUP, "func_48m_fclk" }, 364*4882a593Smuzhiyun { DRA7_PCIE1_CLKCTRL, dra7_pcie1_bit_data, CLKF_SW_SUP, "l4_root_clk_div", "pcie_clkdm" }, 365*4882a593Smuzhiyun { DRA7_PCIE2_CLKCTRL, dra7_pcie2_bit_data, CLKF_SW_SUP, "l4_root_clk_div", "pcie_clkdm" }, 366*4882a593Smuzhiyun { DRA7_GMAC_CLKCTRL, dra7_gmac_bit_data, CLKF_SW_SUP, "dpll_gmac_ck", "gmac_clkdm" }, 367*4882a593Smuzhiyun { DRA7_OCP2SCP1_CLKCTRL, NULL, CLKF_HW_SUP, "l4_root_clk_div" }, 368*4882a593Smuzhiyun { DRA7_OCP2SCP3_CLKCTRL, NULL, CLKF_HW_SUP, "l4_root_clk_div" }, 369*4882a593Smuzhiyun { DRA7_USB_OTG_SS1_CLKCTRL, dra7_usb_otg_ss1_bit_data, CLKF_HW_SUP, "dpll_core_h13x2_ck" }, 370*4882a593Smuzhiyun { 0 }, 371*4882a593Smuzhiyun }; 372*4882a593Smuzhiyun 373*4882a593Smuzhiyun static const char * const dra7_timer10_gfclk_mux_parents[] __initconst = { 374*4882a593Smuzhiyun "timer_sys_clk_div", 375*4882a593Smuzhiyun "sys_32k_ck", 376*4882a593Smuzhiyun "sys_clkin2", 377*4882a593Smuzhiyun "ref_clkin0_ck", 378*4882a593Smuzhiyun "ref_clkin1_ck", 379*4882a593Smuzhiyun "ref_clkin2_ck", 380*4882a593Smuzhiyun "ref_clkin3_ck", 381*4882a593Smuzhiyun "abe_giclk_div", 382*4882a593Smuzhiyun "video1_div_clk", 383*4882a593Smuzhiyun "video2_div_clk", 384*4882a593Smuzhiyun "hdmi_div_clk", 385*4882a593Smuzhiyun NULL, 386*4882a593Smuzhiyun }; 387*4882a593Smuzhiyun 388*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer10_bit_data[] __initconst = { 389*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer10_gfclk_mux_parents, NULL }, 390*4882a593Smuzhiyun { 0 }, 391*4882a593Smuzhiyun }; 392*4882a593Smuzhiyun 393*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer11_bit_data[] __initconst = { 394*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer10_gfclk_mux_parents, NULL }, 395*4882a593Smuzhiyun { 0 }, 396*4882a593Smuzhiyun }; 397*4882a593Smuzhiyun 398*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer2_bit_data[] __initconst = { 399*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer10_gfclk_mux_parents, NULL }, 400*4882a593Smuzhiyun { 0 }, 401*4882a593Smuzhiyun }; 402*4882a593Smuzhiyun 403*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer3_bit_data[] __initconst = { 404*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer10_gfclk_mux_parents, NULL }, 405*4882a593Smuzhiyun { 0 }, 406*4882a593Smuzhiyun }; 407*4882a593Smuzhiyun 408*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer4_bit_data[] __initconst = { 409*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer10_gfclk_mux_parents, NULL }, 410*4882a593Smuzhiyun { 0 }, 411*4882a593Smuzhiyun }; 412*4882a593Smuzhiyun 413*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer9_bit_data[] __initconst = { 414*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer10_gfclk_mux_parents, NULL }, 415*4882a593Smuzhiyun { 0 }, 416*4882a593Smuzhiyun }; 417*4882a593Smuzhiyun 418*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_gpio2_bit_data[] __initconst = { 419*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 420*4882a593Smuzhiyun { 0 }, 421*4882a593Smuzhiyun }; 422*4882a593Smuzhiyun 423*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_gpio3_bit_data[] __initconst = { 424*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 425*4882a593Smuzhiyun { 0 }, 426*4882a593Smuzhiyun }; 427*4882a593Smuzhiyun 428*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_gpio4_bit_data[] __initconst = { 429*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 430*4882a593Smuzhiyun { 0 }, 431*4882a593Smuzhiyun }; 432*4882a593Smuzhiyun 433*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_gpio5_bit_data[] __initconst = { 434*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 435*4882a593Smuzhiyun { 0 }, 436*4882a593Smuzhiyun }; 437*4882a593Smuzhiyun 438*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_gpio6_bit_data[] __initconst = { 439*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 440*4882a593Smuzhiyun { 0 }, 441*4882a593Smuzhiyun }; 442*4882a593Smuzhiyun 443*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer13_bit_data[] __initconst = { 444*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer10_gfclk_mux_parents, NULL }, 445*4882a593Smuzhiyun { 0 }, 446*4882a593Smuzhiyun }; 447*4882a593Smuzhiyun 448*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer14_bit_data[] __initconst = { 449*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer10_gfclk_mux_parents, NULL }, 450*4882a593Smuzhiyun { 0 }, 451*4882a593Smuzhiyun }; 452*4882a593Smuzhiyun 453*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer15_bit_data[] __initconst = { 454*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer10_gfclk_mux_parents, NULL }, 455*4882a593Smuzhiyun { 0 }, 456*4882a593Smuzhiyun }; 457*4882a593Smuzhiyun 458*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_gpio7_bit_data[] __initconst = { 459*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 460*4882a593Smuzhiyun { 0 }, 461*4882a593Smuzhiyun }; 462*4882a593Smuzhiyun 463*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_gpio8_bit_data[] __initconst = { 464*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 465*4882a593Smuzhiyun { 0 }, 466*4882a593Smuzhiyun }; 467*4882a593Smuzhiyun 468*4882a593Smuzhiyun static const char * const dra7_mmc3_gfclk_div_parents[] __initconst = { 469*4882a593Smuzhiyun "l4per_cm:clk:0120:24", 470*4882a593Smuzhiyun NULL, 471*4882a593Smuzhiyun }; 472*4882a593Smuzhiyun 473*4882a593Smuzhiyun static const struct omap_clkctrl_div_data dra7_mmc3_gfclk_div_data __initconst = { 474*4882a593Smuzhiyun .max_div = 4, 475*4882a593Smuzhiyun .flags = CLK_DIVIDER_POWER_OF_TWO, 476*4882a593Smuzhiyun }; 477*4882a593Smuzhiyun 478*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_mmc3_bit_data[] __initconst = { 479*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 480*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_uart6_gfclk_mux_parents, NULL }, 481*4882a593Smuzhiyun { 25, TI_CLK_DIVIDER, dra7_mmc3_gfclk_div_parents, &dra7_mmc3_gfclk_div_data }, 482*4882a593Smuzhiyun { 0 }, 483*4882a593Smuzhiyun }; 484*4882a593Smuzhiyun 485*4882a593Smuzhiyun static const char * const dra7_mmc4_gfclk_div_parents[] __initconst = { 486*4882a593Smuzhiyun "l4per_cm:clk:0128:24", 487*4882a593Smuzhiyun NULL, 488*4882a593Smuzhiyun }; 489*4882a593Smuzhiyun 490*4882a593Smuzhiyun static const struct omap_clkctrl_div_data dra7_mmc4_gfclk_div_data __initconst = { 491*4882a593Smuzhiyun .max_div = 4, 492*4882a593Smuzhiyun .flags = CLK_DIVIDER_POWER_OF_TWO, 493*4882a593Smuzhiyun }; 494*4882a593Smuzhiyun 495*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_mmc4_bit_data[] __initconst = { 496*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 497*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_uart6_gfclk_mux_parents, NULL }, 498*4882a593Smuzhiyun { 25, TI_CLK_DIVIDER, dra7_mmc4_gfclk_div_parents, &dra7_mmc4_gfclk_div_data }, 499*4882a593Smuzhiyun { 0 }, 500*4882a593Smuzhiyun }; 501*4882a593Smuzhiyun 502*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer16_bit_data[] __initconst = { 503*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer10_gfclk_mux_parents, NULL }, 504*4882a593Smuzhiyun { 0 }, 505*4882a593Smuzhiyun }; 506*4882a593Smuzhiyun 507*4882a593Smuzhiyun static const char * const dra7_qspi_gfclk_mux_parents[] __initconst = { 508*4882a593Smuzhiyun "func_128m_clk", 509*4882a593Smuzhiyun "dpll_per_h13x2_ck", 510*4882a593Smuzhiyun NULL, 511*4882a593Smuzhiyun }; 512*4882a593Smuzhiyun 513*4882a593Smuzhiyun static const char * const dra7_qspi_gfclk_div_parents[] __initconst = { 514*4882a593Smuzhiyun "l4per_cm:clk:0138:24", 515*4882a593Smuzhiyun NULL, 516*4882a593Smuzhiyun }; 517*4882a593Smuzhiyun 518*4882a593Smuzhiyun static const struct omap_clkctrl_div_data dra7_qspi_gfclk_div_data __initconst = { 519*4882a593Smuzhiyun .max_div = 4, 520*4882a593Smuzhiyun .flags = CLK_DIVIDER_POWER_OF_TWO, 521*4882a593Smuzhiyun }; 522*4882a593Smuzhiyun 523*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_qspi_bit_data[] __initconst = { 524*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_qspi_gfclk_mux_parents, NULL }, 525*4882a593Smuzhiyun { 25, TI_CLK_DIVIDER, dra7_qspi_gfclk_div_parents, &dra7_qspi_gfclk_div_data }, 526*4882a593Smuzhiyun { 0 }, 527*4882a593Smuzhiyun }; 528*4882a593Smuzhiyun 529*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_uart1_bit_data[] __initconst = { 530*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_uart6_gfclk_mux_parents, NULL }, 531*4882a593Smuzhiyun { 0 }, 532*4882a593Smuzhiyun }; 533*4882a593Smuzhiyun 534*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_uart2_bit_data[] __initconst = { 535*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_uart6_gfclk_mux_parents, NULL }, 536*4882a593Smuzhiyun { 0 }, 537*4882a593Smuzhiyun }; 538*4882a593Smuzhiyun 539*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_uart3_bit_data[] __initconst = { 540*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_uart6_gfclk_mux_parents, NULL }, 541*4882a593Smuzhiyun { 0 }, 542*4882a593Smuzhiyun }; 543*4882a593Smuzhiyun 544*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_uart4_bit_data[] __initconst = { 545*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_uart6_gfclk_mux_parents, NULL }, 546*4882a593Smuzhiyun { 0 }, 547*4882a593Smuzhiyun }; 548*4882a593Smuzhiyun 549*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_mcasp2_bit_data[] __initconst = { 550*4882a593Smuzhiyun { 22, TI_CLK_MUX, dra7_mcasp1_aux_gfclk_mux_parents, NULL }, 551*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_mcasp1_ahclkx_mux_parents, NULL }, 552*4882a593Smuzhiyun { 28, TI_CLK_MUX, dra7_mcasp1_ahclkx_mux_parents, NULL }, 553*4882a593Smuzhiyun { 0 }, 554*4882a593Smuzhiyun }; 555*4882a593Smuzhiyun 556*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_mcasp3_bit_data[] __initconst = { 557*4882a593Smuzhiyun { 22, TI_CLK_MUX, dra7_mcasp1_aux_gfclk_mux_parents, NULL }, 558*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_mcasp1_ahclkx_mux_parents, NULL }, 559*4882a593Smuzhiyun { 0 }, 560*4882a593Smuzhiyun }; 561*4882a593Smuzhiyun 562*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_uart5_bit_data[] __initconst = { 563*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_uart6_gfclk_mux_parents, NULL }, 564*4882a593Smuzhiyun { 0 }, 565*4882a593Smuzhiyun }; 566*4882a593Smuzhiyun 567*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_mcasp5_bit_data[] __initconst = { 568*4882a593Smuzhiyun { 22, TI_CLK_MUX, dra7_mcasp1_aux_gfclk_mux_parents, NULL }, 569*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_mcasp1_ahclkx_mux_parents, NULL }, 570*4882a593Smuzhiyun { 0 }, 571*4882a593Smuzhiyun }; 572*4882a593Smuzhiyun 573*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_mcasp8_bit_data[] __initconst = { 574*4882a593Smuzhiyun { 22, TI_CLK_MUX, dra7_mcasp1_aux_gfclk_mux_parents, NULL }, 575*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_mcasp1_ahclkx_mux_parents, NULL }, 576*4882a593Smuzhiyun { 0 }, 577*4882a593Smuzhiyun }; 578*4882a593Smuzhiyun 579*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_mcasp4_bit_data[] __initconst = { 580*4882a593Smuzhiyun { 22, TI_CLK_MUX, dra7_mcasp1_aux_gfclk_mux_parents, NULL }, 581*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_mcasp1_ahclkx_mux_parents, NULL }, 582*4882a593Smuzhiyun { 0 }, 583*4882a593Smuzhiyun }; 584*4882a593Smuzhiyun 585*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_uart7_bit_data[] __initconst = { 586*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_uart6_gfclk_mux_parents, NULL }, 587*4882a593Smuzhiyun { 0 }, 588*4882a593Smuzhiyun }; 589*4882a593Smuzhiyun 590*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_uart8_bit_data[] __initconst = { 591*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_uart6_gfclk_mux_parents, NULL }, 592*4882a593Smuzhiyun { 0 }, 593*4882a593Smuzhiyun }; 594*4882a593Smuzhiyun 595*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_uart9_bit_data[] __initconst = { 596*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_uart6_gfclk_mux_parents, NULL }, 597*4882a593Smuzhiyun { 0 }, 598*4882a593Smuzhiyun }; 599*4882a593Smuzhiyun 600*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_mcasp6_bit_data[] __initconst = { 601*4882a593Smuzhiyun { 22, TI_CLK_MUX, dra7_mcasp1_aux_gfclk_mux_parents, NULL }, 602*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_mcasp1_ahclkx_mux_parents, NULL }, 603*4882a593Smuzhiyun { 0 }, 604*4882a593Smuzhiyun }; 605*4882a593Smuzhiyun 606*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_mcasp7_bit_data[] __initconst = { 607*4882a593Smuzhiyun { 22, TI_CLK_MUX, dra7_mcasp1_aux_gfclk_mux_parents, NULL }, 608*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_mcasp1_ahclkx_mux_parents, NULL }, 609*4882a593Smuzhiyun { 0 }, 610*4882a593Smuzhiyun }; 611*4882a593Smuzhiyun 612*4882a593Smuzhiyun static const struct omap_clkctrl_reg_data dra7_l4per_clkctrl_regs[] __initconst = { 613*4882a593Smuzhiyun { DRA7_L4_PER2_CLKCTRL, NULL, 0, "l3_iclk_div", "l4per2_clkdm" }, 614*4882a593Smuzhiyun { DRA7_L4_PER3_CLKCTRL, NULL, 0, "l3_iclk_div", "l4per3_clkdm" }, 615*4882a593Smuzhiyun { DRA7_TIMER10_CLKCTRL, dra7_timer10_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0028:24" }, 616*4882a593Smuzhiyun { DRA7_TIMER11_CLKCTRL, dra7_timer11_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0030:24" }, 617*4882a593Smuzhiyun { DRA7_TIMER2_CLKCTRL, dra7_timer2_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0038:24" }, 618*4882a593Smuzhiyun { DRA7_TIMER3_CLKCTRL, dra7_timer3_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0040:24" }, 619*4882a593Smuzhiyun { DRA7_TIMER4_CLKCTRL, dra7_timer4_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0048:24" }, 620*4882a593Smuzhiyun { DRA7_TIMER9_CLKCTRL, dra7_timer9_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0050:24" }, 621*4882a593Smuzhiyun { DRA7_ELM_CLKCTRL, NULL, 0, "l3_iclk_div" }, 622*4882a593Smuzhiyun { DRA7_GPIO2_CLKCTRL, dra7_gpio2_bit_data, CLKF_HW_SUP, "l3_iclk_div" }, 623*4882a593Smuzhiyun { DRA7_GPIO3_CLKCTRL, dra7_gpio3_bit_data, CLKF_HW_SUP, "l3_iclk_div" }, 624*4882a593Smuzhiyun { DRA7_GPIO4_CLKCTRL, dra7_gpio4_bit_data, CLKF_HW_SUP, "l3_iclk_div" }, 625*4882a593Smuzhiyun { DRA7_GPIO5_CLKCTRL, dra7_gpio5_bit_data, CLKF_HW_SUP, "l3_iclk_div" }, 626*4882a593Smuzhiyun { DRA7_GPIO6_CLKCTRL, dra7_gpio6_bit_data, CLKF_HW_SUP, "l3_iclk_div" }, 627*4882a593Smuzhiyun { DRA7_HDQ1W_CLKCTRL, NULL, CLKF_SW_SUP, "func_12m_fclk" }, 628*4882a593Smuzhiyun { DRA7_EPWMSS1_CLKCTRL, NULL, CLKF_SW_SUP, "l4_root_clk_div", "l4per2_clkdm" }, 629*4882a593Smuzhiyun { DRA7_EPWMSS2_CLKCTRL, NULL, CLKF_SW_SUP, "l4_root_clk_div", "l4per2_clkdm" }, 630*4882a593Smuzhiyun { DRA7_I2C1_CLKCTRL, NULL, CLKF_SW_SUP, "func_96m_fclk" }, 631*4882a593Smuzhiyun { DRA7_I2C2_CLKCTRL, NULL, CLKF_SW_SUP, "func_96m_fclk" }, 632*4882a593Smuzhiyun { DRA7_I2C3_CLKCTRL, NULL, CLKF_SW_SUP, "func_96m_fclk" }, 633*4882a593Smuzhiyun { DRA7_I2C4_CLKCTRL, NULL, CLKF_SW_SUP, "func_96m_fclk" }, 634*4882a593Smuzhiyun { DRA7_L4_PER1_CLKCTRL, NULL, 0, "l3_iclk_div" }, 635*4882a593Smuzhiyun { DRA7_EPWMSS0_CLKCTRL, NULL, CLKF_SW_SUP, "l4_root_clk_div", "l4per2_clkdm" }, 636*4882a593Smuzhiyun { DRA7_TIMER13_CLKCTRL, dra7_timer13_bit_data, CLKF_SW_SUP, "l4per_cm:clk:00c8:24", "l4per3_clkdm" }, 637*4882a593Smuzhiyun { DRA7_TIMER14_CLKCTRL, dra7_timer14_bit_data, CLKF_SW_SUP, "l4per_cm:clk:00d0:24", "l4per3_clkdm" }, 638*4882a593Smuzhiyun { DRA7_TIMER15_CLKCTRL, dra7_timer15_bit_data, CLKF_SW_SUP, "l4per_cm:clk:00d8:24", "l4per3_clkdm" }, 639*4882a593Smuzhiyun { DRA7_MCSPI1_CLKCTRL, NULL, CLKF_SW_SUP, "func_48m_fclk" }, 640*4882a593Smuzhiyun { DRA7_MCSPI2_CLKCTRL, NULL, CLKF_SW_SUP, "func_48m_fclk" }, 641*4882a593Smuzhiyun { DRA7_MCSPI3_CLKCTRL, NULL, CLKF_SW_SUP, "func_48m_fclk" }, 642*4882a593Smuzhiyun { DRA7_MCSPI4_CLKCTRL, NULL, CLKF_SW_SUP, "func_48m_fclk" }, 643*4882a593Smuzhiyun { DRA7_GPIO7_CLKCTRL, dra7_gpio7_bit_data, CLKF_HW_SUP, "l3_iclk_div" }, 644*4882a593Smuzhiyun { DRA7_GPIO8_CLKCTRL, dra7_gpio8_bit_data, CLKF_HW_SUP, "l3_iclk_div" }, 645*4882a593Smuzhiyun { DRA7_MMC3_CLKCTRL, dra7_mmc3_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0120:25" }, 646*4882a593Smuzhiyun { DRA7_MMC4_CLKCTRL, dra7_mmc4_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0128:25" }, 647*4882a593Smuzhiyun { DRA7_TIMER16_CLKCTRL, dra7_timer16_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0130:24", "l4per3_clkdm" }, 648*4882a593Smuzhiyun { DRA7_QSPI_CLKCTRL, dra7_qspi_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0138:25", "l4per2_clkdm" }, 649*4882a593Smuzhiyun { DRA7_UART1_CLKCTRL, dra7_uart1_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0140:24" }, 650*4882a593Smuzhiyun { DRA7_UART2_CLKCTRL, dra7_uart2_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0148:24" }, 651*4882a593Smuzhiyun { DRA7_UART3_CLKCTRL, dra7_uart3_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0150:24" }, 652*4882a593Smuzhiyun { DRA7_UART4_CLKCTRL, dra7_uart4_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0158:24" }, 653*4882a593Smuzhiyun { DRA7_MCASP2_CLKCTRL, dra7_mcasp2_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0160:22", "l4per2_clkdm" }, 654*4882a593Smuzhiyun { DRA7_MCASP3_CLKCTRL, dra7_mcasp3_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0168:22", "l4per2_clkdm" }, 655*4882a593Smuzhiyun { DRA7_UART5_CLKCTRL, dra7_uart5_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0170:24" }, 656*4882a593Smuzhiyun { DRA7_MCASP5_CLKCTRL, dra7_mcasp5_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0178:22", "l4per2_clkdm" }, 657*4882a593Smuzhiyun { DRA7_MCASP8_CLKCTRL, dra7_mcasp8_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0190:24", "l4per2_clkdm" }, 658*4882a593Smuzhiyun { DRA7_MCASP4_CLKCTRL, dra7_mcasp4_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0198:22", "l4per2_clkdm" }, 659*4882a593Smuzhiyun { DRA7_AES1_CLKCTRL, NULL, CLKF_HW_SUP, "l3_iclk_div", "l4sec_clkdm" }, 660*4882a593Smuzhiyun { DRA7_AES2_CLKCTRL, NULL, CLKF_HW_SUP, "l3_iclk_div", "l4sec_clkdm" }, 661*4882a593Smuzhiyun { DRA7_DES_CLKCTRL, NULL, CLKF_HW_SUP, "l3_iclk_div", "l4sec_clkdm" }, 662*4882a593Smuzhiyun { DRA7_RNG_CLKCTRL, NULL, CLKF_HW_SUP | CLKF_SOC_NONSEC, "l3_iclk_div", "l4sec_clkdm" }, 663*4882a593Smuzhiyun { DRA7_SHAM_CLKCTRL, NULL, CLKF_HW_SUP, "l3_iclk_div", "l4sec_clkdm" }, 664*4882a593Smuzhiyun { DRA7_UART7_CLKCTRL, dra7_uart7_bit_data, CLKF_SW_SUP, "l4per_cm:clk:01d0:24", "l4per2_clkdm" }, 665*4882a593Smuzhiyun { DRA7_UART8_CLKCTRL, dra7_uart8_bit_data, CLKF_SW_SUP, "l4per_cm:clk:01e0:24", "l4per2_clkdm" }, 666*4882a593Smuzhiyun { DRA7_UART9_CLKCTRL, dra7_uart9_bit_data, CLKF_SW_SUP, "l4per_cm:clk:01e8:24", "l4per2_clkdm" }, 667*4882a593Smuzhiyun { DRA7_DCAN2_CLKCTRL, NULL, CLKF_SW_SUP, "sys_clkin1", "l4per2_clkdm" }, 668*4882a593Smuzhiyun { DRA7_MCASP6_CLKCTRL, dra7_mcasp6_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0204:22", "l4per2_clkdm" }, 669*4882a593Smuzhiyun { DRA7_MCASP7_CLKCTRL, dra7_mcasp7_bit_data, CLKF_SW_SUP, "l4per_cm:clk:0208:22", "l4per2_clkdm" }, 670*4882a593Smuzhiyun { 0 }, 671*4882a593Smuzhiyun }; 672*4882a593Smuzhiyun 673*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_gpio1_bit_data[] __initconst = { 674*4882a593Smuzhiyun { 8, TI_CLK_GATE, dra7_dss_32khz_clk_parents, NULL }, 675*4882a593Smuzhiyun { 0 }, 676*4882a593Smuzhiyun }; 677*4882a593Smuzhiyun 678*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_timer1_bit_data[] __initconst = { 679*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_timer10_gfclk_mux_parents, NULL }, 680*4882a593Smuzhiyun { 0 }, 681*4882a593Smuzhiyun }; 682*4882a593Smuzhiyun 683*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_uart10_bit_data[] __initconst = { 684*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_uart6_gfclk_mux_parents, NULL }, 685*4882a593Smuzhiyun { 0 }, 686*4882a593Smuzhiyun }; 687*4882a593Smuzhiyun 688*4882a593Smuzhiyun static const char * const dra7_dcan1_sys_clk_mux_parents[] __initconst = { 689*4882a593Smuzhiyun "sys_clkin1", 690*4882a593Smuzhiyun "sys_clkin2", 691*4882a593Smuzhiyun NULL, 692*4882a593Smuzhiyun }; 693*4882a593Smuzhiyun 694*4882a593Smuzhiyun static const struct omap_clkctrl_bit_data dra7_dcan1_bit_data[] __initconst = { 695*4882a593Smuzhiyun { 24, TI_CLK_MUX, dra7_dcan1_sys_clk_mux_parents, NULL }, 696*4882a593Smuzhiyun { 0 }, 697*4882a593Smuzhiyun }; 698*4882a593Smuzhiyun 699*4882a593Smuzhiyun static const struct omap_clkctrl_reg_data dra7_wkupaon_clkctrl_regs[] __initconst = { 700*4882a593Smuzhiyun { DRA7_L4_WKUP_CLKCTRL, NULL, 0, "wkupaon_iclk_mux" }, 701*4882a593Smuzhiyun { DRA7_WD_TIMER2_CLKCTRL, NULL, CLKF_SW_SUP, "sys_32k_ck" }, 702*4882a593Smuzhiyun { DRA7_GPIO1_CLKCTRL, dra7_gpio1_bit_data, CLKF_HW_SUP, "wkupaon_iclk_mux" }, 703*4882a593Smuzhiyun { DRA7_TIMER1_CLKCTRL, dra7_timer1_bit_data, CLKF_SW_SUP, "wkupaon_cm:clk:0020:24" }, 704*4882a593Smuzhiyun { DRA7_TIMER12_CLKCTRL, NULL, CLKF_SOC_NONSEC, "secure_32k_clk_src_ck" }, 705*4882a593Smuzhiyun { DRA7_COUNTER_32K_CLKCTRL, NULL, 0, "wkupaon_iclk_mux" }, 706*4882a593Smuzhiyun { DRA7_UART10_CLKCTRL, dra7_uart10_bit_data, CLKF_SW_SUP, "wkupaon_cm:clk:0060:24" }, 707*4882a593Smuzhiyun { DRA7_DCAN1_CLKCTRL, dra7_dcan1_bit_data, CLKF_SW_SUP, "wkupaon_cm:clk:0068:24" }, 708*4882a593Smuzhiyun { DRA7_ADC_CLKCTRL, NULL, CLKF_SW_SUP, "mcan_clk"}, 709*4882a593Smuzhiyun { 0 }, 710*4882a593Smuzhiyun }; 711*4882a593Smuzhiyun 712*4882a593Smuzhiyun const struct omap_clkctrl_data dra7_clkctrl_compat_data[] __initconst = { 713*4882a593Smuzhiyun { 0x4a005320, dra7_mpu_clkctrl_regs }, 714*4882a593Smuzhiyun { 0x4a005540, dra7_ipu_clkctrl_regs }, 715*4882a593Smuzhiyun { 0x4a005740, dra7_rtc_clkctrl_regs }, 716*4882a593Smuzhiyun { 0x4a008620, dra7_coreaon_clkctrl_regs }, 717*4882a593Smuzhiyun { 0x4a008720, dra7_l3main1_clkctrl_regs }, 718*4882a593Smuzhiyun { 0x4a008a20, dra7_dma_clkctrl_regs }, 719*4882a593Smuzhiyun { 0x4a008b20, dra7_emif_clkctrl_regs }, 720*4882a593Smuzhiyun { 0x4a008c00, dra7_atl_clkctrl_regs }, 721*4882a593Smuzhiyun { 0x4a008d20, dra7_l4cfg_clkctrl_regs }, 722*4882a593Smuzhiyun { 0x4a008e20, dra7_l3instr_clkctrl_regs }, 723*4882a593Smuzhiyun { 0x4a009120, dra7_dss_clkctrl_regs }, 724*4882a593Smuzhiyun { 0x4a009320, dra7_l3init_clkctrl_regs }, 725*4882a593Smuzhiyun { 0x4a009700, dra7_l4per_clkctrl_regs }, 726*4882a593Smuzhiyun { 0x4ae07820, dra7_wkupaon_clkctrl_regs }, 727*4882a593Smuzhiyun { 0 }, 728*4882a593Smuzhiyun }; 729*4882a593Smuzhiyun 730*4882a593Smuzhiyun struct ti_dt_clk dra7xx_compat_clks[] = { 731*4882a593Smuzhiyun DT_CLK(NULL, "timer_32k_ck", "sys_32k_ck"), 732*4882a593Smuzhiyun DT_CLK(NULL, "sys_clkin_ck", "timer_sys_clk_div"), 733*4882a593Smuzhiyun DT_CLK(NULL, "sys_clkin", "sys_clkin1"), 734*4882a593Smuzhiyun DT_CLK(NULL, "atl_dpll_clk_mux", "atl_cm:0000:24"), 735*4882a593Smuzhiyun DT_CLK(NULL, "atl_gfclk_mux", "atl_cm:0000:26"), 736*4882a593Smuzhiyun DT_CLK(NULL, "dcan1_sys_clk_mux", "wkupaon_cm:0068:24"), 737*4882a593Smuzhiyun DT_CLK(NULL, "dss_32khz_clk", "dss_cm:0000:11"), 738*4882a593Smuzhiyun DT_CLK(NULL, "dss_48mhz_clk", "dss_cm:0000:9"), 739*4882a593Smuzhiyun DT_CLK(NULL, "dss_dss_clk", "dss_cm:0000:8"), 740*4882a593Smuzhiyun DT_CLK(NULL, "dss_hdmi_clk", "dss_cm:0000:10"), 741*4882a593Smuzhiyun DT_CLK(NULL, "dss_video1_clk", "dss_cm:0000:12"), 742*4882a593Smuzhiyun DT_CLK(NULL, "dss_video2_clk", "dss_cm:0000:13"), 743*4882a593Smuzhiyun DT_CLK(NULL, "gmac_rft_clk_mux", "l3init_cm:00b0:25"), 744*4882a593Smuzhiyun DT_CLK(NULL, "gpio1_dbclk", "wkupaon_cm:0018:8"), 745*4882a593Smuzhiyun DT_CLK(NULL, "gpio2_dbclk", "l4per_cm:0060:8"), 746*4882a593Smuzhiyun DT_CLK(NULL, "gpio3_dbclk", "l4per_cm:0068:8"), 747*4882a593Smuzhiyun DT_CLK(NULL, "gpio4_dbclk", "l4per_cm:0070:8"), 748*4882a593Smuzhiyun DT_CLK(NULL, "gpio5_dbclk", "l4per_cm:0078:8"), 749*4882a593Smuzhiyun DT_CLK(NULL, "gpio6_dbclk", "l4per_cm:0080:8"), 750*4882a593Smuzhiyun DT_CLK(NULL, "gpio7_dbclk", "l4per_cm:0110:8"), 751*4882a593Smuzhiyun DT_CLK(NULL, "gpio8_dbclk", "l4per_cm:0118:8"), 752*4882a593Smuzhiyun DT_CLK(NULL, "mcasp1_ahclkr_mux", "ipu_cm:0010:28"), 753*4882a593Smuzhiyun DT_CLK(NULL, "mcasp1_ahclkx_mux", "ipu_cm:0010:24"), 754*4882a593Smuzhiyun DT_CLK(NULL, "mcasp1_aux_gfclk_mux", "ipu_cm:0010:22"), 755*4882a593Smuzhiyun DT_CLK(NULL, "mcasp2_ahclkr_mux", "l4per_cm:0160:28"), 756*4882a593Smuzhiyun DT_CLK(NULL, "mcasp2_ahclkx_mux", "l4per_cm:0160:24"), 757*4882a593Smuzhiyun DT_CLK(NULL, "mcasp2_aux_gfclk_mux", "l4per_cm:0160:22"), 758*4882a593Smuzhiyun DT_CLK(NULL, "mcasp3_ahclkx_mux", "l4per_cm:0168:24"), 759*4882a593Smuzhiyun DT_CLK(NULL, "mcasp3_aux_gfclk_mux", "l4per_cm:0168:22"), 760*4882a593Smuzhiyun DT_CLK(NULL, "mcasp4_ahclkx_mux", "l4per_cm:0198:24"), 761*4882a593Smuzhiyun DT_CLK(NULL, "mcasp4_aux_gfclk_mux", "l4per_cm:0198:22"), 762*4882a593Smuzhiyun DT_CLK(NULL, "mcasp5_ahclkx_mux", "l4per_cm:0178:24"), 763*4882a593Smuzhiyun DT_CLK(NULL, "mcasp5_aux_gfclk_mux", "l4per_cm:0178:22"), 764*4882a593Smuzhiyun DT_CLK(NULL, "mcasp6_ahclkx_mux", "l4per_cm:0204:24"), 765*4882a593Smuzhiyun DT_CLK(NULL, "mcasp6_aux_gfclk_mux", "l4per_cm:0204:22"), 766*4882a593Smuzhiyun DT_CLK(NULL, "mcasp7_ahclkx_mux", "l4per_cm:0208:24"), 767*4882a593Smuzhiyun DT_CLK(NULL, "mcasp7_aux_gfclk_mux", "l4per_cm:0208:22"), 768*4882a593Smuzhiyun DT_CLK(NULL, "mcasp8_ahclkx_mux", "l4per_cm:0190:22"), 769*4882a593Smuzhiyun DT_CLK(NULL, "mcasp8_aux_gfclk_mux", "l4per_cm:0190:24"), 770*4882a593Smuzhiyun DT_CLK(NULL, "mmc1_clk32k", "l3init_cm:0008:8"), 771*4882a593Smuzhiyun DT_CLK(NULL, "mmc1_fclk_div", "l3init_cm:0008:25"), 772*4882a593Smuzhiyun DT_CLK(NULL, "mmc1_fclk_mux", "l3init_cm:0008:24"), 773*4882a593Smuzhiyun DT_CLK(NULL, "mmc2_clk32k", "l3init_cm:0010:8"), 774*4882a593Smuzhiyun DT_CLK(NULL, "mmc2_fclk_div", "l3init_cm:0010:25"), 775*4882a593Smuzhiyun DT_CLK(NULL, "mmc2_fclk_mux", "l3init_cm:0010:24"), 776*4882a593Smuzhiyun DT_CLK(NULL, "mmc3_clk32k", "l4per_cm:0120:8"), 777*4882a593Smuzhiyun DT_CLK(NULL, "mmc3_gfclk_div", "l4per_cm:0120:25"), 778*4882a593Smuzhiyun DT_CLK(NULL, "mmc3_gfclk_mux", "l4per_cm:0120:24"), 779*4882a593Smuzhiyun DT_CLK(NULL, "mmc4_clk32k", "l4per_cm:0128:8"), 780*4882a593Smuzhiyun DT_CLK(NULL, "mmc4_gfclk_div", "l4per_cm:0128:25"), 781*4882a593Smuzhiyun DT_CLK(NULL, "mmc4_gfclk_mux", "l4per_cm:0128:24"), 782*4882a593Smuzhiyun DT_CLK(NULL, "optfclk_pciephy1_32khz", "l3init_cm:0090:8"), 783*4882a593Smuzhiyun DT_CLK(NULL, "optfclk_pciephy1_clk", "l3init_cm:0090:9"), 784*4882a593Smuzhiyun DT_CLK(NULL, "optfclk_pciephy1_div_clk", "l3init_cm:0090:10"), 785*4882a593Smuzhiyun DT_CLK(NULL, "optfclk_pciephy2_32khz", "l3init_cm:0098:8"), 786*4882a593Smuzhiyun DT_CLK(NULL, "optfclk_pciephy2_clk", "l3init_cm:0098:9"), 787*4882a593Smuzhiyun DT_CLK(NULL, "optfclk_pciephy2_div_clk", "l3init_cm:0098:10"), 788*4882a593Smuzhiyun DT_CLK(NULL, "qspi_gfclk_div", "l4per_cm:0138:25"), 789*4882a593Smuzhiyun DT_CLK(NULL, "qspi_gfclk_mux", "l4per_cm:0138:24"), 790*4882a593Smuzhiyun DT_CLK(NULL, "rmii_50mhz_clk_mux", "l3init_cm:00b0:24"), 791*4882a593Smuzhiyun DT_CLK(NULL, "sata_ref_clk", "l3init_cm:0068:8"), 792*4882a593Smuzhiyun DT_CLK(NULL, "timer10_gfclk_mux", "l4per_cm:0028:24"), 793*4882a593Smuzhiyun DT_CLK(NULL, "timer11_gfclk_mux", "l4per_cm:0030:24"), 794*4882a593Smuzhiyun DT_CLK(NULL, "timer13_gfclk_mux", "l4per_cm:00c8:24"), 795*4882a593Smuzhiyun DT_CLK(NULL, "timer14_gfclk_mux", "l4per_cm:00d0:24"), 796*4882a593Smuzhiyun DT_CLK(NULL, "timer15_gfclk_mux", "l4per_cm:00d8:24"), 797*4882a593Smuzhiyun DT_CLK(NULL, "timer16_gfclk_mux", "l4per_cm:0130:24"), 798*4882a593Smuzhiyun DT_CLK(NULL, "timer1_gfclk_mux", "wkupaon_cm:0020:24"), 799*4882a593Smuzhiyun DT_CLK(NULL, "timer2_gfclk_mux", "l4per_cm:0038:24"), 800*4882a593Smuzhiyun DT_CLK(NULL, "timer3_gfclk_mux", "l4per_cm:0040:24"), 801*4882a593Smuzhiyun DT_CLK(NULL, "timer4_gfclk_mux", "l4per_cm:0048:24"), 802*4882a593Smuzhiyun DT_CLK(NULL, "timer5_gfclk_mux", "ipu_cm:0018:24"), 803*4882a593Smuzhiyun DT_CLK(NULL, "timer6_gfclk_mux", "ipu_cm:0020:24"), 804*4882a593Smuzhiyun DT_CLK(NULL, "timer7_gfclk_mux", "ipu_cm:0028:24"), 805*4882a593Smuzhiyun DT_CLK(NULL, "timer8_gfclk_mux", "ipu_cm:0030:24"), 806*4882a593Smuzhiyun DT_CLK(NULL, "timer9_gfclk_mux", "l4per_cm:0050:24"), 807*4882a593Smuzhiyun DT_CLK(NULL, "uart10_gfclk_mux", "wkupaon_cm:0060:24"), 808*4882a593Smuzhiyun DT_CLK(NULL, "uart1_gfclk_mux", "l4per_cm:0140:24"), 809*4882a593Smuzhiyun DT_CLK(NULL, "uart2_gfclk_mux", "l4per_cm:0148:24"), 810*4882a593Smuzhiyun DT_CLK(NULL, "uart3_gfclk_mux", "l4per_cm:0150:24"), 811*4882a593Smuzhiyun DT_CLK(NULL, "uart4_gfclk_mux", "l4per_cm:0158:24"), 812*4882a593Smuzhiyun DT_CLK(NULL, "uart5_gfclk_mux", "l4per_cm:0170:24"), 813*4882a593Smuzhiyun DT_CLK(NULL, "uart6_gfclk_mux", "ipu_cm:0040:24"), 814*4882a593Smuzhiyun DT_CLK(NULL, "uart7_gfclk_mux", "l4per_cm:01d0:24"), 815*4882a593Smuzhiyun DT_CLK(NULL, "uart8_gfclk_mux", "l4per_cm:01e0:24"), 816*4882a593Smuzhiyun DT_CLK(NULL, "uart9_gfclk_mux", "l4per_cm:01e8:24"), 817*4882a593Smuzhiyun DT_CLK(NULL, "usb_otg_ss1_refclk960m", "l3init_cm:00d0:8"), 818*4882a593Smuzhiyun DT_CLK(NULL, "usb_otg_ss2_refclk960m", "l3init_cm:0020:8"), 819*4882a593Smuzhiyun { .node_name = NULL }, 820*4882a593Smuzhiyun }; 821