aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDouglas Anderson <dianders@chromium.org>2015-09-30 10:07:38 -0400
committerUlf Hansson <ulf.hansson@linaro.org>2015-10-26 11:00:07 -0400
commit4351f19a337d48a780762d076408ebe9b0c1f945 (patch)
tree903abc321be44907394e9d399066126c2f0db5de
parentf0232063fb64fc79bfb7b6b35d611b2e4a79ffe6 (diff)
clk: rockchip: Make calculations use rounding
Let's use DIV_ROUND_CLOSEST for rounding, not just truncating division. This lets us get closer to the right rate. Before this: set_phase(86) delay_nums=26 reg[0xf000420c]=0x468 actual_degrees=83 set_phase(89) delay_nums=27 reg[0xf000420c]=0x46c actual_degrees=86 After this: set_phase(86) delay_nums=27 reg[0xf000420c]=0x46c actual_degrees=86 set_phase(89) delay_nums=28 reg[0xf000420c]=0x470 actual_degrees=90 Signed-off-by: Douglas Anderson <dianders@chromium.org> Signed-off-by: Heiko Stuebner <heiko@sntech.de> Acked-by: Stephen Boyd <sboyd@codeaurora.org> Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
-rw-r--r--drivers/clk/rockchip/clk-mmc-phase.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/drivers/clk/rockchip/clk-mmc-phase.c b/drivers/clk/rockchip/clk-mmc-phase.c
index a797d8625f6d..bc24e5a002e7 100644
--- a/drivers/clk/rockchip/clk-mmc-phase.c
+++ b/drivers/clk/rockchip/clk-mmc-phase.c
@@ -69,7 +69,7 @@ static int rockchip_mmc_get_phase(struct clk_hw *hw)
69 69
70 delay_num = (raw_value & ROCKCHIP_MMC_DELAYNUM_MASK); 70 delay_num = (raw_value & ROCKCHIP_MMC_DELAYNUM_MASK);
71 delay_num >>= ROCKCHIP_MMC_DELAYNUM_OFFSET; 71 delay_num >>= ROCKCHIP_MMC_DELAYNUM_OFFSET;
72 degrees += delay_num * factor / 10000; 72 degrees += DIV_ROUND_CLOSEST(delay_num * factor, 10000);
73 } 73 }
74 74
75 return degrees % 360; 75 return degrees % 360;
@@ -82,7 +82,7 @@ static int rockchip_mmc_set_phase(struct clk_hw *hw, int degrees)
82 u8 nineties, remainder; 82 u8 nineties, remainder;
83 u8 delay_num; 83 u8 delay_num;
84 u32 raw_value; 84 u32 raw_value;
85 u64 delay; 85 u32 delay;
86 86
87 nineties = degrees / 90; 87 nineties = degrees / 90;
88 remainder = (degrees % 90); 88 remainder = (degrees % 90);
@@ -110,12 +110,13 @@ static int rockchip_mmc_set_phase(struct clk_hw *hw, int degrees)
110 * Convert to delay; do a little extra work to make sure we 110 * Convert to delay; do a little extra work to make sure we
111 * don't overflow 32-bit / 64-bit numbers. 111 * don't overflow 32-bit / 64-bit numbers.
112 */ 112 */
113 delay = PSECS_PER_SEC; 113 delay = 10000000; /* PSECS_PER_SEC / 10000 / 10 */
114 delay *= remainder; 114 delay *= remainder;
115 do_div(delay, 10000); 115 delay = DIV_ROUND_CLOSEST(delay,
116 do_div(delay, (rate / 1000) * 36 * ROCKCHIP_MMC_DELAY_ELEMENT_PSEC); 116 (rate / 1000) * 36 *
117 (ROCKCHIP_MMC_DELAY_ELEMENT_PSEC / 10));
117 118
118 delay_num = (u8) min(delay, 255ULL); 119 delay_num = (u8) min_t(u32, delay, 255);
119 120
120 raw_value = delay_num ? ROCKCHIP_MMC_DELAY_SEL : 0; 121 raw_value = delay_num ? ROCKCHIP_MMC_DELAY_SEL : 0;
121 raw_value |= delay_num << ROCKCHIP_MMC_DELAYNUM_OFFSET; 122 raw_value |= delay_num << ROCKCHIP_MMC_DELAYNUM_OFFSET;