diff options
author | Mikko Perttunen <mikko.perttunen@kapsi.fi> | 2015-09-15 05:55:15 -0400 |
---|---|---|
committer | Thierry Reding <treding@nvidia.com> | 2015-09-15 06:54:39 -0400 |
commit | 10d9be6ebe9199feb7680433a24b564a31a8f9b1 (patch) | |
tree | 16a3843c12fcd7c9e9dc75ee49dd57dd525fc650 | |
parent | 6ff33f3902c3b1c5d0db6b1e2c70b6d76fba357f (diff) |
clk: tegra: Unlock top rates for Tegra124 DFLL clock
The new determine_rate prototype allows for clock rates exceeding
2^31-1 Hz to be used. Switch the DFLL clock to use determine_rate
instead of round_rate and unlock the top rates supported by the
Tegra124.
Signed-off-by: Mikko Perttunen <mikko.perttunen@kapsi.fi>
Signed-off-by: Thierry Reding <treding@nvidia.com>
-rw-r--r-- | drivers/clk/tegra/clk-dfll.c | 15 | ||||
-rw-r--r-- | drivers/clk/tegra/cvb.c | 7 |
2 files changed, 8 insertions, 14 deletions
diff --git a/drivers/clk/tegra/clk-dfll.c b/drivers/clk/tegra/clk-dfll.c index c2ff859ee0e8..6a75a7482b08 100644 --- a/drivers/clk/tegra/clk-dfll.c +++ b/drivers/clk/tegra/clk-dfll.c | |||
@@ -1000,24 +1000,25 @@ static unsigned long dfll_clk_recalc_rate(struct clk_hw *hw, | |||
1000 | return td->last_unrounded_rate; | 1000 | return td->last_unrounded_rate; |
1001 | } | 1001 | } |
1002 | 1002 | ||
1003 | static long dfll_clk_round_rate(struct clk_hw *hw, | 1003 | /* Must use determine_rate since it allows for rates exceeding 2^31-1 */ |
1004 | unsigned long rate, | 1004 | static int dfll_clk_determine_rate(struct clk_hw *hw, |
1005 | unsigned long *parent_rate) | 1005 | struct clk_rate_request *clk_req) |
1006 | { | 1006 | { |
1007 | struct tegra_dfll *td = clk_hw_to_dfll(hw); | 1007 | struct tegra_dfll *td = clk_hw_to_dfll(hw); |
1008 | struct dfll_rate_req req; | 1008 | struct dfll_rate_req req; |
1009 | int ret; | 1009 | int ret; |
1010 | 1010 | ||
1011 | ret = dfll_calculate_rate_request(td, &req, rate); | 1011 | ret = dfll_calculate_rate_request(td, &req, clk_req->rate); |
1012 | if (ret) | 1012 | if (ret) |
1013 | return ret; | 1013 | return ret; |
1014 | 1014 | ||
1015 | /* | 1015 | /* |
1016 | * Don't return the rounded rate, since it doesn't really matter as | 1016 | * Don't set the rounded rate, since it doesn't really matter as |
1017 | * the output rate will be voltage controlled anyway, and cpufreq | 1017 | * the output rate will be voltage controlled anyway, and cpufreq |
1018 | * freaks out if any rounding happens. | 1018 | * freaks out if any rounding happens. |
1019 | */ | 1019 | */ |
1020 | return rate; | 1020 | |
1021 | return 0; | ||
1021 | } | 1022 | } |
1022 | 1023 | ||
1023 | static int dfll_clk_set_rate(struct clk_hw *hw, unsigned long rate, | 1024 | static int dfll_clk_set_rate(struct clk_hw *hw, unsigned long rate, |
@@ -1033,7 +1034,7 @@ static const struct clk_ops dfll_clk_ops = { | |||
1033 | .enable = dfll_clk_enable, | 1034 | .enable = dfll_clk_enable, |
1034 | .disable = dfll_clk_disable, | 1035 | .disable = dfll_clk_disable, |
1035 | .recalc_rate = dfll_clk_recalc_rate, | 1036 | .recalc_rate = dfll_clk_recalc_rate, |
1036 | .round_rate = dfll_clk_round_rate, | 1037 | .determine_rate = dfll_clk_determine_rate, |
1037 | .set_rate = dfll_clk_set_rate, | 1038 | .set_rate = dfll_clk_set_rate, |
1038 | }; | 1039 | }; |
1039 | 1040 | ||
diff --git a/drivers/clk/tegra/cvb.c b/drivers/clk/tegra/cvb.c index 0204e0861134..69c74eec3a4b 100644 --- a/drivers/clk/tegra/cvb.c +++ b/drivers/clk/tegra/cvb.c | |||
@@ -78,13 +78,6 @@ static int build_opp_table(const struct cvb_table *d, | |||
78 | if (!table->freq || (table->freq > max_freq)) | 78 | if (!table->freq || (table->freq > max_freq)) |
79 | break; | 79 | break; |
80 | 80 | ||
81 | /* | ||
82 | * FIXME after clk_round_rate/clk_determine_rate prototypes | ||
83 | * have been updated | ||
84 | */ | ||
85 | if (table->freq & (1<<31)) | ||
86 | continue; | ||
87 | |||
88 | dfll_mv = get_cvb_voltage( | 81 | dfll_mv = get_cvb_voltage( |
89 | speedo_value, d->speedo_scale, &table->coefficients); | 82 | speedo_value, d->speedo_scale, &table->coefficients); |
90 | dfll_mv = round_cvb_voltage(dfll_mv, d->voltage_scale, align); | 83 | dfll_mv = round_cvb_voltage(dfll_mv, d->voltage_scale, align); |