Gitweb:     
http://git.kernel.org/git/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commit;h=d4ca23b188d458ef508649a0c6866937b48d4bf8
Commit:     d4ca23b188d458ef508649a0c6866937b48d4bf8
Parent:     08cdf94c076121cd0214ef9ea18ae3fbb9ace684
Author:     Pierre Willenbrock <[EMAIL PROTECTED]>
AuthorDate: Sun Mar 18 19:54:07 2007 -0300
Committer:  Mauro Carvalho Chehab <[EMAIL PROTECTED]>
CommitDate: Fri Apr 27 15:44:59 2007 -0300

    V4L/DVB (5459): M920x: add support for Anubis Electronics / MSI Digi Vox 
Mini II
    
    Add support for Anubis Electronics "Lifeview" (USB-ID: 0x10fd:0x1513)
    
    Signed-off-by: Pierre Willenbrock <[EMAIL PROTECTED]>
    Signed-off-by: Michael Krufky <[EMAIL PROTECTED]>
    Signed-off-by: Mauro Carvalho Chehab <[EMAIL PROTECTED]>
---
 drivers/media/dvb/dvb-usb/dvb-usb-ids.h |    2 +
 drivers/media/dvb/dvb-usb/m920x.c       |   83 ++++++++++++++++++++++++++++++-
 2 files changed, 84 insertions(+), 1 deletions(-)

diff --git a/drivers/media/dvb/dvb-usb/dvb-usb-ids.h 
b/drivers/media/dvb/dvb-usb/dvb-usb-ids.h
index 6dbf0c0..dda636a 100644
--- a/drivers/media/dvb/dvb-usb/dvb-usb-ids.h
+++ b/drivers/media/dvb/dvb-usb/dvb-usb-ids.h
@@ -13,6 +13,7 @@
 #define USB_VID_ADSTECH                                0x06e1
 #define USB_VID_ALCOR_MICRO            0x058f
 #define USB_VID_ANCHOR                         0x0547
+#define USB_VID_ANUBIS_ELECTRONIC              0x10fd
 #define USB_VID_AVERMEDIA                      0x07ca
 #define USB_VID_COMPRO                         0x185b
 #define USB_VID_COMPRO_UNK                     0x145f
@@ -140,6 +141,7 @@
 #define USB_PID_GENPIX_8PSK_COLD                       0x0200
 #define USB_PID_GENPIX_8PSK_WARM                       0x0201
 #define USB_PID_SIGMATEK_DVB_110                       0x6610
+#define USB_PID_MSI_DIGI_VOX_MINI_II                   0x1513
 
 
 #endif
diff --git a/drivers/media/dvb/dvb-usb/m920x.c 
b/drivers/media/dvb/dvb-usb/m920x.c
index fd6583b..45d7bc2 100644
--- a/drivers/media/dvb/dvb-usb/m920x.c
+++ b/drivers/media/dvb/dvb-usb/m920x.c
@@ -14,6 +14,8 @@
 #include "mt352.h"
 #include "mt352_priv.h"
 #include "qt1010.h"
+#include "tda1004x.h"
+#include "tda827x.h"
 
 /* debug */
 static int dvb_usb_m920x_debug;
@@ -414,8 +416,40 @@ static int megasky_qt1010_tuner_attach(struct 
dvb_usb_adapter *adap)
        return 0;
 }
 
+static struct tda1004x_config digivox_tda10046_config = {
+       .demod_address = 0x08,
+       .invert = 0,
+       .invert_oclk = 0,
+       .ts_mode = TDA10046_TS_SERIAL,
+       .xtal_freq = TDA10046_XTAL_16M,
+       .if_freq = TDA10046_FREQ_045,
+       .agc_config = TDA10046_AGC_TDA827X,
+       .gpio_config = TDA10046_GPTRI,
+       .request_firmware = NULL,
+};
+
+static int digivox_tda10046_frontend_attach(struct dvb_usb_adapter *adap)
+{
+       deb_rc("digivox_tda10046_frontend_attach!\n");
+
+       if ((adap->fe = dvb_attach(tda10046_attach, &digivox_tda10046_config,
+                                  &adap->dev->i2c_adap)) == NULL)
+               return -EIO;
+
+       return 0;
+}
+
+static int digivox_tda8275_tuner_attach(struct dvb_usb_adapter *adap)
+{
+       if (dvb_attach(tda827x_attach, adap->fe, 0x60, &adap->dev->i2c_adap,
+                      NULL) == NULL)
+               return -ENODEV;
+       return 0;
+}
+
 /* DVB USB Driver stuff */
 static struct dvb_usb_device_properties megasky_properties;
+static struct dvb_usb_device_properties digivox_mini_ii_properties;
 
 static int m920x_probe(struct usb_interface *intf,
                       const struct usb_device_id *id)
@@ -426,7 +460,8 @@ static int m920x_probe(struct usb_interface *intf,
 
        deb_rc("Probed!\n");
 
-       if ((ret = dvb_usb_device_init(intf, &megasky_properties, THIS_MODULE, 
&d)) == 0)
+       if (((ret = dvb_usb_device_init(intf, &megasky_properties, THIS_MODULE, 
&d)) == 0) ||
+           ((ret = dvb_usb_device_init(intf, &digivox_mini_ii_properties, 
THIS_MODULE, &d)) == 0))
                goto found;
 
        return ret;
@@ -451,6 +486,8 @@ found:
 
 static struct usb_device_id m920x_table [] = {
                { USB_DEVICE(USB_VID_MSI, USB_PID_MSI_MEGASKY580) },
+               { USB_DEVICE(USB_VID_ANUBIS_ELECTRONIC,
+                            USB_PID_MSI_DIGI_VOX_MINI_II) },
                { }             /* Terminating entry */
 };
 MODULE_DEVICE_TABLE (usb, m920x_table);
@@ -500,6 +537,50 @@ static struct dvb_usb_device_properties megasky_properties 
= {
                {   "MSI Mega Sky 580 DVB-T USB2.0",
                        { &m920x_table[0], NULL },
                        { NULL },
+               }
+       }
+};
+
+static struct dvb_usb_device_properties digivox_mini_ii_properties = {
+       .caps = DVB_USB_IS_AN_I2C_ADAPTER,
+
+       .usb_ctrl = DEVICE_SPECIFIC,
+       .firmware = "dvb-usb-digivox-02.fw",
+       .download_firmware = m9206_firmware_download,
+
+       .size_of_priv     = sizeof(struct m9206_state),
+
+       .identify_state   = m920x_identify_state,
+       .num_adapters = 1,
+       .adapter = {{
+               .caps = DVB_USB_ADAP_HAS_PID_FILTER |
+               DVB_USB_ADAP_PID_FILTER_CAN_BE_TURNED_OFF,
+
+               .pid_filter_count = 8,
+               .pid_filter       = m9206_pid_filter,
+               .pid_filter_ctrl  = m9206_pid_filter_ctrl,
+
+               .frontend_attach  = digivox_tda10046_frontend_attach,
+               .tuner_attach     = digivox_tda8275_tuner_attach,
+
+               .stream = {
+                       .type = USB_BULK,
+                       .count = 8,
+                       .endpoint = 0x81,
+                       .u = {
+                               .bulk = {
+                                       .buffersize = 0x4000,
+                               }
+                       }
+               },
+       }},
+       .i2c_algo         = &m9206_i2c_algo,
+
+       .num_device_descs = 1,
+       .devices = {
+               {   "MSI DIGI VOX mini II DVB-T USB2.0",
+                       { &m920x_table[1], NULL },
+                       { NULL },
                },
        }
 };
-
To unsubscribe from this list: send the line "unsubscribe git-commits-head" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to