diff options
author | Boris BREZILLON <b.brezillon@overkiz.com> | 2013-12-21 04:34:47 -0500 |
---|---|---|
committer | Mike Turquette <mturquette@linaro.org> | 2013-12-23 02:14:27 -0500 |
commit | 5279fc402ae59361a224d641d5823b21b4206232 (patch) | |
tree | 0d6ab9695d994cedc85c32b08f6e8d211acf4207 /Documentation | |
parent | e8ab2f11bb8fa73280ce7d0fca3c22be456437df (diff) |
clk: add clk accuracy retrieval support
The clock accuracy is expressed in ppb (parts per billion) and represents
the possible clock drift.
Say you have a clock (e.g. an oscillator) which provides a fixed clock of
20MHz with an accuracy of +- 20Hz. This accuracy expressed in ppb is
20Hz/20MHz = 1000 ppb (or 1 ppm).
Clock users may need the clock accuracy information in order to choose
the best clock (the one with the best accuracy) across several available
clocks.
This patch adds clk accuracy retrieval support for common clk framework by
means of a new function called clk_get_accuracy.
This function returns the given clock accuracy expressed in ppb.
In order to get the clock accuracy, this implementation adds one callback
called recalc_accuracy to the clk_ops structure.
This callback is given the parent clock accuracy (if the clock is not a
root clock) and should recalculate the given clock accuracy.
This callback is optional and may be implemented if the clock is not
a perfect clock (accuracy != 0 ppb).
Signed-off-by: Boris BREZILLON <b.brezillon@overkiz.com>
Signed-off-by: Mike Turquette <mturquette@linaro.org>
Diffstat (limited to 'Documentation')
-rw-r--r-- | Documentation/clk.txt | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/Documentation/clk.txt b/Documentation/clk.txt index 3aeb5c440442..eb20198783cd 100644 --- a/Documentation/clk.txt +++ b/Documentation/clk.txt | |||
@@ -77,6 +77,8 @@ the operations defined in clk.h: | |||
77 | int (*set_parent)(struct clk_hw *hw, u8 index); | 77 | int (*set_parent)(struct clk_hw *hw, u8 index); |
78 | u8 (*get_parent)(struct clk_hw *hw); | 78 | u8 (*get_parent)(struct clk_hw *hw); |
79 | int (*set_rate)(struct clk_hw *hw, unsigned long); | 79 | int (*set_rate)(struct clk_hw *hw, unsigned long); |
80 | unsigned long (*recalc_accuracy)(struct clk_hw *hw, | ||
81 | unsigned long parent_accuracy); | ||
80 | void (*init)(struct clk_hw *hw); | 82 | void (*init)(struct clk_hw *hw); |
81 | }; | 83 | }; |
82 | 84 | ||
@@ -202,6 +204,8 @@ optional or must be evaluated on a case-by-case basis. | |||
202 | .set_parent | | | n | y | n | | 204 | .set_parent | | | n | y | n | |
203 | .get_parent | | | n | y | n | | 205 | .get_parent | | | n | y | n | |
204 | | | | | | | | 206 | | | | | | | |
207 | .recalc_accuracy| | | | | | | ||
208 | | | | | | | | ||
205 | .init | | | | | | | 209 | .init | | | | | | |
206 | ----------------------------------------------------------- | 210 | ----------------------------------------------------------- |
207 | [1] either one of round_rate or determine_rate is required. | 211 | [1] either one of round_rate or determine_rate is required. |