aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/media/dvb/frontends/Makefile1
-rw-r--r--drivers/media/dvb/frontends/tda18271.c33
2 files changed, 26 insertions, 8 deletions
diff --git a/drivers/media/dvb/frontends/Makefile b/drivers/media/dvb/frontends/Makefile
index 457effcda5da..57e5fa80589b 100644
--- a/drivers/media/dvb/frontends/Makefile
+++ b/drivers/media/dvb/frontends/Makefile
@@ -3,6 +3,7 @@
3# 3#
4 4
5EXTRA_CFLAGS += -Idrivers/media/dvb/dvb-core/ 5EXTRA_CFLAGS += -Idrivers/media/dvb/dvb-core/
6EXTRA_CFLAGS += -Idrivers/media/video/
6 7
7obj-$(CONFIG_DVB_PLL) += dvb-pll.o 8obj-$(CONFIG_DVB_PLL) += dvb-pll.o
8obj-$(CONFIG_DVB_STV0299) += stv0299.o 9obj-$(CONFIG_DVB_STV0299) += stv0299.o
diff --git a/drivers/media/dvb/frontends/tda18271.c b/drivers/media/dvb/frontends/tda18271.c
index 1b9c143888ea..aaaa2f885186 100644
--- a/drivers/media/dvb/frontends/tda18271.c
+++ b/drivers/media/dvb/frontends/tda18271.c
@@ -21,6 +21,7 @@
21#include <linux/i2c.h> 21#include <linux/i2c.h>
22#include <linux/delay.h> 22#include <linux/delay.h>
23#include <linux/videodev2.h> 23#include <linux/videodev2.h>
24#include "tuner-driver.h"
24 25
25#include "tda18271.h" 26#include "tda18271.h"
26 27
@@ -324,6 +325,26 @@ struct tda18271_priv {
324 u32 bandwidth; 325 u32 bandwidth;
325}; 326};
326 327
328static int tda18271_i2c_gate_ctrl(struct dvb_frontend *fe, int enable)
329{
330 struct tda18271_priv *priv = fe->tuner_priv;
331 struct analog_tuner_ops *ops = fe->ops.analog_demod_ops;
332 int ret = 0;
333
334 switch (priv->mode) {
335 case TDA18271_ANALOG:
336 if (ops && ops->i2c_gate_ctrl)
337 ret = ops->i2c_gate_ctrl(fe, enable);
338 break;
339 case TDA18271_DIGITAL:
340 if (fe->ops.i2c_gate_ctrl)
341 ret = fe->ops.i2c_gate_ctrl(fe, enable);
342 break;
343 }
344
345 return ret;
346};
347
327/*---------------------------------------------------------------------*/ 348/*---------------------------------------------------------------------*/
328 349
329static void tda18271_dump_regs(struct dvb_frontend *fe) 350static void tda18271_dump_regs(struct dvb_frontend *fe)
@@ -363,14 +384,12 @@ static void tda18271_read_regs(struct dvb_frontend *fe)
363 .buf = regs, .len = 16 } 384 .buf = regs, .len = 16 }
364 }; 385 };
365 386
366 if (fe->ops.i2c_gate_ctrl) 387 tda18271_i2c_gate_ctrl(fe, 1);
367 fe->ops.i2c_gate_ctrl(fe, 1);
368 388
369 /* read all registers */ 389 /* read all registers */
370 ret = i2c_transfer(priv->i2c_adap, msg, 2); 390 ret = i2c_transfer(priv->i2c_adap, msg, 2);
371 391
372 if (fe->ops.i2c_gate_ctrl) 392 tda18271_i2c_gate_ctrl(fe, 0);
373 fe->ops.i2c_gate_ctrl(fe, 0);
374 393
375 if (ret != 2) 394 if (ret != 2)
376 printk("ERROR: %s: i2c_transfer returned: %d\n", 395 printk("ERROR: %s: i2c_transfer returned: %d\n",
@@ -396,14 +415,12 @@ static void tda18271_write_regs(struct dvb_frontend *fe, int idx, int len)
396 buf[i] = regs[idx-1+i]; 415 buf[i] = regs[idx-1+i];
397 } 416 }
398 417
399 if (fe->ops.i2c_gate_ctrl) 418 tda18271_i2c_gate_ctrl(fe, 1);
400 fe->ops.i2c_gate_ctrl(fe, 1);
401 419
402 /* write registers */ 420 /* write registers */
403 ret = i2c_transfer(priv->i2c_adap, &msg, 1); 421 ret = i2c_transfer(priv->i2c_adap, &msg, 1);
404 422
405 if (fe->ops.i2c_gate_ctrl) 423 tda18271_i2c_gate_ctrl(fe, 0);
406 fe->ops.i2c_gate_ctrl(fe, 0);
407 424
408 if (ret != 1) 425 if (ret != 1)
409 printk(KERN_WARNING "ERROR: %s: i2c_transfer returned: %d\n", 426 printk(KERN_WARNING "ERROR: %s: i2c_transfer returned: %d\n",