On 01/18/2018 07:05 AM, Sekhar Nori wrote:
On Monday 08 January 2018 07:47 AM, David Lechner wrote:

+static int da8xx_usb1_phy_clk_set_parent(struct clk_hw *hw, u8 index)
+{
+       struct da8xx_usb1_phy_clk *clk = to_da8xx_usb1_phy_clk(hw);
+       unsigned int mask, val;
+
+       /* Set the USB 1.1 PHY clock mux based on the parent clock. */
+       mask = CFGCHIP2_USB1PHYCLKMUX;
+       switch (index) {
+       case DA8XX_USB1_PHY_CLK_PARENT_USB_REFCLKIN:
+               val = CFGCHIP2_USB1PHYCLKMUX;
+               break;
+       case DA8XX_USB1_PHY_CLK_PARENT_USB0_PHY_PLL:
+               val = 0;
+               break;
+       default:
+               return -EINVAL;
+       }
+
+       regmap_write_bits(clk->regmap, CFGCHIP(2), mask, val);

This function can be simplified quite a bit if you use a shift.

#define CFGCHIP2_USB1PHYCLKMUX_SHIFT    12

static int da8xx_usb1_phy_clk_set_parent(struct clk_hw *hw, u8 index)
{
        struct da8xx_usb1_phy_clk *clk = to_da8xx_usb1_phy_clk(hw);

        regmap_write_bits(clk->regmap, CFGCHIP(2),
                          CFGCHIP2_USB1PHYCLKMUX,
                          index << CFGCHIP2_USB1PHYCLKMUX_SHIFT);
}

Same thing for da8xx_usb0_phy_clk_set_parent() as well.


or to avoid defining a new macro?


        regmap_write_bits(clk->regmap, CFGCHIP(2),
                          CFGCHIP2_USB1PHYCLKMUX,
                          index ? CFGCHIP2_USB1PHYCLKMUX : 0);

Reply via email to