2019-02-01 15:53:44 +01:00
// SPDX-License-Identifier: GPL-2.0+
/*
* Amlogic Meson - G12A Clock Controller Driver
*
* Copyright ( c ) 2016 Baylibre SAS .
* Author : Michael Turquette < mturquette @ baylibre . com >
*
* Copyright ( c ) 2018 Amlogic , inc .
* Author : Qiufang Dai < qiufang . dai @ amlogic . com >
* Author : Jian Hu < jian . hu @ amlogic . com >
*/
# include <linux/clk-provider.h>
# include <linux/init.h>
# include <linux/of_device.h>
# include <linux/platform_device.h>
# include "clk-input.h"
# include "clk-mpll.h"
# include "clk-pll.h"
# include "clk-regmap.h"
# include "vid-pll-div.h"
2019-02-01 15:53:45 +01:00
# include "meson-eeclk.h"
2019-02-01 15:53:44 +01:00
# include "g12a.h"
static DEFINE_SPINLOCK ( meson_clk_lock ) ;
static struct clk_regmap g12a_fixed_pll_dco = {
. data = & ( struct meson_clk_pll_data ) {
. en = {
. reg_off = HHI_FIX_PLL_CNTL0 ,
. shift = 28 ,
. width = 1 ,
} ,
. m = {
. reg_off = HHI_FIX_PLL_CNTL0 ,
. shift = 0 ,
. width = 8 ,
} ,
. n = {
. reg_off = HHI_FIX_PLL_CNTL0 ,
. shift = 10 ,
. width = 5 ,
} ,
. frac = {
. reg_off = HHI_FIX_PLL_CNTL1 ,
. shift = 0 ,
. width = 17 ,
} ,
. l = {
. reg_off = HHI_FIX_PLL_CNTL0 ,
. shift = 31 ,
. width = 1 ,
} ,
. rst = {
. reg_off = HHI_FIX_PLL_CNTL0 ,
. shift = 29 ,
. width = 1 ,
} ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " fixed_pll_dco " ,
. ops = & meson_clk_pll_ro_ops ,
. parent_names = ( const char * [ ] ) { IN_PREFIX " xtal " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_fixed_pll = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_FIX_PLL_CNTL0 ,
. shift = 16 ,
. width = 2 ,
. flags = CLK_DIVIDER_POWER_OF_TWO ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " fixed_pll " ,
. ops = & clk_regmap_divider_ro_ops ,
. parent_names = ( const char * [ ] ) { " fixed_pll_dco " } ,
. num_parents = 1 ,
/*
* This clock won ' t ever change at runtime so
* CLK_SET_RATE_PARENT is not required
*/
} ,
} ;
/*
* Internal sys pll emulation configuration parameters
*/
static const struct reg_sequence g12a_sys_init_regs [ ] = {
{ . reg = HHI_SYS_PLL_CNTL1 , . def = 0x00000000 } ,
{ . reg = HHI_SYS_PLL_CNTL2 , . def = 0x00000000 } ,
{ . reg = HHI_SYS_PLL_CNTL3 , . def = 0x48681c00 } ,
{ . reg = HHI_SYS_PLL_CNTL4 , . def = 0x88770290 } ,
{ . reg = HHI_SYS_PLL_CNTL5 , . def = 0x39272000 } ,
{ . reg = HHI_SYS_PLL_CNTL6 , . def = 0x56540000 } ,
} ;
static struct clk_regmap g12a_sys_pll_dco = {
. data = & ( struct meson_clk_pll_data ) {
. en = {
. reg_off = HHI_SYS_PLL_CNTL0 ,
. shift = 28 ,
. width = 1 ,
} ,
. m = {
. reg_off = HHI_SYS_PLL_CNTL0 ,
. shift = 0 ,
. width = 8 ,
} ,
. n = {
. reg_off = HHI_SYS_PLL_CNTL0 ,
. shift = 10 ,
. width = 5 ,
} ,
. l = {
. reg_off = HHI_SYS_PLL_CNTL0 ,
. shift = 31 ,
. width = 1 ,
} ,
. rst = {
. reg_off = HHI_SYS_PLL_CNTL0 ,
. shift = 29 ,
. width = 1 ,
} ,
. init_regs = g12a_sys_init_regs ,
. init_count = ARRAY_SIZE ( g12a_sys_init_regs ) ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " sys_pll_dco " ,
. ops = & meson_clk_pll_ro_ops ,
. parent_names = ( const char * [ ] ) { IN_PREFIX " xtal " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_sys_pll = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_SYS_PLL_CNTL0 ,
. shift = 16 ,
. width = 3 ,
. flags = CLK_DIVIDER_POWER_OF_TWO ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " sys_pll " ,
. ops = & clk_regmap_divider_ro_ops ,
. parent_names = ( const char * [ ] ) { " sys_pll_dco " } ,
. num_parents = 1 ,
} ,
} ;
2019-03-04 14:11:29 +01:00
static struct clk_regmap g12a_sys_pll_div16_en = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL1 ,
. bit_idx = 24 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " sys_pll_div16_en " ,
. ops = & clk_regmap_gate_ro_ops ,
. parent_names = ( const char * [ ] ) { " sys_pll " } ,
. num_parents = 1 ,
/*
* This clock is used to debug the sys_pll range
* Linux should not change it at runtime
*/
} ,
} ;
static struct clk_fixed_factor g12a_sys_pll_div16 = {
. mult = 1 ,
. div = 16 ,
. hw . init = & ( struct clk_init_data ) {
. name = " sys_pll_div16 " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " sys_pll_div16_en " } ,
. num_parents = 1 ,
} ,
} ;
/* Datasheet names this field as "premux0" */
static struct clk_regmap g12a_cpu_clk_premux0 = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL0 ,
. mask = 0x3 ,
. shift = 0 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_dyn0_sel " ,
. ops = & clk_regmap_mux_ro_ops ,
. parent_names = ( const char * [ ] ) { IN_PREFIX " xtal " ,
" fclk_div2 " ,
" fclk_div3 " } ,
. num_parents = 3 ,
} ,
} ;
/* Datasheet names this field as "mux0_divn_tcnt" */
static struct clk_regmap g12a_cpu_clk_mux0_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL0 ,
. shift = 4 ,
. width = 6 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_dyn0_div " ,
. ops = & clk_regmap_divider_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk_dyn0_sel " } ,
. num_parents = 1 ,
} ,
} ;
/* Datasheet names this field as "postmux0" */
static struct clk_regmap g12a_cpu_clk_postmux0 = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL0 ,
. mask = 0x1 ,
. shift = 2 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_dyn0 " ,
. ops = & clk_regmap_mux_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk_dyn0_sel " ,
" cpu_clk_dyn0_div " } ,
. num_parents = 2 ,
} ,
} ;
/* Datasheet names this field as "premux1" */
static struct clk_regmap g12a_cpu_clk_premux1 = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL0 ,
. mask = 0x3 ,
. shift = 16 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_dyn1_sel " ,
. ops = & clk_regmap_mux_ro_ops ,
. parent_names = ( const char * [ ] ) { IN_PREFIX " xtal " ,
" fclk_div2 " ,
" fclk_div3 " } ,
. num_parents = 3 ,
} ,
} ;
/* Datasheet names this field as "Mux1_divn_tcnt" */
static struct clk_regmap g12a_cpu_clk_mux1_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL0 ,
. shift = 20 ,
. width = 6 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_dyn1_div " ,
. ops = & clk_regmap_divider_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk_dyn1_sel " } ,
. num_parents = 1 ,
} ,
} ;
/* Datasheet names this field as "postmux1" */
static struct clk_regmap g12a_cpu_clk_postmux1 = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL0 ,
. mask = 0x1 ,
. shift = 18 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_dyn1 " ,
. ops = & clk_regmap_mux_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk_dyn1_sel " ,
" cpu_clk_dyn1_div " } ,
. num_parents = 2 ,
} ,
} ;
/* Datasheet names this field as "Final_dyn_mux_sel" */
static struct clk_regmap g12a_cpu_clk_dyn = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL0 ,
. mask = 0x1 ,
. shift = 10 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_dyn " ,
. ops = & clk_regmap_mux_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk_dyn0 " ,
" cpu_clk_dyn1 " } ,
. num_parents = 2 ,
} ,
} ;
/* Datasheet names this field as "Final_mux_sel" */
static struct clk_regmap g12a_cpu_clk = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL0 ,
. mask = 0x1 ,
. shift = 11 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk " ,
. ops = & clk_regmap_mux_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk_dyn " ,
" sys_pll " } ,
. num_parents = 2 ,
} ,
} ;
static struct clk_regmap g12a_cpu_clk_div16_en = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL1 ,
. bit_idx = 1 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_div16_en " ,
. ops = & clk_regmap_gate_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk " } ,
. num_parents = 1 ,
/*
* This clock is used to debug the cpu_clk range
* Linux should not change it at runtime
*/
} ,
} ;
static struct clk_fixed_factor g12a_cpu_clk_div16 = {
. mult = 1 ,
. div = 16 ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_div16 " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk_div16_en " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_cpu_clk_apb_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL1 ,
. shift = 3 ,
. width = 3 ,
. flags = CLK_DIVIDER_POWER_OF_TWO ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_apb_div " ,
. ops = & clk_regmap_divider_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_cpu_clk_apb = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL1 ,
. bit_idx = 1 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_apb " ,
. ops = & clk_regmap_gate_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk_apb_div " } ,
. num_parents = 1 ,
/*
* This clock is set by the ROM monitor code ,
* Linux should not change it at runtime
*/
} ,
} ;
static struct clk_regmap g12a_cpu_clk_atb_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL1 ,
. shift = 6 ,
. width = 3 ,
. flags = CLK_DIVIDER_POWER_OF_TWO ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_atb_div " ,
. ops = & clk_regmap_divider_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_cpu_clk_atb = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL1 ,
. bit_idx = 17 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_atb " ,
. ops = & clk_regmap_gate_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk_atb_div " } ,
. num_parents = 1 ,
/*
* This clock is set by the ROM monitor code ,
* Linux should not change it at runtime
*/
} ,
} ;
static struct clk_regmap g12a_cpu_clk_axi_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL1 ,
. shift = 9 ,
. width = 3 ,
. flags = CLK_DIVIDER_POWER_OF_TWO ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_axi_div " ,
. ops = & clk_regmap_divider_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_cpu_clk_axi = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL1 ,
. bit_idx = 18 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_axi " ,
. ops = & clk_regmap_gate_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk_axi_div " } ,
. num_parents = 1 ,
/*
* This clock is set by the ROM monitor code ,
* Linux should not change it at runtime
*/
} ,
} ;
static struct clk_regmap g12a_cpu_clk_trace_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL1 ,
. shift = 20 ,
. width = 3 ,
. flags = CLK_DIVIDER_POWER_OF_TWO ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_trace_div " ,
. ops = & clk_regmap_divider_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_cpu_clk_trace = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_SYS_CPU_CLK_CNTL1 ,
. bit_idx = 23 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cpu_clk_trace " ,
. ops = & clk_regmap_gate_ro_ops ,
. parent_names = ( const char * [ ] ) { " cpu_clk_trace_div " } ,
. num_parents = 1 ,
/*
* This clock is set by the ROM monitor code ,
* Linux should not change it at runtime
*/
} ,
} ;
2019-02-01 15:53:44 +01:00
static const struct pll_mult_range g12a_gp0_pll_mult_range = {
. min = 55 ,
. max = 255 ,
} ;
/*
* Internal gp0 pll emulation configuration parameters
*/
static const struct reg_sequence g12a_gp0_init_regs [ ] = {
{ . reg = HHI_GP0_PLL_CNTL1 , . def = 0x00000000 } ,
{ . reg = HHI_GP0_PLL_CNTL2 , . def = 0x00000000 } ,
{ . reg = HHI_GP0_PLL_CNTL3 , . def = 0x48681c00 } ,
{ . reg = HHI_GP0_PLL_CNTL4 , . def = 0x33771290 } ,
{ . reg = HHI_GP0_PLL_CNTL5 , . def = 0x39272000 } ,
{ . reg = HHI_GP0_PLL_CNTL6 , . def = 0x56540000 } ,
} ;
static struct clk_regmap g12a_gp0_pll_dco = {
. data = & ( struct meson_clk_pll_data ) {
. en = {
. reg_off = HHI_GP0_PLL_CNTL0 ,
. shift = 28 ,
. width = 1 ,
} ,
. m = {
. reg_off = HHI_GP0_PLL_CNTL0 ,
. shift = 0 ,
. width = 8 ,
} ,
. n = {
. reg_off = HHI_GP0_PLL_CNTL0 ,
. shift = 10 ,
. width = 5 ,
} ,
. frac = {
. reg_off = HHI_GP0_PLL_CNTL1 ,
. shift = 0 ,
. width = 17 ,
} ,
. l = {
. reg_off = HHI_GP0_PLL_CNTL0 ,
. shift = 31 ,
. width = 1 ,
} ,
. rst = {
. reg_off = HHI_GP0_PLL_CNTL0 ,
. shift = 29 ,
. width = 1 ,
} ,
. range = & g12a_gp0_pll_mult_range ,
. init_regs = g12a_gp0_init_regs ,
. init_count = ARRAY_SIZE ( g12a_gp0_init_regs ) ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " gp0_pll_dco " ,
. ops = & meson_clk_pll_ops ,
. parent_names = ( const char * [ ] ) { IN_PREFIX " xtal " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_gp0_pll = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_GP0_PLL_CNTL0 ,
. shift = 16 ,
. width = 3 ,
. flags = ( CLK_DIVIDER_POWER_OF_TWO |
CLK_DIVIDER_ROUND_CLOSEST ) ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " gp0_pll " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " gp0_pll_dco " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
/*
* Internal hifi pll emulation configuration parameters
*/
static const struct reg_sequence g12a_hifi_init_regs [ ] = {
{ . reg = HHI_HIFI_PLL_CNTL1 , . def = 0x00000000 } ,
{ . reg = HHI_HIFI_PLL_CNTL2 , . def = 0x00000000 } ,
{ . reg = HHI_HIFI_PLL_CNTL3 , . def = 0x6a285c00 } ,
{ . reg = HHI_HIFI_PLL_CNTL4 , . def = 0x65771290 } ,
{ . reg = HHI_HIFI_PLL_CNTL5 , . def = 0x39272000 } ,
{ . reg = HHI_HIFI_PLL_CNTL6 , . def = 0x56540000 } ,
} ;
static struct clk_regmap g12a_hifi_pll_dco = {
. data = & ( struct meson_clk_pll_data ) {
. en = {
. reg_off = HHI_HIFI_PLL_CNTL0 ,
. shift = 28 ,
. width = 1 ,
} ,
. m = {
. reg_off = HHI_HIFI_PLL_CNTL0 ,
. shift = 0 ,
. width = 8 ,
} ,
. n = {
. reg_off = HHI_HIFI_PLL_CNTL0 ,
. shift = 10 ,
. width = 5 ,
} ,
. frac = {
. reg_off = HHI_HIFI_PLL_CNTL1 ,
. shift = 0 ,
. width = 17 ,
} ,
. l = {
. reg_off = HHI_HIFI_PLL_CNTL0 ,
. shift = 31 ,
. width = 1 ,
} ,
. rst = {
. reg_off = HHI_HIFI_PLL_CNTL0 ,
. shift = 29 ,
. width = 1 ,
} ,
. range = & g12a_gp0_pll_mult_range ,
. init_regs = g12a_hifi_init_regs ,
. init_count = ARRAY_SIZE ( g12a_hifi_init_regs ) ,
. flags = CLK_MESON_PLL_ROUND_CLOSEST ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " hifi_pll_dco " ,
. ops = & meson_clk_pll_ops ,
. parent_names = ( const char * [ ] ) { IN_PREFIX " xtal " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_hifi_pll = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_HIFI_PLL_CNTL0 ,
. shift = 16 ,
. width = 2 ,
. flags = ( CLK_DIVIDER_POWER_OF_TWO |
CLK_DIVIDER_ROUND_CLOSEST ) ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " hifi_pll " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " hifi_pll_dco " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
2019-03-07 15:14:55 +01:00
/*
* The Meson G12A PCIE PLL is fined tuned to deliver a very precise
* 100 MHz reference clock for the PCIe Analog PHY , and thus requires
* a strict register sequence to enable the PLL .
*/
static const struct reg_sequence g12a_pcie_pll_init_regs [ ] = {
{ . reg = HHI_PCIE_PLL_CNTL0 , . def = 0x20090496 } ,
{ . reg = HHI_PCIE_PLL_CNTL0 , . def = 0x30090496 } ,
{ . reg = HHI_PCIE_PLL_CNTL1 , . def = 0x00000000 } ,
{ . reg = HHI_PCIE_PLL_CNTL2 , . def = 0x00001100 } ,
{ . reg = HHI_PCIE_PLL_CNTL3 , . def = 0x10058e00 } ,
{ . reg = HHI_PCIE_PLL_CNTL4 , . def = 0x000100c0 } ,
{ . reg = HHI_PCIE_PLL_CNTL5 , . def = 0x68000048 } ,
{ . reg = HHI_PCIE_PLL_CNTL5 , . def = 0x68000068 , . delay_us = 20 } ,
{ . reg = HHI_PCIE_PLL_CNTL4 , . def = 0x008100c0 , . delay_us = 10 } ,
{ . reg = HHI_PCIE_PLL_CNTL0 , . def = 0x34090496 } ,
{ . reg = HHI_PCIE_PLL_CNTL0 , . def = 0x14090496 , . delay_us = 10 } ,
{ . reg = HHI_PCIE_PLL_CNTL2 , . def = 0x00001000 } ,
} ;
/* Keep a single entry table for recalc/round_rate() ops */
static const struct pll_params_table g12a_pcie_pll_table [ ] = {
PLL_PARAMS ( 150 , 1 ) ,
{ 0 , 0 } ,
} ;
static struct clk_regmap g12a_pcie_pll_dco = {
. data = & ( struct meson_clk_pll_data ) {
. en = {
. reg_off = HHI_PCIE_PLL_CNTL0 ,
. shift = 28 ,
. width = 1 ,
} ,
. m = {
. reg_off = HHI_PCIE_PLL_CNTL0 ,
. shift = 0 ,
. width = 8 ,
} ,
. n = {
. reg_off = HHI_PCIE_PLL_CNTL0 ,
. shift = 10 ,
. width = 5 ,
} ,
. frac = {
. reg_off = HHI_PCIE_PLL_CNTL1 ,
. shift = 0 ,
. width = 12 ,
} ,
. l = {
. reg_off = HHI_PCIE_PLL_CNTL0 ,
. shift = 31 ,
. width = 1 ,
} ,
. rst = {
. reg_off = HHI_PCIE_PLL_CNTL0 ,
. shift = 29 ,
. width = 1 ,
} ,
. table = g12a_pcie_pll_table ,
. init_regs = g12a_pcie_pll_init_regs ,
. init_count = ARRAY_SIZE ( g12a_pcie_pll_init_regs ) ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " pcie_pll_dco " ,
. ops = & meson_clk_pcie_pll_ops ,
. parent_names = ( const char * [ ] ) { IN_PREFIX " xtal " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_fixed_factor g12a_pcie_pll_dco_div2 = {
. mult = 1 ,
. div = 2 ,
. hw . init = & ( struct clk_init_data ) {
. name = " pcie_pll_dco_div2 " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " pcie_pll_dco " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_pcie_pll_od = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_PCIE_PLL_CNTL0 ,
. shift = 16 ,
. width = 5 ,
. flags = CLK_DIVIDER_ROUND_CLOSEST |
CLK_DIVIDER_ONE_BASED |
CLK_DIVIDER_ALLOW_ZERO ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " pcie_pll_od " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " pcie_pll_dco_div2 " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_fixed_factor g12a_pcie_pll = {
. mult = 1 ,
. div = 2 ,
. hw . init = & ( struct clk_init_data ) {
. name = " pcie_pll_pll " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " pcie_pll_od " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
2019-02-01 15:53:44 +01:00
static struct clk_regmap g12a_hdmi_pll_dco = {
. data = & ( struct meson_clk_pll_data ) {
. en = {
. reg_off = HHI_HDMI_PLL_CNTL0 ,
. shift = 28 ,
. width = 1 ,
} ,
. m = {
. reg_off = HHI_HDMI_PLL_CNTL0 ,
. shift = 0 ,
. width = 8 ,
} ,
. n = {
. reg_off = HHI_HDMI_PLL_CNTL0 ,
. shift = 10 ,
. width = 5 ,
} ,
. frac = {
. reg_off = HHI_HDMI_PLL_CNTL1 ,
. shift = 0 ,
. width = 16 ,
} ,
. l = {
. reg_off = HHI_HDMI_PLL_CNTL0 ,
. shift = 30 ,
. width = 1 ,
} ,
. rst = {
. reg_off = HHI_HDMI_PLL_CNTL0 ,
. shift = 29 ,
. width = 1 ,
} ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " hdmi_pll_dco " ,
. ops = & meson_clk_pll_ro_ops ,
. parent_names = ( const char * [ ] ) { IN_PREFIX " xtal " } ,
. num_parents = 1 ,
/*
* Display directly handle hdmi pll registers ATM , we need
* NOCACHE to keep our view of the clock as accurate as possible
*/
. flags = CLK_GET_RATE_NOCACHE ,
} ,
} ;
static struct clk_regmap g12a_hdmi_pll_od = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_HDMI_PLL_CNTL0 ,
. shift = 16 ,
. width = 2 ,
. flags = CLK_DIVIDER_POWER_OF_TWO ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " hdmi_pll_od " ,
. ops = & clk_regmap_divider_ro_ops ,
. parent_names = ( const char * [ ] ) { " hdmi_pll_dco " } ,
. num_parents = 1 ,
. flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_hdmi_pll_od2 = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_HDMI_PLL_CNTL0 ,
. shift = 18 ,
. width = 2 ,
. flags = CLK_DIVIDER_POWER_OF_TWO ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " hdmi_pll_od2 " ,
. ops = & clk_regmap_divider_ro_ops ,
. parent_names = ( const char * [ ] ) { " hdmi_pll_od " } ,
. num_parents = 1 ,
. flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_hdmi_pll = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_HDMI_PLL_CNTL0 ,
. shift = 20 ,
. width = 2 ,
. flags = CLK_DIVIDER_POWER_OF_TWO ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " hdmi_pll " ,
. ops = & clk_regmap_divider_ro_ops ,
. parent_names = ( const char * [ ] ) { " hdmi_pll_od2 " } ,
. num_parents = 1 ,
. flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_fixed_factor g12a_fclk_div2_div = {
. mult = 1 ,
. div = 2 ,
. hw . init = & ( struct clk_init_data ) {
. name = " fclk_div2_div " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " fixed_pll " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_fclk_div2 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_FIX_PLL_CNTL1 ,
. bit_idx = 24 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " fclk_div2 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " fclk_div2_div " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_fixed_factor g12a_fclk_div3_div = {
. mult = 1 ,
. div = 3 ,
. hw . init = & ( struct clk_init_data ) {
. name = " fclk_div3_div " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " fixed_pll " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_fclk_div3 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_FIX_PLL_CNTL1 ,
. bit_idx = 20 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " fclk_div3 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " fclk_div3_div " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_fixed_factor g12a_fclk_div4_div = {
. mult = 1 ,
. div = 4 ,
. hw . init = & ( struct clk_init_data ) {
. name = " fclk_div4_div " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " fixed_pll " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_fclk_div4 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_FIX_PLL_CNTL1 ,
. bit_idx = 21 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " fclk_div4 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " fclk_div4_div " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_fixed_factor g12a_fclk_div5_div = {
. mult = 1 ,
. div = 5 ,
. hw . init = & ( struct clk_init_data ) {
. name = " fclk_div5_div " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " fixed_pll " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_fclk_div5 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_FIX_PLL_CNTL1 ,
. bit_idx = 22 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " fclk_div5 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " fclk_div5_div " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_fixed_factor g12a_fclk_div7_div = {
. mult = 1 ,
. div = 7 ,
. hw . init = & ( struct clk_init_data ) {
. name = " fclk_div7_div " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " fixed_pll " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_fclk_div7 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_FIX_PLL_CNTL1 ,
. bit_idx = 23 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " fclk_div7 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " fclk_div7_div " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_fixed_factor g12a_fclk_div2p5_div = {
. mult = 1 ,
. div = 5 ,
. hw . init = & ( struct clk_init_data ) {
. name = " fclk_div2p5_div " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " fixed_pll_dco " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_fclk_div2p5 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_FIX_PLL_CNTL1 ,
. bit_idx = 25 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " fclk_div2p5 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " fclk_div2p5_div " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_fixed_factor g12a_mpll_50m_div = {
. mult = 1 ,
. div = 80 ,
. hw . init = & ( struct clk_init_data ) {
. name = " mpll_50m_div " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " fixed_pll_dco " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_mpll_50m = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_FIX_PLL_CNTL3 ,
. mask = 0x1 ,
. shift = 5 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mpll_50m " ,
. ops = & clk_regmap_mux_ro_ops ,
. parent_names = ( const char * [ ] ) { IN_PREFIX " xtal " ,
" mpll_50m_div " } ,
. num_parents = 2 ,
} ,
} ;
static struct clk_fixed_factor g12a_mpll_prediv = {
. mult = 1 ,
. div = 2 ,
. hw . init = & ( struct clk_init_data ) {
. name = " mpll_prediv " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " fixed_pll_dco " } ,
. num_parents = 1 ,
} ,
} ;
2019-05-13 14:31:13 +02:00
static const struct reg_sequence g12a_mpll0_init_regs [ ] = {
{ . reg = HHI_MPLL_CNTL2 , . def = 0x40000033 } ,
} ;
2019-02-01 15:53:44 +01:00
static struct clk_regmap g12a_mpll0_div = {
. data = & ( struct meson_clk_mpll_data ) {
. sdm = {
. reg_off = HHI_MPLL_CNTL1 ,
. shift = 0 ,
. width = 14 ,
} ,
. sdm_en = {
. reg_off = HHI_MPLL_CNTL1 ,
. shift = 30 ,
. width = 1 ,
} ,
. n2 = {
. reg_off = HHI_MPLL_CNTL1 ,
. shift = 20 ,
. width = 9 ,
} ,
. ssen = {
. reg_off = HHI_MPLL_CNTL1 ,
. shift = 29 ,
. width = 1 ,
} ,
. lock = & meson_clk_lock ,
2019-05-13 14:31:13 +02:00
. init_regs = g12a_mpll0_init_regs ,
. init_count = ARRAY_SIZE ( g12a_mpll0_init_regs ) ,
2019-02-01 15:53:44 +01:00
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mpll0_div " ,
. ops = & meson_clk_mpll_ops ,
. parent_names = ( const char * [ ] ) { " mpll_prediv " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_mpll0 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_MPLL_CNTL1 ,
. bit_idx = 31 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mpll0 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " mpll0_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
2019-05-13 14:31:13 +02:00
static const struct reg_sequence g12a_mpll1_init_regs [ ] = {
{ . reg = HHI_MPLL_CNTL4 , . def = 0x40000033 } ,
} ;
2019-02-01 15:53:44 +01:00
static struct clk_regmap g12a_mpll1_div = {
. data = & ( struct meson_clk_mpll_data ) {
. sdm = {
. reg_off = HHI_MPLL_CNTL3 ,
. shift = 0 ,
. width = 14 ,
} ,
. sdm_en = {
. reg_off = HHI_MPLL_CNTL3 ,
. shift = 30 ,
. width = 1 ,
} ,
. n2 = {
. reg_off = HHI_MPLL_CNTL3 ,
. shift = 20 ,
. width = 9 ,
} ,
. ssen = {
. reg_off = HHI_MPLL_CNTL3 ,
. shift = 29 ,
. width = 1 ,
} ,
. lock = & meson_clk_lock ,
2019-05-13 14:31:13 +02:00
. init_regs = g12a_mpll1_init_regs ,
. init_count = ARRAY_SIZE ( g12a_mpll1_init_regs ) ,
2019-02-01 15:53:44 +01:00
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mpll1_div " ,
. ops = & meson_clk_mpll_ops ,
. parent_names = ( const char * [ ] ) { " mpll_prediv " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_mpll1 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_MPLL_CNTL3 ,
. bit_idx = 31 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mpll1 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " mpll1_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
2019-05-13 14:31:13 +02:00
static const struct reg_sequence g12a_mpll2_init_regs [ ] = {
{ . reg = HHI_MPLL_CNTL6 , . def = 0x40000033 } ,
} ;
2019-02-01 15:53:44 +01:00
static struct clk_regmap g12a_mpll2_div = {
. data = & ( struct meson_clk_mpll_data ) {
. sdm = {
. reg_off = HHI_MPLL_CNTL5 ,
. shift = 0 ,
. width = 14 ,
} ,
. sdm_en = {
. reg_off = HHI_MPLL_CNTL5 ,
. shift = 30 ,
. width = 1 ,
} ,
. n2 = {
. reg_off = HHI_MPLL_CNTL5 ,
. shift = 20 ,
. width = 9 ,
} ,
. ssen = {
. reg_off = HHI_MPLL_CNTL5 ,
. shift = 29 ,
. width = 1 ,
} ,
. lock = & meson_clk_lock ,
2019-05-13 14:31:13 +02:00
. init_regs = g12a_mpll2_init_regs ,
. init_count = ARRAY_SIZE ( g12a_mpll2_init_regs ) ,
2019-02-01 15:53:44 +01:00
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mpll2_div " ,
. ops = & meson_clk_mpll_ops ,
. parent_names = ( const char * [ ] ) { " mpll_prediv " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_mpll2 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_MPLL_CNTL5 ,
. bit_idx = 31 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mpll2 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " mpll2_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
2019-05-13 14:31:13 +02:00
static const struct reg_sequence g12a_mpll3_init_regs [ ] = {
{ . reg = HHI_MPLL_CNTL8 , . def = 0x40000033 } ,
} ;
2019-02-01 15:53:44 +01:00
static struct clk_regmap g12a_mpll3_div = {
. data = & ( struct meson_clk_mpll_data ) {
. sdm = {
. reg_off = HHI_MPLL_CNTL7 ,
. shift = 0 ,
. width = 14 ,
} ,
. sdm_en = {
. reg_off = HHI_MPLL_CNTL7 ,
. shift = 30 ,
. width = 1 ,
} ,
. n2 = {
. reg_off = HHI_MPLL_CNTL7 ,
. shift = 20 ,
. width = 9 ,
} ,
. ssen = {
. reg_off = HHI_MPLL_CNTL7 ,
. shift = 29 ,
. width = 1 ,
} ,
. lock = & meson_clk_lock ,
2019-05-13 14:31:13 +02:00
. init_regs = g12a_mpll3_init_regs ,
. init_count = ARRAY_SIZE ( g12a_mpll3_init_regs ) ,
2019-02-01 15:53:44 +01:00
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mpll3_div " ,
. ops = & meson_clk_mpll_ops ,
. parent_names = ( const char * [ ] ) { " mpll_prediv " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_regmap g12a_mpll3 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_MPLL_CNTL7 ,
. bit_idx = 31 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mpll3 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " mpll3_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static u32 mux_table_clk81 [ ] = { 0 , 2 , 3 , 4 , 5 , 6 , 7 } ;
static const char * const clk81_parent_names [ ] = {
IN_PREFIX " xtal " , " fclk_div7 " , " mpll1 " , " mpll2 " , " fclk_div4 " ,
" fclk_div3 " , " fclk_div5 "
} ;
static struct clk_regmap g12a_mpeg_clk_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_MPEG_CLK_CNTL ,
. mask = 0x7 ,
. shift = 12 ,
. table = mux_table_clk81 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mpeg_clk_sel " ,
. ops = & clk_regmap_mux_ro_ops ,
. parent_names = clk81_parent_names ,
. num_parents = ARRAY_SIZE ( clk81_parent_names ) ,
} ,
} ;
static struct clk_regmap g12a_mpeg_clk_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_MPEG_CLK_CNTL ,
. shift = 0 ,
. width = 7 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mpeg_clk_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " mpeg_clk_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_clk81 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_MPEG_CLK_CNTL ,
. bit_idx = 7 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " clk81 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " mpeg_clk_div " } ,
. num_parents = 1 ,
. flags = ( CLK_SET_RATE_PARENT | CLK_IS_CRITICAL ) ,
} ,
} ;
static const char * const g12a_sd_emmc_clk0_parent_names [ ] = {
IN_PREFIX " xtal " , " fclk_div2 " , " fclk_div3 " , " fclk_div5 " , " fclk_div7 " ,
/*
* Following these parent clocks , we should also have had mpll2 , mpll3
* and gp0_pll but these clocks are too precious to be used here . All
* the necessary rates for MMC and NAND operation can be acheived using
* g12a_ee_core or fclk_div clocks
*/
} ;
/* SDIO clock */
static struct clk_regmap g12a_sd_emmc_a_clk0_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_SD_EMMC_CLK_CNTL ,
. mask = 0x7 ,
. shift = 9 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " sd_emmc_a_clk0_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_sd_emmc_clk0_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_sd_emmc_clk0_parent_names ) ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_sd_emmc_a_clk0_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_SD_EMMC_CLK_CNTL ,
. shift = 0 ,
. width = 7 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " sd_emmc_a_clk0_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " sd_emmc_a_clk0_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_sd_emmc_a_clk0 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_SD_EMMC_CLK_CNTL ,
. bit_idx = 7 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " sd_emmc_a_clk0 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " sd_emmc_a_clk0_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
/* SDcard clock */
static struct clk_regmap g12a_sd_emmc_b_clk0_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_SD_EMMC_CLK_CNTL ,
. mask = 0x7 ,
. shift = 25 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " sd_emmc_b_clk0_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_sd_emmc_clk0_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_sd_emmc_clk0_parent_names ) ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_sd_emmc_b_clk0_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_SD_EMMC_CLK_CNTL ,
. shift = 16 ,
. width = 7 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " sd_emmc_b_clk0_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " sd_emmc_b_clk0_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_sd_emmc_b_clk0 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_SD_EMMC_CLK_CNTL ,
. bit_idx = 23 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " sd_emmc_b_clk0 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " sd_emmc_b_clk0_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
/* EMMC/NAND clock */
static struct clk_regmap g12a_sd_emmc_c_clk0_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_NAND_CLK_CNTL ,
. mask = 0x7 ,
. shift = 9 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " sd_emmc_c_clk0_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_sd_emmc_clk0_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_sd_emmc_clk0_parent_names ) ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_sd_emmc_c_clk0_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_NAND_CLK_CNTL ,
. shift = 0 ,
. width = 7 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " sd_emmc_c_clk0_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " sd_emmc_c_clk0_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_sd_emmc_c_clk0 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_NAND_CLK_CNTL ,
. bit_idx = 7 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " sd_emmc_c_clk0 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " sd_emmc_c_clk0_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
/* VPU Clock */
static const char * const g12a_vpu_parent_names [ ] = {
2019-03-13 14:55:03 +01:00
" fclk_div3 " , " fclk_div4 " , " fclk_div5 " , " fclk_div7 " ,
2019-02-01 15:53:44 +01:00
" mpll1 " , " vid_pll " , " hifi_pll " , " gp0_pll " ,
} ;
static struct clk_regmap g12a_vpu_0_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VPU_CLK_CNTL ,
2019-03-19 09:26:11 +01:00
. mask = 0x7 ,
2019-02-01 15:53:44 +01:00
. shift = 9 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vpu_0_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_vpu_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_vpu_parent_names ) ,
. flags = CLK_SET_RATE_NO_REPARENT ,
} ,
} ;
static struct clk_regmap g12a_vpu_0_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_VPU_CLK_CNTL ,
. shift = 0 ,
. width = 7 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vpu_0_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " vpu_0_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_vpu_0 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VPU_CLK_CNTL ,
. bit_idx = 8 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vpu_0 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vpu_0_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vpu_1_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VPU_CLK_CNTL ,
2019-03-19 09:26:11 +01:00
. mask = 0x7 ,
2019-02-01 15:53:44 +01:00
. shift = 25 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vpu_1_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_vpu_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_vpu_parent_names ) ,
. flags = CLK_SET_RATE_NO_REPARENT ,
} ,
} ;
static struct clk_regmap g12a_vpu_1_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_VPU_CLK_CNTL ,
. shift = 16 ,
. width = 7 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vpu_1_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " vpu_1_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_vpu_1 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VPU_CLK_CNTL ,
. bit_idx = 24 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vpu_1 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vpu_1_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vpu = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VPU_CLK_CNTL ,
. mask = 1 ,
. shift = 31 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vpu " ,
. ops = & clk_regmap_mux_ops ,
/*
* bit 31 selects from 2 possible parents :
* vpu_0 or vpu_1
*/
. parent_names = ( const char * [ ] ) { " vpu_0 " , " vpu_1 " } ,
. num_parents = 2 ,
. flags = CLK_SET_RATE_NO_REPARENT ,
} ,
} ;
2019-03-19 11:11:38 +01:00
/* VDEC clocks */
static const char * const g12a_vdec_parent_names [ ] = {
" fclk_div2p5 " , " fclk_div3 " , " fclk_div4 " , " fclk_div5 " , " fclk_div7 " ,
" hifi_pll " , " gp0_pll " ,
} ;
static struct clk_regmap g12a_vdec_1_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VDEC_CLK_CNTL ,
. mask = 0x7 ,
. shift = 9 ,
. flags = CLK_MUX_ROUND_CLOSEST ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vdec_1_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_vdec_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_vdec_parent_names ) ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_vdec_1_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_VDEC_CLK_CNTL ,
. shift = 0 ,
. width = 7 ,
. flags = CLK_DIVIDER_ROUND_CLOSEST ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vdec_1_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " vdec_1_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_vdec_1 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VDEC_CLK_CNTL ,
. bit_idx = 8 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vdec_1 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vdec_1_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_vdec_hevcf_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VDEC2_CLK_CNTL ,
. mask = 0x7 ,
. shift = 9 ,
. flags = CLK_MUX_ROUND_CLOSEST ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vdec_hevcf_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_vdec_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_vdec_parent_names ) ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_vdec_hevcf_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_VDEC2_CLK_CNTL ,
. shift = 0 ,
. width = 7 ,
. flags = CLK_DIVIDER_ROUND_CLOSEST ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vdec_hevcf_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " vdec_hevcf_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_vdec_hevcf = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VDEC2_CLK_CNTL ,
. bit_idx = 8 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vdec_hevcf " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vdec_hevcf_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_vdec_hevc_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VDEC2_CLK_CNTL ,
. mask = 0x7 ,
. shift = 25 ,
. flags = CLK_MUX_ROUND_CLOSEST ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vdec_hevc_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_vdec_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_vdec_parent_names ) ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_vdec_hevc_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_VDEC2_CLK_CNTL ,
. shift = 16 ,
. width = 7 ,
. flags = CLK_DIVIDER_ROUND_CLOSEST ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vdec_hevc_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " vdec_hevc_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_vdec_hevc = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VDEC2_CLK_CNTL ,
. bit_idx = 24 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vdec_hevc " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vdec_hevc_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
2019-02-01 15:53:44 +01:00
/* VAPB Clock */
static const char * const g12a_vapb_parent_names [ ] = {
" fclk_div4 " , " fclk_div3 " , " fclk_div5 " , " fclk_div7 " ,
" mpll1 " , " vid_pll " , " mpll2 " , " fclk_div2p5 " ,
} ;
static struct clk_regmap g12a_vapb_0_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VAPBCLK_CNTL ,
. mask = 0x3 ,
. shift = 9 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vapb_0_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_vapb_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_vapb_parent_names ) ,
. flags = CLK_SET_RATE_NO_REPARENT ,
} ,
} ;
static struct clk_regmap g12a_vapb_0_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_VAPBCLK_CNTL ,
. shift = 0 ,
. width = 7 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vapb_0_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " vapb_0_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_vapb_0 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VAPBCLK_CNTL ,
. bit_idx = 8 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vapb_0 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vapb_0_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vapb_1_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VAPBCLK_CNTL ,
. mask = 0x3 ,
. shift = 25 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vapb_1_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_vapb_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_vapb_parent_names ) ,
. flags = CLK_SET_RATE_NO_REPARENT ,
} ,
} ;
static struct clk_regmap g12a_vapb_1_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_VAPBCLK_CNTL ,
. shift = 16 ,
. width = 7 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vapb_1_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " vapb_1_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_vapb_1 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VAPBCLK_CNTL ,
. bit_idx = 24 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vapb_1 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vapb_1_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vapb_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VAPBCLK_CNTL ,
. mask = 1 ,
. shift = 31 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vapb_sel " ,
. ops = & clk_regmap_mux_ops ,
/*
* bit 31 selects from 2 possible parents :
* vapb_0 or vapb_1
*/
. parent_names = ( const char * [ ] ) { " vapb_0 " , " vapb_1 " } ,
. num_parents = 2 ,
. flags = CLK_SET_RATE_NO_REPARENT ,
} ,
} ;
static struct clk_regmap g12a_vapb = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VAPBCLK_CNTL ,
. bit_idx = 30 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vapb " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vapb_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
/* Video Clocks */
static struct clk_regmap g12a_vid_pll_div = {
. data = & ( struct meson_vid_pll_div_data ) {
. val = {
. reg_off = HHI_VID_PLL_CLK_DIV ,
. shift = 0 ,
. width = 15 ,
} ,
. sel = {
. reg_off = HHI_VID_PLL_CLK_DIV ,
. shift = 16 ,
. width = 2 ,
} ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vid_pll_div " ,
. ops = & meson_vid_pll_div_ro_ops ,
. parent_names = ( const char * [ ] ) { " hdmi_pll " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_GET_RATE_NOCACHE ,
} ,
} ;
static const char * const g12a_vid_pll_parent_names [ ] = { " vid_pll_div " ,
" hdmi_pll " } ;
static struct clk_regmap g12a_vid_pll_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VID_PLL_CLK_DIV ,
. mask = 0x1 ,
. shift = 18 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vid_pll_sel " ,
. ops = & clk_regmap_mux_ops ,
/*
* bit 18 selects from 2 possible parents :
* vid_pll_div or hdmi_pll
*/
. parent_names = g12a_vid_pll_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_vid_pll_parent_names ) ,
. flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE ,
} ,
} ;
static struct clk_regmap g12a_vid_pll = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VID_PLL_CLK_DIV ,
. bit_idx = 19 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vid_pll " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vid_pll_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static const char * const g12a_vclk_parent_names [ ] = {
" vid_pll " , " gp0_pll " , " hifi_pll " , " mpll1 " , " fclk_div3 " , " fclk_div4 " ,
" fclk_div5 " , " fclk_div7 "
} ;
static struct clk_regmap g12a_vclk_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VID_CLK_CNTL ,
. mask = 0x7 ,
. shift = 16 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_vclk_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_vclk_parent_names ) ,
. flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE ,
} ,
} ;
static struct clk_regmap g12a_vclk2_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VIID_CLK_CNTL ,
. mask = 0x7 ,
. shift = 16 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk2_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_vclk_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_vclk_parent_names ) ,
. flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE ,
} ,
} ;
static struct clk_regmap g12a_vclk_input = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VID_CLK_DIV ,
. bit_idx = 16 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk_input " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vclk_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vclk2_input = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VIID_CLK_DIV ,
. bit_idx = 16 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk2_input " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vclk2_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vclk_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_VID_CLK_DIV ,
. shift = 0 ,
. width = 8 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " vclk_input " } ,
. num_parents = 1 ,
. flags = CLK_GET_RATE_NOCACHE ,
} ,
} ;
static struct clk_regmap g12a_vclk2_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_VIID_CLK_DIV ,
. shift = 0 ,
. width = 8 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk2_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " vclk2_input " } ,
. num_parents = 1 ,
. flags = CLK_GET_RATE_NOCACHE ,
} ,
} ;
static struct clk_regmap g12a_vclk = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VID_CLK_CNTL ,
. bit_idx = 19 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vclk_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vclk2 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VIID_CLK_CNTL ,
. bit_idx = 19 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk2 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vclk2_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vclk_div1 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VID_CLK_CNTL ,
. bit_idx = 0 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk_div1 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vclk " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vclk_div2_en = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VID_CLK_CNTL ,
. bit_idx = 1 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk_div2_en " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vclk " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vclk_div4_en = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VID_CLK_CNTL ,
. bit_idx = 2 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk_div4_en " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vclk " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vclk_div6_en = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VID_CLK_CNTL ,
. bit_idx = 3 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk_div6_en " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vclk " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vclk_div12_en = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VID_CLK_CNTL ,
. bit_idx = 4 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk_div12_en " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vclk " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vclk2_div1 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VIID_CLK_CNTL ,
. bit_idx = 0 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk2_div1 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vclk2 " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vclk2_div2_en = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VIID_CLK_CNTL ,
. bit_idx = 1 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk2_div2_en " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vclk2 " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vclk2_div4_en = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VIID_CLK_CNTL ,
. bit_idx = 2 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk2_div4_en " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vclk2 " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vclk2_div6_en = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VIID_CLK_CNTL ,
. bit_idx = 3 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk2_div6_en " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vclk2 " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_vclk2_div12_en = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VIID_CLK_CNTL ,
. bit_idx = 4 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk2_div12_en " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " vclk2 " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_fixed_factor g12a_vclk_div2 = {
. mult = 1 ,
. div = 2 ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk_div2 " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " vclk_div2_en " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_fixed_factor g12a_vclk_div4 = {
. mult = 1 ,
. div = 4 ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk_div4 " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " vclk_div4_en " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_fixed_factor g12a_vclk_div6 = {
. mult = 1 ,
. div = 6 ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk_div6 " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " vclk_div6_en " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_fixed_factor g12a_vclk_div12 = {
. mult = 1 ,
. div = 12 ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk_div12 " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " vclk_div12_en " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_fixed_factor g12a_vclk2_div2 = {
. mult = 1 ,
. div = 2 ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk2_div2 " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " vclk2_div2_en " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_fixed_factor g12a_vclk2_div4 = {
. mult = 1 ,
. div = 4 ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk2_div4 " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " vclk2_div4_en " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_fixed_factor g12a_vclk2_div6 = {
. mult = 1 ,
. div = 6 ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk2_div6 " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " vclk2_div6_en " } ,
. num_parents = 1 ,
} ,
} ;
static struct clk_fixed_factor g12a_vclk2_div12 = {
. mult = 1 ,
. div = 12 ,
. hw . init = & ( struct clk_init_data ) {
. name = " vclk2_div12 " ,
. ops = & clk_fixed_factor_ops ,
. parent_names = ( const char * [ ] ) { " vclk2_div12_en " } ,
. num_parents = 1 ,
} ,
} ;
static u32 mux_table_cts_sel [ ] = { 0 , 1 , 2 , 3 , 4 , 8 , 9 , 10 , 11 , 12 } ;
static const char * const g12a_cts_parent_names [ ] = {
" vclk_div1 " , " vclk_div2 " , " vclk_div4 " , " vclk_div6 " ,
" vclk_div12 " , " vclk2_div1 " , " vclk2_div2 " , " vclk2_div4 " ,
" vclk2_div6 " , " vclk2_div12 "
} ;
static struct clk_regmap g12a_cts_enci_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VID_CLK_DIV ,
. mask = 0xf ,
. shift = 28 ,
. table = mux_table_cts_sel ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cts_enci_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_cts_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_cts_parent_names ) ,
. flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE ,
} ,
} ;
static struct clk_regmap g12a_cts_encp_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VID_CLK_DIV ,
. mask = 0xf ,
. shift = 20 ,
. table = mux_table_cts_sel ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cts_encp_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_cts_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_cts_parent_names ) ,
. flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE ,
} ,
} ;
static struct clk_regmap g12a_cts_vdac_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_VIID_CLK_DIV ,
. mask = 0xf ,
. shift = 28 ,
. table = mux_table_cts_sel ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cts_vdac_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_cts_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_cts_parent_names ) ,
. flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE ,
} ,
} ;
/* TOFIX: add support for cts_tcon */
static u32 mux_table_hdmi_tx_sel [ ] = { 0 , 1 , 2 , 3 , 4 , 8 , 9 , 10 , 11 , 12 } ;
static const char * const g12a_cts_hdmi_tx_parent_names [ ] = {
" vclk_div1 " , " vclk_div2 " , " vclk_div4 " , " vclk_div6 " ,
" vclk_div12 " , " vclk2_div1 " , " vclk2_div2 " , " vclk2_div4 " ,
" vclk2_div6 " , " vclk2_div12 "
} ;
static struct clk_regmap g12a_hdmi_tx_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_HDMI_CLK_CNTL ,
. mask = 0xf ,
. shift = 16 ,
. table = mux_table_hdmi_tx_sel ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " hdmi_tx_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_cts_hdmi_tx_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_cts_hdmi_tx_parent_names ) ,
. flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE ,
} ,
} ;
static struct clk_regmap g12a_cts_enci = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VID_CLK_CNTL2 ,
. bit_idx = 0 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cts_enci " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " cts_enci_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_cts_encp = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VID_CLK_CNTL2 ,
. bit_idx = 2 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cts_encp " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " cts_encp_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_cts_vdac = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VID_CLK_CNTL2 ,
. bit_idx = 4 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " cts_vdac " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " cts_vdac_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
static struct clk_regmap g12a_hdmi_tx = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_VID_CLK_CNTL2 ,
. bit_idx = 5 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " hdmi_tx " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " hdmi_tx_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
/* HDMI Clocks */
static const char * const g12a_hdmi_parent_names [ ] = {
IN_PREFIX " xtal " , " fclk_div4 " , " fclk_div3 " , " fclk_div5 "
} ;
static struct clk_regmap g12a_hdmi_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_HDMI_CLK_CNTL ,
. mask = 0x3 ,
. shift = 9 ,
. flags = CLK_MUX_ROUND_CLOSEST ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " hdmi_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_hdmi_parent_names ,
. num_parents = ARRAY_SIZE ( g12a_hdmi_parent_names ) ,
. flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE ,
} ,
} ;
static struct clk_regmap g12a_hdmi_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_HDMI_CLK_CNTL ,
. shift = 0 ,
. width = 7 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " hdmi_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " hdmi_sel " } ,
. num_parents = 1 ,
. flags = CLK_GET_RATE_NOCACHE ,
} ,
} ;
static struct clk_regmap g12a_hdmi = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_HDMI_CLK_CNTL ,
. bit_idx = 8 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " hdmi " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " hdmi_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED ,
} ,
} ;
/*
* The MALI IP is clocked by two identical clocks ( mali_0 and mali_1 )
* muxed by a glitch - free switch .
*/
static const char * const g12a_mali_0_1_parent_names [ ] = {
IN_PREFIX " xtal " , " gp0_pll " , " hihi_pll " , " fclk_div2p5 " ,
" fclk_div3 " , " fclk_div4 " , " fclk_div5 " , " fclk_div7 "
} ;
static struct clk_regmap g12a_mali_0_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_MALI_CLK_CNTL ,
. mask = 0x7 ,
. shift = 9 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mali_0_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_mali_0_1_parent_names ,
. num_parents = 8 ,
. flags = CLK_SET_RATE_NO_REPARENT ,
} ,
} ;
static struct clk_regmap g12a_mali_0_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_MALI_CLK_CNTL ,
. shift = 0 ,
. width = 7 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mali_0_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " mali_0_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_NO_REPARENT ,
} ,
} ;
static struct clk_regmap g12a_mali_0 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_MALI_CLK_CNTL ,
. bit_idx = 8 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mali_0 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " mali_0_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static struct clk_regmap g12a_mali_1_sel = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_MALI_CLK_CNTL ,
. mask = 0x7 ,
. shift = 25 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mali_1_sel " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_mali_0_1_parent_names ,
. num_parents = 8 ,
. flags = CLK_SET_RATE_NO_REPARENT ,
} ,
} ;
static struct clk_regmap g12a_mali_1_div = {
. data = & ( struct clk_regmap_div_data ) {
. offset = HHI_MALI_CLK_CNTL ,
. shift = 16 ,
. width = 7 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mali_1_div " ,
. ops = & clk_regmap_divider_ops ,
. parent_names = ( const char * [ ] ) { " mali_1_sel " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_NO_REPARENT ,
} ,
} ;
static struct clk_regmap g12a_mali_1 = {
. data = & ( struct clk_regmap_gate_data ) {
. offset = HHI_MALI_CLK_CNTL ,
. bit_idx = 24 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mali_1 " ,
. ops = & clk_regmap_gate_ops ,
. parent_names = ( const char * [ ] ) { " mali_1_div " } ,
. num_parents = 1 ,
. flags = CLK_SET_RATE_PARENT ,
} ,
} ;
static const char * const g12a_mali_parent_names [ ] = {
" mali_0 " , " mali_1 "
} ;
static struct clk_regmap g12a_mali = {
. data = & ( struct clk_regmap_mux_data ) {
. offset = HHI_MALI_CLK_CNTL ,
. mask = 1 ,
. shift = 31 ,
} ,
. hw . init = & ( struct clk_init_data ) {
. name = " mali " ,
. ops = & clk_regmap_mux_ops ,
. parent_names = g12a_mali_parent_names ,
. num_parents = 2 ,
. flags = CLK_SET_RATE_NO_REPARENT ,
} ,
} ;
/* Everything Else (EE) domain gates */
static MESON_GATE ( g12a_ddr , HHI_GCLK_MPEG0 , 0 ) ;
static MESON_GATE ( g12a_dos , HHI_GCLK_MPEG0 , 1 ) ;
static MESON_GATE ( g12a_audio_locker , HHI_GCLK_MPEG0 , 2 ) ;
static MESON_GATE ( g12a_mipi_dsi_host , HHI_GCLK_MPEG0 , 3 ) ;
static MESON_GATE ( g12a_eth_phy , HHI_GCLK_MPEG0 , 4 ) ;
static MESON_GATE ( g12a_isa , HHI_GCLK_MPEG0 , 5 ) ;
static MESON_GATE ( g12a_pl301 , HHI_GCLK_MPEG0 , 6 ) ;
static MESON_GATE ( g12a_periphs , HHI_GCLK_MPEG0 , 7 ) ;
static MESON_GATE ( g12a_spicc_0 , HHI_GCLK_MPEG0 , 8 ) ;
static MESON_GATE ( g12a_i2c , HHI_GCLK_MPEG0 , 9 ) ;
static MESON_GATE ( g12a_sana , HHI_GCLK_MPEG0 , 10 ) ;
static MESON_GATE ( g12a_sd , HHI_GCLK_MPEG0 , 11 ) ;
static MESON_GATE ( g12a_rng0 , HHI_GCLK_MPEG0 , 12 ) ;
static MESON_GATE ( g12a_uart0 , HHI_GCLK_MPEG0 , 13 ) ;
static MESON_GATE ( g12a_spicc_1 , HHI_GCLK_MPEG0 , 14 ) ;
static MESON_GATE ( g12a_hiu_reg , HHI_GCLK_MPEG0 , 19 ) ;
static MESON_GATE ( g12a_mipi_dsi_phy , HHI_GCLK_MPEG0 , 20 ) ;
static MESON_GATE ( g12a_assist_misc , HHI_GCLK_MPEG0 , 23 ) ;
static MESON_GATE ( g12a_emmc_a , HHI_GCLK_MPEG0 , 4 ) ;
static MESON_GATE ( g12a_emmc_b , HHI_GCLK_MPEG0 , 25 ) ;
static MESON_GATE ( g12a_emmc_c , HHI_GCLK_MPEG0 , 26 ) ;
static MESON_GATE ( g12a_audio_codec , HHI_GCLK_MPEG0 , 28 ) ;
static MESON_GATE ( g12a_audio , HHI_GCLK_MPEG1 , 0 ) ;
static MESON_GATE ( g12a_eth_core , HHI_GCLK_MPEG1 , 3 ) ;
static MESON_GATE ( g12a_demux , HHI_GCLK_MPEG1 , 4 ) ;
static MESON_GATE ( g12a_audio_ififo , HHI_GCLK_MPEG1 , 11 ) ;
static MESON_GATE ( g12a_adc , HHI_GCLK_MPEG1 , 13 ) ;
static MESON_GATE ( g12a_uart1 , HHI_GCLK_MPEG1 , 16 ) ;
static MESON_GATE ( g12a_g2d , HHI_GCLK_MPEG1 , 20 ) ;
static MESON_GATE ( g12a_reset , HHI_GCLK_MPEG1 , 23 ) ;
static MESON_GATE ( g12a_pcie_comb , HHI_GCLK_MPEG1 , 24 ) ;
static MESON_GATE ( g12a_parser , HHI_GCLK_MPEG1 , 25 ) ;
static MESON_GATE ( g12a_usb_general , HHI_GCLK_MPEG1 , 26 ) ;
static MESON_GATE ( g12a_pcie_phy , HHI_GCLK_MPEG1 , 27 ) ;
static MESON_GATE ( g12a_ahb_arb0 , HHI_GCLK_MPEG1 , 29 ) ;
static MESON_GATE ( g12a_ahb_data_bus , HHI_GCLK_MPEG2 , 1 ) ;
static MESON_GATE ( g12a_ahb_ctrl_bus , HHI_GCLK_MPEG2 , 2 ) ;
static MESON_GATE ( g12a_htx_hdcp22 , HHI_GCLK_MPEG2 , 3 ) ;
static MESON_GATE ( g12a_htx_pclk , HHI_GCLK_MPEG2 , 4 ) ;
static MESON_GATE ( g12a_bt656 , HHI_GCLK_MPEG2 , 6 ) ;
static MESON_GATE ( g12a_usb1_to_ddr , HHI_GCLK_MPEG2 , 8 ) ;
static MESON_GATE ( g12a_mmc_pclk , HHI_GCLK_MPEG2 , 11 ) ;
static MESON_GATE ( g12a_uart2 , HHI_GCLK_MPEG2 , 15 ) ;
static MESON_GATE ( g12a_vpu_intr , HHI_GCLK_MPEG2 , 25 ) ;
static MESON_GATE ( g12a_gic , HHI_GCLK_MPEG2 , 30 ) ;
static MESON_GATE ( g12a_vclk2_venci0 , HHI_GCLK_OTHER , 1 ) ;
static MESON_GATE ( g12a_vclk2_venci1 , HHI_GCLK_OTHER , 2 ) ;
static MESON_GATE ( g12a_vclk2_vencp0 , HHI_GCLK_OTHER , 3 ) ;
static MESON_GATE ( g12a_vclk2_vencp1 , HHI_GCLK_OTHER , 4 ) ;
static MESON_GATE ( g12a_vclk2_venct0 , HHI_GCLK_OTHER , 5 ) ;
static MESON_GATE ( g12a_vclk2_venct1 , HHI_GCLK_OTHER , 6 ) ;
static MESON_GATE ( g12a_vclk2_other , HHI_GCLK_OTHER , 7 ) ;
static MESON_GATE ( g12a_vclk2_enci , HHI_GCLK_OTHER , 8 ) ;
static MESON_GATE ( g12a_vclk2_encp , HHI_GCLK_OTHER , 9 ) ;
static MESON_GATE ( g12a_dac_clk , HHI_GCLK_OTHER , 10 ) ;
static MESON_GATE ( g12a_aoclk_gate , HHI_GCLK_OTHER , 14 ) ;
static MESON_GATE ( g12a_iec958_gate , HHI_GCLK_OTHER , 16 ) ;
static MESON_GATE ( g12a_enc480p , HHI_GCLK_OTHER , 20 ) ;
static MESON_GATE ( g12a_rng1 , HHI_GCLK_OTHER , 21 ) ;
static MESON_GATE ( g12a_vclk2_enct , HHI_GCLK_OTHER , 22 ) ;
static MESON_GATE ( g12a_vclk2_encl , HHI_GCLK_OTHER , 23 ) ;
static MESON_GATE ( g12a_vclk2_venclmmc , HHI_GCLK_OTHER , 24 ) ;
static MESON_GATE ( g12a_vclk2_vencl , HHI_GCLK_OTHER , 25 ) ;
static MESON_GATE ( g12a_vclk2_other1 , HHI_GCLK_OTHER , 26 ) ;
static MESON_GATE_RO ( g12a_dma , HHI_GCLK_OTHER2 , 0 ) ;
static MESON_GATE_RO ( g12a_efuse , HHI_GCLK_OTHER2 , 1 ) ;
static MESON_GATE_RO ( g12a_rom_boot , HHI_GCLK_OTHER2 , 2 ) ;
static MESON_GATE_RO ( g12a_reset_sec , HHI_GCLK_OTHER2 , 3 ) ;
static MESON_GATE_RO ( g12a_sec_ahb_apb3 , HHI_GCLK_OTHER2 , 4 ) ;
/* Array of all clocks provided by this provider */
static struct clk_hw_onecell_data g12a_hw_onecell_data = {
. hws = {
[ CLKID_SYS_PLL ] = & g12a_sys_pll . hw ,
[ CLKID_FIXED_PLL ] = & g12a_fixed_pll . hw ,
[ CLKID_FCLK_DIV2 ] = & g12a_fclk_div2 . hw ,
[ CLKID_FCLK_DIV3 ] = & g12a_fclk_div3 . hw ,
[ CLKID_FCLK_DIV4 ] = & g12a_fclk_div4 . hw ,
[ CLKID_FCLK_DIV5 ] = & g12a_fclk_div5 . hw ,
[ CLKID_FCLK_DIV7 ] = & g12a_fclk_div7 . hw ,
[ CLKID_FCLK_DIV2P5 ] = & g12a_fclk_div2p5 . hw ,
[ CLKID_GP0_PLL ] = & g12a_gp0_pll . hw ,
[ CLKID_MPEG_SEL ] = & g12a_mpeg_clk_sel . hw ,
[ CLKID_MPEG_DIV ] = & g12a_mpeg_clk_div . hw ,
[ CLKID_CLK81 ] = & g12a_clk81 . hw ,
[ CLKID_MPLL0 ] = & g12a_mpll0 . hw ,
[ CLKID_MPLL1 ] = & g12a_mpll1 . hw ,
[ CLKID_MPLL2 ] = & g12a_mpll2 . hw ,
[ CLKID_MPLL3 ] = & g12a_mpll3 . hw ,
[ CLKID_DDR ] = & g12a_ddr . hw ,
[ CLKID_DOS ] = & g12a_dos . hw ,
[ CLKID_AUDIO_LOCKER ] = & g12a_audio_locker . hw ,
[ CLKID_MIPI_DSI_HOST ] = & g12a_mipi_dsi_host . hw ,
[ CLKID_ETH_PHY ] = & g12a_eth_phy . hw ,
[ CLKID_ISA ] = & g12a_isa . hw ,
[ CLKID_PL301 ] = & g12a_pl301 . hw ,
[ CLKID_PERIPHS ] = & g12a_periphs . hw ,
[ CLKID_SPICC0 ] = & g12a_spicc_0 . hw ,
[ CLKID_I2C ] = & g12a_i2c . hw ,
[ CLKID_SANA ] = & g12a_sana . hw ,
[ CLKID_SD ] = & g12a_sd . hw ,
[ CLKID_RNG0 ] = & g12a_rng0 . hw ,
[ CLKID_UART0 ] = & g12a_uart0 . hw ,
[ CLKID_SPICC1 ] = & g12a_spicc_1 . hw ,
[ CLKID_HIU_IFACE ] = & g12a_hiu_reg . hw ,
[ CLKID_MIPI_DSI_PHY ] = & g12a_mipi_dsi_phy . hw ,
[ CLKID_ASSIST_MISC ] = & g12a_assist_misc . hw ,
[ CLKID_SD_EMMC_A ] = & g12a_emmc_a . hw ,
[ CLKID_SD_EMMC_B ] = & g12a_emmc_b . hw ,
[ CLKID_SD_EMMC_C ] = & g12a_emmc_c . hw ,
[ CLKID_AUDIO_CODEC ] = & g12a_audio_codec . hw ,
[ CLKID_AUDIO ] = & g12a_audio . hw ,
[ CLKID_ETH ] = & g12a_eth_core . hw ,
[ CLKID_DEMUX ] = & g12a_demux . hw ,
[ CLKID_AUDIO_IFIFO ] = & g12a_audio_ififo . hw ,
[ CLKID_ADC ] = & g12a_adc . hw ,
[ CLKID_UART1 ] = & g12a_uart1 . hw ,
[ CLKID_G2D ] = & g12a_g2d . hw ,
[ CLKID_RESET ] = & g12a_reset . hw ,
[ CLKID_PCIE_COMB ] = & g12a_pcie_comb . hw ,
[ CLKID_PARSER ] = & g12a_parser . hw ,
[ CLKID_USB ] = & g12a_usb_general . hw ,
[ CLKID_PCIE_PHY ] = & g12a_pcie_phy . hw ,
[ CLKID_AHB_ARB0 ] = & g12a_ahb_arb0 . hw ,
[ CLKID_AHB_DATA_BUS ] = & g12a_ahb_data_bus . hw ,
[ CLKID_AHB_CTRL_BUS ] = & g12a_ahb_ctrl_bus . hw ,
[ CLKID_HTX_HDCP22 ] = & g12a_htx_hdcp22 . hw ,
[ CLKID_HTX_PCLK ] = & g12a_htx_pclk . hw ,
[ CLKID_BT656 ] = & g12a_bt656 . hw ,
[ CLKID_USB1_DDR_BRIDGE ] = & g12a_usb1_to_ddr . hw ,
[ CLKID_MMC_PCLK ] = & g12a_mmc_pclk . hw ,
[ CLKID_UART2 ] = & g12a_uart2 . hw ,
[ CLKID_VPU_INTR ] = & g12a_vpu_intr . hw ,
[ CLKID_GIC ] = & g12a_gic . hw ,
[ CLKID_SD_EMMC_A_CLK0_SEL ] = & g12a_sd_emmc_a_clk0_sel . hw ,
[ CLKID_SD_EMMC_A_CLK0_DIV ] = & g12a_sd_emmc_a_clk0_div . hw ,
[ CLKID_SD_EMMC_A_CLK0 ] = & g12a_sd_emmc_a_clk0 . hw ,
[ CLKID_SD_EMMC_B_CLK0_SEL ] = & g12a_sd_emmc_b_clk0_sel . hw ,
[ CLKID_SD_EMMC_B_CLK0_DIV ] = & g12a_sd_emmc_b_clk0_div . hw ,
[ CLKID_SD_EMMC_B_CLK0 ] = & g12a_sd_emmc_b_clk0 . hw ,
[ CLKID_SD_EMMC_C_CLK0_SEL ] = & g12a_sd_emmc_c_clk0_sel . hw ,
[ CLKID_SD_EMMC_C_CLK0_DIV ] = & g12a_sd_emmc_c_clk0_div . hw ,
[ CLKID_SD_EMMC_C_CLK0 ] = & g12a_sd_emmc_c_clk0 . hw ,
[ CLKID_MPLL0_DIV ] = & g12a_mpll0_div . hw ,
[ CLKID_MPLL1_DIV ] = & g12a_mpll1_div . hw ,
[ CLKID_MPLL2_DIV ] = & g12a_mpll2_div . hw ,
[ CLKID_MPLL3_DIV ] = & g12a_mpll3_div . hw ,
[ CLKID_FCLK_DIV2_DIV ] = & g12a_fclk_div2_div . hw ,
[ CLKID_FCLK_DIV3_DIV ] = & g12a_fclk_div3_div . hw ,
[ CLKID_FCLK_DIV4_DIV ] = & g12a_fclk_div4_div . hw ,
[ CLKID_FCLK_DIV5_DIV ] = & g12a_fclk_div5_div . hw ,
[ CLKID_FCLK_DIV7_DIV ] = & g12a_fclk_div7_div . hw ,
[ CLKID_FCLK_DIV2P5_DIV ] = & g12a_fclk_div2p5_div . hw ,
[ CLKID_HIFI_PLL ] = & g12a_hifi_pll . hw ,
[ CLKID_VCLK2_VENCI0 ] = & g12a_vclk2_venci0 . hw ,
[ CLKID_VCLK2_VENCI1 ] = & g12a_vclk2_venci1 . hw ,
[ CLKID_VCLK2_VENCP0 ] = & g12a_vclk2_vencp0 . hw ,
[ CLKID_VCLK2_VENCP1 ] = & g12a_vclk2_vencp1 . hw ,
[ CLKID_VCLK2_VENCT0 ] = & g12a_vclk2_venct0 . hw ,
[ CLKID_VCLK2_VENCT1 ] = & g12a_vclk2_venct1 . hw ,
[ CLKID_VCLK2_OTHER ] = & g12a_vclk2_other . hw ,
[ CLKID_VCLK2_ENCI ] = & g12a_vclk2_enci . hw ,
[ CLKID_VCLK2_ENCP ] = & g12a_vclk2_encp . hw ,
[ CLKID_DAC_CLK ] = & g12a_dac_clk . hw ,
[ CLKID_AOCLK ] = & g12a_aoclk_gate . hw ,
[ CLKID_IEC958 ] = & g12a_iec958_gate . hw ,
[ CLKID_ENC480P ] = & g12a_enc480p . hw ,
[ CLKID_RNG1 ] = & g12a_rng1 . hw ,
[ CLKID_VCLK2_ENCT ] = & g12a_vclk2_enct . hw ,
[ CLKID_VCLK2_ENCL ] = & g12a_vclk2_encl . hw ,
[ CLKID_VCLK2_VENCLMMC ] = & g12a_vclk2_venclmmc . hw ,
[ CLKID_VCLK2_VENCL ] = & g12a_vclk2_vencl . hw ,
[ CLKID_VCLK2_OTHER1 ] = & g12a_vclk2_other1 . hw ,
[ CLKID_FIXED_PLL_DCO ] = & g12a_fixed_pll_dco . hw ,
[ CLKID_SYS_PLL_DCO ] = & g12a_sys_pll_dco . hw ,
[ CLKID_GP0_PLL_DCO ] = & g12a_gp0_pll_dco . hw ,
[ CLKID_HIFI_PLL_DCO ] = & g12a_hifi_pll_dco . hw ,
[ CLKID_DMA ] = & g12a_dma . hw ,
[ CLKID_EFUSE ] = & g12a_efuse . hw ,
[ CLKID_ROM_BOOT ] = & g12a_rom_boot . hw ,
[ CLKID_RESET_SEC ] = & g12a_reset_sec . hw ,
[ CLKID_SEC_AHB_APB3 ] = & g12a_sec_ahb_apb3 . hw ,
[ CLKID_MPLL_PREDIV ] = & g12a_mpll_prediv . hw ,
[ CLKID_VPU_0_SEL ] = & g12a_vpu_0_sel . hw ,
[ CLKID_VPU_0_DIV ] = & g12a_vpu_0_div . hw ,
[ CLKID_VPU_0 ] = & g12a_vpu_0 . hw ,
[ CLKID_VPU_1_SEL ] = & g12a_vpu_1_sel . hw ,
[ CLKID_VPU_1_DIV ] = & g12a_vpu_1_div . hw ,
[ CLKID_VPU_1 ] = & g12a_vpu_1 . hw ,
[ CLKID_VPU ] = & g12a_vpu . hw ,
[ CLKID_VAPB_0_SEL ] = & g12a_vapb_0_sel . hw ,
[ CLKID_VAPB_0_DIV ] = & g12a_vapb_0_div . hw ,
[ CLKID_VAPB_0 ] = & g12a_vapb_0 . hw ,
[ CLKID_VAPB_1_SEL ] = & g12a_vapb_1_sel . hw ,
[ CLKID_VAPB_1_DIV ] = & g12a_vapb_1_div . hw ,
[ CLKID_VAPB_1 ] = & g12a_vapb_1 . hw ,
[ CLKID_VAPB_SEL ] = & g12a_vapb_sel . hw ,
[ CLKID_VAPB ] = & g12a_vapb . hw ,
[ CLKID_HDMI_PLL_DCO ] = & g12a_hdmi_pll_dco . hw ,
[ CLKID_HDMI_PLL_OD ] = & g12a_hdmi_pll_od . hw ,
[ CLKID_HDMI_PLL_OD2 ] = & g12a_hdmi_pll_od2 . hw ,
[ CLKID_HDMI_PLL ] = & g12a_hdmi_pll . hw ,
[ CLKID_VID_PLL ] = & g12a_vid_pll_div . hw ,
[ CLKID_VID_PLL_SEL ] = & g12a_vid_pll_sel . hw ,
[ CLKID_VID_PLL_DIV ] = & g12a_vid_pll . hw ,
[ CLKID_VCLK_SEL ] = & g12a_vclk_sel . hw ,
[ CLKID_VCLK2_SEL ] = & g12a_vclk2_sel . hw ,
[ CLKID_VCLK_INPUT ] = & g12a_vclk_input . hw ,
[ CLKID_VCLK2_INPUT ] = & g12a_vclk2_input . hw ,
[ CLKID_VCLK_DIV ] = & g12a_vclk_div . hw ,
[ CLKID_VCLK2_DIV ] = & g12a_vclk2_div . hw ,
[ CLKID_VCLK ] = & g12a_vclk . hw ,
[ CLKID_VCLK2 ] = & g12a_vclk2 . hw ,
[ CLKID_VCLK_DIV1 ] = & g12a_vclk_div1 . hw ,
[ CLKID_VCLK_DIV2_EN ] = & g12a_vclk_div2_en . hw ,
[ CLKID_VCLK_DIV4_EN ] = & g12a_vclk_div4_en . hw ,
[ CLKID_VCLK_DIV6_EN ] = & g12a_vclk_div6_en . hw ,
[ CLKID_VCLK_DIV12_EN ] = & g12a_vclk_div12_en . hw ,
[ CLKID_VCLK2_DIV1 ] = & g12a_vclk2_div1 . hw ,
[ CLKID_VCLK2_DIV2_EN ] = & g12a_vclk2_div2_en . hw ,
[ CLKID_VCLK2_DIV4_EN ] = & g12a_vclk2_div4_en . hw ,
[ CLKID_VCLK2_DIV6_EN ] = & g12a_vclk2_div6_en . hw ,
[ CLKID_VCLK2_DIV12_EN ] = & g12a_vclk2_div12_en . hw ,
[ CLKID_VCLK_DIV2 ] = & g12a_vclk_div2 . hw ,
[ CLKID_VCLK_DIV4 ] = & g12a_vclk_div4 . hw ,
[ CLKID_VCLK_DIV6 ] = & g12a_vclk_div6 . hw ,
[ CLKID_VCLK_DIV12 ] = & g12a_vclk_div12 . hw ,
[ CLKID_VCLK2_DIV2 ] = & g12a_vclk2_div2 . hw ,
[ CLKID_VCLK2_DIV4 ] = & g12a_vclk2_div4 . hw ,
[ CLKID_VCLK2_DIV6 ] = & g12a_vclk2_div6 . hw ,
[ CLKID_VCLK2_DIV12 ] = & g12a_vclk2_div12 . hw ,
[ CLKID_CTS_ENCI_SEL ] = & g12a_cts_enci_sel . hw ,
[ CLKID_CTS_ENCP_SEL ] = & g12a_cts_encp_sel . hw ,
[ CLKID_CTS_VDAC_SEL ] = & g12a_cts_vdac_sel . hw ,
[ CLKID_HDMI_TX_SEL ] = & g12a_hdmi_tx_sel . hw ,
[ CLKID_CTS_ENCI ] = & g12a_cts_enci . hw ,
[ CLKID_CTS_ENCP ] = & g12a_cts_encp . hw ,
[ CLKID_CTS_VDAC ] = & g12a_cts_vdac . hw ,
[ CLKID_HDMI_TX ] = & g12a_hdmi_tx . hw ,
[ CLKID_HDMI_SEL ] = & g12a_hdmi_sel . hw ,
[ CLKID_HDMI_DIV ] = & g12a_hdmi_div . hw ,
[ CLKID_HDMI ] = & g12a_hdmi . hw ,
[ CLKID_MALI_0_SEL ] = & g12a_mali_0_sel . hw ,
[ CLKID_MALI_0_DIV ] = & g12a_mali_0_div . hw ,
[ CLKID_MALI_0 ] = & g12a_mali_0 . hw ,
[ CLKID_MALI_1_SEL ] = & g12a_mali_1_sel . hw ,
[ CLKID_MALI_1_DIV ] = & g12a_mali_1_div . hw ,
[ CLKID_MALI_1 ] = & g12a_mali_1 . hw ,
[ CLKID_MALI ] = & g12a_mali . hw ,
2019-05-12 22:57:43 +02:00
[ CLKID_MPLL_50M_DIV ] = & g12a_mpll_50m_div . hw ,
[ CLKID_MPLL_50M ] = & g12a_mpll_50m . hw ,
2019-03-04 14:11:29 +01:00
[ CLKID_SYS_PLL_DIV16_EN ] = & g12a_sys_pll_div16_en . hw ,
[ CLKID_SYS_PLL_DIV16 ] = & g12a_sys_pll_div16 . hw ,
[ CLKID_CPU_CLK_DYN0_SEL ] = & g12a_cpu_clk_premux0 . hw ,
[ CLKID_CPU_CLK_DYN0_DIV ] = & g12a_cpu_clk_mux0_div . hw ,
[ CLKID_CPU_CLK_DYN0 ] = & g12a_cpu_clk_postmux0 . hw ,
[ CLKID_CPU_CLK_DYN1_SEL ] = & g12a_cpu_clk_premux1 . hw ,
[ CLKID_CPU_CLK_DYN1_DIV ] = & g12a_cpu_clk_mux1_div . hw ,
[ CLKID_CPU_CLK_DYN1 ] = & g12a_cpu_clk_postmux1 . hw ,
[ CLKID_CPU_CLK_DYN ] = & g12a_cpu_clk_dyn . hw ,
[ CLKID_CPU_CLK ] = & g12a_cpu_clk . hw ,
[ CLKID_CPU_CLK_DIV16_EN ] = & g12a_cpu_clk_div16_en . hw ,
[ CLKID_CPU_CLK_DIV16 ] = & g12a_cpu_clk_div16 . hw ,
[ CLKID_CPU_CLK_APB_DIV ] = & g12a_cpu_clk_apb_div . hw ,
[ CLKID_CPU_CLK_APB ] = & g12a_cpu_clk_apb . hw ,
[ CLKID_CPU_CLK_ATB_DIV ] = & g12a_cpu_clk_atb_div . hw ,
[ CLKID_CPU_CLK_ATB ] = & g12a_cpu_clk_atb . hw ,
[ CLKID_CPU_CLK_AXI_DIV ] = & g12a_cpu_clk_axi_div . hw ,
[ CLKID_CPU_CLK_AXI ] = & g12a_cpu_clk_axi . hw ,
[ CLKID_CPU_CLK_TRACE_DIV ] = & g12a_cpu_clk_trace_div . hw ,
[ CLKID_CPU_CLK_TRACE ] = & g12a_cpu_clk_trace . hw ,
2019-03-07 15:14:55 +01:00
[ CLKID_PCIE_PLL_DCO ] = & g12a_pcie_pll_dco . hw ,
[ CLKID_PCIE_PLL_DCO_DIV2 ] = & g12a_pcie_pll_dco_div2 . hw ,
[ CLKID_PCIE_PLL_OD ] = & g12a_pcie_pll_od . hw ,
[ CLKID_PCIE_PLL ] = & g12a_pcie_pll . hw ,
2019-03-19 11:11:38 +01:00
[ CLKID_VDEC_1_SEL ] = & g12a_vdec_1_sel . hw ,
[ CLKID_VDEC_1_DIV ] = & g12a_vdec_1_div . hw ,
[ CLKID_VDEC_1 ] = & g12a_vdec_1 . hw ,
[ CLKID_VDEC_HEVC_SEL ] = & g12a_vdec_hevc_sel . hw ,
[ CLKID_VDEC_HEVC_DIV ] = & g12a_vdec_hevc_div . hw ,
[ CLKID_VDEC_HEVC ] = & g12a_vdec_hevc . hw ,
[ CLKID_VDEC_HEVCF_SEL ] = & g12a_vdec_hevcf_sel . hw ,
[ CLKID_VDEC_HEVCF_DIV ] = & g12a_vdec_hevcf_div . hw ,
[ CLKID_VDEC_HEVCF ] = & g12a_vdec_hevcf . hw ,
2019-02-01 15:53:44 +01:00
[ NR_CLKS ] = NULL ,
} ,
. num = NR_CLKS ,
} ;
/* Convenience table to populate regmap in .probe */
static struct clk_regmap * const g12a_clk_regmaps [ ] = {
& g12a_clk81 ,
& g12a_dos ,
& g12a_ddr ,
& g12a_audio_locker ,
& g12a_mipi_dsi_host ,
& g12a_eth_phy ,
& g12a_isa ,
& g12a_pl301 ,
& g12a_periphs ,
& g12a_spicc_0 ,
& g12a_i2c ,
& g12a_sana ,
& g12a_sd ,
& g12a_rng0 ,
& g12a_uart0 ,
& g12a_spicc_1 ,
& g12a_hiu_reg ,
& g12a_mipi_dsi_phy ,
& g12a_assist_misc ,
& g12a_emmc_a ,
& g12a_emmc_b ,
& g12a_emmc_c ,
& g12a_audio_codec ,
& g12a_audio ,
& g12a_eth_core ,
& g12a_demux ,
& g12a_audio_ififo ,
& g12a_adc ,
& g12a_uart1 ,
& g12a_g2d ,
& g12a_reset ,
& g12a_pcie_comb ,
& g12a_parser ,
& g12a_usb_general ,
& g12a_pcie_phy ,
& g12a_ahb_arb0 ,
& g12a_ahb_data_bus ,
& g12a_ahb_ctrl_bus ,
& g12a_htx_hdcp22 ,
& g12a_htx_pclk ,
& g12a_bt656 ,
& g12a_usb1_to_ddr ,
& g12a_mmc_pclk ,
& g12a_vpu_intr ,
& g12a_gic ,
& g12a_sd_emmc_a_clk0 ,
& g12a_sd_emmc_b_clk0 ,
& g12a_sd_emmc_c_clk0 ,
& g12a_mpeg_clk_div ,
& g12a_sd_emmc_a_clk0_div ,
& g12a_sd_emmc_b_clk0_div ,
& g12a_sd_emmc_c_clk0_div ,
& g12a_mpeg_clk_sel ,
& g12a_sd_emmc_a_clk0_sel ,
& g12a_sd_emmc_b_clk0_sel ,
& g12a_sd_emmc_c_clk0_sel ,
& g12a_mpll0 ,
& g12a_mpll1 ,
& g12a_mpll2 ,
& g12a_mpll3 ,
& g12a_mpll0_div ,
& g12a_mpll1_div ,
& g12a_mpll2_div ,
& g12a_mpll3_div ,
& g12a_fixed_pll ,
& g12a_sys_pll ,
& g12a_gp0_pll ,
& g12a_hifi_pll ,
& g12a_vclk2_venci0 ,
& g12a_vclk2_venci1 ,
& g12a_vclk2_vencp0 ,
& g12a_vclk2_vencp1 ,
& g12a_vclk2_venct0 ,
& g12a_vclk2_venct1 ,
& g12a_vclk2_other ,
& g12a_vclk2_enci ,
& g12a_vclk2_encp ,
& g12a_dac_clk ,
& g12a_aoclk_gate ,
& g12a_iec958_gate ,
& g12a_enc480p ,
& g12a_rng1 ,
& g12a_vclk2_enct ,
& g12a_vclk2_encl ,
& g12a_vclk2_venclmmc ,
& g12a_vclk2_vencl ,
& g12a_vclk2_other1 ,
& g12a_fixed_pll_dco ,
& g12a_sys_pll_dco ,
& g12a_gp0_pll_dco ,
& g12a_hifi_pll_dco ,
& g12a_fclk_div2 ,
& g12a_fclk_div3 ,
& g12a_fclk_div4 ,
& g12a_fclk_div5 ,
& g12a_fclk_div7 ,
& g12a_fclk_div2p5 ,
& g12a_dma ,
& g12a_efuse ,
& g12a_rom_boot ,
& g12a_reset_sec ,
& g12a_sec_ahb_apb3 ,
& g12a_vpu_0_sel ,
& g12a_vpu_0_div ,
& g12a_vpu_0 ,
& g12a_vpu_1_sel ,
& g12a_vpu_1_div ,
& g12a_vpu_1 ,
& g12a_vpu ,
& g12a_vapb_0_sel ,
& g12a_vapb_0_div ,
& g12a_vapb_0 ,
& g12a_vapb_1_sel ,
& g12a_vapb_1_div ,
& g12a_vapb_1 ,
& g12a_vapb_sel ,
& g12a_vapb ,
& g12a_hdmi_pll_dco ,
& g12a_hdmi_pll_od ,
& g12a_hdmi_pll_od2 ,
& g12a_hdmi_pll ,
& g12a_vid_pll_div ,
& g12a_vid_pll_sel ,
& g12a_vid_pll ,
& g12a_vclk_sel ,
& g12a_vclk2_sel ,
& g12a_vclk_input ,
& g12a_vclk2_input ,
& g12a_vclk_div ,
& g12a_vclk2_div ,
& g12a_vclk ,
& g12a_vclk2 ,
& g12a_vclk_div1 ,
& g12a_vclk_div2_en ,
& g12a_vclk_div4_en ,
& g12a_vclk_div6_en ,
& g12a_vclk_div12_en ,
& g12a_vclk2_div1 ,
& g12a_vclk2_div2_en ,
& g12a_vclk2_div4_en ,
& g12a_vclk2_div6_en ,
& g12a_vclk2_div12_en ,
& g12a_cts_enci_sel ,
& g12a_cts_encp_sel ,
& g12a_cts_vdac_sel ,
& g12a_hdmi_tx_sel ,
& g12a_cts_enci ,
& g12a_cts_encp ,
& g12a_cts_vdac ,
& g12a_hdmi_tx ,
& g12a_hdmi_sel ,
& g12a_hdmi_div ,
& g12a_hdmi ,
& g12a_mali_0_sel ,
& g12a_mali_0_div ,
& g12a_mali_0 ,
& g12a_mali_1_sel ,
& g12a_mali_1_div ,
& g12a_mali_1 ,
& g12a_mali ,
& g12a_mpll_50m ,
2019-03-04 14:11:29 +01:00
& g12a_sys_pll_div16_en ,
& g12a_cpu_clk_premux0 ,
& g12a_cpu_clk_mux0_div ,
& g12a_cpu_clk_postmux0 ,
& g12a_cpu_clk_premux1 ,
& g12a_cpu_clk_mux1_div ,
& g12a_cpu_clk_postmux1 ,
& g12a_cpu_clk_dyn ,
& g12a_cpu_clk ,
& g12a_cpu_clk_div16_en ,
& g12a_cpu_clk_apb_div ,
& g12a_cpu_clk_apb ,
& g12a_cpu_clk_atb_div ,
& g12a_cpu_clk_atb ,
& g12a_cpu_clk_axi_div ,
& g12a_cpu_clk_axi ,
& g12a_cpu_clk_trace_div ,
& g12a_cpu_clk_trace ,
2019-03-07 15:14:55 +01:00
& g12a_pcie_pll_od ,
& g12a_pcie_pll_dco ,
2019-03-19 11:11:38 +01:00
& g12a_vdec_1_sel ,
& g12a_vdec_1_div ,
& g12a_vdec_1 ,
& g12a_vdec_hevc_sel ,
& g12a_vdec_hevc_div ,
& g12a_vdec_hevc ,
& g12a_vdec_hevcf_sel ,
& g12a_vdec_hevcf_div ,
& g12a_vdec_hevcf ,
2019-02-01 15:53:44 +01:00
} ;
2019-02-01 15:53:45 +01:00
static const struct meson_eeclkc_data g12a_clkc_data = {
. regmap_clks = g12a_clk_regmaps ,
. regmap_clk_num = ARRAY_SIZE ( g12a_clk_regmaps ) ,
. hw_onecell_data = & g12a_hw_onecell_data
} ;
2019-02-01 15:53:44 +01:00
static const struct of_device_id clkc_match_table [ ] = {
2019-02-01 15:53:45 +01:00
{ . compatible = " amlogic,g12a-clkc " , . data = & g12a_clkc_data } ,
2019-02-01 15:53:44 +01:00
{ }
} ;
static struct platform_driver g12a_driver = {
2019-02-01 15:53:45 +01:00
. probe = meson_eeclkc_probe ,
2019-02-01 15:53:44 +01:00
. driver = {
. name = " g12a-clkc " ,
. of_match_table = clkc_match_table ,
} ,
} ;
builtin_platform_driver ( g12a_driver ) ;