int i, tuner_freq, if_freq;
        u32 N;
 
-       dprintk("%s:\n", __FUNCTION__);
+       dprintk("%s:\n", __func__);
        switch (params->u.ofdm.bandwidth) {
        case BANDWIDTH_6_MHZ:
                if_freq = 4000000;
                fe->ops.i2c_gate_ctrl(fe, 1);
        if (i2c_transfer(priv->i2c_adap, &msg, 1) != 1) {
                printk("%s: could not write to tuner at addr: 0x%02x\n",
-                      __FUNCTION__, priv->i2c_addr << 1);
+                      __func__, priv->i2c_addr << 1);
                return -EIO;
        }
        msleep(500);
        struct i2c_msg msg = { .addr = priv->i2c_addr, .flags = 0,
                               .buf = buf, .len = sizeof(buf) };
 
-       dprintk("%s:\n", __FUNCTION__);
+       dprintk("%s:\n", __func__);
        if (fe->ops.i2c_gate_ctrl)
                fe->ops.i2c_gate_ctrl(fe, 1);
        i2c_transfer(priv->i2c_adap, &msg, 1);
        { .lomax =         0, .svco = 0, .spd = 0, .scr = 0, .sbs = 0, .gc3 = 0}
 };
 
+static int tda827xa_sleep(struct dvb_frontend *fe)
+{
+       struct tda827x_priv *priv = fe->tuner_priv;
+       static u8 buf[] = { 0x30, 0x90 };
+       struct i2c_msg msg = { .addr = priv->i2c_addr, .flags = 0,
+                              .buf = buf, .len = sizeof(buf) };
+
+       dprintk("%s:\n", __func__);
+       if (fe->ops.i2c_gate_ctrl)
+               fe->ops.i2c_gate_ctrl(fe, 1);
+
+       i2c_transfer(priv->i2c_adap, &msg, 1);
+
+       if (fe->ops.i2c_gate_ctrl)
+               fe->ops.i2c_gate_ctrl(fe, 0);
+
+       if (priv->cfg && priv->cfg->sleep)
+               priv->cfg->sleep(fe);
+
+       return 0;
+}
+
+static void tda827xa_lna_gain(struct dvb_frontend *fe, int high,
+                             struct analog_parameters *params)
+{
+       struct tda827x_priv *priv = fe->tuner_priv;
+       unsigned char buf[] = {0x22, 0x01};
+       int arg;
+       int gp_func;
+       struct i2c_msg msg = { .addr = priv->cfg->switch_addr, .flags = 0,
+                              .buf = buf, .len = sizeof(buf) };
+
+       if (NULL == priv->cfg) {
+               dprintk("tda827x_config not defined, cannot set LNA gain!\n");
+               return;
+       }
+       if (priv->cfg->config) {
+               if (high)
+                       dprintk("setting LNA to high gain\n");
+               else
+                       dprintk("setting LNA to low gain\n");
+       }
+       switch (priv->cfg->config) {
+       case 0: /* no LNA */
+               break;
+       case 1: /* switch is GPIO 0 of tda8290 */
+       case 2:
+               if (params == NULL) {
+                       gp_func = 0;
+                       arg  = 0;
+               } else {
+                       /* turn Vsync on */
+                       gp_func = 1;
+                       if (params->std & V4L2_STD_MN)
+                               arg = 1;
+                       else
+                               arg = 0;
+               }
+               if (priv->cfg->tuner_callback)
+                       priv->cfg->tuner_callback(priv->i2c_adap->algo_data,
+                                                               gp_func, arg);
+               buf[1] = high ? 0 : 1;
+               if (priv->cfg->config == 2)
+                       buf[1] = high ? 1 : 0;
+               i2c_transfer(priv->i2c_adap, &msg, 1);
+               break;
+       case 3: /* switch with GPIO of saa713x */
+               if (priv->cfg->tuner_callback)
+                       priv->cfg->tuner_callback(priv->i2c_adap->algo_data, 0, high);
+               break;
+       }
+}
+
 static int tda827xa_set_params(struct dvb_frontend *fe,
                               struct dvb_frontend_parameters *params)
 {
        int i, tuner_freq, if_freq;
        u32 N;
 
-       dprintk("%s:\n", __FUNCTION__);
-       if (priv->cfg && priv->cfg->lna_gain)
-               priv->cfg->lna_gain(fe, 1);
+       dprintk("%s:\n", __func__);
+
+       tda827xa_lna_gain(fe, 1, NULL);
        msleep(20);
 
        switch (params->u.ofdm.bandwidth) {
                fe->ops.i2c_gate_ctrl(fe, 1);
        if (i2c_transfer(priv->i2c_adap, &msg, 1) != 1) {
                printk("%s: could not write to tuner at addr: 0x%02x\n",
-                      __FUNCTION__, priv->i2c_addr << 1);
+                      __func__, priv->i2c_addr << 1);
                return -EIO;
        }
        buf[0] = 0x90;
        buf[1] >>= 4;
        dprintk("tda8275a AGC2 gain is: %d\n", buf[1]);
        if ((buf[1]) < 2) {
-               if (priv->cfg && priv->cfg->lna_gain)
-                       priv->cfg->lna_gain(fe, 0);
+               tda827xa_lna_gain(fe, 0, NULL);
                buf[0] = 0x60;
                buf[1] = 0x0c;
                if (fe->ops.i2c_gate_ctrl)
        return 0;
 }
 
-static int tda827xa_sleep(struct dvb_frontend *fe)
-{
-       struct tda827x_priv *priv = fe->tuner_priv;
-       static u8 buf[] = { 0x30, 0x90 };
-       struct i2c_msg msg = { .addr = priv->i2c_addr, .flags = 0,
-                              .buf = buf, .len = sizeof(buf) };
-
-       dprintk("%s:\n", __FUNCTION__);
-       if (fe->ops.i2c_gate_ctrl)
-               fe->ops.i2c_gate_ctrl(fe, 1);
-
-       i2c_transfer(priv->i2c_adap, &msg, 1);
-
-       if (fe->ops.i2c_gate_ctrl)
-               fe->ops.i2c_gate_ctrl(fe, 0);
-
-       if (priv->cfg && priv->cfg->sleep)
-               priv->cfg->sleep(fe);
-
-       return 0;
-}
-
-/* ------------------------------------------------------------------ */
-
-static void tda827xa_lna_gain(struct dvb_frontend *fe, int high,
-                             struct analog_parameters *params)
-{
-       struct tda827x_priv *priv = fe->tuner_priv;
-       unsigned char buf[] = {0x22, 0x01};
-       int arg;
-       struct i2c_msg msg = { .addr = priv->i2c_addr, .flags = 0,
-                              .buf = buf, .len = sizeof(buf) };
-
-       if (NULL == priv->cfg) {
-               dprintk("tda827x_config not defined, cannot set LNA gain!\n");
-               return;
-       }
-
-       if (priv->cfg->config) {
-               if (high)
-                       dprintk("setting LNA to high gain\n");
-               else
-                       dprintk("setting LNA to low gain\n");
-       }
-       switch (*priv->cfg->config) {
-       case 0: /* no LNA */
-               break;
-       case 1: /* switch is GPIO 0 of tda8290 */
-       case 2:
-               /* turn Vsync on */
-               if (params->std & V4L2_STD_MN)
-                       arg = 1;
-               else
-                       arg = 0;
-               if (priv->cfg->tuner_callback)
-                       priv->cfg->tuner_callback(priv, 1, arg);
-               buf[1] = high ? 0 : 1;
-               if (*priv->cfg->config == 2)
-                       buf[1] = high ? 1 : 0;
-               i2c_transfer(priv->i2c_adap, &msg, 1);
-               break;
-       case 3: /* switch with GPIO of saa713x */
-               if (priv->cfg->tuner_callback)
-                       priv->cfg->tuner_callback(priv, 0, high);
-               break;
-       }
-}
 
 static int tda827xa_set_analog_params(struct dvb_frontend *fe,
                                      struct analog_parameters *params)
 static int tda827x_init(struct dvb_frontend *fe)
 {
        struct tda827x_priv *priv = fe->tuner_priv;
-       dprintk("%s:\n", __FUNCTION__);
+       dprintk("%s:\n", __func__);
        if (priv->cfg && priv->cfg->init)
                priv->cfg->init(fe);
 
                fe->ops.i2c_gate_ctrl(fe, 1);
        if (i2c_transfer(priv->i2c_adap, &msg, 1) != 1) {
                printk("%s: could not read from tuner at addr: 0x%02x\n",
-                      __FUNCTION__, msg.addr << 1);
+                      __func__, msg.addr << 1);
                return -EIO;
        }
        if ((data & 0x3c) == 0) {
 {
        struct tda827x_priv *priv = NULL;
 
-       dprintk("%s:\n", __FUNCTION__);
+       dprintk("%s:\n", __func__);
        priv = kzalloc(sizeof(struct tda827x_priv), GFP_KERNEL);
        if (priv == NULL)
                return NULL;
 
        .request_firmware = philips_tda1004x_request_firmware
 };
 
-/* ------------------------------------------------------------------ */
-
 static struct tda1004x_config medion_cardbus = {
        .demod_address = 0x08,
        .invert        = 1,
  * tda 1004x based cards with philips silicon tuner
  */
 
-static void philips_tda827x_lna_gain(struct dvb_frontend *fe, int high)
-{
-       struct saa7134_dev *dev = fe->dvb->priv;
-       struct tda1004x_state *state = fe->demodulator_priv;
-       u8 addr = state->config->i2c_gate;
-       u8 config = state->config->tuner_config;
-       u8 GP00_CF[] = {0x20, 0x01};
-       u8 GP00_LEV[] = {0x22, 0x00};
-
-       struct i2c_msg msg = {.addr = addr,.flags = 0,.buf = GP00_CF, .len = 2};
-       if (config) {
-               if (high) {
-                       dprintk("setting LNA to high gain\n");
-               } else {
-                       dprintk("setting LNA to low gain\n");
-               }
-       }
-       switch (config) {
-       case 0: /* no LNA */
-               break;
-       case 1: /* switch is GPIO 0 of tda8290 */
-       case 2:
-               /* turn Vsync off */
-               saa7134_set_gpio(dev, 22, 0);
-               GP00_LEV[1] = high ? 0 : 1;
-               if (i2c_transfer(&dev->i2c_adap, &msg, 1) != 1) {
-                       wprintk("could not access tda8290 at addr: 0x%02x\n",
-                               addr << 1);
-                       return;
-               }
-               msg.buf = GP00_LEV;
-               if (config == 2)
-                       GP00_LEV[1] = high ? 1 : 0;
-               i2c_transfer(&dev->i2c_adap, &msg, 1);
-               break;
-       case 3: /* switch with GPIO of saa713x */
-               saa7134_set_gpio(dev, 22, high);
-               break;
-       }
-}
-
 static int tda8290_i2c_gate_ctrl( struct dvb_frontend* fe, int enable)
 {
        struct tda1004x_state *state = fe->demodulator_priv;
        return 0;
 }
 
-/* ------------------------------------------------------------------ */
-
 static int philips_tda827x_tuner_init(struct dvb_frontend *fe)
 {
        struct saa7134_dev *dev = fe->dvb->priv;
        return 0;
 }
 
-static struct tda827x_config tda827x_cfg = {
-       .lna_gain = philips_tda827x_lna_gain,
-       .init = philips_tda827x_tuner_init,
-       .sleep = philips_tda827x_tuner_sleep
-};
-
-static void configure_tda827x_fe(struct saa7134_dev *dev, struct tda1004x_config *tda_conf)
+static void configure_tda827x_fe(struct saa7134_dev *dev, struct tda1004x_config *cdec_conf,
+                                                         struct tda827x_config *tuner_conf)
 {
-       dev->dvb.frontend = dvb_attach(tda10046_attach, tda_conf, &dev->i2c_adap);
+       dev->dvb.frontend = dvb_attach(tda10046_attach, cdec_conf, &dev->i2c_adap);
        if (dev->dvb.frontend) {
-               if (tda_conf->i2c_gate)
+               if (cdec_conf->i2c_gate)
                        dev->dvb.frontend->ops.i2c_gate_ctrl = tda8290_i2c_gate_ctrl;
-               if (dvb_attach(tda827x_attach, dev->dvb.frontend, tda_conf->tuner_address,
-                                               &dev->i2c_adap,&tda827x_cfg) == NULL) {
+               if (dvb_attach(tda827x_attach, dev->dvb.frontend, cdec_conf->tuner_address,
+                                                       &dev->i2c_adap, tuner_conf) == NULL) {
                        wprintk("no tda827x tuner found at addr: %02x\n",
-                               tda_conf->tuner_address);
+                               cdec_conf->tuner_address);
                }
        }
 }
 
 /* ------------------------------------------------------------------ */
 
+static struct tda827x_config tda827x_cfg_0 = {
+       .tuner_callback = saa7134_tuner_callback,
+       .init = philips_tda827x_tuner_init,
+       .sleep = philips_tda827x_tuner_sleep,
+       .config = 0,
+       .switch_addr = 0
+};
+
+static struct tda827x_config tda827x_cfg_1 = {
+       .tuner_callback = saa7134_tuner_callback,
+       .init = philips_tda827x_tuner_init,
+       .sleep = philips_tda827x_tuner_sleep,
+       .config = 1,
+       .switch_addr = 0x4b
+};
+
+static struct tda827x_config tda827x_cfg_2 = {
+       .tuner_callback = saa7134_tuner_callback,
+       .init = philips_tda827x_tuner_init,
+       .sleep = philips_tda827x_tuner_sleep,
+       .config = 2,
+       .switch_addr = 0x4b
+};
+
+static struct tda827x_config tda827x_cfg_2_sw42 = {
+       .tuner_callback = saa7134_tuner_callback,
+       .init = philips_tda827x_tuner_init,
+       .sleep = philips_tda827x_tuner_sleep,
+       .config = 2,
+       .switch_addr = 0x42
+};
+
+/* ------------------------------------------------------------------ */
+
 static struct tda1004x_config tda827x_lifeview_config = {
        .demod_address = 0x08,
        .invert        = 1,
        .if_freq       = TDA10046_FREQ_045,
        .i2c_gate      = 0x4b,
        .tuner_address = 0x61,
-       .tuner_config  = 0,
        .antenna_switch= 1,
        .request_firmware = philips_tda1004x_request_firmware
 };
        .if_freq       = TDA10046_FREQ_045,
        .i2c_gate      = 0x4b,
        .tuner_address = 0x61,
-       .tuner_config  = 0,
        .request_firmware = philips_tda1004x_request_firmware
 };
 
        .if_freq       = TDA10046_FREQ_045,
        .i2c_gate      = 0x4b,
        .tuner_address = 0x60,
-       .tuner_config  = 0,
        .request_firmware = philips_tda1004x_request_firmware
 };
 
        .if_freq       = TDA10046_FREQ_045,
        .i2c_gate      = 0x4b,
        .tuner_address = 0x61,
-       .tuner_config  = 2,
        .antenna_switch= 1,
        .request_firmware = philips_tda1004x_request_firmware
 };
        .if_freq       = TDA10046_FREQ_045,
        .i2c_gate      = 0x4b,
        .tuner_address = 0x61,
-       .tuner_config  = 1,
        .request_firmware = philips_tda1004x_request_firmware
 };
 
        .if_freq       = TDA10046_FREQ_045,
        .i2c_gate      = 0x4b,
        .tuner_address = 0x61,
-       .tuner_config  = 1,
        .request_firmware = philips_tda1004x_request_firmware
 };
 
        .if_freq       = TDA10046_FREQ_045,
        .i2c_gate      = 0x4b,
        .tuner_address = 0x61,
-       .tuner_config  = 0,
        .antenna_switch= 2,
        .request_firmware = philips_tda1004x_request_firmware
 };
        .if_freq       = TDA10046_FREQ_045,
        .i2c_gate      = 0x4b,
        .tuner_address = 0x60,
-       .tuner_config  = 0,
        .request_firmware = philips_tda1004x_request_firmware
 };
 
        .if_freq       = TDA10046_FREQ_045,
        .i2c_gate      = 0x4b,
        .tuner_address = 0x61,
-       .tuner_config  = 2,
        .antenna_switch= 2,
        .request_firmware = philips_tda1004x_request_firmware
 };
        .if_freq       = TDA10046_FREQ_045,
        .i2c_gate      = 0x4b,
        .tuner_address = 0x61,
-       .tuner_config  = 2,
        .antenna_switch= 2,
        .request_firmware = philips_tda1004x_request_firmware
 };
        .if_freq       = TDA10046_FREQ_045,
        .i2c_gate      = 0x4b,
        .tuner_address = 0x61,
-       .tuner_config  = 2,
        .antenna_switch= 1,
        .request_firmware = philips_tda1004x_request_firmware
 };
        .if_freq       = TDA10046_FREQ_045,
        .i2c_gate      = 0x4b,
        .tuner_address = 0x60,
-       .tuner_config  = 0,
        .antenna_switch= 1,
        .request_firmware = philips_tda1004x_request_firmware
 };
        .if_freq       = TDA10046_FREQ_045,
        .i2c_gate      = 0x42,
        .tuner_address = 0x61,
-       .tuner_config  = 2,
        .antenna_switch = 1,
        .request_firmware = philips_tda1004x_request_firmware
 };
 }
 
 static struct tda827x_config ads_duo_cfg = {
-       .lna_gain = philips_tda827x_lna_gain,
+       .tuner_callback = saa7134_tuner_callback,
        .init = ads_duo_tuner_init,
-       .sleep = ads_duo_tuner_sleep
+       .sleep = ads_duo_tuner_sleep,
+       .config = 0
 };
 
 static struct tda1004x_config ads_tech_duo_config = {
                break;
        case SAA7134_BOARD_FLYDVBTDUO:
        case SAA7134_BOARD_FLYDVBT_DUO_CARDBUS:
-               configure_tda827x_fe(dev, &tda827x_lifeview_config);
+               configure_tda827x_fe(dev, &tda827x_lifeview_config, &tda827x_cfg_0);
                break;
        case SAA7134_BOARD_PHILIPS_EUROPA:
        case SAA7134_BOARD_VIDEOMATE_DVBT_300:
                }
                break;
        case SAA7134_BOARD_KWORLD_DVBT_210:
-               configure_tda827x_fe(dev, &kworld_dvb_t_210_config);
+               configure_tda827x_fe(dev, &kworld_dvb_t_210_config, &tda827x_cfg_2);
                break;
        case SAA7134_BOARD_PHILIPS_TIGER:
-               configure_tda827x_fe(dev, &philips_tiger_config);
+               configure_tda827x_fe(dev, &philips_tiger_config, &tda827x_cfg_0);
                break;
        case SAA7134_BOARD_PINNACLE_PCTV_310i:
-               configure_tda827x_fe(dev, &pinnacle_pctv_310i_config);
+               configure_tda827x_fe(dev, &pinnacle_pctv_310i_config, &tda827x_cfg_1);
                break;
        case SAA7134_BOARD_HAUPPAUGE_HVR1110:
-               configure_tda827x_fe(dev, &hauppauge_hvr_1110_config);
+               configure_tda827x_fe(dev, &hauppauge_hvr_1110_config, &tda827x_cfg_1);
                break;
        case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
-               configure_tda827x_fe(dev, &asus_p7131_dual_config);
+               configure_tda827x_fe(dev, &asus_p7131_dual_config, &tda827x_cfg_0);
                break;
        case SAA7134_BOARD_FLYDVBT_LR301:
-               configure_tda827x_fe(dev, &tda827x_lifeview_config);
+               configure_tda827x_fe(dev, &tda827x_lifeview_config, &tda827x_cfg_0);
                break;
        case SAA7134_BOARD_FLYDVB_TRIO:
                if(! use_frontend) {    /* terrestrial */
-                       configure_tda827x_fe(dev, &lifeview_trio_config);
-               } else {                /* satellite */
+                       configure_tda827x_fe(dev, &lifeview_trio_config, &tda827x_cfg_0);
+               } else {                /* satellite */
                        dev->dvb.frontend = dvb_attach(tda10086_attach, &flydvbs, &dev->i2c_adap);
                        if (dev->dvb.frontend) {
                                if (dvb_attach(tda826x_attach, dev->dvb.frontend, 0x63,
                                               &dev->i2c_adap);
                if (dev->dvb.frontend) {
                        if (dvb_attach(tda827x_attach,dev->dvb.frontend,
-                                  ads_tech_duo_config.tuner_address,
-                                  &dev->i2c_adap,&ads_duo_cfg) == NULL) {
+                                  ads_tech_duo_config.tuner_address, &dev->i2c_adap,
+                                                               &ads_duo_cfg) == NULL) {
                                wprintk("no tda827x tuner found at addr: %02x\n",
                                        ads_tech_duo_config.tuner_address);
                        }
                }
                break;
        case SAA7134_BOARD_TEVION_DVBT_220RF:
-               configure_tda827x_fe(dev, &tevion_dvbt220rf_config);
+               configure_tda827x_fe(dev, &tevion_dvbt220rf_config, &tda827x_cfg_0);
                break;
        case SAA7134_BOARD_MEDION_MD8800_QUADRO:
                if (!use_frontend) {     /* terrestrial */
-                       configure_tda827x_fe(dev, &md8800_dvbt_config);
+                       configure_tda827x_fe(dev, &md8800_dvbt_config, &tda827x_cfg_0);
                } else {        /* satellite */
                        dev->dvb.frontend = dvb_attach(tda10086_attach,
                                                        &flydvbs, &dev->i2c_adap);
                }
                break;
        case SAA7134_BOARD_CINERGY_HT_PCMCIA:
-               configure_tda827x_fe(dev, &cinergy_ht_config);
+               configure_tda827x_fe(dev, &cinergy_ht_config, &tda827x_cfg_0);
                break;
        case SAA7134_BOARD_CINERGY_HT_PCI:
-               configure_tda827x_fe(dev, &cinergy_ht_pci_config);
+               configure_tda827x_fe(dev, &cinergy_ht_pci_config, &tda827x_cfg_0);
                break;
        case SAA7134_BOARD_PHILIPS_TIGER_S:
-               configure_tda827x_fe(dev, &philips_tiger_s_config);
+               configure_tda827x_fe(dev, &philips_tiger_s_config, &tda827x_cfg_2);
                break;
        case SAA7134_BOARD_ASUS_P7131_4871:
-               configure_tda827x_fe(dev, &asus_p7131_4871_config);
+               configure_tda827x_fe(dev, &asus_p7131_4871_config, &tda827x_cfg_2);
                break;
        case SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA:
-               configure_tda827x_fe(dev, &asus_p7131_hybrid_lna_config);
+               configure_tda827x_fe(dev, &asus_p7131_hybrid_lna_config, &tda827x_cfg_2);
                break;
        case SAA7134_BOARD_AVERMEDIA_SUPER_007:
-               configure_tda827x_fe(dev, &avermedia_super_007_config);
+               configure_tda827x_fe(dev, &avermedia_super_007_config, &tda827x_cfg_0);
                break;
        case SAA7134_BOARD_TWINHAN_DTV_DVB_3056:
-               configure_tda827x_fe(dev, &twinhan_dtv_dvb_3056_config);
+               configure_tda827x_fe(dev, &twinhan_dtv_dvb_3056_config, &tda827x_cfg_2_sw42);
                break;
        case SAA7134_BOARD_PHILIPS_SNAKE:
                dev->dvb.frontend = dvb_attach(tda10086_attach, &flydvbs,
                }
                break;
        case SAA7134_BOARD_CREATIX_CTX953:
-               configure_tda827x_fe(dev, &md8800_dvbt_config);
+               configure_tda827x_fe(dev, &md8800_dvbt_config, &tda827x_cfg_0);
                break;
        case SAA7134_BOARD_MSI_TVANYWHERE_AD11:
-               configure_tda827x_fe(dev, &philips_tiger_s_config);
+               configure_tda827x_fe(dev, &philips_tiger_s_config, &tda827x_cfg_2);
                break;
        case SAA7134_BOARD_AVERMEDIA_CARDBUS_506:
                dev->dvb.frontend = dvb_attach(mt352_attach,