aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/media/dvb/frontends/lgh06xf.c43
1 files changed, 19 insertions, 24 deletions
diff --git a/drivers/media/dvb/frontends/lgh06xf.c b/drivers/media/dvb/frontends/lgh06xf.c
index badbea8ad821..2202d0cc878b 100644
--- a/drivers/media/dvb/frontends/lgh06xf.c
+++ b/drivers/media/dvb/frontends/lgh06xf.c
@@ -40,19 +40,23 @@ static int lgh06xf_set_params(struct dvb_frontend* fe,
40 u8 buf[4]; 40 u8 buf[4];
41 struct i2c_msg msg = { .addr = LG_H06XF_PLL_I2C_ADDR, .flags = 0, 41 struct i2c_msg msg = { .addr = LG_H06XF_PLL_I2C_ADDR, .flags = 0,
42 .buf = buf, .len = sizeof(buf) }; 42 .buf = buf, .len = sizeof(buf) };
43 u32 div; 43 u32 frequency;
44 int i; 44 int result;
45 int err; 45
46 if ((result = dvb_pll_configure(&dvb_pll_lg_tdvs_h06xf, buf,
47 params->frequency, 0)) < 0)
48 return result;
49 else
50 frequency = result;
46 51
47 dvb_pll_configure(&dvb_pll_lg_tdvs_h06xf, buf, params->frequency, 0);
48 if (fe->ops.i2c_gate_ctrl) 52 if (fe->ops.i2c_gate_ctrl)
49 fe->ops.i2c_gate_ctrl(fe, 1); 53 fe->ops.i2c_gate_ctrl(fe, 1);
50 if ((err = i2c_transfer(priv->i2c, &msg, 1)) != 1) { 54 if ((result = i2c_transfer(priv->i2c, &msg, 1)) != 1) {
51 printk(KERN_WARNING "lgh06xf: %s error " 55 printk(KERN_WARNING "lgh06xf: %s error "
52 "(addr %02x <- %02x, err = %i)\n", 56 "(addr %02x <- %02x, result = %i)\n",
53 __FUNCTION__, buf[0], buf[1], err); 57 __FUNCTION__, buf[0], buf[1], result);
54 if (err < 0) 58 if (result < 0)
55 return err; 59 return result;
56 else 60 else
57 return -EREMOTEIO; 61 return -EREMOTEIO;
58 } 62 }
@@ -65,26 +69,17 @@ static int lgh06xf_set_params(struct dvb_frontend* fe,
65 msg.len = 2; 69 msg.len = 2;
66 if (fe->ops.i2c_gate_ctrl) 70 if (fe->ops.i2c_gate_ctrl)
67 fe->ops.i2c_gate_ctrl(fe, 1); 71 fe->ops.i2c_gate_ctrl(fe, 1);
68 if ((err = i2c_transfer(priv->i2c, &msg, 1)) != 1) { 72 if ((result = i2c_transfer(priv->i2c, &msg, 1)) != 1) {
69 printk(KERN_WARNING "lgh06xf: %s error " 73 printk(KERN_WARNING "lgh06xf: %s error "
70 "(addr %02x <- %02x, err = %i)\n", 74 "(addr %02x <- %02x, result = %i)\n",
71 __FUNCTION__, buf[0], buf[1], err); 75 __FUNCTION__, buf[0], buf[1], result);
72 if (err < 0) 76 if (result < 0)
73 return err; 77 return result;
74 else 78 else
75 return -EREMOTEIO; 79 return -EREMOTEIO;
76 } 80 }
77 81
78 // calculate the frequency we set it to 82 priv->frequency = frequency;
79 for (i = 0; i < dvb_pll_lg_tdvs_h06xf.count; i++) {
80 if (params->frequency > dvb_pll_lg_tdvs_h06xf.entries[i].limit)
81 continue;
82 break;
83 }
84 div = (params->frequency + dvb_pll_lg_tdvs_h06xf.entries[i].offset) /
85 dvb_pll_lg_tdvs_h06xf.entries[i].stepsize;
86 priv->frequency = (div * dvb_pll_lg_tdvs_h06xf.entries[i].stepsize) -
87 dvb_pll_lg_tdvs_h06xf.entries[i].offset;
88 83
89 return 0; 84 return 0;
90} 85}