This patch adds DVB support for Hauppauge HVR950.
Thanks to Michael Krufky <mkrufky@linuxtv.org> for getting those values.
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
 config VIDEO_EM28XX_DVB
        tristate "DVB/ATSC Support for em28xx based TV cards"
        depends on VIDEO_EM28XX && DVB_CORE
+       select DVB_LGDT330X if !DVB_FE_CUSTOMISE
        select VIDEOBUF_DVB
        select FW_LOADER
        ---help---
 
                .tuner_type     = TUNER_XC2028,
                .mts_firmware   = 1,
                .has_12mhz_i2s  = 1,
+               .has_dvb        = 1,
                .decoder        = EM28XX_TVP5150,
                .input          = { {
                        .type     = EM28XX_VMUX_TELEVISION,
                        .vmux     = TVP5150_SVIDEO,
                        .amux     = 1,
                } },
+               .analog_gpio = {
+                       {               /* xc3028 reset seq */
+                               .reg = 0x08,
+                               .val = 0x3d,
+                               .rst = 0x2d,
+                               .t1 = 5,
+                               .t2 = 10,
+                               .t3 = 5,
+                       },
+               },
+               .digital_gpio = {
+                       {               /* xc3028 reset seq */
+                               .reg = 0x08,
+                               .val = 0x3e,
+                               .rst = 0x2e,
+                               .t1 = 6,
+                               .t2 = 6,
+                               .t3 = 6,
+                       }, {            /* demod reset seq */
+                               .reg = 0x04,
+                               .val = 0x0c,
+                               .rst = 0x04,
+                               .t2 = 10,
+                               .t3 = 10,
+                       }
+               },
        },
        [EM2880_BOARD_TERRATEC_HYBRID_XS] = {
                .name         = "Terratec Hybrid XS",
 
        /* Put xc2028 tuners and demods into a sane state */
        if (dev->tuner_type == TUNER_XC2028) {
-               dev->mode = EM28XX_DIGITAL_MODE;
+               dev->mode = EM28XX_ANALOG_MODE;
                em28xx_tuner_callback(dev, XC2028_TUNER_RESET, 0);
        };
 }
 
 
 /* ------------------------------------------------------------------ */
 
-/* Add demods here */
+static struct lgdt330x_config em2880_lgdt3303_dev = {
+       .demod_address = 0x0e,
+       .demod_chip = LGDT3303,
+};
 
 /* ------------------------------------------------------------------ */
 
                .i2c_adap  = &dev->i2c_adap,
                .i2c_addr  = addr,
                .ctrl      = &ctl,
+               .callback  = em28xx_tuner_callback,
        };
 
        if (!dev->dvb.frontend) {
 
        /* init frontend */
        switch (dev->model) {
+       case EM2880_BOARD_HAUPPAUGE_WINTV_HVR_950:
+               /* Enable lgdt330x */
+               dev->mode = EM28XX_ANALOG_MODE;
+               em28xx_tuner_callback(dev, XC2028_TUNER_RESET, 0);
+
+               dev->dvb.frontend = dvb_attach(lgdt330x_attach,
+                                              &em2880_lgdt3303_dev,
+                                              &dev->i2c_adap);
+               if (attach_xc3028(0x61, dev) < 0)
+                       return -EINVAL;
+               break;
        default:
                printk(KERN_ERR "%s/2: The frontend of your DVB/ATSC card"
                                " isn't supported yet\n",