Commit c582935c authored by Tomi Valkeinen's avatar Tomi Valkeinen

OMAPDSS: DISPC: fix 64 bit issue in 5-tap

The DISPC driver uses 64 bit arithmetic to calculate the required clock
rate for scaling. The code does not seem to work correctly, and instead
calculates with 32 bit numbers, giving wrong result.

Fix the code by typecasting values to u64 first, so that the
calculations do happen in 64 bits.
Signed-off-by: default avatarTomi Valkeinen <tomi.valkeinen@ti.com>
parent f2aee319
...@@ -2166,7 +2166,7 @@ static unsigned long calc_core_clk_five_taps(unsigned long pclk, ...@@ -2166,7 +2166,7 @@ static unsigned long calc_core_clk_five_taps(unsigned long pclk,
if (height > out_height) { if (height > out_height) {
unsigned int ppl = mgr_timings->x_res; unsigned int ppl = mgr_timings->x_res;
tmp = pclk * height * out_width; tmp = (u64)pclk * height * out_width;
do_div(tmp, 2 * out_height * ppl); do_div(tmp, 2 * out_height * ppl);
core_clk = tmp; core_clk = tmp;
...@@ -2174,14 +2174,14 @@ static unsigned long calc_core_clk_five_taps(unsigned long pclk, ...@@ -2174,14 +2174,14 @@ static unsigned long calc_core_clk_five_taps(unsigned long pclk,
if (ppl == out_width) if (ppl == out_width)
return 0; return 0;
tmp = pclk * (height - 2 * out_height) * out_width; tmp = (u64)pclk * (height - 2 * out_height) * out_width;
do_div(tmp, 2 * out_height * (ppl - out_width)); do_div(tmp, 2 * out_height * (ppl - out_width));
core_clk = max_t(u32, core_clk, tmp); core_clk = max_t(u32, core_clk, tmp);
} }
} }
if (width > out_width) { if (width > out_width) {
tmp = pclk * width; tmp = (u64)pclk * width;
do_div(tmp, out_width); do_div(tmp, out_width);
core_clk = max_t(u32, core_clk, tmp); core_clk = max_t(u32, core_clk, tmp);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment