OSDN Git Service

[media] au0828: explicitly identify boards with analog TV
authorMauro Carvalho Chehab <m.chehab@samsung.com>
Mon, 18 Aug 2014 11:51:28 +0000 (08:51 -0300)
committerMauro Carvalho Chehab <mchehab@osg.samsung.com>
Mon, 22 Sep 2014 20:51:19 +0000 (17:51 -0300)
Right now, the au0828 driver uses .tuner to detect if analog
tv is being used or not. By not filling .tuner fields at the
board struct, the I2C core can't do decisions based on it.

So, add a field to explicitly tell when analog TV is supported.

No functional changes.

Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
drivers/media/usb/au0828/au0828-cards.c
drivers/media/usb/au0828/au0828.h

index 585a8f8..9fd3c4b 100644 (file)
@@ -47,6 +47,7 @@ struct au0828_board au0828_boards[] = {
                .tuner_type = TUNER_XC5000,
                .tuner_addr = 0x61,
                .has_ir_i2c = 1,
+               .has_analog = 1,
                .i2c_clk_divider = AU0828_I2C_CLK_250KHZ,
                .input = {
                        {
@@ -73,6 +74,7 @@ struct au0828_board au0828_boards[] = {
                .tuner_type = TUNER_XC5000,
                .tuner_addr = 0x61,
                .has_ir_i2c = 1,
+               .has_analog = 1,
                .i2c_clk_divider = AU0828_I2C_CLK_250KHZ,
                .input = {
                        {
@@ -226,7 +228,7 @@ void au0828_card_analog_fe_setup(struct au0828_dev *dev)
        }
 
        /* Setup tuners */
-       if (dev->board.tuner_type != TUNER_ABSENT) {
+       if (dev->board.tuner_type != TUNER_ABSENT && dev->board.has_analog) {
                /* Load the tuner module, which does the attach */
                sd = v4l2_i2c_new_subdev(&dev->v4l2_dev, &dev->i2c_adap,
                                "tuner", dev->board.tuner_addr, NULL);
index a7cc6e3..36815a3 100644 (file)
@@ -90,6 +90,7 @@ struct au0828_board {
        unsigned char tuner_addr;
        unsigned char i2c_clk_divider;
        unsigned char has_ir_i2c:1;
+       unsigned char has_analog:1;
        struct au0828_input input[AU0828_MAX_INPUT];
 
 };