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:
Jerome Brunet 2017-12-01 22:51:53 +01:00 committed by Michael Turquette
parent 91baa9ffe6
commit 9e4d04adeb
1 changed files with 21 additions and 12 deletions

View File

@ -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;