Merge ssh://master.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6
authorMauro Carvalho Chehab <mchehab@infradead.org>
Sun, 15 Jan 2006 22:59:29 +0000 (20:59 -0200)
committerMauro Carvalho Chehab <mchehab@infradead.org>
Sun, 15 Jan 2006 22:59:29 +0000 (20:59 -0200)
26 files changed:
Documentation/video4linux/CARDLIST.tuner
drivers/media/dvb/bt8xx/bt878.c
drivers/media/dvb/dvb-usb/cxusb.c
drivers/media/dvb/ttpci/av7110.c
drivers/media/video/Makefile
drivers/media/video/arv.c
drivers/media/video/bt832.c
drivers/media/video/btcx-risc.c
drivers/media/video/bttv-cards.c
drivers/media/video/bttv-driver.c
drivers/media/video/bttv-i2c.c
drivers/media/video/bttvp.h
drivers/media/video/cx25840/cx25840-core.c
drivers/media/video/cx88/Makefile
drivers/media/video/cx88/cx88-alsa.c
drivers/media/video/cx88/cx88-vp3054-i2c.c
drivers/media/video/msp3400-driver.c
drivers/media/video/planb.c
drivers/media/video/saa6588.c
drivers/media/video/saa711x.c
drivers/media/video/saa7134/saa7134-core.c
drivers/media/video/tuner-simple.c
drivers/media/video/tuner-types.c [new file with mode: 0644]
drivers/media/video/tveeprom.c
include/media/tuner-types.h [new file with mode: 0644]
include/media/tuner.h

index 0bf3d5b..f6d0cf7 100644 (file)
@@ -68,3 +68,4 @@ tuner=66 - LG NTSC (TALN mini series)
 tuner=67 - Philips TD1316 Hybrid Tuner
 tuner=68 - Philips TUV1236D ATSC/NTSC dual in
 tuner=69 - Tena TNF 5335 MF
+tuner=70 - Samsung TCPN 2121P30A
index f295714..a04bb61 100644 (file)
@@ -542,7 +542,7 @@ static struct pci_driver bt878_pci_driver = {
       .remove  = bt878_remove,
 };
 
-static int bt878_pci_driver_registered = 0;
+static int bt878_pci_driver_registered;
 
 /*******************************/
 /* Module management functions */
index 18d1698..a7fb06f 100644 (file)
@@ -691,6 +691,8 @@ module_init (cxusb_module_init);
 module_exit (cxusb_module_exit);
 
 MODULE_AUTHOR("Patrick Boettcher <patrick.boettcher@desy.de>");
+MODULE_AUTHOR("Michael Krufky <mkrufky@m1k.net>");
+MODULE_AUTHOR("Chris Pascoe <c.pascoe@itee.uq.edu.au>");
 MODULE_DESCRIPTION("Driver for Conexant USB2.0 hybrid reference design");
 MODULE_VERSION("1.0-alpha");
 MODULE_LICENSE("GPL");
index 327a808..2749490 100644 (file)
@@ -81,7 +81,7 @@ static int adac = DVB_ADAC_TI;
 static int hw_sections;
 static int rgb_on;
 static int volume = 255;
-static int budgetpatch = 0;
+static int budgetpatch;
 
 module_param_named(debug, av7110_debug, int, 0644);
 MODULE_PARM_DESC(debug, "debug level (bitmask, default 0)");
@@ -103,7 +103,7 @@ MODULE_PARM_DESC(budgetpatch, "use budget-patch hardware modification: default 0
 
 static void restart_feeds(struct av7110 *av7110);
 
-static int av7110_num = 0;
+static int av7110_num;
 
 #define FE_FUNC_OVERRIDE(fe_func, av7110_copy, av7110_func) \
 {\
index dd24896..faf7283 100644 (file)
@@ -8,7 +8,8 @@ bttv-objs       :=      bttv-driver.o bttv-cards.o bttv-if.o \
 zoran-objs      :=     zr36120.o zr36120_i2c.o zr36120_mem.o
 zr36067-objs   :=      zoran_procfs.o zoran_device.o \
                        zoran_driver.o zoran_card.o
-tuner-objs     :=      tuner-core.o tuner-simple.o mt20xx.o tda8290.o tea5767.o
+tuner-objs     :=      tuner-core.o tuner-types.o tuner-simple.o \
+                       mt20xx.o tda8290.o tea5767.o
 
 msp3400-objs   :=      msp3400-driver.o msp3400-kthreads.o
 
index 7d5a068..994b75f 100644 (file)
@@ -129,9 +129,9 @@ static unsigned char        yuv[MAX_AR_FRAME_BYTES];
 static int freq = DEFAULT_FREQ;        /* BCLK: available 50 or 70 (MHz) */
 static int vga = 0;            /* default mode(0:QVGA mode, other:VGA mode) */
 static int vga_interlace = 0;  /* 0 is normal mode for, else interlace mode */
-MODULE_PARM(freq, "i");
-MODULE_PARM(vga, "i");
-MODULE_PARM(vga_interlace, "i");
+module_param(freq, int, 0);
+module_param(vga, int, 0);
+module_param(vga_interlace, int, 0);
 
 static int ar_initialize(struct video_device *dev);
 
index 07c78f1..cc54b62 100644 (file)
@@ -43,7 +43,7 @@ static unsigned short normal_i2c[] = { I2C_BT832_ALT1>>1, I2C_BT832_ALT2>>1,
                                       I2C_CLIENT_END };
 I2C_CLIENT_INSMOD;
 
-int debug    = 0;    /* debug output */
+int debug;    /* debug output */
 module_param(debug,            int, 0644);
 
 /* ---------------------------------------------------------------------- */
index a48de3c..b4aca72 100644 (file)
@@ -37,7 +37,7 @@ MODULE_DESCRIPTION("some code shared by bttv and cx88xx drivers");
 MODULE_AUTHOR("Gerd Knorr");
 MODULE_LICENSE("GPL");
 
-static unsigned int debug = 0;
+static unsigned int debug;
 module_param(debug, int, 0644);
 MODULE_PARM_DESC(debug,"debug messages, default is 0 (no)");
 
index 65323e7..9749d6e 100644 (file)
@@ -92,8 +92,8 @@ static void identify_by_eeprom(struct bttv *btv,
 static int __devinit pvr_boot(struct bttv *btv);
 
 /* config variables */
-static unsigned int triton1=0;
-static unsigned int vsfx=0;
+static unsigned int triton1;
+static unsigned int vsfx;
 static unsigned int latency = UNSET;
 int no_overlay=-1;
 
@@ -106,7 +106,7 @@ static struct bttv  *master[BTTV_MAX] = { [ 0 ... (BTTV_MAX-1) ] = NULL };
 #ifdef MODULE
 static unsigned int autoload = 1;
 #else
-static unsigned int autoload = 0;
+static unsigned int autoload;
 #endif
 static unsigned int gpiomask = UNSET;
 static unsigned int audioall = UNSET;
index 0e69703..aa4c4c5 100644 (file)
 unsigned int bttv_num;                 /* number of Bt848s in use */
 struct bttv bttvs[BTTV_MAX];
 
-unsigned int bttv_debug = 0;
+unsigned int bttv_debug;
 unsigned int bttv_verbose = 1;
-unsigned int bttv_gpio = 0;
+unsigned int bttv_gpio;
 
 /* config variables */
 #ifdef __BIG_ENDIAN
 static unsigned int bigendian=1;
 #else
-static unsigned int bigendian=0;
+static unsigned int bigendian;
 #endif
 static unsigned int radio[BTTV_MAX];
-static unsigned int irq_debug = 0;
+static unsigned int irq_debug;
 static unsigned int gbuffers = 8;
 static unsigned int gbufsize = 0x208000;
 
 static int video_nr = -1;
 static int radio_nr = -1;
 static int vbi_nr = -1;
-static int debug_latency = 0;
+static int debug_latency;
 
-static unsigned int fdsr = 0;
+static unsigned int fdsr;
 
 /* options */
-static unsigned int combfilter  = 0;
-static unsigned int lumafilter  = 0;
+static unsigned int combfilter;
+static unsigned int lumafilter;
 static unsigned int automute    = 1;
-static unsigned int chroma_agc  = 0;
+static unsigned int chroma_agc;
 static unsigned int adc_crush   = 1;
 static unsigned int whitecrush_upper = 0xCF;
 static unsigned int whitecrush_lower = 0x7F;
-static unsigned int vcr_hack    = 0;
-static unsigned int irq_iswitch = 0;
+static unsigned int vcr_hack;
+static unsigned int irq_iswitch;
 static unsigned int uv_ratio    = 50;
-static unsigned int full_luma_range = 0;
-static unsigned int coring      = 0;
+static unsigned int full_luma_range;
+static unsigned int coring;
 extern int no_overlay;
 
 /* API features (turn on/off stuff for testing) */
 static unsigned int v4l2        = 1;
 
-
 /* insmod args */
 module_param(bttv_verbose,      int, 0644);
 module_param(bttv_gpio,         int, 0644);
@@ -685,16 +684,16 @@ int check_alloc_btres(struct bttv *btv, struct bttv_fh *fh, int bit)
                return 1;
 
        /* is it free? */
-       down(&btv->reslock);
+       mutex_lock(&btv->reslock);
        if (btv->resources & bit) {
                /* no, someone else uses it */
-               up(&btv->reslock);
+               mutex_unlock(&btv->reslock);
                return 0;
        }
        /* it's free, grab it */
        fh->resources  |= bit;
        btv->resources |= bit;
-       up(&btv->reslock);
+       mutex_unlock(&btv->reslock);
        return 1;
 }
 
@@ -717,10 +716,10 @@ void free_btres(struct bttv *btv, struct bttv_fh *fh, int bits)
                /* trying to free ressources not allocated by us ... */
                printk("bttv: BUG! (btres)\n");
        }
-       down(&btv->reslock);
+       mutex_lock(&btv->reslock);
        fh->resources  &= ~bits;
        btv->resources &= ~bits;
-       up(&btv->reslock);
+       mutex_unlock(&btv->reslock);
 }
 
 /* ----------------------------------------------------------------------- */
@@ -1537,12 +1536,12 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)
        case VIDIOCSFREQ:
        {
                unsigned long *freq = arg;
-               down(&btv->lock);
+               mutex_lock(&btv->lock);
                btv->freq=*freq;
                bttv_call_i2c_clients(btv,VIDIOCSFREQ,freq);
                if (btv->has_matchbox && btv->radio_user)
                        tea5757_set_freq(btv,*freq);
-               up(&btv->lock);
+               mutex_unlock(&btv->lock);
                return 0;
        }
 
@@ -1572,10 +1571,10 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)
                if (v->mode >= BTTV_TVNORMS)
                        return -EINVAL;
 
-               down(&btv->lock);
+               mutex_lock(&btv->lock);
                set_tvnorm(btv,v->mode);
                bttv_call_i2c_clients(btv,cmd,v);
-               up(&btv->lock);
+               mutex_unlock(&btv->lock);
                return 0;
        }
 
@@ -1612,17 +1611,17 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)
                if (v->norm >= BTTV_TVNORMS)
                        return -EINVAL;
 
-               down(&btv->lock);
+               mutex_lock(&btv->lock);
                if (channel == btv->input &&
                    v->norm == btv->tvnorm) {
                        /* nothing to do */
-                       up(&btv->lock);
+                       mutex_unlock(&btv->lock);
                        return 0;
                }
 
                btv->tvnorm = v->norm;
                set_input(btv,v->channel);
-               up(&btv->lock);
+               mutex_unlock(&btv->lock);
                return 0;
        }
 
@@ -1635,14 +1634,14 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)
                v->flags |= VIDEO_AUDIO_MUTABLE;
                v->mode  = VIDEO_SOUND_MONO;
 
-               down(&btv->lock);
+               mutex_lock(&btv->lock);
                bttv_call_i2c_clients(btv,cmd,v);
 
                /* card specific hooks */
                if (btv->audio_hook)
                        btv->audio_hook(btv,v,0);
 
-               up(&btv->lock);
+               mutex_unlock(&btv->lock);
                return 0;
        }
        case VIDIOCSAUDIO:
@@ -1653,7 +1652,7 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)
                if (audio >= bttv_tvcards[btv->c.type].audio_inputs)
                        return -EINVAL;
 
-               down(&btv->lock);
+               mutex_lock(&btv->lock);
                audio_mux(btv, (v->flags&VIDEO_AUDIO_MUTE) ? AUDIO_MUTE : AUDIO_UNMUTE);
                bttv_call_i2c_clients(btv,cmd,v);
 
@@ -1661,7 +1660,7 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)
                if (btv->audio_hook)
                        btv->audio_hook(btv,v,1);
 
-               up(&btv->lock);
+               mutex_unlock(&btv->lock);
                return 0;
        }
 
@@ -1695,10 +1694,10 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)
                if (i == BTTV_TVNORMS)
                        return -EINVAL;
 
-               down(&btv->lock);
+               mutex_lock(&btv->lock);
                set_tvnorm(btv,i);
                i2c_vidiocschan(btv);
-               up(&btv->lock);
+               mutex_unlock(&btv->lock);
                return 0;
        }
        case VIDIOC_QUERYSTD:
@@ -1756,9 +1755,9 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)
 
                if (*i > bttv_tvcards[btv->c.type].video_inputs)
                        return -EINVAL;
-               down(&btv->lock);
+               mutex_lock(&btv->lock);
                set_input(btv,*i);
-               up(&btv->lock);
+               mutex_unlock(&btv->lock);
                return 0;
        }
 
@@ -1770,7 +1769,7 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)
                        return -EINVAL;
                if (0 != t->index)
                        return -EINVAL;
-               down(&btv->lock);
+               mutex_lock(&btv->lock);
                memset(t,0,sizeof(*t));
                strcpy(t->name, "Television");
                t->type       = V4L2_TUNER_ANALOG_TV;
@@ -1805,7 +1804,7 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)
                        }
                }
                /* FIXME: fill capability+audmode */
-               up(&btv->lock);
+               mutex_unlock(&btv->lock);
                return 0;
        }
        case VIDIOC_S_TUNER:
@@ -1816,7 +1815,7 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)
                        return -EINVAL;
                if (0 != t->index)
                        return -EINVAL;
-               down(&btv->lock);
+               mutex_lock(&btv->lock);
                {
                        struct video_audio va;
                        memset(&va, 0, sizeof(struct video_audio));
@@ -1833,7 +1832,7 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)
                        if (btv->audio_hook)
                                btv->audio_hook(btv,&va,1);
                }
-               up(&btv->lock);
+               mutex_unlock(&btv->lock);
                return 0;
        }
 
@@ -1854,12 +1853,12 @@ static int bttv_common_ioctls(struct bttv *btv, unsigned int cmd, void *arg)
                        return -EINVAL;
                if (unlikely (f->type != V4L2_TUNER_ANALOG_TV))
                        return -EINVAL;
-               down(&btv->lock);
+               mutex_lock(&btv->lock);
                btv->freq = f->frequency;
                bttv_call_i2c_clients(btv,VIDIOCSFREQ,&btv->freq);
                if (btv->has_matchbox && btv->radio_user)
                        tea5757_set_freq(btv,btv->freq);
-               up(&btv->lock);
+               mutex_unlock(&btv->lock);
                return 0;
        }
        case VIDIOC_LOG_STATUS:
@@ -3157,7 +3156,7 @@ static int radio_open(struct inode *inode, struct file *file)
                return -ENODEV;
 
        dprintk("bttv%d: open called (radio)\n",btv->c.nr);
-       down(&btv->lock);
+       mutex_lock(&btv->lock);
 
        btv->radio_user++;
 
@@ -3166,7 +3165,7 @@ static int radio_open(struct inode *inode, struct file *file)
        bttv_call_i2c_clients(btv,AUDC_SET_RADIO,&btv->tuner_type);
        audio_mux(btv,AUDIO_RADIO);
 
-       up(&btv->lock);
+       mutex_unlock(&btv->lock);
        return 0;
 }
 
@@ -3921,8 +3920,8 @@ static int __devinit bttv_probe(struct pci_dev *dev,
        sprintf(btv->c.name,"bttv%d",btv->c.nr);
 
        /* initialize structs / fill in defaults */
-       init_MUTEX(&btv->lock);
-       init_MUTEX(&btv->reslock);
+       mutex_init(&btv->lock);
+       mutex_init(&btv->reslock);
        spin_lock_init(&btv->s_lock);
        spin_lock_init(&btv->gpio_lock);
        init_waitqueue_head(&btv->gpioq);
index 748d630..614c120 100644 (file)
@@ -41,9 +41,9 @@ static struct i2c_client bttv_i2c_client_template;
 
 static int attach_inform(struct i2c_client *client);
 
-static int i2c_debug = 0;
-static int i2c_hw = 0;
-static int i2c_scan = 0;
+static int i2c_debug;
+static int i2c_hw;
+static int i2c_scan;
 module_param(i2c_debug, int, 0644);
 module_param(i2c_hw,    int, 0444);
 module_param(i2c_scan,  int, 0444);
index dd00c20..9cb72f1 100644 (file)
@@ -35,6 +35,7 @@
 #include <linux/videodev.h>
 #include <linux/pci.h>
 #include <linux/input.h>
+#include <linux/mutex.h>
 #include <asm/scatterlist.h>
 #include <asm/io.h>
 
@@ -309,9 +310,9 @@ struct bttv {
 
        /* locking */
        spinlock_t s_lock;
-       struct semaphore lock;
+       struct mutex lock;
        int resources;
-       struct semaphore reslock;
+       struct mutex reslock;
 #ifdef VIDIOC_G_PRIORITY
        struct v4l2_prio_state prio;
 #endif
index 1d75a42..0da744c 100644 (file)
@@ -43,7 +43,7 @@ MODULE_LICENSE("GPL");
 static unsigned short normal_i2c[] = { 0x88 >> 1, I2C_CLIENT_END };
 
 
-int cx25840_debug = 0;
+int cx25840_debug;
 
 module_param_named(debug,cx25840_debug, int, 0644);
 
index e4b2134..6e5eaa2 100644 (file)
@@ -5,6 +5,7 @@ cx8802-objs     := cx88-mpeg.o
 
 obj-$(CONFIG_VIDEO_CX88) += cx88xx.o cx8800.o cx8802.o cx88-blackbird.o
 obj-$(CONFIG_VIDEO_CX88_DVB) += cx88-dvb.o cx88-vp3054-i2c.o
+obj-$(CONFIG_VIDEO_CX88_ALSA) += cx88-alsa.o
 
 EXTRA_CFLAGS += -I$(src)/..
 EXTRA_CFLAGS += -I$(srctree)/drivers/media/dvb/dvb-core
index 7695b52..fd8bc71 100644 (file)
@@ -116,7 +116,7 @@ MODULE_LICENSE("GPL");
 MODULE_SUPPORTED_DEVICE("{{Conexant,23881},"
                        "{{Conexant,23882},"
                        "{{Conexant,23883}");
-static unsigned int debug = 0;
+static unsigned int debug;
 module_param(debug,int,0644);
 MODULE_PARM_DESC(debug,"enable debug messages");
 
@@ -653,7 +653,7 @@ static void snd_cx88_dev_free(snd_card_t * card)
  * Alsa Constructor - Component probe
  */
 
-static int devno=0;
+static int devno;
 static int __devinit snd_cx88_create(snd_card_t *card, struct pci_dev *pci,
                                    snd_cx88_card_t **rchip)
 {
index 372cd29..751a754 100644 (file)
 #include "cx88-vp3054-i2c.h"
 
 
+MODULE_DESCRIPTION("driver for cx2388x VP3054 design");
+MODULE_AUTHOR("Chris Pascoe <c.pascoe@itee.uq.edu.au>");
+MODULE_LICENSE("GPL");
+
 /* ----------------------------------------------------------------------- */
 
 static void vp3054_bit_setscl(void *data, int state)
index 9b05a0a..09ff25b 100644 (file)
@@ -66,12 +66,12 @@ MODULE_LICENSE("GPL");
 
 /* module parameters */
 static int opmode   = OPMODE_AUTO;
-int msp_debug    = 0;    /* msp_debug output */
-int msp_once     = 0;    /* no continous stereo monitoring */
-int msp_amsound  = 0;    /* hard-wire AM sound at 6.5 Hz (france),
-                              the autoscan seems work well only with FM... */
+int msp_debug;          /* msp_debug output */
+int msp_once;           /* no continous stereo monitoring */
+int msp_amsound;        /* hard-wire AM sound at 6.5 Hz (france),
+                           the autoscan seems work well only with FM... */
 int msp_standard = 1;    /* Override auto detect of audio msp_standard, if needed. */
-int msp_dolby    = 0;
+int msp_dolby;
 
 int msp_stereo_thresh = 0x190; /* a2 threshold for stereo/bilingual
                                        (msp34xxg only) 0x00a0-0x03c0 */
index b19c334..f3fc361 100644 (file)
@@ -76,9 +76,9 @@ static volatile struct planb_registers *planb_regs;
 static int def_norm = PLANB_DEF_NORM;  /* default norm */
 static int video_nr = -1;
 
-MODULE_PARM(def_norm, "i");
+module_param(def_norm, int, 0);
 MODULE_PARM_DESC(def_norm, "Default startup norm (0=PAL, 1=NTSC, 2=SECAM)");
-MODULE_PARM(video_nr,"i");
+module_param(video_nr, int, 0);
 MODULE_LICENSE("GPL");
 
 
index e70b17e..d17395c 100644 (file)
@@ -50,15 +50,15 @@ static unsigned int rbds = 0;
 static unsigned int plvl = 0;
 static unsigned int bufblocks = 100;
 
-MODULE_PARM(debug, "i");
+module_param(debug, int, 0644);
 MODULE_PARM_DESC(debug, "enable debug messages");
-MODULE_PARM(xtal, "i");
+module_param(xtal, int, 0);
 MODULE_PARM_DESC(xtal, "select oscillator frequency (0..3), default 0");
-MODULE_PARM(rbds, "i");
+module_param(rbds, int, 0);
 MODULE_PARM_DESC(rbds, "select mode, 0=RDS, 1=RBDS, default 0");
-MODULE_PARM(plvl, "i");
+module_param(plvl, int, 0);
 MODULE_PARM_DESC(plvl, "select pause level (0..3), default 0");
-MODULE_PARM(bufblocks, "i");
+module_param(bufblocks, int, 0);
 MODULE_PARM_DESC(bufblocks, "number of buffered blocks, default 100");
 
 MODULE_DESCRIPTION("v4l2 driver module for SAA6588 RDS decoder");
index ae53063..6c161f2 100644 (file)
@@ -52,7 +52,7 @@ MODULE_LICENSE("GPL");
 #include <linux/video_decoder.h>
 
 static int debug = 0;
-MODULE_PARM(debug, "i");
+module_param(debug, int, 0644);
 MODULE_PARM_DESC(debug, " Set the default Debug level.  Default: 0 (Off) - (0-1)");
 
 
index 3983a65..3dd42ef 100644 (file)
@@ -140,7 +140,7 @@ static int pending_call(struct notifier_block *self, unsigned long state,
        return NOTIFY_DONE;
 }
 
-static int pending_registered=0;
+static int pending_registered;
 static struct notifier_block pending_notifier = {
        .notifier_call = pending_call,
 };
index e5fb743..3879262 100644 (file)
@@ -79,722 +79,16 @@ MODULE_PARM_DESC(offset,"Allows to specify an offset for tuner");
 #define TUNER_PLL_LOCKED   0x40
 #define TUNER_STEREO_MK3   0x04
 
-#define TUNER_MAX_RANGES   3
-
-/* ---------------------------------------------------------------------- */
-
-struct tunertype
-{
-       char *name;
-
-       int count;
-       struct {
-               unsigned short thresh;
-               unsigned char cb;
-       } ranges[TUNER_MAX_RANGES];
-       unsigned char config;
-};
-
-/*
- *     The floats in the tuner struct are computed at compile time
- *     by gcc and cast back to integers. Thus we don't violate the
- *     "no float in kernel" rule.
+#define TUNER_PARAM_ANALOG 0  /* to be removed */
+/* FIXME:
+ * Right now, all tuners are using the first tuner_params[] array element
+ * for analog mode. In the future, we will be merging similar tuner
+ * definitions together, such that each tuner definition will have a
+ * tuner_params struct for each available video standard. At that point,
+ * TUNER_PARAM_ANALOG will be removed, and the tuner_params[] array
+ * element will be chosen based on the video standard in use.
+ *
  */
-static struct tunertype tuners[] = {
-       /* 0-9 */
-       [TUNER_TEMIC_PAL] = { /* TEMIC PAL */
-               .name   = "Temic PAL (4002 FH5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 140.25 /*MHz*/, 0x02, },
-                       { 16 * 463.25 /*MHz*/, 0x04, },
-                       { 16 * 999.99        , 0x01, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_PAL_I] = { /* Philips PAL_I */
-               .name   = "Philips PAL_I (FI1246 and compatibles)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 140.25 /*MHz*/, 0xa0, },
-                       { 16 * 463.25 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_NTSC] = { /* Philips NTSC */
-               .name   = "Philips NTSC (FI1236,FM1236 and compatibles)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 157.25 /*MHz*/, 0xa0, },
-                       { 16 * 451.25 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_SECAM] = { /* Philips SECAM */
-               .name   = "Philips (SECAM+PAL_BG) (FI1216MF, FM1216MF, FR1216MF)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 168.25 /*MHz*/, 0xa7, },
-                       { 16 * 447.25 /*MHz*/, 0x97, },
-                       { 16 * 999.99        , 0x37, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_ABSENT] = { /* Tuner Absent */
-               .name   = "NoTuner",
-               .count  = 1,
-               .ranges = {
-                       { 0, 0x00, },
-               },
-               .config = 0x00,
-       },
-       [TUNER_PHILIPS_PAL] = { /* Philips PAL */
-               .name   = "Philips PAL_BG (FI1216 and compatibles)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 168.25 /*MHz*/, 0xa0, },
-                       { 16 * 447.25 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_TEMIC_NTSC] = { /* TEMIC NTSC */
-               .name   = "Temic NTSC (4032 FY5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 157.25 /*MHz*/, 0x02, },
-                       { 16 * 463.25 /*MHz*/, 0x04, },
-                       { 16 * 999.99        , 0x01, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_TEMIC_PAL_I] = { /* TEMIC PAL_I */
-               .name   = "Temic PAL_I (4062 FY5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 170.00 /*MHz*/, 0x02, },
-                       { 16 * 450.00 /*MHz*/, 0x04, },
-                       { 16 * 999.99        , 0x01, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_TEMIC_4036FY5_NTSC] = { /* TEMIC NTSC */
-               .name   = "Temic NTSC (4036 FY5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 157.25 /*MHz*/, 0xa0, },
-                       { 16 * 463.25 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_ALPS_TSBH1_NTSC] = { /* TEMIC NTSC */
-               .name   = "Alps HSBH1",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 137.25 /*MHz*/, 0x01, },
-                       { 16 * 385.25 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x08, },
-               },
-               .config = 0x8e,
-       },
-
-       /* 10-19 */
-       [TUNER_ALPS_TSBE1_PAL] = { /* TEMIC PAL */
-               .name   = "Alps TSBE1",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 137.25 /*MHz*/, 0x01, },
-                       { 16 * 385.25 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x08, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_ALPS_TSBB5_PAL_I] = { /* Alps PAL_I */
-               .name   = "Alps TSBB5",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 133.25 /*MHz*/, 0x01, },
-                       { 16 * 351.25 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x08, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_ALPS_TSBE5_PAL] = { /* Alps PAL */
-               .name   = "Alps TSBE5",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 133.25 /*MHz*/, 0x01, },
-                       { 16 * 351.25 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x08, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_ALPS_TSBC5_PAL] = { /* Alps PAL */
-               .name   = "Alps TSBC5",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 133.25 /*MHz*/, 0x01, },
-                       { 16 * 351.25 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x08, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_TEMIC_4006FH5_PAL] = { /* TEMIC PAL */
-               .name   = "Temic PAL_BG (4006FH5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 170.00 /*MHz*/, 0xa0, },
-                       { 16 * 450.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_ALPS_TSHC6_NTSC] = { /* Alps NTSC */
-               .name   = "Alps TSCH6",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 137.25 /*MHz*/, 0x14, },
-                       { 16 * 385.25 /*MHz*/, 0x12, },
-                       { 16 * 999.99        , 0x11, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_TEMIC_PAL_DK] = { /* TEMIC PAL */
-               .name   = "Temic PAL_DK (4016 FY5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 168.25 /*MHz*/, 0xa0, },
-                       { 16 * 456.25 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_NTSC_M] = { /* Philips NTSC */
-               .name   = "Philips NTSC_M (MK2)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.00 /*MHz*/, 0xa0, },
-                       { 16 * 454.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_TEMIC_4066FY5_PAL_I] = { /* TEMIC PAL_I */
-               .name   = "Temic PAL_I (4066 FY5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 169.00 /*MHz*/, 0xa0, },
-                       { 16 * 454.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_TEMIC_4006FN5_MULTI_PAL] = { /* TEMIC PAL */
-               .name   = "Temic PAL* auto (4006 FN5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 169.00 /*MHz*/, 0xa0, },
-                       { 16 * 454.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-
-       /* 20-29 */
-       [TUNER_TEMIC_4009FR5_PAL] = { /* TEMIC PAL */
-               .name   = "Temic PAL_BG (4009 FR5) or PAL_I (4069 FR5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 141.00 /*MHz*/, 0xa0, },
-                       { 16 * 464.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_TEMIC_4039FR5_NTSC] = { /* TEMIC NTSC */
-               .name   = "Temic NTSC (4039 FR5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 158.00 /*MHz*/, 0xa0, },
-                       { 16 * 453.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_TEMIC_4046FM5] = { /* TEMIC PAL */
-               .name   = "Temic PAL/SECAM multi (4046 FM5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 169.00 /*MHz*/, 0xa0, },
-                       { 16 * 454.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_PAL_DK] = { /* Philips PAL */
-               .name   = "Philips PAL_DK (FI1256 and compatibles)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 170.00 /*MHz*/, 0xa0, },
-                       { 16 * 450.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_FQ1216ME] = { /* Philips PAL */
-               .name   = "Philips PAL/SECAM multi (FQ1216ME)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 170.00 /*MHz*/, 0xa0, },
-                       { 16 * 450.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_LG_PAL_I_FM] = { /* LGINNOTEK PAL_I */
-               .name   = "LG PAL_I+FM (TAPC-I001D)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 170.00 /*MHz*/, 0xa0, },
-                       { 16 * 450.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_LG_PAL_I] = { /* LGINNOTEK PAL_I */
-               .name   = "LG PAL_I (TAPC-I701D)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 170.00 /*MHz*/, 0xa0, },
-                       { 16 * 450.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_LG_NTSC_FM] = { /* LGINNOTEK NTSC */
-               .name   = "LG NTSC+FM (TPI8NSR01F)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 210.00 /*MHz*/, 0xa0, },
-                       { 16 * 497.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_LG_PAL_FM] = { /* LGINNOTEK PAL */
-               .name   = "LG PAL_BG+FM (TPI8PSB01D)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 170.00 /*MHz*/, 0xa0, },
-                       { 16 * 450.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_LG_PAL] = { /* LGINNOTEK PAL */
-               .name   = "LG PAL_BG (TPI8PSB11D)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 170.00 /*MHz*/, 0xa0, },
-                       { 16 * 450.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-
-       /* 30-39 */
-       [TUNER_TEMIC_4009FN5_MULTI_PAL_FM] = { /* TEMIC PAL */
-               .name   = "Temic PAL* auto + FM (4009 FN5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 141.00 /*MHz*/, 0xa0, },
-                       { 16 * 464.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_SHARP_2U5JF5540_NTSC] = { /* SHARP NTSC */
-               .name   = "SHARP NTSC_JP (2U5JF5540)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 137.25 /*MHz*/, 0x01, },
-                       { 16 * 317.25 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x08, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_Samsung_PAL_TCPM9091PD27] = { /* Samsung PAL */
-               .name   = "Samsung PAL TCPM9091PD27",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 169 /*MHz*/, 0xa0, },
-                       { 16 * 464 /*MHz*/, 0x90, },
-                       { 16 * 999.99     , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_MT2032] = { /* Microtune PAL|NTSC */
-               .name   = "MT20xx universal",
-         /* see mt20xx.c for details */ },
-       [TUNER_TEMIC_4106FH5] = { /* TEMIC PAL */
-               .name   = "Temic PAL_BG (4106 FH5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 141.00 /*MHz*/, 0xa0, },
-                       { 16 * 464.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_TEMIC_4012FY5] = { /* TEMIC PAL */
-               .name   = "Temic PAL_DK/SECAM_L (4012 FY5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 140.25 /*MHz*/, 0x02, },
-                       { 16 * 463.25 /*MHz*/, 0x04, },
-                       { 16 * 999.99        , 0x01, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_TEMIC_4136FY5] = { /* TEMIC NTSC */
-               .name   = "Temic NTSC (4136 FY5)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 158.00 /*MHz*/, 0xa0, },
-                       { 16 * 453.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_LG_PAL_NEW_TAPC] = { /* LGINNOTEK PAL */
-               .name   = "LG PAL (newer TAPC series)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 170.00 /*MHz*/, 0x01, },
-                       { 16 * 450.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x08, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_FM1216ME_MK3] = { /* Philips PAL */
-               .name   = "Philips PAL/SECAM multi (FM1216ME MK3)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 158.00 /*MHz*/, 0x01, },
-                       { 16 * 442.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x04, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_LG_NTSC_NEW_TAPC] = { /* LGINNOTEK NTSC */
-               .name   = "LG NTSC (newer TAPC series)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 170.00 /*MHz*/, 0x01, },
-                       { 16 * 450.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x08, },
-               },
-               .config = 0x8e,
-       },
-
-       /* 40-49 */
-       [TUNER_HITACHI_NTSC] = { /* HITACHI NTSC */
-               .name   = "HITACHI V7-J180AT",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 170.00 /*MHz*/, 0x01, },
-                       { 16 * 450.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x08, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_PAL_MK] = { /* Philips PAL */
-               .name   = "Philips PAL_MK (FI1216 MK)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 140.25 /*MHz*/, 0x01, },
-                       { 16 * 463.25 /*MHz*/, 0xc2, },
-                       { 16 * 999.99        , 0xcf, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_ATSC] = { /* Philips ATSC */
-               .name   = "Philips 1236D ATSC/NTSC dual in",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 157.25 /*MHz*/, 0xa0, },
-                       { 16 * 454.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_FM1236_MK3] = { /* Philips NTSC */
-               .name   = "Philips NTSC MK3 (FM1236MK3 or FM1236/F)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.00 /*MHz*/, 0x01, },
-                       { 16 * 442.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x04, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_4IN1] = { /* Philips NTSC */
-               .name   = "Philips 4 in 1 (ATI TV Wonder Pro/Conexant)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.00 /*MHz*/, 0x01, },
-                       { 16 * 442.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x04, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_MICROTUNE_4049FM5] = { /* Microtune PAL */
-               .name   = "Microtune 4049 FM5",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 141.00 /*MHz*/, 0xa0, },
-                       { 16 * 464.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PANASONIC_VP27] = { /* Panasonic NTSC */
-               .name   = "Panasonic VP27s/ENGE4324D",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.00 /*MHz*/, 0x01, },
-                       { 16 * 454.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x08, },
-               },
-               .config = 0xce,
-       },
-       [TUNER_LG_NTSC_TAPE] = { /* LGINNOTEK NTSC */
-               .name   = "LG NTSC (TAPE series)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.00 /*MHz*/, 0x01, },
-                       { 16 * 442.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x04, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_TNF_8831BGFF] = { /* Philips PAL */
-               .name   = "Tenna TNF 8831 BGFF)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 161.25 /*MHz*/, 0xa0, },
-                       { 16 * 463.25 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_MICROTUNE_4042FI5] = { /* Microtune NTSC */
-               .name   = "Microtune 4042 FI5 ATSC/NTSC dual in",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 162.00 /*MHz*/, 0xa2, },
-                       { 16 * 457.00 /*MHz*/, 0x94, },
-                       { 16 * 999.99        , 0x31, },
-               },
-               .config = 0x8e,
-       },
-
-       /* 50-59 */
-       [TUNER_TCL_2002N] = { /* TCL NTSC */
-               .name   = "TCL 2002N",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 172.00 /*MHz*/, 0x01, },
-                       { 16 * 448.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x08, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_FM1256_IH3] = { /* Philips PAL */
-               .name   = "Philips PAL/SECAM_D (FM 1256 I-H3)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.00 /*MHz*/, 0x01, },
-                       { 16 * 442.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x04, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_THOMSON_DTT7610] = { /* THOMSON ATSC */
-               .name   = "Thomson DTT 7610 (ATSC/NTSC)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 157.25 /*MHz*/, 0x39, },
-                       { 16 * 454.00 /*MHz*/, 0x3a, },
-                       { 16 * 999.99        , 0x3c, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_FQ1286] = { /* Philips NTSC */
-               .name   = "Philips FQ1286",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.00 /*MHz*/, 0x41, },
-                       { 16 * 454.00 /*MHz*/, 0x42, },
-                       { 16 * 999.99        , 0x04, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_TDA8290] = { /* Philips PAL|NTSC */
-               .name   = "tda8290+75",
-         /* see tda8290.c for details */ },
-       [TUNER_TCL_2002MB] = { /* TCL PAL */
-               .name   = "TCL 2002MB",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 170.00 /*MHz*/, 0x01, },
-                       { 16 * 450.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x08, },
-               },
-               .config = 0xce,
-       },
-       [TUNER_PHILIPS_FQ1216AME_MK4] = { /* Philips PAL */
-               .name   = "Philips PAL/SECAM multi (FQ1216AME MK4)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.00 /*MHz*/, 0x01, },
-                       { 16 * 442.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x04, },
-               },
-               .config = 0xce,
-       },
-       [TUNER_PHILIPS_FQ1236A_MK4] = { /* Philips NTSC */
-               .name   = "Philips FQ1236A MK4",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.00 /*MHz*/, 0x01, },
-                       { 16 * 442.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x04, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_YMEC_TVF_8531MF] = { /* Philips NTSC */
-               .name   = "Ymec TVision TVF-8531MF/8831MF/8731MF",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.00 /*MHz*/, 0xa0, },
-                       { 16 * 454.00 /*MHz*/, 0x90, },
-                       { 16 * 999.99        , 0x30, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_YMEC_TVF_5533MF] = { /* Philips NTSC */
-               .name   = "Ymec TVision TVF-5533MF",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.00 /*MHz*/, 0x01, },
-                       { 16 * 454.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x04, },
-               },
-               .config = 0x8e,
-       },
-
-       /* 60-69 */
-       [TUNER_THOMSON_DTT761X] = { /* THOMSON ATSC */
-               /* DTT 7611 7611A 7612 7613 7613A 7614 7615 7615A */
-               .name   = "Thomson DTT 761X (ATSC/NTSC)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 145.25 /*MHz*/, 0x39, },
-                       { 16 * 415.25 /*MHz*/, 0x3a, },
-                       { 16 * 999.99        , 0x3c, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_TENA_9533_DI] = { /* Philips PAL */
-               .name   = "Tena TNF9533-D/IF/TNF9533-B/DF",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.25 /*MHz*/, 0x01, },
-                       { 16 * 464.25 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x04, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_TEA5767] = { /* Philips RADIO */
-               .name   = "Philips TEA5767HN FM Radio",
-         /* see tea5767.c for details */},
-       [TUNER_PHILIPS_FMD1216ME_MK3] = { /* Philips PAL */
-               .name   = "Philips FMD1216ME MK3 Hybrid Tuner",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.00 /*MHz*/, 0x51, },
-                       { 16 * 442.00 /*MHz*/, 0x52, },
-                       { 16 * 999.99        , 0x54, },
-               },
-               .config = 0x86,
-       },
-       [TUNER_LG_TDVS_H062F] = { /* LGINNOTEK ATSC */
-               .name   = "LG TDVS-H062F/TUA6034",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.00 /*MHz*/, 0x01 },
-                       { 16 * 455.00 /*MHz*/, 0x02 },
-                       { 16 * 999.99        , 0x04 },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_YMEC_TVF66T5_B_DFF] = { /* Philips PAL */
-               .name   = "Ymec TVF66T5-B/DFF",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.25 /*MHz*/, 0x01, },
-                       { 16 * 464.25 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x08, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_LG_NTSC_TALN_MINI] = { /* LGINNOTEK NTSC */
-               .name   = "LG NTSC (TALN mini series)",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 137.25 /*MHz*/, 0x01, },
-                       { 16 * 373.25 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x08, },
-               },
-               .config = 0x8e,
-       },
-       [TUNER_PHILIPS_TD1316] = { /* Philips PAL */
-               .name   = "Philips TD1316 Hybrid Tuner",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 160.00 /*MHz*/, 0xa1, },
-                       { 16 * 442.00 /*MHz*/, 0xa2, },
-                       { 16 * 999.99        , 0xa4, },
-               },
-               .config = 0xc8,
-       },
-       [TUNER_PHILIPS_TUV1236D] = { /* Philips ATSC */
-               .name   = "Philips TUV1236D ATSC/NTSC dual in",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 157.25 /*MHz*/, 0x01, },
-                       { 16 * 454.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x04, },
-               },
-               .config = 0xce,
-       },
-       [TUNER_TNF_5335MF] = { /* Philips NTSC */
-               .name   = "Tena TNF 5335 MF",
-               .count  = 3,
-               .ranges = {
-                       { 16 * 157.25 /*MHz*/, 0x01, },
-                       { 16 * 454.00 /*MHz*/, 0x02, },
-                       { 16 * 999.99        , 0x04, },
-               },
-               .config = 0x8e,
-       },
-};
-
-unsigned const int tuner_count = ARRAY_SIZE(tuners);
 
 /* ---------------------------------------------------------------------- */
 
@@ -843,15 +137,17 @@ static void default_set_tv_freq(struct i2c_client *c, unsigned int freq)
        u16 div;
        struct tunertype *tun;
        unsigned char buffer[4];
-       int rc, IFPCoff, i;
+       int rc, IFPCoff, i, j;
 
        tun = &tuners[t->type];
-       for (i = 0; i < tun->count; i++) {
-               if (freq > tun->ranges[i].thresh)
+       j = TUNER_PARAM_ANALOG;
+
+       for (i = 0; i < tun->params[j].count; i++) {
+               if (freq > tun->params[j].ranges[i].limit)
                        continue;
                break;
        }
-       config = tun->ranges[i].cb;
+       config = tun->params[j].ranges[i].cb;
        /*  i == 0 -> VHF_LO  */
        /*  i == 1 -> VHF_HI  */
        /*  i == 2 -> UHF     */
@@ -914,7 +210,7 @@ static void default_set_tv_freq(struct i2c_client *c, unsigned int freq)
 
        case TUNER_MICROTUNE_4042FI5:
                /* Set the charge pump for fast tuning */
-               tun->config |= TUNER_CHARGE_PUMP;
+               tun->params[j].config |= TUNER_CHARGE_PUMP;
                break;
 
        case TUNER_PHILIPS_TUV1236D:
@@ -989,14 +285,14 @@ static void default_set_tv_freq(struct i2c_client *c, unsigned int freq)
                                        div);
 
        if (t->type == TUNER_PHILIPS_SECAM && freq < t->freq) {
-               buffer[0] = tun->config;
+               buffer[0] = tun->params[j].config;
                buffer[1] = config;
                buffer[2] = (div>>8) & 0x7f;
                buffer[3] = div      & 0xff;
        } else {
                buffer[0] = (div>>8) & 0x7f;
                buffer[1] = div      & 0xff;
-               buffer[2] = tun->config;
+               buffer[2] = tun->params[j].config;
                buffer[3] = config;
        }
        tuner_dbg("tv 0x%02x 0x%02x 0x%02x 0x%02x\n",
@@ -1024,10 +320,10 @@ static void default_set_tv_freq(struct i2c_client *c, unsigned int freq)
                }
 
                /* Set the charge pump for optimized phase noise figure */
-               tun->config &= ~TUNER_CHARGE_PUMP;
+               tun->params[j].config &= ~TUNER_CHARGE_PUMP;
                buffer[0] = (div>>8) & 0x7f;
                buffer[1] = div      & 0xff;
-               buffer[2] = tun->config;
+               buffer[2] = tun->params[j].config;
                buffer[3] = config;
                tuner_dbg("tv 0x%02x 0x%02x 0x%02x 0x%02x\n",
                       buffer[0],buffer[1],buffer[2],buffer[3]);
@@ -1043,11 +339,13 @@ static void default_set_radio_freq(struct i2c_client *c, unsigned int freq)
        struct tuner *t = i2c_get_clientdata(c);
        unsigned char buffer[4];
        unsigned div;
-       int rc;
+       int rc, j;
 
        tun = &tuners[t->type];
+       j = TUNER_PARAM_ANALOG;
+
        div = (20 * freq / 16000) + (int)(20*10.7); /* IF 10.7 MHz */
-       buffer[2] = (tun->config & ~TUNER_RATIO_MASK) | TUNER_RATIO_SELECT_50; /* 50 kHz step */
+       buffer[2] = (tun->params[j].config & ~TUNER_RATIO_MASK) | TUNER_RATIO_SELECT_50; /* 50 kHz step */
 
        switch (t->type) {
        case TUNER_TENA_9533_DI:
diff --git a/drivers/media/video/tuner-types.c b/drivers/media/video/tuner-types.c
new file mode 100644 (file)
index 0000000..32c9be4
--- /dev/null
@@ -0,0 +1,1400 @@
+/*
+ *
+ * i2c tv tuner chip device type database.
+ *
+ */
+
+#include <linux/i2c.h>
+#include <media/tuner.h>
+#include <media/tuner-types.h>
+
+/* ---------------------------------------------------------------------- */
+
+/*
+ *     The floats in the tuner struct are computed at compile time
+ *     by gcc and cast back to integers. Thus we don't violate the
+ *     "no float in kernel" rule.
+ *
+ *     A tuner_range may be referenced by multiple tuner_params structs.
+ *     There are many duplicates in here. Reusing tuner_range structs,
+ *     rather than defining new ones for each tuner, will cut down on
+ *     memory usage, and is preferred when possible.
+ *
+ *     Each tuner_params array may contain one or more elements, one
+ *     for each video standard.
+ *
+ *     FIXME: Some tuner_range definitions are duplicated, and
+ *     should be eliminated.
+ *
+ *     FIXME: tunertype struct contains an element, has_tda988x.
+ *     We must set this for all tunertypes that contain a tda988x
+ *     chip, and then we can remove this setting from the various
+ *     card structs.
+ */
+
+/* 0-9 */
+/* ------------ TUNER_TEMIC_PAL - TEMIC PAL ------------ */
+
+static struct tuner_range tuner_temic_pal_ranges[] = {
+       { 16 * 140.25 /*MHz*/, 0x02, },
+       { 16 * 463.25 /*MHz*/, 0x04, },
+       { 16 * 999.99        , 0x01, },
+};
+
+static struct tuner_params tuner_temic_pal_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_temic_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_PAL_I - Philips PAL_I ------------ */
+
+static struct tuner_range tuner_philips_pal_i_ranges[] = {
+       { 16 * 140.25 /*MHz*/, 0xa0, },
+       { 16 * 463.25 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_philips_pal_i_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_philips_pal_i_ranges,
+               .count  = ARRAY_SIZE(tuner_philips_pal_i_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_NTSC - Philips NTSC ------------ */
+
+static struct tuner_range tuner_philips_ntsc_ranges[] = {
+       { 16 * 157.25 /*MHz*/, 0xa0, },
+       { 16 * 451.25 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_philips_ntsc_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_philips_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_philips_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_SECAM - Philips SECAM ------------ */
+
+static struct tuner_range tuner_philips_secam_ranges[] = {
+       { 16 * 168.25 /*MHz*/, 0xa7, },
+       { 16 * 447.25 /*MHz*/, 0x97, },
+       { 16 * 999.99        , 0x37, },
+};
+
+static struct tuner_params tuner_philips_secam_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_SECAM,
+               .ranges = tuner_philips_secam_ranges,
+               .count  = ARRAY_SIZE(tuner_philips_secam_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_PAL - Philips PAL ------------ */
+
+static struct tuner_range tuner_philips_pal_ranges[] = {
+       { 16 * 168.25 /*MHz*/, 0xa0, },
+       { 16 * 447.25 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_philips_pal_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_philips_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_philips_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TEMIC_NTSC - TEMIC NTSC ------------ */
+
+static struct tuner_range tuner_temic_ntsc_ranges[] = {
+       { 16 * 157.25 /*MHz*/, 0x02, },
+       { 16 * 463.25 /*MHz*/, 0x04, },
+       { 16 * 999.99        , 0x01, },
+};
+
+static struct tuner_params tuner_temic_ntsc_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_temic_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TEMIC_PAL_I - TEMIC PAL_I ------------ */
+
+static struct tuner_range tuner_temic_pal_i_ranges[] = {
+       { 16 * 170.00 /*MHz*/, 0x02, },
+       { 16 * 450.00 /*MHz*/, 0x04, },
+       { 16 * 999.99        , 0x01, },
+};
+
+static struct tuner_params tuner_temic_pal_i_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_temic_pal_i_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_pal_i_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TEMIC_4036FY5_NTSC - TEMIC NTSC ------------ */
+
+static struct tuner_range tuner_temic_4036fy5_ntsc_ranges[] = {
+       { 16 * 157.25 /*MHz*/, 0xa0, },
+       { 16 * 463.25 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_temic_4036fy5_ntsc_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_temic_4036fy5_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_4036fy5_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_ALPS_TSBH1_NTSC - TEMIC NTSC ------------ */
+
+static struct tuner_range tuner_alps_tsb_1_ranges[] = {
+       { 16 * 137.25 /*MHz*/, 0x01, },
+       { 16 * 385.25 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x08, },
+};
+
+static struct tuner_params tuner_alps_tsbh1_ntsc_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_alps_tsb_1_ranges,
+               .count  = ARRAY_SIZE(tuner_alps_tsb_1_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* 10-19 */
+/* ------------ TUNER_ALPS_TSBE1_PAL - TEMIC PAL ------------ */
+
+static struct tuner_params tuner_alps_tsb_1_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_alps_tsb_1_ranges,
+               .count  = ARRAY_SIZE(tuner_alps_tsb_1_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_ALPS_TSBB5_PAL_I - Alps PAL_I ------------ */
+
+static struct tuner_range tuner_alps_tsb_5_pal_ranges[] = {
+       { 16 * 133.25 /*MHz*/, 0x01, },
+       { 16 * 351.25 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x08, },
+};
+
+static struct tuner_params tuner_alps_tsbb5_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_alps_tsb_5_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_alps_tsb_5_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_ALPS_TSBE5_PAL - Alps PAL ------------ */
+
+static struct tuner_params tuner_alps_tsbe5_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_alps_tsb_5_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_alps_tsb_5_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_ALPS_TSBC5_PAL - Alps PAL ------------ */
+
+static struct tuner_params tuner_alps_tsbc5_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_alps_tsb_5_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_alps_tsb_5_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TEMIC_4006FH5_PAL - TEMIC PAL ------------ */
+
+static struct tuner_range tuner_temic_4006fh5_pal_ranges[] = {
+       { 16 * 170.00 /*MHz*/, 0xa0, },
+       { 16 * 450.00 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_temic_4006fh5_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_temic_4006fh5_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_4006fh5_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_ALPS_TSHC6_NTSC - Alps NTSC ------------ */
+
+static struct tuner_range tuner_alps_tshc6_ntsc_ranges[] = {
+       { 16 * 137.25 /*MHz*/, 0x14, },
+       { 16 * 385.25 /*MHz*/, 0x12, },
+       { 16 * 999.99        , 0x11, },
+};
+
+static struct tuner_params tuner_alps_tshc6_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_alps_tshc6_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_alps_tshc6_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TEMIC_PAL_DK - TEMIC PAL ------------ */
+
+static struct tuner_range tuner_temic_pal_dk_ranges[] = {
+       { 16 * 168.25 /*MHz*/, 0xa0, },
+       { 16 * 456.25 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_temic_pal_dk_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_temic_pal_dk_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_pal_dk_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_NTSC_M - Philips NTSC ------------ */
+
+static struct tuner_range tuner_philips_ntsc_m_ranges[] = {
+       { 16 * 160.00 /*MHz*/, 0xa0, },
+       { 16 * 454.00 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_philips_ntsc_m_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_philips_ntsc_m_ranges,
+               .count  = ARRAY_SIZE(tuner_philips_ntsc_m_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TEMIC_4066FY5_PAL_I - TEMIC PAL_I ------------ */
+
+static struct tuner_range tuner_temic_40x6f_5_pal_ranges[] = {
+       { 16 * 169.00 /*MHz*/, 0xa0, },
+       { 16 * 454.00 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_temic_4066fy5_pal_i_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_temic_40x6f_5_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_40x6f_5_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TEMIC_4006FN5_MULTI_PAL - TEMIC PAL ------------ */
+
+static struct tuner_params tuner_temic_4006fn5_multi_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_temic_40x6f_5_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_40x6f_5_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* 20-29 */
+/* ------------ TUNER_TEMIC_4009FR5_PAL - TEMIC PAL ------------ */
+
+static struct tuner_range tuner_temic_4009f_5_pal_ranges[] = {
+       { 16 * 141.00 /*MHz*/, 0xa0, },
+       { 16 * 464.00 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_temic_4009f_5_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_temic_4009f_5_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_4009f_5_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TEMIC_4039FR5_NTSC - TEMIC NTSC ------------ */
+
+static struct tuner_range tuner_temic_4039fr5_ntsc_ranges[] = {
+       { 16 * 158.00 /*MHz*/, 0xa0, },
+       { 16 * 453.00 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_temic_4039fr5_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_temic_4039fr5_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_4039fr5_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TEMIC_4046FM5 - TEMIC PAL ------------ */
+
+static struct tuner_range tuner_temic_4046fm5_pal_ranges[] = {
+       { 16 * 169.00 /*MHz*/, 0xa0, },
+       { 16 * 454.00 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_temic_4046fm5_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_temic_4046fm5_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_4046fm5_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_PAL_DK - Philips PAL ------------ */
+
+static struct tuner_range tuner_lg_pal_ranges[] = {
+       { 16 * 170.00 /*MHz*/, 0xa0, },
+       { 16 * 450.00 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_philips_pal_dk_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_lg_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_lg_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_FQ1216ME - Philips PAL ------------ */
+
+static struct tuner_params tuner_philips_fq1216me_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_lg_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_lg_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_LG_PAL_I_FM - LGINNOTEK PAL_I ------------ */
+
+static struct tuner_params tuner_lg_pal_i_fm_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_lg_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_lg_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_LG_PAL_I - LGINNOTEK PAL_I ------------ */
+
+static struct tuner_params tuner_lg_pal_i_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_lg_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_lg_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_LG_NTSC_FM - LGINNOTEK NTSC ------------ */
+
+static struct tuner_range tuner_lg_ntsc_fm_ranges[] = {
+       { 16 * 210.00 /*MHz*/, 0xa0, },
+       { 16 * 497.00 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_lg_ntsc_fm_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_lg_ntsc_fm_ranges,
+               .count  = ARRAY_SIZE(tuner_lg_ntsc_fm_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_LG_PAL_FM - LGINNOTEK PAL ------------ */
+
+static struct tuner_params tuner_lg_pal_fm_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_lg_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_lg_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_LG_PAL - LGINNOTEK PAL ------------ */
+
+static struct tuner_params tuner_lg_pal_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_lg_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_lg_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* 30-39 */
+/* ------------ TUNER_TEMIC_4009FN5_MULTI_PAL_FM - TEMIC PAL ------------ */
+
+static struct tuner_params tuner_temic_4009_fn5_multi_pal_fm_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_temic_4009f_5_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_4009f_5_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_SHARP_2U5JF5540_NTSC - SHARP NTSC ------------ */
+
+static struct tuner_range tuner_sharp_2u5jf5540_ntsc_ranges[] = {
+       { 16 * 137.25 /*MHz*/, 0x01, },
+       { 16 * 317.25 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x08, },
+};
+
+static struct tuner_params tuner_sharp_2u5jf5540_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_sharp_2u5jf5540_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_sharp_2u5jf5540_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_Samsung_PAL_TCPM9091PD27 - Samsung PAL ------------ */
+
+static struct tuner_range tuner_samsung_pal_tcpm9091pd27_ranges[] = {
+       { 16 * 169 /*MHz*/, 0xa0, },
+       { 16 * 464 /*MHz*/, 0x90, },
+       { 16 * 999.99     , 0x30, },
+};
+
+static struct tuner_params tuner_samsung_pal_tcpm9091pd27_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_samsung_pal_tcpm9091pd27_ranges,
+               .count  = ARRAY_SIZE(tuner_samsung_pal_tcpm9091pd27_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TEMIC_4106FH5 - TEMIC PAL ------------ */
+
+static struct tuner_params tuner_temic_4106fh5_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_temic_4009f_5_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_4009f_5_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TEMIC_4012FY5 - TEMIC PAL ------------ */
+
+static struct tuner_range tuner_temic_4012fy5_pal_ranges[] = {
+       { 16 * 140.25 /*MHz*/, 0x02, },
+       { 16 * 463.25 /*MHz*/, 0x04, },
+       { 16 * 999.99        , 0x01, },
+};
+
+static struct tuner_params tuner_temic_4012fy5_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_temic_4012fy5_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_4012fy5_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TEMIC_4136FY5 - TEMIC NTSC ------------ */
+
+static struct tuner_range tuner_temic_4136_fy5_ntsc_ranges[] = {
+       { 16 * 158.00 /*MHz*/, 0xa0, },
+       { 16 * 453.00 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_temic_4136_fy5_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_temic_4136_fy5_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_4136_fy5_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_LG_PAL_NEW_TAPC - LGINNOTEK PAL ------------ */
+
+static struct tuner_range tuner_lg_new_tapc_ranges[] = {
+       { 16 * 170.00 /*MHz*/, 0x01, },
+       { 16 * 450.00 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x08, },
+};
+
+static struct tuner_params tuner_lg_pal_new_tapc_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_lg_new_tapc_ranges,
+               .count  = ARRAY_SIZE(tuner_lg_new_tapc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_FM1216ME_MK3 - Philips PAL ------------ */
+
+static struct tuner_range tuner_fm1216me_mk3_pal_ranges[] = {
+       { 16 * 158.00 /*MHz*/, 0x01, },
+       { 16 * 442.00 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x04, },
+};
+
+static struct tuner_params tuner_fm1216me_mk3_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_fm1216me_mk3_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_fm1216me_mk3_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_LG_NTSC_NEW_TAPC - LGINNOTEK NTSC ------------ */
+
+static struct tuner_params tuner_lg_ntsc_new_tapc_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_lg_new_tapc_ranges,
+               .count  = ARRAY_SIZE(tuner_lg_new_tapc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* 40-49 */
+/* ------------ TUNER_HITACHI_NTSC - HITACHI NTSC ------------ */
+
+static struct tuner_params tuner_hitachi_ntsc_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_lg_new_tapc_ranges,
+               .count  = ARRAY_SIZE(tuner_lg_new_tapc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_PAL_MK - Philips PAL ------------ */
+
+static struct tuner_range tuner_philips_pal_mk_pal_ranges[] = {
+       { 16 * 140.25 /*MHz*/, 0x01, },
+       { 16 * 463.25 /*MHz*/, 0xc2, },
+       { 16 * 999.99        , 0xcf, },
+};
+
+static struct tuner_params tuner_philips_pal_mk_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_philips_pal_mk_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_philips_pal_mk_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_ATSC - Philips ATSC ------------ */
+
+static struct tuner_range tuner_philips_atsc_ranges[] = {
+       { 16 * 157.25 /*MHz*/, 0xa0, },
+       { 16 * 454.00 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_philips_atsc_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_philips_atsc_ranges,
+               .count  = ARRAY_SIZE(tuner_philips_atsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_FM1236_MK3 - Philips NTSC ------------ */
+
+static struct tuner_range tuner_fm1236_mk3_ntsc_ranges[] = {
+       { 16 * 160.00 /*MHz*/, 0x01, },
+       { 16 * 442.00 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x04, },
+};
+
+static struct tuner_params tuner_fm1236_mk3_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_fm1236_mk3_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_fm1236_mk3_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_4IN1 - Philips NTSC ------------ */
+
+static struct tuner_range tuner_philips_4in1_ntsc_ranges[] = {
+       { 16 * 160.00 /*MHz*/, 0x01, },
+       { 16 * 442.00 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x04, },
+};
+
+static struct tuner_params tuner_philips_4in1_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_philips_4in1_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_philips_4in1_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_MICROTUNE_4049FM5 - Microtune PAL ------------ */
+
+static struct tuner_params tuner_microtune_4049_fm5_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_temic_4009f_5_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_temic_4009f_5_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PANASONIC_VP27 - Panasonic NTSC ------------ */
+
+static struct tuner_range tuner_panasonic_vp27_ntsc_ranges[] = {
+       { 16 * 160.00 /*MHz*/, 0x01, },
+       { 16 * 454.00 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x08, },
+};
+
+static struct tuner_params tuner_panasonic_vp27_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_panasonic_vp27_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_panasonic_vp27_ntsc_ranges),
+               .config = 0xce,
+       },
+};
+
+/* ------------ TUNER_LG_NTSC_TAPE - LGINNOTEK NTSC ------------ */
+
+static struct tuner_range tuner_lg_ntsc_tape_ranges[] = {
+       { 16 * 160.00 /*MHz*/, 0x01, },
+       { 16 * 442.00 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x04, },
+};
+
+static struct tuner_params tuner_lg_ntsc_tape_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_lg_ntsc_tape_ranges,
+               .count  = ARRAY_SIZE(tuner_lg_ntsc_tape_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TNF_8831BGFF - Philips PAL ------------ */
+
+static struct tuner_range tuner_tnf_8831bgff_pal_ranges[] = {
+       { 16 * 161.25 /*MHz*/, 0xa0, },
+       { 16 * 463.25 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_tnf_8831bgff_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_tnf_8831bgff_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_tnf_8831bgff_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_MICROTUNE_4042FI5 - Microtune NTSC ------------ */
+
+static struct tuner_range tuner_microtune_4042fi5_ntsc_ranges[] = {
+       { 16 * 162.00 /*MHz*/, 0xa2, },
+       { 16 * 457.00 /*MHz*/, 0x94, },
+       { 16 * 999.99        , 0x31, },
+};
+
+static struct tuner_params tuner_microtune_4042fi5_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_microtune_4042fi5_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_microtune_4042fi5_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* 50-59 */
+/* ------------ TUNER_TCL_2002N - TCL NTSC ------------ */
+
+static struct tuner_range tuner_tcl_2002n_ntsc_ranges[] = {
+       { 16 * 172.00 /*MHz*/, 0x01, },
+       { 16 * 448.00 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x08, },
+};
+
+static struct tuner_params tuner_tcl_2002n_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_tcl_2002n_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_tcl_2002n_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_FM1256_IH3 - Philips PAL ------------ */
+
+static struct tuner_range tuner_philips_fm1256_ih3_pal_ranges[] = {
+       { 16 * 160.00 /*MHz*/, 0x01, },
+       { 16 * 442.00 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x04, },
+};
+
+static struct tuner_params tuner_philips_fm1256_ih3_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_philips_fm1256_ih3_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_philips_fm1256_ih3_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_THOMSON_DTT7610 - THOMSON ATSC ------------ */
+
+static struct tuner_range tuner_thomson_dtt7610_ntsc_ranges[] = {
+       { 16 * 157.25 /*MHz*/, 0x39, },
+       { 16 * 454.00 /*MHz*/, 0x3a, },
+       { 16 * 999.99        , 0x3c, },
+};
+
+static struct tuner_params tuner_thomson_dtt7610_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_thomson_dtt7610_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_thomson_dtt7610_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_FQ1286 - Philips NTSC ------------ */
+
+static struct tuner_range tuner_philips_fq1286_ntsc_ranges[] = {
+       { 16 * 160.00 /*MHz*/, 0x41, },
+       { 16 * 454.00 /*MHz*/, 0x42, },
+       { 16 * 999.99        , 0x04, },
+};
+
+static struct tuner_params tuner_philips_fq1286_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_philips_fq1286_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_philips_fq1286_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TCL_2002MB - TCL PAL ------------ */
+
+static struct tuner_range tuner_tcl_2002mb_pal_ranges[] = {
+       { 16 * 170.00 /*MHz*/, 0x01, },
+       { 16 * 450.00 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x08, },
+};
+
+static struct tuner_params tuner_tcl_2002mb_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_tcl_2002mb_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_tcl_2002mb_pal_ranges),
+               .config = 0xce,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_FQ1216AME_MK4 - Philips PAL ------------ */
+
+static struct tuner_range tuner_philips_fq12_6a___mk4_ranges[] = {
+       { 16 * 160.00 /*MHz*/, 0x01, },
+       { 16 * 442.00 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x04, },
+};
+
+static struct tuner_params tuner_philips_fq1216ame_mk4_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_philips_fq12_6a___mk4_ranges,
+               .count  = ARRAY_SIZE(tuner_philips_fq12_6a___mk4_ranges),
+               .config = 0xce,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_FQ1236A_MK4 - Philips NTSC ------------ */
+
+static struct tuner_params tuner_philips_fq1236a_mk4_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_philips_fq12_6a___mk4_ranges,
+               .count  = ARRAY_SIZE(tuner_philips_fq12_6a___mk4_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_YMEC_TVF_8531MF - Philips NTSC ------------ */
+
+static struct tuner_range tuner_ymec_tvf_8531mf_ntsc_ranges[] = {
+       { 16 * 160.00 /*MHz*/, 0xa0, },
+       { 16 * 454.00 /*MHz*/, 0x90, },
+       { 16 * 999.99        , 0x30, },
+};
+
+static struct tuner_params tuner_ymec_tvf_8531mf_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_ymec_tvf_8531mf_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_ymec_tvf_8531mf_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_YMEC_TVF_5533MF - Philips NTSC ------------ */
+
+static struct tuner_range tuner_ymec_tvf_5533mf_ntsc_ranges[] = {
+       { 16 * 160.00 /*MHz*/, 0x01, },
+       { 16 * 454.00 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x04, },
+};
+
+static struct tuner_params tuner_ymec_tvf_5533mf_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_ymec_tvf_5533mf_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_ymec_tvf_5533mf_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* 60-69 */
+/* ------------ TUNER_THOMSON_DTT761X - THOMSON ATSC ------------ */
+/* DTT 7611 7611A 7612 7613 7613A 7614 7615 7615A */
+
+static struct tuner_range tuner_thomson_dtt761x_ntsc_ranges[] = {
+       { 16 * 145.25 /*MHz*/, 0x39, },
+       { 16 * 415.25 /*MHz*/, 0x3a, },
+       { 16 * 999.99        , 0x3c, },
+};
+
+
+static struct tuner_params tuner_thomson_dtt761x_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_thomson_dtt761x_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_thomson_dtt761x_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_TENA_9533_DI - Philips PAL ------------ */
+
+static struct tuner_range tuner_tuner_tena_9533_di_pal_ranges[] = {
+       { 16 * 160.25 /*MHz*/, 0x01, },
+       { 16 * 464.25 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x04, },
+};
+
+static struct tuner_params tuner_tena_9533_di_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_tuner_tena_9533_di_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_tuner_tena_9533_di_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_FMD1216ME_MK3 - Philips PAL ------------ */
+
+static struct tuner_range tuner_philips_fmd1216me_mk3_pal_ranges[] = {
+       { 16 * 160.00 /*MHz*/, 0x51, },
+       { 16 * 442.00 /*MHz*/, 0x52, },
+       { 16 * 999.99        , 0x54, },
+};
+
+
+static struct tuner_params tuner_tuner_philips_fmd1216me_mk3_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_philips_fmd1216me_mk3_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_philips_fmd1216me_mk3_pal_ranges),
+               .config = 0x86,
+       },
+};
+
+
+/* ------------ TUNER_LG_TDVS_H062F - INFINEON ATSC ------------ */
+
+static struct tuner_range tuner_tua6034_ntsc_ranges[] = {
+       { 16 * 160.00 /*MHz*/, 0x01 },
+       { 16 * 455.00 /*MHz*/, 0x02 },
+       { 16 * 999.99        , 0x04 },
+};
+
+
+static struct tuner_params tuner_tua6034_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_tua6034_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_tua6034_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_YMEC_TVF66T5_B_DFF - Philips PAL ------------ */
+
+static struct tuner_range tuner_ymec_tvf66t5_b_dff_pal_ranges[] = {
+       { 16 * 160.25 /*MHz*/, 0x01, },
+       { 16 * 464.25 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x08, },
+};
+
+static struct tuner_params tuner_ymec_tvf66t5_b_dff_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_ymec_tvf66t5_b_dff_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_ymec_tvf66t5_b_dff_pal_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_LG_NTSC_TALN_MINI - LGINNOTEK NTSC ------------ */
+
+static struct tuner_range tuner_lg_taln_mini_ntsc_ranges[] = {
+       { 16 * 137.25 /*MHz*/, 0x01, },
+       { 16 * 373.25 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x08, },
+};
+
+static struct tuner_params tuner_lg_taln_mini_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_lg_taln_mini_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_lg_taln_mini_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_TD1316 - Philips PAL ------------ */
+
+static struct tuner_range tuner_philips_td1316_pal_ranges[] = {
+       { 16 * 160.00 /*MHz*/, 0xa1, },
+       { 16 * 442.00 /*MHz*/, 0xa2, },
+       { 16 * 999.99        , 0xa4, },
+};
+
+static struct tuner_params tuner_philips_td1316_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_PAL,
+               .ranges = tuner_philips_td1316_pal_ranges,
+               .count  = ARRAY_SIZE(tuner_philips_td1316_pal_ranges),
+               .config = 0xc8,
+       },
+};
+
+/* ------------ TUNER_PHILIPS_TUV1236D - Philips ATSC ------------ */
+
+static struct tuner_range tuner_tuv1236d_ntsc_ranges[] = {
+       { 16 * 157.25 /*MHz*/, 0x01, },
+       { 16 * 454.00 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x04, },
+};
+
+
+static struct tuner_params tuner_tuner_tuv1236d_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_tuv1236d_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_tuv1236d_ntsc_ranges),
+               .config = 0xce,
+       },
+};
+
+/* ------------ TUNER_TNF_5335MF - Philips NTSC ------------ */
+
+static struct tuner_range tuner_tnf_5335mf_ntsc_ranges[] = {
+       { 16 * 157.25 /*MHz*/, 0x01, },
+       { 16 * 454.00 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x04, },
+};
+
+static struct tuner_params tuner_tnf_5335mf_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_tnf_5335mf_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_tnf_5335mf_ntsc_ranges),
+               .config = 0x8e,
+       },
+};
+
+/* 70-79 */
+/* ------------ TUNER_SAMSUNG_TCPN_2121P30A - Samsung NTSC ------------ */
+
+static struct tuner_range tuner_samsung_tcpn_2121p30a_ntsc_ranges[] = {
+       { 16 * 175.75 /*MHz*/, 0x01, },
+       { 16 * 410.25 /*MHz*/, 0x02, },
+       { 16 * 999.99        , 0x08, },
+};
+
+static struct tuner_params tuner_samsung_tcpn_2121p30a_params[] = {
+       {
+               .type   = TUNER_PARAM_TYPE_NTSC,
+               .ranges = tuner_samsung_tcpn_2121p30a_ntsc_ranges,
+               .count  = ARRAY_SIZE(tuner_samsung_tcpn_2121p30a_ntsc_ranges),
+               .config = 0xce,
+       },
+};
+
+/* --------------------------------------------------------------------- */
+
+struct tunertype tuners[] = {
+       /* 0-9 */
+       [TUNER_TEMIC_PAL] = { /* TEMIC PAL */
+               .name   = "Temic PAL (4002 FH5)",
+               .params = tuner_temic_pal_params,
+       },
+       [TUNER_PHILIPS_PAL_I] = { /* Philips PAL_I */
+               .name   = "Philips PAL_I (FI1246 and compatibles)",
+               .params = tuner_philips_pal_i_params,
+       },
+       [TUNER_PHILIPS_NTSC] = { /* Philips NTSC */
+               .name   = "Philips NTSC (FI1236,FM1236 and compatibles)",
+               .params = tuner_philips_ntsc_params,
+       },
+       [TUNER_PHILIPS_SECAM] = { /* Philips SECAM */
+               .name   = "Philips (SECAM+PAL_BG) (FI1216MF, FM1216MF, FR1216MF)",
+               .params = tuner_philips_secam_params,
+       },
+       [TUNER_ABSENT] = { /* Tuner Absent */
+               .name   = "NoTuner",
+       },
+       [TUNER_PHILIPS_PAL] = { /* Philips PAL */
+               .name   = "Philips PAL_BG (FI1216 and compatibles)",
+               .params = tuner_philips_pal_params,
+       },
+       [TUNER_TEMIC_NTSC] = { /* TEMIC NTSC */
+               .name   = "Temic NTSC (4032 FY5)",
+               .params = tuner_temic_ntsc_params,
+       },
+       [TUNER_TEMIC_PAL_I] = { /* TEMIC PAL_I */
+               .name   = "Temic PAL_I (4062 FY5)",
+               .params = tuner_temic_pal_i_params,
+       },
+       [TUNER_TEMIC_4036FY5_NTSC] = { /* TEMIC NTSC */
+               .name   = "Temic NTSC (4036 FY5)",
+               .params = tuner_temic_4036fy5_ntsc_params,
+       },
+       [TUNER_ALPS_TSBH1_NTSC] = { /* TEMIC NTSC */
+               .name   = "Alps HSBH1",
+               .params = tuner_alps_tsbh1_ntsc_params,
+       },
+
+       /* 10-19 */
+       [TUNER_ALPS_TSBE1_PAL] = { /* TEMIC PAL */
+               .name   = "Alps TSBE1",
+               .params = tuner_alps_tsb_1_params,
+       },
+       [TUNER_ALPS_TSBB5_PAL_I] = { /* Alps PAL_I */
+               .name   = "Alps TSBB5",
+               .params = tuner_alps_tsbb5_params,
+       },
+       [TUNER_ALPS_TSBE5_PAL] = { /* Alps PAL */
+               .name   = "Alps TSBE5",
+               .params = tuner_alps_tsbe5_params,
+       },
+       [TUNER_ALPS_TSBC5_PAL] = { /* Alps PAL */
+               .name   = "Alps TSBC5",
+               .params = tuner_alps_tsbc5_params,
+       },
+       [TUNER_TEMIC_4006FH5_PAL] = { /* TEMIC PAL */
+               .name   = "Temic PAL_BG (4006FH5)",
+               .params = tuner_temic_4006fh5_params,
+       },
+       [TUNER_ALPS_TSHC6_NTSC] = { /* Alps NTSC */
+               .name   = "Alps TSCH6",
+               .params = tuner_alps_tshc6_params,
+       },
+       [TUNER_TEMIC_PAL_DK] = { /* TEMIC PAL */
+               .name   = "Temic PAL_DK (4016 FY5)",
+               .params = tuner_temic_pal_dk_params,
+       },
+       [TUNER_PHILIPS_NTSC_M] = { /* Philips NTSC */
+               .name   = "Philips NTSC_M (MK2)",
+               .params = tuner_philips_ntsc_m_params,
+       },
+       [TUNER_TEMIC_4066FY5_PAL_I] = { /* TEMIC PAL_I */
+               .name   = "Temic PAL_I (4066 FY5)",
+               .params = tuner_temic_4066fy5_pal_i_params,
+       },
+       [TUNER_TEMIC_4006FN5_MULTI_PAL] = { /* TEMIC PAL */
+               .name   = "Temic PAL* auto (4006 FN5)",
+               .params = tuner_temic_4006fn5_multi_params,
+       },
+
+       /* 20-29 */
+       [TUNER_TEMIC_4009FR5_PAL] = { /* TEMIC PAL */
+               .name   = "Temic PAL_BG (4009 FR5) or PAL_I (4069 FR5)",
+               .params = tuner_temic_4009f_5_params,
+       },
+       [TUNER_TEMIC_4039FR5_NTSC] = { /* TEMIC NTSC */
+               .name   = "Temic NTSC (4039 FR5)",
+               .params = tuner_temic_4039fr5_params,
+       },
+       [TUNER_TEMIC_4046FM5] = { /* TEMIC PAL */
+               .name   = "Temic PAL/SECAM multi (4046 FM5)",
+               .params = tuner_temic_4046fm5_params,
+       },
+       [TUNER_PHILIPS_PAL_DK] = { /* Philips PAL */
+               .name   = "Philips PAL_DK (FI1256 and compatibles)",
+               .params = tuner_philips_pal_dk_params,
+       },
+       [TUNER_PHILIPS_FQ1216ME] = { /* Philips PAL */
+               .name   = "Philips PAL/SECAM multi (FQ1216ME)",
+               .params = tuner_philips_fq1216me_params,
+       },
+       [TUNER_LG_PAL_I_FM] = { /* LGINNOTEK PAL_I */
+               .name   = "LG PAL_I+FM (TAPC-I001D)",
+               .params = tuner_lg_pal_i_fm_params,
+       },
+       [TUNER_LG_PAL_I] = { /* LGINNOTEK PAL_I */
+               .name   = "LG PAL_I (TAPC-I701D)",
+               .params = tuner_lg_pal_i_params,
+       },
+       [TUNER_LG_NTSC_FM] = { /* LGINNOTEK NTSC */
+               .name   = "LG NTSC+FM (TPI8NSR01F)",
+               .params = tuner_lg_ntsc_fm_params,
+       },
+       [TUNER_LG_PAL_FM] = { /* LGINNOTEK PAL */
+               .name   = "LG PAL_BG+FM (TPI8PSB01D)",
+               .params = tuner_lg_pal_fm_params,
+       },
+       [TUNER_LG_PAL] = { /* LGINNOTEK PAL */
+               .name   = "LG PAL_BG (TPI8PSB11D)",
+               .params = tuner_lg_pal_params,
+       },
+
+       /* 30-39 */
+       [TUNER_TEMIC_4009FN5_MULTI_PAL_FM] = { /* TEMIC PAL */
+               .name   = "Temic PAL* auto + FM (4009 FN5)",
+               .params = tuner_temic_4009_fn5_multi_pal_fm_params,
+       },
+       [TUNER_SHARP_2U5JF5540_NTSC] = { /* SHARP NTSC */
+               .name   = "SHARP NTSC_JP (2U5JF5540)",
+               .params = tuner_sharp_2u5jf5540_params,
+       },
+       [TUNER_Samsung_PAL_TCPM9091PD27] = { /* Samsung PAL */
+               .name   = "Samsung PAL TCPM9091PD27",
+               .params = tuner_samsung_pal_tcpm9091pd27_params,
+       },
+       [TUNER_MT2032] = { /* Microtune PAL|NTSC */
+               .name   = "MT20xx universal",
+               /* see mt20xx.c for details */ },
+       [TUNER_TEMIC_4106FH5] = { /* TEMIC PAL */
+               .name   = "Temic PAL_BG (4106 FH5)",
+               .params = tuner_temic_4106fh5_params,
+       },
+       [TUNER_TEMIC_4012FY5] = { /* TEMIC PAL */
+               .name   = "Temic PAL_DK/SECAM_L (4012 FY5)",
+               .params = tuner_temic_4012fy5_params,
+       },
+       [TUNER_TEMIC_4136FY5] = { /* TEMIC NTSC */
+               .name   = "Temic NTSC (4136 FY5)",
+               .params = tuner_temic_4136_fy5_params,
+       },
+       [TUNER_LG_PAL_NEW_TAPC] = { /* LGINNOTEK PAL */
+               .name   = "LG PAL (newer TAPC series)",
+               .params = tuner_lg_pal_new_tapc_params,
+       },
+       [TUNER_PHILIPS_FM1216ME_MK3] = { /* Philips PAL */
+               .name   = "Philips PAL/SECAM multi (FM1216ME MK3)",
+               .params = tuner_fm1216me_mk3_params,
+       },
+       [TUNER_LG_NTSC_NEW_TAPC] = { /* LGINNOTEK NTSC */
+               .name   = "LG NTSC (newer TAPC series)",
+               .params = tuner_lg_ntsc_new_tapc_params,
+       },
+
+       /* 40-49 */
+       [TUNER_HITACHI_NTSC] = { /* HITACHI NTSC */
+               .name   = "HITACHI V7-J180AT",
+               .params = tuner_hitachi_ntsc_params,
+       },
+       [TUNER_PHILIPS_PAL_MK] = { /* Philips PAL */
+               .name   = "Philips PAL_MK (FI1216 MK)",
+               .params = tuner_philips_pal_mk_params,
+       },
+       [TUNER_PHILIPS_ATSC] = { /* Philips ATSC */
+               .name   = "Philips 1236D ATSC/NTSC dual in",
+               .params = tuner_philips_atsc_params,
+       },
+       [TUNER_PHILIPS_FM1236_MK3] = { /* Philips NTSC */
+               .name   = "Philips NTSC MK3 (FM1236MK3 or FM1236/F)",
+               .params = tuner_fm1236_mk3_params,
+       },
+       [TUNER_PHILIPS_4IN1] = { /* Philips NTSC */
+               .name   = "Philips 4 in 1 (ATI TV Wonder Pro/Conexant)",
+               .params = tuner_philips_4in1_params,
+       },
+       [TUNER_MICROTUNE_4049FM5] = { /* Microtune PAL */
+               .name   = "Microtune 4049 FM5",
+               .params = tuner_microtune_4049_fm5_params,
+       },
+       [TUNER_PANASONIC_VP27] = { /* Panasonic NTSC */
+               .name   = "Panasonic VP27s/ENGE4324D",
+               .params = tuner_panasonic_vp27_params,
+       },
+       [TUNER_LG_NTSC_TAPE] = { /* LGINNOTEK NTSC */
+               .name   = "LG NTSC (TAPE series)",
+               .params = tuner_lg_ntsc_tape_params,
+       },
+       [TUNER_TNF_8831BGFF] = { /* Philips PAL */
+               .name   = "Tenna TNF 8831 BGFF)",
+               .params = tuner_tnf_8831bgff_params,
+       },
+       [TUNER_MICROTUNE_4042FI5] = { /* Microtune NTSC */
+               .name   = "Microtune 4042 FI5 ATSC/NTSC dual in",
+               .params = tuner_microtune_4042fi5_params,
+       },
+
+       /* 50-59 */
+       [TUNER_TCL_2002N] = { /* TCL NTSC */
+               .name   = "TCL 2002N",
+               .params = tuner_tcl_2002n_params,
+       },
+       [TUNER_PHILIPS_FM1256_IH3] = { /* Philips PAL */
+               .name   = "Philips PAL/SECAM_D (FM 1256 I-H3)",
+               .params = tuner_philips_fm1256_ih3_params,
+       },
+       [TUNER_THOMSON_DTT7610] = { /* THOMSON ATSC */
+               .name   = "Thomson DTT 7610 (ATSC/NTSC)",
+               .params = tuner_thomson_dtt7610_params,
+       },
+       [TUNER_PHILIPS_FQ1286] = { /* Philips NTSC */
+               .name   = "Philips FQ1286",
+               .params = tuner_philips_fq1286_params,
+       },
+       [TUNER_PHILIPS_TDA8290] = { /* Philips PAL|NTSC */
+               .name   = "tda8290+75",
+               /* see tda8290.c for details */ },
+       [TUNER_TCL_2002MB] = { /* TCL PAL */
+               .name   = "TCL 2002MB",
+               .params = tuner_tcl_2002mb_params,
+       },
+       [TUNER_PHILIPS_FQ1216AME_MK4] = { /* Philips PAL */
+               .name   = "Philips PAL/SECAM multi (FQ1216AME MK4)",
+               .params = tuner_philips_fq1216ame_mk4_params,
+       },
+       [TUNER_PHILIPS_FQ1236A_MK4] = { /* Philips NTSC */
+               .name   = "Philips FQ1236A MK4",
+               .params = tuner_philips_fq1236a_mk4_params,
+       },
+       [TUNER_YMEC_TVF_8531MF] = { /* Philips NTSC */
+               .name   = "Ymec TVision TVF-8531MF/8831MF/8731MF",
+               .params = tuner_ymec_tvf_8531mf_params,
+       },
+       [TUNER_YMEC_TVF_5533MF] = { /* Philips NTSC */
+               .name   = "Ymec TVision TVF-5533MF",
+               .params = tuner_ymec_tvf_5533mf_params,
+       },
+
+       /* 60-69 */
+       [TUNER_THOMSON_DTT761X] = { /* THOMSON ATSC */
+               /* DTT 7611 7611A 7612 7613 7613A 7614 7615 7615A */
+               .name   = "Thomson DTT 761X (ATSC/NTSC)",
+               .params = tuner_thomson_dtt761x_params,
+       },
+       [TUNER_TENA_9533_DI] = { /* Philips PAL */
+               .name   = "Tena TNF9533-D/IF/TNF9533-B/DF",
+               .params = tuner_tena_9533_di_params,
+       },
+       [TUNER_TEA5767] = { /* Philips RADIO */
+               .name   = "Philips TEA5767HN FM Radio",
+               /* see tea5767.c for details */
+       },
+       [TUNER_PHILIPS_FMD1216ME_MK3] = { /* Philips PAL */
+               .name   = "Philips FMD1216ME MK3 Hybrid Tuner",
+               .params = tuner_tuner_philips_fmd1216me_mk3_params,
+       },
+       [TUNER_LG_TDVS_H062F] = { /* LGINNOTEK ATSC */
+               .name   = "LG TDVS-H062F/TUA6034",
+               .params = tuner_tua6034_params,
+       },
+       [TUNER_YMEC_TVF66T5_B_DFF] = { /* Philips PAL */
+               .name   = "Ymec TVF66T5-B/DFF",
+               .params = tuner_ymec_tvf66t5_b_dff_params,
+       },
+       [TUNER_LG_NTSC_TALN_MINI] = { /* LGINNOTEK NTSC */
+               .name   = "LG NTSC (TALN mini series)",
+               .params = tuner_lg_taln_mini_params,
+       },
+       [TUNER_PHILIPS_TD1316] = { /* Philips PAL */
+               .name   = "Philips TD1316 Hybrid Tuner",
+               .params = tuner_philips_td1316_params,
+       },
+       [TUNER_PHILIPS_TUV1236D] = { /* Philips ATSC */
+               .name   = "Philips TUV1236D ATSC/NTSC dual in",
+               .params = tuner_tuner_tuv1236d_params,
+       },
+       [TUNER_TNF_5335MF] = { /* Philips NTSC */
+               .name   = "Tena TNF 5335 MF",
+               .params = tuner_tnf_5335mf_params,
+       },
+
+       /* 70-79 */
+       [TUNER_SAMSUNG_TCPN_2121P30A] = { /* Samsung NTSC */
+               .name   = "Samsung TCPN 2121P30A",
+               .params = tuner_samsung_tcpn_2121p30a_params,
+       },
+};
+
+unsigned const int tuner_count = ARRAY_SIZE(tuners);
index 5e71a35..582551b 100644 (file)
@@ -190,7 +190,7 @@ hauppauge_tuner[] =
        { TUNER_LG_PAL_NEW_TAPC, "TCL 2002MI 3"},
        { TUNER_TCL_2002N,     "TCL 2002N 6A"},
        { TUNER_PHILIPS_FM1236_MK3, "Philips FQ1236 MK3"},
-       { TUNER_ABSENT,        "Samsung TCPN 2121P30A"},
+       { TUNER_SAMSUNG_TCPN_2121P30A, "Samsung TCPN 2121P30A"},
        { TUNER_ABSENT,        "Samsung TCPE 4121P30A"},
        { TUNER_PHILIPS_FM1216ME_MK3, "TCL MFPE05 2"},
        /* 90-99 */
diff --git a/include/media/tuner-types.h b/include/media/tuner-types.h
new file mode 100644 (file)
index 0000000..64b16b1
--- /dev/null
@@ -0,0 +1,37 @@
+/*
+ * descriptions for simple tuners.
+ */
+
+#ifndef __TUNER_TYPES_H__
+#define __TUNER_TYPES_H__
+
+enum param_type {
+       TUNER_PARAM_TYPE_RADIO, \
+       TUNER_PARAM_TYPE_PAL, \
+       TUNER_PARAM_TYPE_SECAM, \
+       TUNER_PARAM_TYPE_NTSC
+};
+
+struct tuner_range {
+       unsigned short limit;
+       unsigned char cb;
+};
+
+struct tuner_params {
+       enum param_type type;
+       unsigned char config; /* to be moved into struct tuner_range for dvb-pll merge */
+
+       unsigned int count;
+       struct tuner_range *ranges;
+};
+
+struct tunertype {
+       char *name;
+       unsigned int has_tda988x:1;
+       struct tuner_params *params;
+};
+
+extern struct tunertype tuners[];
+extern unsigned const int tuner_count;
+
+#endif
index 27cbf08..a1d6378 100644 (file)
@@ -23,6 +23,7 @@
 #define _TUNER_H
 
 #include <linux/videodev2.h>
+#include <media/tuner-types.h>
 
 #define ADDR_UNSET (255)
 
 
 #define TUNER_PHILIPS_TUV1236D         68      /* ATI HDTV Wonder */
 #define TUNER_TNF_5335MF                69     /* Sabrent Bt848   */
+#define TUNER_SAMSUNG_TCPN_2121P30A     70     /* Hauppauge PVR-500MCE NTSC */
 
 /* tv card specific */
 #define TDA9887_PRESENT                (1<<0)