On 09/22, Jisheng Zhang wrote:
> +
> +static u8 clk_div[] = {1, 2, 4, 6, 8, 12, 1, 1};
> +
> +static unsigned long berlin_clk_recalc_rate(struct clk_hw *hw,
> +                                     unsigned long parent_rate)
> +{
> +     u32 val, divider;
> +     struct berlin_clk *clk = to_berlin_clk(hw);
> +
> +     val = readl_relaxed(clk->base);
> +     if (val & CLKD3SWITCH)
> +             divider = 3;
> +     else {
> +             if (val & CLKSWITCH) {
> +                     val >>= CLKSEL_SHIFT;
> +                     val &= CLKSEL_MASK;
> +                     divider = clk_div[val];
> +             } else
> +                     divider = 1;
> +     }

How about we drop the clk_div array and use code?

                if (val & CLKSWITCH) {
                        val >>= CLKSEL_SHIFT;
                        val &= CLKSEL_MASK;
                }

                divider = 1
                if (val < 6)
                        divider <<= val;

> +
> +     return parent_rate / divider;
> +}

-- 
Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum,
a Linux Foundation Collaborative Project
--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to