These changes are the raw update to linux-4.4.6-rt14. Kernel sources
[kvmfornfv.git] / kernel / drivers / clk / qcom / mmcc-msm8960.c
index 9711bca..00e3619 100644 (file)
@@ -19,6 +19,7 @@
 #include <linux/module.h>
 #include <linux/of.h>
 #include <linux/of_device.h>
+#include <linux/clk.h>
 #include <linux/clk-provider.h>
 #include <linux/regmap.h>
 #include <linux/reset-controller.h>
@@ -40,6 +41,10 @@ enum {
        P_PLL3,
        P_PLL15,
        P_HDMI_PLL,
+       P_DSI1_PLL_DSICLK,
+       P_DSI2_PLL_DSICLK,
+       P_DSI1_PLL_BYTECLK,
+       P_DSI2_PLL_BYTECLK,
 };
 
 #define F_MN(f, s, _m, _n) { .freq = f, .src = s, .m = _m, .n = _n }
@@ -50,7 +55,7 @@ static const struct parent_map mmcc_pxo_pll8_pll2_map[] = {
        { P_PLL2, 1 }
 };
 
-static const char *mmcc_pxo_pll8_pll2[] = {
+static const char * const mmcc_pxo_pll8_pll2[] = {
        "pxo",
        "pll8_vote",
        "pll2",
@@ -63,7 +68,7 @@ static const struct parent_map mmcc_pxo_pll8_pll2_pll3_map[] = {
        { P_PLL3, 3 }
 };
 
-static const char *mmcc_pxo_pll8_pll2_pll15[] = {
+static const char * const mmcc_pxo_pll8_pll2_pll15[] = {
        "pxo",
        "pll8_vote",
        "pll2",
@@ -77,13 +82,37 @@ static const struct parent_map mmcc_pxo_pll8_pll2_pll15_map[] = {
        { P_PLL15, 3 }
 };
 
-static const char *mmcc_pxo_pll8_pll2_pll3[] = {
+static const char * const mmcc_pxo_pll8_pll2_pll3[] = {
        "pxo",
        "pll8_vote",
        "pll2",
        "pll3",
 };
 
+static const struct parent_map mmcc_pxo_dsi2_dsi1_map[] = {
+       { P_PXO, 0 },
+       { P_DSI2_PLL_DSICLK, 1 },
+       { P_DSI1_PLL_DSICLK, 3 },
+};
+
+static const char * const mmcc_pxo_dsi2_dsi1[] = {
+       "pxo",
+       "dsi2pll",
+       "dsi1pll",
+};
+
+static const struct parent_map mmcc_pxo_dsi1_dsi2_byte_map[] = {
+       { P_PXO, 0 },
+       { P_DSI1_PLL_BYTECLK, 1 },
+       { P_DSI2_PLL_BYTECLK, 2 },
+};
+
+static const char * const mmcc_pxo_dsi1_dsi2_byte[] = {
+       "pxo",
+       "dsi1pllbyte",
+       "dsi2pllbyte",
+};
+
 static struct clk_pll pll2 = {
        .l_reg = 0x320,
        .m_reg = 0x324,
@@ -508,8 +537,7 @@ static int pix_rdi_set_parent(struct clk_hw *hw, u8 index)
        int ret = 0;
        u32 val;
        struct clk_pix_rdi *rdi = to_clk_pix_rdi(hw);
-       struct clk *clk = hw->clk;
-       int num_parents = __clk_get_num_parents(hw->clk);
+       int num_parents = clk_hw_get_num_parents(hw);
 
        /*
         * These clocks select three inputs via two muxes. One mux selects
@@ -520,7 +548,8 @@ static int pix_rdi_set_parent(struct clk_hw *hw, u8 index)
         * needs to be on at what time.
         */
        for (i = 0; i < num_parents; i++) {
-               ret = clk_prepare_enable(clk_get_parent_by_index(clk, i));
+               struct clk_hw *p = clk_hw_get_parent_by_index(hw, i);
+               ret = clk_prepare_enable(p->clk);
                if (ret)
                        goto err;
        }
@@ -548,8 +577,10 @@ static int pix_rdi_set_parent(struct clk_hw *hw, u8 index)
        udelay(1);
 
 err:
-       for (i--; i >= 0; i--)
-               clk_disable_unprepare(clk_get_parent_by_index(clk, i));
+       for (i--; i >= 0; i--) {
+               struct clk_hw *p = clk_hw_get_parent_by_index(hw, i);
+               clk_disable_unprepare(p->clk);
+       }
 
        return ret;
 }
@@ -579,7 +610,7 @@ static const struct clk_ops clk_ops_pix_rdi = {
        .determine_rate = __clk_mux_determine_rate,
 };
 
-static const char *pix_rdi_parents[] = {
+static const char * const pix_rdi_parents[] = {
        "csi0_clk",
        "csi1_clk",
        "csi2_clk",
@@ -709,7 +740,7 @@ static struct clk_rcg csiphytimer_src = {
        },
 };
 
-static const char *csixphy_timer_src[] = { "csiphytimer_src" };
+static const char * const csixphy_timer_src[] = { "csiphytimer_src" };
 
 static struct clk_branch csiphy0_timer_clk = {
        .halt_reg = 0x01e8,
@@ -1385,7 +1416,7 @@ static const struct parent_map mmcc_pxo_hdmi_map[] = {
        { P_HDMI_PLL, 3 }
 };
 
-static const char *mmcc_pxo_hdmi[] = {
+static const char * const mmcc_pxo_hdmi[] = {
        "pxo",
        "hdmi_pll",
 };
@@ -1428,7 +1459,7 @@ static struct clk_rcg tv_src = {
        },
 };
 
-static const char *tv_src_name[] = { "tv_src" };
+static const char * const tv_src_name[] = { "tv_src" };
 
 static struct clk_branch tv_enc_clk = {
        .halt_reg = 0x01d4,
@@ -2039,6 +2070,350 @@ static struct clk_branch dsi2_s_ahb_clk = {
        },
 };
 
+static struct clk_rcg dsi1_src = {
+       .ns_reg = 0x0054,
+       .md_reg = 0x0050,
+       .mn = {
+               .mnctr_en_bit = 5,
+               .mnctr_reset_bit = 7,
+               .mnctr_mode_shift = 6,
+               .n_val_shift = 24,
+               .m_val_shift = 8,
+               .width = 8,
+       },
+       .p = {
+               .pre_div_shift = 14,
+               .pre_div_width = 2,
+       },
+       .s = {
+               .src_sel_shift = 0,
+               .parent_map = mmcc_pxo_dsi2_dsi1_map,
+       },
+       .clkr = {
+               .enable_reg = 0x004c,
+               .enable_mask = BIT(2),
+               .hw.init = &(struct clk_init_data){
+                       .name = "dsi1_src",
+                       .parent_names = mmcc_pxo_dsi2_dsi1,
+                       .num_parents = 3,
+                       .ops = &clk_rcg_bypass2_ops,
+                       .flags = CLK_SET_RATE_PARENT,
+               },
+       },
+};
+
+static struct clk_branch dsi1_clk = {
+       .halt_reg = 0x01d0,
+       .halt_bit = 2,
+       .clkr = {
+               .enable_reg = 0x004c,
+               .enable_mask = BIT(0),
+               .hw.init = &(struct clk_init_data){
+                       .name = "dsi1_clk",
+                       .parent_names = (const char *[]){ "dsi1_src" },
+                       .num_parents = 1,
+                       .ops = &clk_branch_ops,
+                       .flags = CLK_SET_RATE_PARENT,
+               },
+       },
+};
+
+static struct clk_rcg dsi2_src = {
+       .ns_reg = 0x012c,
+       .md_reg = 0x00a8,
+       .mn = {
+               .mnctr_en_bit = 5,
+               .mnctr_reset_bit = 7,
+               .mnctr_mode_shift = 6,
+               .n_val_shift = 24,
+               .m_val_shift = 8,
+               .width = 8,
+       },
+       .p = {
+               .pre_div_shift = 14,
+               .pre_div_width = 2,
+       },
+       .s = {
+               .src_sel_shift = 0,
+               .parent_map = mmcc_pxo_dsi2_dsi1_map,
+       },
+       .clkr = {
+               .enable_reg = 0x003c,
+               .enable_mask = BIT(2),
+               .hw.init = &(struct clk_init_data){
+                       .name = "dsi2_src",
+                       .parent_names = mmcc_pxo_dsi2_dsi1,
+                       .num_parents = 3,
+                       .ops = &clk_rcg_bypass2_ops,
+                       .flags = CLK_SET_RATE_PARENT,
+               },
+       },
+};
+
+static struct clk_branch dsi2_clk = {
+       .halt_reg = 0x01d0,
+       .halt_bit = 20,
+       .clkr = {
+               .enable_reg = 0x003c,
+               .enable_mask = BIT(0),
+               .hw.init = &(struct clk_init_data){
+                       .name = "dsi2_clk",
+                       .parent_names = (const char *[]){ "dsi2_src" },
+                       .num_parents = 1,
+                       .ops = &clk_branch_ops,
+                       .flags = CLK_SET_RATE_PARENT,
+               },
+       },
+};
+
+static struct clk_rcg dsi1_byte_src = {
+       .ns_reg = 0x00b0,
+       .p = {
+               .pre_div_shift = 12,
+               .pre_div_width = 4,
+       },
+       .s = {
+               .src_sel_shift = 0,
+               .parent_map = mmcc_pxo_dsi1_dsi2_byte_map,
+       },
+       .clkr = {
+               .enable_reg = 0x0090,
+               .enable_mask = BIT(2),
+               .hw.init = &(struct clk_init_data){
+                       .name = "dsi1_byte_src",
+                       .parent_names = mmcc_pxo_dsi1_dsi2_byte,
+                       .num_parents = 3,
+                       .ops = &clk_rcg_bypass2_ops,
+                       .flags = CLK_SET_RATE_PARENT,
+               },
+       },
+};
+
+static struct clk_branch dsi1_byte_clk = {
+       .halt_reg = 0x01cc,
+       .halt_bit = 21,
+       .clkr = {
+               .enable_reg = 0x0090,
+               .enable_mask = BIT(0),
+               .hw.init = &(struct clk_init_data){
+                       .name = "dsi1_byte_clk",
+                       .parent_names = (const char *[]){ "dsi1_byte_src" },
+                       .num_parents = 1,
+                       .ops = &clk_branch_ops,
+                       .flags = CLK_SET_RATE_PARENT,
+               },
+       },
+};
+
+static struct clk_rcg dsi2_byte_src = {
+       .ns_reg = 0x012c,
+       .p = {
+               .pre_div_shift = 12,
+               .pre_div_width = 4,
+       },
+       .s = {
+               .src_sel_shift = 0,
+               .parent_map = mmcc_pxo_dsi1_dsi2_byte_map,
+       },
+       .clkr = {
+               .enable_reg = 0x0130,
+               .enable_mask = BIT(2),
+               .hw.init = &(struct clk_init_data){
+                       .name = "dsi2_byte_src",
+                       .parent_names = mmcc_pxo_dsi1_dsi2_byte,
+                       .num_parents = 3,
+                       .ops = &clk_rcg_bypass2_ops,
+                       .flags = CLK_SET_RATE_PARENT,
+               },
+       },
+};
+
+static struct clk_branch dsi2_byte_clk = {
+       .halt_reg = 0x01cc,
+       .halt_bit = 20,
+       .clkr = {
+               .enable_reg = 0x00b4,
+               .enable_mask = BIT(0),
+               .hw.init = &(struct clk_init_data){
+                       .name = "dsi2_byte_clk",
+                       .parent_names = (const char *[]){ "dsi2_byte_src" },
+                       .num_parents = 1,
+                       .ops = &clk_branch_ops,
+                       .flags = CLK_SET_RATE_PARENT,
+               },
+       },
+};
+
+static struct clk_rcg dsi1_esc_src = {
+       .ns_reg = 0x0011c,
+       .p = {
+               .pre_div_shift = 12,
+               .pre_div_width = 4,
+       },
+       .s = {
+               .src_sel_shift = 0,
+               .parent_map = mmcc_pxo_dsi1_dsi2_byte_map,
+       },
+       .clkr = {
+               .enable_reg = 0x00cc,
+               .enable_mask = BIT(2),
+               .hw.init = &(struct clk_init_data){
+                       .name = "dsi1_esc_src",
+                       .parent_names = mmcc_pxo_dsi1_dsi2_byte,
+                       .num_parents = 3,
+                       .ops = &clk_rcg_esc_ops,
+               },
+       },
+};
+
+static struct clk_branch dsi1_esc_clk = {
+       .halt_reg = 0x01e8,
+       .halt_bit = 1,
+       .clkr = {
+               .enable_reg = 0x00cc,
+               .enable_mask = BIT(0),
+               .hw.init = &(struct clk_init_data){
+                       .name = "dsi1_esc_clk",
+                       .parent_names = (const char *[]){ "dsi1_esc_src" },
+                       .num_parents = 1,
+                       .ops = &clk_branch_ops,
+                       .flags = CLK_SET_RATE_PARENT,
+               },
+       },
+};
+
+static struct clk_rcg dsi2_esc_src = {
+       .ns_reg = 0x0150,
+       .p = {
+               .pre_div_shift = 12,
+               .pre_div_width = 4,
+       },
+       .s = {
+               .src_sel_shift = 0,
+               .parent_map = mmcc_pxo_dsi1_dsi2_byte_map,
+       },
+       .clkr = {
+               .enable_reg = 0x013c,
+               .enable_mask = BIT(2),
+               .hw.init = &(struct clk_init_data){
+                       .name = "dsi2_esc_src",
+                       .parent_names = mmcc_pxo_dsi1_dsi2_byte,
+                       .num_parents = 3,
+                       .ops = &clk_rcg_esc_ops,
+               },
+       },
+};
+
+static struct clk_branch dsi2_esc_clk = {
+       .halt_reg = 0x01e8,
+       .halt_bit = 3,
+       .clkr = {
+               .enable_reg = 0x013c,
+               .enable_mask = BIT(0),
+               .hw.init = &(struct clk_init_data){
+                       .name = "dsi2_esc_clk",
+                       .parent_names = (const char *[]){ "dsi2_esc_src" },
+                       .num_parents = 1,
+                       .ops = &clk_branch_ops,
+                       .flags = CLK_SET_RATE_PARENT,
+               },
+       },
+};
+
+static struct clk_rcg dsi1_pixel_src = {
+       .ns_reg = 0x0138,
+       .md_reg = 0x0134,
+       .mn = {
+               .mnctr_en_bit = 5,
+               .mnctr_reset_bit = 7,
+               .mnctr_mode_shift = 6,
+               .n_val_shift = 16,
+               .m_val_shift = 8,
+               .width = 8,
+       },
+       .p = {
+               .pre_div_shift = 12,
+               .pre_div_width = 4,
+       },
+       .s = {
+               .src_sel_shift = 0,
+               .parent_map = mmcc_pxo_dsi2_dsi1_map,
+       },
+       .clkr = {
+               .enable_reg = 0x0130,
+               .enable_mask = BIT(2),
+               .hw.init = &(struct clk_init_data){
+                       .name = "dsi1_pixel_src",
+                       .parent_names = mmcc_pxo_dsi2_dsi1,
+                       .num_parents = 3,
+                       .ops = &clk_rcg_pixel_ops,
+               },
+       },
+};
+
+static struct clk_branch dsi1_pixel_clk = {
+       .halt_reg = 0x01d0,
+       .halt_bit = 6,
+       .clkr = {
+               .enable_reg = 0x0130,
+               .enable_mask = BIT(0),
+               .hw.init = &(struct clk_init_data){
+                       .name = "mdp_pclk1_clk",
+                       .parent_names = (const char *[]){ "dsi1_pixel_src" },
+                       .num_parents = 1,
+                       .ops = &clk_branch_ops,
+                       .flags = CLK_SET_RATE_PARENT,
+               },
+       },
+};
+
+static struct clk_rcg dsi2_pixel_src = {
+       .ns_reg = 0x00e4,
+       .md_reg = 0x00b8,
+       .mn = {
+               .mnctr_en_bit = 5,
+               .mnctr_reset_bit = 7,
+               .mnctr_mode_shift = 6,
+               .n_val_shift = 16,
+               .m_val_shift = 8,
+               .width = 8,
+       },
+       .p = {
+               .pre_div_shift = 12,
+               .pre_div_width = 4,
+       },
+       .s = {
+               .src_sel_shift = 0,
+               .parent_map = mmcc_pxo_dsi2_dsi1_map,
+       },
+       .clkr = {
+               .enable_reg = 0x0094,
+               .enable_mask = BIT(2),
+               .hw.init = &(struct clk_init_data){
+                       .name = "dsi2_pixel_src",
+                       .parent_names = mmcc_pxo_dsi2_dsi1,
+                       .num_parents = 3,
+                       .ops = &clk_rcg_pixel_ops,
+               },
+       },
+};
+
+static struct clk_branch dsi2_pixel_clk = {
+       .halt_reg = 0x01d0,
+       .halt_bit = 19,
+       .clkr = {
+               .enable_reg = 0x0094,
+               .enable_mask = BIT(0),
+               .hw.init = &(struct clk_init_data){
+                       .name = "mdp_pclk2_clk",
+                       .parent_names = (const char *[]){ "dsi2_pixel_src" },
+                       .num_parents = 1,
+                       .ops = &clk_branch_ops,
+                       .flags = CLK_SET_RATE_PARENT,
+               },
+       },
+};
+
 static struct clk_branch gfx2d0_ahb_clk = {
        .hwcg_reg = 0x0038,
        .hwcg_bit = 28,
@@ -2322,6 +2697,8 @@ static struct clk_regmap *mmcc_msm8960_clks[] = {
        [CSI2_SRC] = &csi2_src.clkr,
        [CSI2_CLK] = &csi2_clk.clkr,
        [CSI2_PHY_CLK] = &csi2_phy_clk.clkr,
+       [DSI_SRC] = &dsi1_src.clkr,
+       [DSI_CLK] = &dsi1_clk.clkr,
        [CSI_PIX_CLK] = &csi_pix_clk.clkr,
        [CSI_RDI_CLK] = &csi_rdi_clk.clkr,
        [MDP_VSYNC_CLK] = &mdp_vsync_clk.clkr,
@@ -2342,6 +2719,18 @@ static struct clk_regmap *mmcc_msm8960_clks[] = {
        [MDP_SRC] = &mdp_src.clkr,
        [MDP_CLK] = &mdp_clk.clkr,
        [MDP_LUT_CLK] = &mdp_lut_clk.clkr,
+       [DSI2_PIXEL_SRC] = &dsi2_pixel_src.clkr,
+       [DSI2_PIXEL_CLK] = &dsi2_pixel_clk.clkr,
+       [DSI2_SRC] = &dsi2_src.clkr,
+       [DSI2_CLK] = &dsi2_clk.clkr,
+       [DSI1_BYTE_SRC] = &dsi1_byte_src.clkr,
+       [DSI1_BYTE_CLK] = &dsi1_byte_clk.clkr,
+       [DSI2_BYTE_SRC] = &dsi2_byte_src.clkr,
+       [DSI2_BYTE_CLK] = &dsi2_byte_clk.clkr,
+       [DSI1_ESC_SRC] = &dsi1_esc_src.clkr,
+       [DSI1_ESC_CLK] = &dsi1_esc_clk.clkr,
+       [DSI2_ESC_SRC] = &dsi2_esc_src.clkr,
+       [DSI2_ESC_CLK] = &dsi2_esc_clk.clkr,
        [ROT_SRC] = &rot_src.clkr,
        [ROT_CLK] = &rot_clk.clkr,
        [TV_ENC_CLK] = &tv_enc_clk.clkr,
@@ -2356,6 +2745,8 @@ static struct clk_regmap *mmcc_msm8960_clks[] = {
        [VFE_CSI_CLK] = &vfe_csi_clk.clkr,
        [VPE_SRC] = &vpe_src.clkr,
        [VPE_CLK] = &vpe_clk.clkr,
+       [DSI_PIXEL_SRC] = &dsi1_pixel_src.clkr,
+       [DSI_PIXEL_CLK] = &dsi1_pixel_clk.clkr,
        [CAMCLK0_SRC] = &camclk0_src.clkr,
        [CAMCLK0_CLK] = &camclk0_clk.clkr,
        [CAMCLK1_SRC] = &camclk1_src.clkr,
@@ -2487,6 +2878,8 @@ static struct clk_regmap *mmcc_apq8064_clks[] = {
        [CSI2_SRC] = &csi2_src.clkr,
        [CSI2_CLK] = &csi2_clk.clkr,
        [CSI2_PHY_CLK] = &csi2_phy_clk.clkr,
+       [DSI_SRC] = &dsi1_src.clkr,
+       [DSI_CLK] = &dsi1_clk.clkr,
        [CSI_PIX_CLK] = &csi_pix_clk.clkr,
        [CSI_RDI_CLK] = &csi_rdi_clk.clkr,
        [MDP_VSYNC_CLK] = &mdp_vsync_clk.clkr,
@@ -2503,6 +2896,18 @@ static struct clk_regmap *mmcc_apq8064_clks[] = {
        [MDP_SRC] = &mdp_src.clkr,
        [MDP_CLK] = &mdp_clk.clkr,
        [MDP_LUT_CLK] = &mdp_lut_clk.clkr,
+       [DSI2_PIXEL_SRC] = &dsi2_pixel_src.clkr,
+       [DSI2_PIXEL_CLK] = &dsi2_pixel_clk.clkr,
+       [DSI2_SRC] = &dsi2_src.clkr,
+       [DSI2_CLK] = &dsi2_clk.clkr,
+       [DSI1_BYTE_SRC] = &dsi1_byte_src.clkr,
+       [DSI1_BYTE_CLK] = &dsi1_byte_clk.clkr,
+       [DSI2_BYTE_SRC] = &dsi2_byte_src.clkr,
+       [DSI2_BYTE_CLK] = &dsi2_byte_clk.clkr,
+       [DSI1_ESC_SRC] = &dsi1_esc_src.clkr,
+       [DSI1_ESC_CLK] = &dsi1_esc_clk.clkr,
+       [DSI2_ESC_SRC] = &dsi2_esc_src.clkr,
+       [DSI2_ESC_CLK] = &dsi2_esc_clk.clkr,
        [ROT_SRC] = &rot_src.clkr,
        [ROT_CLK] = &rot_clk.clkr,
        [TV_DAC_CLK] = &tv_dac_clk.clkr,
@@ -2516,6 +2921,8 @@ static struct clk_regmap *mmcc_apq8064_clks[] = {
        [VFE_CSI_CLK] = &vfe_csi_clk.clkr,
        [VPE_SRC] = &vpe_src.clkr,
        [VPE_CLK] = &vpe_clk.clkr,
+       [DSI_PIXEL_SRC] = &dsi1_pixel_src.clkr,
+       [DSI_PIXEL_CLK] = &dsi1_pixel_clk.clkr,
        [CAMCLK0_SRC] = &camclk0_src.clkr,
        [CAMCLK0_CLK] = &camclk0_clk.clkr,
        [CAMCLK1_SRC] = &camclk1_src.clkr,
@@ -2683,15 +3090,8 @@ static int mmcc_msm8960_probe(struct platform_device *pdev)
        return qcom_cc_really_probe(pdev, match->data, regmap);
 }
 
-static int mmcc_msm8960_remove(struct platform_device *pdev)
-{
-       qcom_cc_remove(pdev);
-       return 0;
-}
-
 static struct platform_driver mmcc_msm8960_driver = {
        .probe          = mmcc_msm8960_probe,
-       .remove         = mmcc_msm8960_remove,
        .driver         = {
                .name   = "mmcc-msm8960",
                .of_match_table = mmcc_msm8960_match_table,