瀏覽代碼

clk: versatile: mask VCO bits before writing

The Versatile syscon ICST driver OR:s the bits into place but
forgets to mask the previous value, making the code only work
if the register is zero or giving haphazard results. Mask the
19 bits used by the Versatile syscon interface register.

Regression caused and now fixed by yours truly.

Cc: Michael Turquette <mturquette@baylibre.com>
Cc: Stephen Boyd <sboyd@codeaurora.org>
Cc: linux-clk@vger.kernel.org
Fixes: 179c8fb3c2a6 ("clk: versatile-icst: convert to use regmap")
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Stephen Boyd <sboyd@codeaurora.org>
Linus Walleij 10 年之前
父節點
當前提交
df9cd56421
共有 1 個文件被更改,包括 3 次插入0 次删除
  1. 3 0
      drivers/clk/versatile/clk-icst.c

+ 3 - 0
drivers/clk/versatile/clk-icst.c

@@ -78,6 +78,9 @@ static int vco_set(struct clk_icst *icst, struct icst_vco vco)
 	ret = regmap_read(icst->map, icst->vcoreg_off, &val);
 	ret = regmap_read(icst->map, icst->vcoreg_off, &val);
 	if (ret)
 	if (ret)
 		return ret;
 		return ret;
+
+	/* Mask the 18 bits used by the VCO */
+	val &= ~0x7ffff;
 	val |= vco.v | (vco.r << 9) | (vco.s << 16);
 	val |= vco.v | (vco.r << 9) | (vco.s << 16);
 
 
 	/* This magic unlocks the VCO so it can be controlled */
 	/* This magic unlocks the VCO so it can be controlled */