aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMikko Perttunen <mikko.perttunen@kapsi.fi>2015-09-15 05:55:15 -0400
committerThierry Reding <treding@nvidia.com>2015-09-15 06:54:39 -0400
commit10d9be6ebe9199feb7680433a24b564a31a8f9b1 (patch)
tree16a3843c12fcd7c9e9dc75ee49dd57dd525fc650
parent6ff33f3902c3b1c5d0db6b1e2c70b6d76fba357f (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.c15
-rw-r--r--drivers/clk/tegra/cvb.c7
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
1003static 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, 1004static 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
1023static int dfll_clk_set_rate(struct clk_hw *hw, unsigned long rate, 1024static 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);