clk: add clk_core_set_phase_nolock function
Create a core function for set_phase, as it is done for set_rate and set_parent. This rework is done to ease the integration of "protected" clock functionality. Acked-by: Linus Walleij <linus.walleij@linaro.org> Tested-by: Quentin Schulz <quentin.schulz@free-electrons.com> Tested-by: Maxime Ripard <maxime.ripard@free-electrons.com> Acked-by: Michael Turquette <mturquette@baylibre.com> Signed-off-by: Jerome Brunet <jbrunet@baylibre.com> Signed-off-by: Michael Turquette <mturquette@baylibre.com> Link: lkml.kernel.org/r/20171201215200.23523-4-jbrunet@baylibre.com
This commit is contained in:
parent
91baa9ffe6
commit
9e4d04adeb
|
@ -1966,6 +1966,25 @@ int clk_set_parent(struct clk *clk, struct clk *parent)
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(clk_set_parent);
|
EXPORT_SYMBOL_GPL(clk_set_parent);
|
||||||
|
|
||||||
|
static int clk_core_set_phase_nolock(struct clk_core *core, int degrees)
|
||||||
|
{
|
||||||
|
int ret = -EINVAL;
|
||||||
|
|
||||||
|
lockdep_assert_held(&prepare_lock);
|
||||||
|
|
||||||
|
if (!core)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
trace_clk_set_phase(core, degrees);
|
||||||
|
|
||||||
|
if (core->ops->set_phase)
|
||||||
|
ret = core->ops->set_phase(core->hw, degrees);
|
||||||
|
|
||||||
|
trace_clk_set_phase_complete(core, degrees);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* clk_set_phase - adjust the phase shift of a clock signal
|
* clk_set_phase - adjust the phase shift of a clock signal
|
||||||
* @clk: clock signal source
|
* @clk: clock signal source
|
||||||
|
@ -1988,7 +2007,7 @@ EXPORT_SYMBOL_GPL(clk_set_parent);
|
||||||
*/
|
*/
|
||||||
int clk_set_phase(struct clk *clk, int degrees)
|
int clk_set_phase(struct clk *clk, int degrees)
|
||||||
{
|
{
|
||||||
int ret = -EINVAL;
|
int ret;
|
||||||
|
|
||||||
if (!clk)
|
if (!clk)
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -1999,17 +2018,7 @@ int clk_set_phase(struct clk *clk, int degrees)
|
||||||
degrees += 360;
|
degrees += 360;
|
||||||
|
|
||||||
clk_prepare_lock();
|
clk_prepare_lock();
|
||||||
|
ret = clk_core_set_phase_nolock(clk->core, degrees);
|
||||||
trace_clk_set_phase(clk->core, degrees);
|
|
||||||
|
|
||||||
if (clk->core->ops->set_phase)
|
|
||||||
ret = clk->core->ops->set_phase(clk->core->hw, degrees);
|
|
||||||
|
|
||||||
trace_clk_set_phase_complete(clk->core, degrees);
|
|
||||||
|
|
||||||
if (!ret)
|
|
||||||
clk->core->phase = degrees;
|
|
||||||
|
|
||||||
clk_prepare_unlock();
|
clk_prepare_unlock();
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
|
Loading…
Reference in New Issue