Commit 01874fb2 authored by Lars-Peter Clausen's avatar Lars-Peter Clausen Committed by Stephen Boyd

clk: vc5: Use regmap_{set,clear}_bits() where appropriate

regmap_set_bits() and regmap_clear_bits() are variations of
regmap_update_bits() that can be used if all bits of the mask have to be
set to either 1 or 0 respectively.

Update the versaclk driver to use regmap_set_bits() and regmap_clear_bits()
where appropriate. This results in slightly more compact code and also
makes the intention of the code clearer which can help with review.
Signed-off-by: default avatarLars-Peter Clausen <lars@metafoo.de>
Link: https://lore.kernel.org/r/20220719094637.844946-2-lars@metafoo.deReviewed-by: default avatarLuca Ceresoli <luca@lucaceresoli.net>
Signed-off-by: default avatarStephen Boyd <sboyd@kernel.org>
parent cc323782
...@@ -392,9 +392,8 @@ static int vc5_pfd_set_rate(struct clk_hw *hw, unsigned long rate, ...@@ -392,9 +392,8 @@ static int vc5_pfd_set_rate(struct clk_hw *hw, unsigned long rate,
/* CLKIN within range of PLL input, feed directly to PLL. */ /* CLKIN within range of PLL input, feed directly to PLL. */
if (parent_rate <= 50000000) { if (parent_rate <= 50000000) {
ret = regmap_update_bits(vc5->regmap, VC5_VCO_CTRL_AND_PREDIV, ret = regmap_set_bits(vc5->regmap, VC5_VCO_CTRL_AND_PREDIV,
VC5_VCO_CTRL_AND_PREDIV_BYPASS_PREDIV, VC5_VCO_CTRL_AND_PREDIV_BYPASS_PREDIV);
VC5_VCO_CTRL_AND_PREDIV_BYPASS_PREDIV);
if (ret) if (ret)
return ret; return ret;
...@@ -413,8 +412,8 @@ static int vc5_pfd_set_rate(struct clk_hw *hw, unsigned long rate, ...@@ -413,8 +412,8 @@ static int vc5_pfd_set_rate(struct clk_hw *hw, unsigned long rate,
if (ret) if (ret)
return ret; return ret;
return regmap_update_bits(vc5->regmap, VC5_VCO_CTRL_AND_PREDIV, return regmap_clear_bits(vc5->regmap, VC5_VCO_CTRL_AND_PREDIV,
VC5_VCO_CTRL_AND_PREDIV_BYPASS_PREDIV, 0); VC5_VCO_CTRL_AND_PREDIV_BYPASS_PREDIV);
} }
static const struct clk_ops vc5_pfd_ops = { static const struct clk_ops vc5_pfd_ops = {
...@@ -579,14 +578,13 @@ static int vc5_fod_set_rate(struct clk_hw *hw, unsigned long rate, ...@@ -579,14 +578,13 @@ static int vc5_fod_set_rate(struct clk_hw *hw, unsigned long rate,
* datasheet somewhat implies this is needed, but the register * datasheet somewhat implies this is needed, but the register
* and the bit is not documented. * and the bit is not documented.
*/ */
ret = regmap_update_bits(vc5->regmap, VC5_GLOBAL_REGISTER, ret = regmap_clear_bits(vc5->regmap, VC5_GLOBAL_REGISTER,
VC5_GLOBAL_REGISTER_GLOBAL_RESET, 0); VC5_GLOBAL_REGISTER_GLOBAL_RESET);
if (ret) if (ret)
return ret; return ret;
return regmap_update_bits(vc5->regmap, VC5_GLOBAL_REGISTER, return regmap_set_bits(vc5->regmap, VC5_GLOBAL_REGISTER,
VC5_GLOBAL_REGISTER_GLOBAL_RESET, VC5_GLOBAL_REGISTER_GLOBAL_RESET);
VC5_GLOBAL_REGISTER_GLOBAL_RESET);
} }
static const struct clk_ops vc5_fod_ops = { static const struct clk_ops vc5_fod_ops = {
...@@ -614,10 +612,9 @@ static int vc5_clk_out_prepare(struct clk_hw *hw) ...@@ -614,10 +612,9 @@ static int vc5_clk_out_prepare(struct clk_hw *hw)
* registers. * registers.
*/ */
if (vc5->chip_info->flags & VC5_HAS_BYPASS_SYNC_BIT) { if (vc5->chip_info->flags & VC5_HAS_BYPASS_SYNC_BIT) {
ret = regmap_update_bits(vc5->regmap, ret = regmap_set_bits(vc5->regmap,
VC5_RESERVED_X0(hwdata->num), VC5_RESERVED_X0(hwdata->num),
VC5_RESERVED_X0_BYPASS_SYNC, VC5_RESERVED_X0_BYPASS_SYNC);
VC5_RESERVED_X0_BYPASS_SYNC);
if (ret) if (ret)
return ret; return ret;
} }
...@@ -640,10 +637,8 @@ static int vc5_clk_out_prepare(struct clk_hw *hw) ...@@ -640,10 +637,8 @@ static int vc5_clk_out_prepare(struct clk_hw *hw)
} }
/* Enable the clock buffer */ /* Enable the clock buffer */
ret = regmap_update_bits(vc5->regmap, ret = regmap_set_bits(vc5->regmap, VC5_CLK_OUTPUT_CFG(hwdata->num, 1),
VC5_CLK_OUTPUT_CFG(hwdata->num, 1), VC5_CLK_OUTPUT_CFG1_EN_CLKBUF);
VC5_CLK_OUTPUT_CFG1_EN_CLKBUF,
VC5_CLK_OUTPUT_CFG1_EN_CLKBUF);
if (ret) if (ret)
return ret; return ret;
...@@ -669,8 +664,8 @@ static void vc5_clk_out_unprepare(struct clk_hw *hw) ...@@ -669,8 +664,8 @@ static void vc5_clk_out_unprepare(struct clk_hw *hw)
struct vc5_driver_data *vc5 = hwdata->vc5; struct vc5_driver_data *vc5 = hwdata->vc5;
/* Disable the clock buffer */ /* Disable the clock buffer */
regmap_update_bits(vc5->regmap, VC5_CLK_OUTPUT_CFG(hwdata->num, 1), regmap_clear_bits(vc5->regmap, VC5_CLK_OUTPUT_CFG(hwdata->num, 1),
VC5_CLK_OUTPUT_CFG1_EN_CLKBUF, 0); VC5_CLK_OUTPUT_CFG1_EN_CLKBUF);
} }
static unsigned char vc5_clk_out_get_parent(struct clk_hw *hw) static unsigned char vc5_clk_out_get_parent(struct clk_hw *hw)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment