Commit 8845cc64 authored by Antti Palosaari's avatar Antti Palosaari Committed by Mauro Carvalho Chehab

[media] fc2580: fix tuning failure on 32-bit arch

There was some frequency calculation overflows which caused tuning
failure on 32-bit architecture. Use 64-bit numbers where needed in
order to avoid calculation overflows.

Thanks for the Finnish person, who asked remain anonymous, reporting,
testing and suggesting the fix.

Cc: <stable@vger.kernel.org>
Signed-off-by: default avatarAntti Palosaari <crope@iki.fi>
Signed-off-by: default avatarMauro Carvalho Chehab <m.chehab@samsung.com>
parent 877ed143
...@@ -195,7 +195,7 @@ static int fc2580_set_params(struct dvb_frontend *fe) ...@@ -195,7 +195,7 @@ static int fc2580_set_params(struct dvb_frontend *fe)
f_ref = 2UL * priv->cfg->clock / r_val; f_ref = 2UL * priv->cfg->clock / r_val;
n_val = div_u64_rem(f_vco, f_ref, &k_val); n_val = div_u64_rem(f_vco, f_ref, &k_val);
k_val_reg = 1UL * k_val * (1 << 20) / f_ref; k_val_reg = div_u64(1ULL * k_val * (1 << 20), f_ref);
ret = fc2580_wr_reg(priv, 0x18, r18_val | ((k_val_reg >> 16) & 0xff)); ret = fc2580_wr_reg(priv, 0x18, r18_val | ((k_val_reg >> 16) & 0xff));
if (ret < 0) if (ret < 0)
...@@ -348,8 +348,8 @@ static int fc2580_set_params(struct dvb_frontend *fe) ...@@ -348,8 +348,8 @@ static int fc2580_set_params(struct dvb_frontend *fe)
if (ret < 0) if (ret < 0)
goto err; goto err;
ret = fc2580_wr_reg(priv, 0x37, 1UL * priv->cfg->clock * \ ret = fc2580_wr_reg(priv, 0x37, div_u64(1ULL * priv->cfg->clock *
fc2580_if_filter_lut[i].mul / 1000000000); fc2580_if_filter_lut[i].mul, 1000000000));
if (ret < 0) if (ret < 0)
goto err; goto err;
......
...@@ -22,6 +22,7 @@ ...@@ -22,6 +22,7 @@
#define FC2580_PRIV_H #define FC2580_PRIV_H
#include "fc2580.h" #include "fc2580.h"
#include <linux/math64.h>
struct fc2580_reg_val { struct fc2580_reg_val {
u8 reg; u8 reg;
......
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