3  * i2c tv tuner chip device driver
 
   4  * core core, i.e. kernel interfaces, registering and so on
 
   7 #include <linux/module.h>
 
   8 #include <linux/kernel.h>
 
   9 #include <linux/string.h>
 
  10 #include <linux/timer.h>
 
  11 #include <linux/delay.h>
 
  12 #include <linux/errno.h>
 
  13 #include <linux/slab.h>
 
  14 #include <linux/poll.h>
 
  15 #include <linux/i2c.h>
 
  16 #include <linux/types.h>
 
  17 #include <linux/init.h>
 
  18 #include <linux/videodev.h>
 
  19 #include <media/tuner.h>
 
  20 #include <media/tuner-types.h>
 
  21 #include <media/v4l2-common.h>
 
  22 #include <media/v4l2-i2c-drv-legacy.h>
 
  27 #include "tuner-xc2028.h"
 
  28 #include "tuner-simple.h"
 
  34 #define PREFIX t->i2c->driver->driver.name
 
  38         struct dvb_frontend fe;
 
  39         struct i2c_client   *i2c;
 
  40         struct list_head    list;
 
  41         unsigned int        using_v4l2:1;
 
  43         /* keep track of the current settings */
 
  46         unsigned int        radio_freq;
 
  50         unsigned int        mode_mask; /* Combination of allowable modes */
 
  52         unsigned int        type; /* chip type id */
 
  54         int (*tuner_callback) (void *dev, int command, int arg);
 
  57 /* standard i2c insmod options */
 
  58 static unsigned short normal_i2c[] = {
 
  59 #if defined(CONFIG_TUNER_TEA5761) || (defined(CONFIG_TUNER_TEA5761_MODULE) && defined(MODULE))
 
  62         0x42, 0x43, 0x4a, 0x4b,                 /* tda8290 */
 
  63         0x60, 0x61, 0x62, 0x63, 0x64, 0x65, 0x66, 0x67,
 
  64         0x68, 0x69, 0x6a, 0x6b, 0x6c, 0x6d, 0x6e, 0x6f,
 
  70 /* insmod options used at init time => read/only */
 
  71 static unsigned int addr = 0;
 
  72 static unsigned int no_autodetect = 0;
 
  73 static unsigned int show_i2c = 0;
 
  75 /* insmod options used at runtime => read/write */
 
  76 static int tuner_debug;
 
  78 #define tuner_warn(fmt, arg...) do {                    \
 
  79         printk(KERN_WARNING "%s %d-%04x: " fmt, PREFIX, \
 
  80                i2c_adapter_id(t->i2c->adapter),         \
 
  81                t->i2c->addr, ##arg);                    \
 
  84 #define tuner_info(fmt, arg...) do {                    \
 
  85         printk(KERN_INFO "%s %d-%04x: " fmt, PREFIX,    \
 
  86                i2c_adapter_id(t->i2c->adapter),         \
 
  87                t->i2c->addr, ##arg);                    \
 
  90 #define tuner_err(fmt, arg...) do {                     \
 
  91         printk(KERN_ERR "%s %d-%04x: " fmt, PREFIX,     \
 
  92                i2c_adapter_id(t->i2c->adapter),         \
 
  93                t->i2c->addr, ##arg);                    \
 
  96 #define tuner_dbg(fmt, arg...) do {                             \
 
  98                 printk(KERN_DEBUG "%s %d-%04x: " fmt, PREFIX,   \
 
  99                        i2c_adapter_id(t->i2c->adapter),         \
 
 100                        t->i2c->addr, ##arg);                    \
 
 103 /* ------------------------------------------------------------------------ */
 
 105 static unsigned int tv_range[2] = { 44, 958 };
 
 106 static unsigned int radio_range[2] = { 65, 108 };
 
 108 static char pal[] = "--";
 
 109 static char secam[] = "--";
 
 110 static char ntsc[] = "-";
 
 113 module_param(addr, int, 0444);
 
 114 module_param(no_autodetect, int, 0444);
 
 115 module_param(show_i2c, int, 0444);
 
 116 module_param_named(debug,tuner_debug, int, 0644);
 
 117 module_param_string(pal, pal, sizeof(pal), 0644);
 
 118 module_param_string(secam, secam, sizeof(secam), 0644);
 
 119 module_param_string(ntsc, ntsc, sizeof(ntsc), 0644);
 
 120 module_param_array(tv_range, int, NULL, 0644);
 
 121 module_param_array(radio_range, int, NULL, 0644);
 
 123 MODULE_DESCRIPTION("device driver for various TV and TV+FM radio tuners");
 
 124 MODULE_AUTHOR("Ralph Metzler, Gerd Knorr, Gunther Mayer");
 
 125 MODULE_LICENSE("GPL");
 
 127 /* ---------------------------------------------------------------------- */
 
 129 static void fe_set_params(struct dvb_frontend *fe,
 
 130                           struct analog_parameters *params)
 
 132         struct dvb_tuner_ops *fe_tuner_ops = &fe->ops.tuner_ops;
 
 133         struct tuner *t = fe->analog_demod_priv;
 
 135         if (NULL == fe_tuner_ops->set_analog_params) {
 
 136                 tuner_warn("Tuner frontend module has no way to set freq\n");
 
 139         fe_tuner_ops->set_analog_params(fe, params);
 
 142 static void fe_release(struct dvb_frontend *fe)
 
 144         if (fe->ops.tuner_ops.release)
 
 145                 fe->ops.tuner_ops.release(fe);
 
 147         /* DO NOT kfree(fe->analog_demod_priv)
 
 149          * If we are in this function, analog_demod_priv contains a pointer
 
 150          * to struct tuner *t.  This will be kfree'd in tuner_detach().
 
 152          * Otherwise, fe->ops.analog_demod_ops->release will
 
 153          * handle the cleanup for analog demodulator modules.
 
 155         fe->analog_demod_priv = NULL;
 
 158 static void fe_standby(struct dvb_frontend *fe)
 
 160         struct dvb_tuner_ops *fe_tuner_ops = &fe->ops.tuner_ops;
 
 162         if (fe_tuner_ops->sleep)
 
 163                 fe_tuner_ops->sleep(fe);
 
 166 static int fe_has_signal(struct dvb_frontend *fe)
 
 170         if (fe->ops.tuner_ops.get_rf_strength)
 
 171                 fe->ops.tuner_ops.get_rf_strength(fe, &strength);
 
 176 static int fe_set_config(struct dvb_frontend *fe, void *priv_cfg)
 
 178         struct dvb_tuner_ops *fe_tuner_ops = &fe->ops.tuner_ops;
 
 179         struct tuner *t = fe->analog_demod_priv;
 
 181         if (fe_tuner_ops->set_config)
 
 182                 return fe_tuner_ops->set_config(fe, priv_cfg);
 
 184         tuner_warn("Tuner frontend module has no way to set config\n");
 
 189 static void tuner_status(struct dvb_frontend *fe);
 
 191 static struct analog_demod_ops tuner_core_ops = {
 
 192         .set_params     = fe_set_params,
 
 193         .standby        = fe_standby,
 
 194         .release        = fe_release,
 
 195         .has_signal     = fe_has_signal,
 
 196         .set_config     = fe_set_config,
 
 197         .tuner_status   = tuner_status
 
 200 /* Set tuner frequency,  freq in Units of 62.5kHz = 1/16MHz */
 
 201 static void set_tv_freq(struct i2c_client *c, unsigned int freq)
 
 203         struct tuner *t = i2c_get_clientdata(c);
 
 204         struct analog_demod_ops *analog_ops = &t->fe.ops.analog_ops;
 
 206         struct analog_parameters params = {
 
 208                 .audmode   = t->audmode,
 
 212         if (t->type == UNSET) {
 
 213                 tuner_warn ("tuner type not set\n");
 
 216         if (NULL == analog_ops->set_params) {
 
 217                 tuner_warn ("Tuner has no way to set tv freq\n");
 
 220         if (freq < tv_range[0] * 16 || freq > tv_range[1] * 16) {
 
 221                 tuner_dbg ("TV freq (%d.%02d) out of range (%d-%d)\n",
 
 222                            freq / 16, freq % 16 * 100 / 16, tv_range[0],
 
 224                 /* V4L2 spec: if the freq is not possible then the closest
 
 225                    possible value should be selected */
 
 226                 if (freq < tv_range[0] * 16)
 
 227                         freq = tv_range[0] * 16;
 
 229                         freq = tv_range[1] * 16;
 
 231         params.frequency = freq;
 
 233         analog_ops->set_params(&t->fe, ¶ms);
 
 236 static void set_radio_freq(struct i2c_client *c, unsigned int freq)
 
 238         struct tuner *t = i2c_get_clientdata(c);
 
 239         struct analog_demod_ops *analog_ops = &t->fe.ops.analog_ops;
 
 241         struct analog_parameters params = {
 
 243                 .audmode   = t->audmode,
 
 247         if (t->type == UNSET) {
 
 248                 tuner_warn ("tuner type not set\n");
 
 251         if (NULL == analog_ops->set_params) {
 
 252                 tuner_warn ("tuner has no way to set radio frequency\n");
 
 255         if (freq < radio_range[0] * 16000 || freq > radio_range[1] * 16000) {
 
 256                 tuner_dbg ("radio freq (%d.%02d) out of range (%d-%d)\n",
 
 257                            freq / 16000, freq % 16000 * 100 / 16000,
 
 258                            radio_range[0], radio_range[1]);
 
 259                 /* V4L2 spec: if the freq is not possible then the closest
 
 260                    possible value should be selected */
 
 261                 if (freq < radio_range[0] * 16000)
 
 262                         freq = radio_range[0] * 16000;
 
 264                         freq = radio_range[1] * 16000;
 
 266         params.frequency = freq;
 
 268         analog_ops->set_params(&t->fe, ¶ms);
 
 271 static void set_freq(struct i2c_client *c, unsigned long freq)
 
 273         struct tuner *t = i2c_get_clientdata(c);
 
 276         case V4L2_TUNER_RADIO:
 
 277                 tuner_dbg("radio freq set to %lu.%02lu\n",
 
 278                           freq / 16000, freq % 16000 * 100 / 16000);
 
 279                 set_radio_freq(c, freq);
 
 280                 t->radio_freq = freq;
 
 282         case V4L2_TUNER_ANALOG_TV:
 
 283         case V4L2_TUNER_DIGITAL_TV:
 
 284                 tuner_dbg("tv freq set to %lu.%02lu\n",
 
 285                           freq / 16, freq % 16 * 100 / 16);
 
 286                 set_tv_freq(c, freq);
 
 290                 tuner_dbg("freq set: unknown mode: 0x%04x!\n",t->mode);
 
 294 static void tuner_i2c_address_check(struct tuner *t)
 
 296         if ((t->type == UNSET || t->type == TUNER_ABSENT) ||
 
 297             ((t->i2c->addr < 0x64) || (t->i2c->addr > 0x6f)))
 
 300         /* We already know that the XC5000 can only be located at
 
 301          * i2c address 0x61, 0x62, 0x63 or 0x64 */
 
 302         if ((t->type == TUNER_XC5000) &&
 
 303             ((t->i2c->addr <= 0x64)) && (t->i2c->addr >= 0x61))
 
 306         tuner_warn("====================== WARNING! ======================\n");
 
 307         tuner_warn("Support for tuners in i2c address range 0x64 thru 0x6f\n");
 
 308         tuner_warn("will soon be dropped. This message indicates that your\n");
 
 309         tuner_warn("hardware has a %s tuner at i2c address 0x%02x.\n",
 
 310                    t->i2c->name, t->i2c->addr);
 
 311         tuner_warn("To ensure continued support for your device, please\n");
 
 312         tuner_warn("send a copy of this message, along with full dmesg\n");
 
 313         tuner_warn("output to v4l-dvb-maintainer@linuxtv.org\n");
 
 314         tuner_warn("Please use subject line: \"obsolete tuner i2c address.\"\n");
 
 315         tuner_warn("driver: %s, addr: 0x%02x, type: %d (%s)\n",
 
 316                    t->i2c->adapter->name, t->i2c->addr, t->type,
 
 317                    tuners[t->type].name);
 
 318         tuner_warn("====================== WARNING! ======================\n");
 
 321 static void attach_simple_tuner(struct tuner *t)
 
 323         struct simple_tuner_config cfg = {
 
 325                 .tun  = &tuners[t->type]
 
 327         simple_tuner_attach(&t->fe, t->i2c->adapter, t->i2c->addr, &cfg);
 
 330 static void attach_tda829x(struct tuner *t)
 
 332         struct tda829x_config cfg = {
 
 333                 .lna_cfg        = &t->config,
 
 334                 .tuner_callback = t->tuner_callback,
 
 336         tda829x_attach(&t->fe, t->i2c->adapter, t->i2c->addr, &cfg);
 
 339 static struct xc5000_config xc5000_cfg;
 
 341 static void set_type(struct i2c_client *c, unsigned int type,
 
 342                      unsigned int new_mode_mask, unsigned int new_config,
 
 343                      int (*tuner_callback) (void *dev, int command,int arg))
 
 345         struct tuner *t = i2c_get_clientdata(c);
 
 346         struct dvb_tuner_ops *fe_tuner_ops = &t->fe.ops.tuner_ops;
 
 347         struct analog_demod_ops *analog_ops = &t->fe.ops.analog_ops;
 
 348         unsigned char buffer[4];
 
 350         if (type == UNSET || type == TUNER_ABSENT) {
 
 351                 tuner_dbg ("tuner 0x%02x: Tuner type absent\n",c->addr);
 
 355         if (type >= tuner_count) {
 
 356                 tuner_warn ("tuner 0x%02x: Tuner count greater than %d\n",c->addr,tuner_count);
 
 361         t->config = new_config;
 
 362         if (tuner_callback != NULL) {
 
 363                 tuner_dbg("defining GPIO callback\n");
 
 364                 t->tuner_callback = tuner_callback;
 
 367         if (t->mode == T_UNINITIALIZED) {
 
 368                 tuner_dbg ("tuner 0x%02x: called during i2c_client register by adapter's attach_inform\n", c->addr);
 
 373         /* discard private data, in case set_type() was previously called */
 
 374         if (analog_ops->release)
 
 375                 analog_ops->release(&t->fe);
 
 379                 microtune_attach(&t->fe, t->i2c->adapter, t->i2c->addr);
 
 381         case TUNER_PHILIPS_TDA8290:
 
 387                 if (tea5767_attach(&t->fe, t->i2c->adapter, t->i2c->addr) == NULL) {
 
 388                         t->type = TUNER_ABSENT;
 
 389                         t->mode_mask = T_UNINITIALIZED;
 
 392                 t->mode_mask = T_RADIO;
 
 395                 if (tea5761_attach(&t->fe, t->i2c->adapter, t->i2c->addr) == NULL) {
 
 396                         t->type = TUNER_ABSENT;
 
 397                         t->mode_mask = T_UNINITIALIZED;
 
 400                 t->mode_mask = T_RADIO;
 
 402         case TUNER_PHILIPS_FMD1216ME_MK3:
 
 407                 i2c_master_send(c, buffer, 4);
 
 411                 i2c_master_send(c, buffer, 4);
 
 412                 attach_simple_tuner(t);
 
 414         case TUNER_PHILIPS_TD1316:
 
 419                 i2c_master_send(c,buffer,4);
 
 420                 attach_simple_tuner(t);
 
 424                 struct xc2028_config cfg = {
 
 425                         .i2c_adap  = t->i2c->adapter,
 
 426                         .i2c_addr  = t->i2c->addr,
 
 427                         .video_dev = c->adapter->algo_data,
 
 428                         .callback  = t->tuner_callback,
 
 430                 if (!xc2028_attach(&t->fe, &cfg)) {
 
 431                         t->type = TUNER_ABSENT;
 
 432                         t->mode_mask = T_UNINITIALIZED;
 
 438                 tda9887_attach(&t->fe, t->i2c->adapter, t->i2c->addr);
 
 441                 xc5000_cfg.i2c_address    = t->i2c->addr;
 
 442                 xc5000_cfg.if_khz         = 5380;
 
 443                 xc5000_cfg.priv           = c->adapter->algo_data;
 
 444                 xc5000_cfg.tuner_callback = t->tuner_callback;
 
 445                 if (!xc5000_attach(&t->fe, t->i2c->adapter, &xc5000_cfg)) {
 
 446                         t->type = TUNER_ABSENT;
 
 447                         t->mode_mask = T_UNINITIALIZED;
 
 451                 struct dvb_tuner_ops *xc_tuner_ops;
 
 452                 xc_tuner_ops = &t->fe.ops.tuner_ops;
 
 453                 if(xc_tuner_ops->init != NULL)
 
 454                         xc_tuner_ops->init(&t->fe);
 
 458                 attach_simple_tuner(t);
 
 462         if ((NULL == analog_ops->set_params) &&
 
 463             (fe_tuner_ops->set_analog_params)) {
 
 464                 strlcpy(t->i2c->name, fe_tuner_ops->info.name,
 
 465                         sizeof(t->i2c->name));
 
 467                 t->fe.analog_demod_priv = t;
 
 468                 memcpy(analog_ops, &tuner_core_ops,
 
 469                        sizeof(struct analog_demod_ops));
 
 471                 strlcpy(t->i2c->name, analog_ops->info.name,
 
 472                         sizeof(t->i2c->name));
 
 475         tuner_dbg("type set to %s\n", t->i2c->name);
 
 477         if (t->mode_mask == T_UNINITIALIZED)
 
 478                 t->mode_mask = new_mode_mask;
 
 480         set_freq(c, (V4L2_TUNER_RADIO == t->mode) ? t->radio_freq : t->tv_freq);
 
 481         tuner_dbg("%s %s I2C addr 0x%02x with type %d used for 0x%02x\n",
 
 482                   c->adapter->name, c->driver->driver.name, c->addr << 1, type,
 
 484         tuner_i2c_address_check(t);
 
 488  * This function apply tuner config to tuner specified
 
 489  * by tun_setup structure. I addr is unset, then admin status
 
 490  * and tun addr status is more precise then current status,
 
 491  * it's applied. Otherwise status and type are applied only to
 
 492  * tuner with exactly the same addr.
 
 495 static void set_addr(struct i2c_client *c, struct tuner_setup *tun_setup)
 
 497         struct tuner *t = i2c_get_clientdata(c);
 
 499         tuner_dbg("set addr for type %i\n", t->type);
 
 501         if ( (t->type == UNSET && ((tun_setup->addr == ADDR_UNSET) &&
 
 502                 (t->mode_mask & tun_setup->mode_mask))) ||
 
 503                 (tun_setup->addr == c->addr)) {
 
 504                         set_type(c, tun_setup->type, tun_setup->mode_mask,
 
 505                                  tun_setup->config, tun_setup->tuner_callback);
 
 509 static inline int check_mode(struct tuner *t, char *cmd)
 
 511         if ((1 << t->mode & t->mode_mask) == 0) {
 
 516         case V4L2_TUNER_RADIO:
 
 517                 tuner_dbg("Cmd %s accepted for radio\n", cmd);
 
 519         case V4L2_TUNER_ANALOG_TV:
 
 520                 tuner_dbg("Cmd %s accepted for analog TV\n", cmd);
 
 522         case V4L2_TUNER_DIGITAL_TV:
 
 523                 tuner_dbg("Cmd %s accepted for digital TV\n", cmd);
 
 529 /* get more precise norm info from insmod option */
 
 530 static int tuner_fixup_std(struct tuner *t)
 
 532         if ((t->std & V4L2_STD_PAL) == V4L2_STD_PAL) {
 
 535                         tuner_dbg ("insmod fixup: PAL => PAL-60\n");
 
 536                         t->std = V4L2_STD_PAL_60;
 
 542                         tuner_dbg ("insmod fixup: PAL => PAL-BG\n");
 
 543                         t->std = V4L2_STD_PAL_BG;
 
 547                         tuner_dbg ("insmod fixup: PAL => PAL-I\n");
 
 548                         t->std = V4L2_STD_PAL_I;
 
 554                         tuner_dbg ("insmod fixup: PAL => PAL-DK\n");
 
 555                         t->std = V4L2_STD_PAL_DK;
 
 559                         tuner_dbg ("insmod fixup: PAL => PAL-M\n");
 
 560                         t->std = V4L2_STD_PAL_M;
 
 564                         if (pal[1] == 'c' || pal[1] == 'C') {
 
 565                                 tuner_dbg("insmod fixup: PAL => PAL-Nc\n");
 
 566                                 t->std = V4L2_STD_PAL_Nc;
 
 568                                 tuner_dbg ("insmod fixup: PAL => PAL-N\n");
 
 569                                 t->std = V4L2_STD_PAL_N;
 
 573                         /* default parameter, do nothing */
 
 576                         tuner_warn ("pal= argument not recognised\n");
 
 580         if ((t->std & V4L2_STD_SECAM) == V4L2_STD_SECAM) {
 
 588                         tuner_dbg("insmod fixup: SECAM => SECAM-BGH\n");
 
 589                         t->std = V4L2_STD_SECAM_B | V4L2_STD_SECAM_G | V4L2_STD_SECAM_H;
 
 595                         tuner_dbg ("insmod fixup: SECAM => SECAM-DK\n");
 
 596                         t->std = V4L2_STD_SECAM_DK;
 
 600                         if ((secam[1]=='C')||(secam[1]=='c')) {
 
 601                                 tuner_dbg ("insmod fixup: SECAM => SECAM-L'\n");
 
 602                                 t->std = V4L2_STD_SECAM_LC;
 
 604                                 tuner_dbg ("insmod fixup: SECAM => SECAM-L\n");
 
 605                                 t->std = V4L2_STD_SECAM_L;
 
 609                         /* default parameter, do nothing */
 
 612                         tuner_warn ("secam= argument not recognised\n");
 
 617         if ((t->std & V4L2_STD_NTSC) == V4L2_STD_NTSC) {
 
 621                         tuner_dbg("insmod fixup: NTSC => NTSC-M\n");
 
 622                         t->std = V4L2_STD_NTSC_M;
 
 626                         tuner_dbg("insmod fixup: NTSC => NTSC_M_JP\n");
 
 627                         t->std = V4L2_STD_NTSC_M_JP;
 
 631                         tuner_dbg("insmod fixup: NTSC => NTSC_M_KR\n");
 
 632                         t->std = V4L2_STD_NTSC_M_KR;
 
 635                         /* default parameter, do nothing */
 
 638                         tuner_info("ntsc= argument not recognised\n");
 
 645 static void tuner_status(struct dvb_frontend *fe)
 
 647         struct tuner *t = fe->analog_demod_priv;
 
 648         unsigned long freq, freq_fraction;
 
 649         struct dvb_tuner_ops *fe_tuner_ops = &t->fe.ops.tuner_ops;
 
 650         struct analog_demod_ops *analog_ops = &t->fe.ops.analog_ops;
 
 654                 case V4L2_TUNER_RADIO:      p = "radio"; break;
 
 655                 case V4L2_TUNER_ANALOG_TV:  p = "analog TV"; break;
 
 656                 case V4L2_TUNER_DIGITAL_TV: p = "digital TV"; break;
 
 657                 default: p = "undefined"; break;
 
 659         if (t->mode == V4L2_TUNER_RADIO) {
 
 660                 freq = t->radio_freq / 16000;
 
 661                 freq_fraction = (t->radio_freq % 16000) * 100 / 16000;
 
 663                 freq = t->tv_freq / 16;
 
 664                 freq_fraction = (t->tv_freq % 16) * 100 / 16;
 
 666         tuner_info("Tuner mode:      %s\n", p);
 
 667         tuner_info("Frequency:       %lu.%02lu MHz\n", freq, freq_fraction);
 
 668         tuner_info("Standard:        0x%08lx\n", (unsigned long)t->std);
 
 669         if (t->mode != V4L2_TUNER_RADIO)
 
 671         if (fe_tuner_ops->get_status) {
 
 674                 fe_tuner_ops->get_status(&t->fe, &tuner_status);
 
 675                 if (tuner_status & TUNER_STATUS_LOCKED)
 
 676                         tuner_info("Tuner is locked.\n");
 
 677                 if (tuner_status & TUNER_STATUS_STEREO)
 
 678                         tuner_info("Stereo:          yes\n");
 
 680         if (analog_ops->has_signal)
 
 681                 tuner_info("Signal strength: %d\n",
 
 682                            analog_ops->has_signal(fe));
 
 683         if (analog_ops->is_stereo)
 
 684                 tuner_info("Stereo:          %s\n",
 
 685                            analog_ops->is_stereo(fe) ? "yes" : "no");
 
 688 /* ---------------------------------------------------------------------- */
 
 691  * Switch tuner to other mode. If tuner support both tv and radio,
 
 692  * set another frequency to some value (This is needed for some pal
 
 693  * tuners to avoid locking). Otherwise, just put second tuner in
 
 697 static inline int set_mode(struct i2c_client *client, struct tuner *t, int mode, char *cmd)
 
 699         struct analog_demod_ops *analog_ops = &t->fe.ops.analog_ops;
 
 706         if (check_mode(t, cmd) == EINVAL) {
 
 708                 if (analog_ops->standby)
 
 709                         analog_ops->standby(&t->fe);
 
 715 #define switch_v4l2()   if (!t->using_v4l2) \
 
 716                             tuner_dbg("switching to v4l2\n"); \
 
 719 static inline int check_v4l2(struct tuner *t)
 
 721         /* bttv still uses both v4l1 and v4l2 calls to the tuner (v4l2 for
 
 722            TV, v4l1 for radio), until that is fixed this code is disabled.
 
 723            Otherwise the radio (v4l1) wouldn't tune after using the TV (v4l2)
 
 728 static int tuner_command(struct i2c_client *client, unsigned int cmd, void *arg)
 
 730         struct tuner *t = i2c_get_clientdata(client);
 
 731         struct dvb_tuner_ops *fe_tuner_ops = &t->fe.ops.tuner_ops;
 
 732         struct analog_demod_ops *analog_ops = &t->fe.ops.analog_ops;
 
 735                 v4l_i2c_print_ioctl(client,cmd);
 
 738         /* --- configuration --- */
 
 739         case TUNER_SET_TYPE_ADDR:
 
 740                 tuner_dbg ("Calling set_type_addr for type=%d, addr=0x%02x, mode=0x%02x, config=0x%02x\n",
 
 741                                 ((struct tuner_setup *)arg)->type,
 
 742                                 ((struct tuner_setup *)arg)->addr,
 
 743                                 ((struct tuner_setup *)arg)->mode_mask,
 
 744                                 ((struct tuner_setup *)arg)->config);
 
 746                 set_addr(client, (struct tuner_setup *)arg);
 
 749                 if (set_mode(client, t, V4L2_TUNER_RADIO, "AUDC_SET_RADIO")
 
 753                         set_freq(client, t->radio_freq);
 
 755         case TUNER_SET_STANDBY:
 
 756                 if (check_mode(t, "TUNER_SET_STANDBY") == EINVAL)
 
 759                 if (analog_ops->standby)
 
 760                         analog_ops->standby(&t->fe);
 
 762 #ifdef CONFIG_VIDEO_V4L1
 
 764                 if (check_mode(t, "VIDIOCSAUDIO") == EINVAL)
 
 766                 if (check_v4l2(t) == EINVAL)
 
 769                 /* Should be implemented, since bttv calls it */
 
 770                 tuner_dbg("VIDIOCSAUDIO not implemented.\n");
 
 774                         static const v4l2_std_id map[] = {
 
 775                                 [VIDEO_MODE_PAL] = V4L2_STD_PAL,
 
 776                                 [VIDEO_MODE_NTSC] = V4L2_STD_NTSC_M,
 
 777                                 [VIDEO_MODE_SECAM] = V4L2_STD_SECAM,
 
 778                                 [4 /* bttv */ ] = V4L2_STD_PAL_M,
 
 779                                 [5 /* bttv */ ] = V4L2_STD_PAL_N,
 
 780                                 [6 /* bttv */ ] = V4L2_STD_NTSC_M_JP,
 
 782                         struct video_channel *vc = arg;
 
 784                         if (check_v4l2(t) == EINVAL)
 
 787                         if (set_mode(client,t,V4L2_TUNER_ANALOG_TV, "VIDIOCSCHAN")==EINVAL)
 
 790                         if (vc->norm < ARRAY_SIZE(map))
 
 791                                 t->std = map[vc->norm];
 
 794                                 set_tv_freq(client, t->tv_freq);
 
 799                         unsigned long *v = arg;
 
 801                         if (check_mode(t, "VIDIOCSFREQ") == EINVAL)
 
 803                         if (check_v4l2(t) == EINVAL)
 
 806                         set_freq(client, *v);
 
 811                         struct video_tuner *vt = arg;
 
 813                         if (check_mode(t, "VIDIOCGTUNER") == EINVAL)
 
 815                         if (check_v4l2(t) == EINVAL)
 
 818                         if (V4L2_TUNER_RADIO == t->mode) {
 
 819                                 if (fe_tuner_ops->get_status) {
 
 822                                         fe_tuner_ops->get_status(&t->fe, &tuner_status);
 
 823                                         if (tuner_status & TUNER_STATUS_STEREO)
 
 824                                                 vt->flags |= VIDEO_TUNER_STEREO_ON;
 
 826                                                 vt->flags &= ~VIDEO_TUNER_STEREO_ON;
 
 828                                         if (analog_ops->is_stereo) {
 
 829                                                 if (analog_ops->is_stereo(&t->fe))
 
 831                                                                 VIDEO_TUNER_STEREO_ON;
 
 834                                                                 ~VIDEO_TUNER_STEREO_ON;
 
 837                                 if (analog_ops->has_signal)
 
 839                                                 analog_ops->has_signal(&t->fe);
 
 841                                 vt->flags |= VIDEO_TUNER_LOW;   /* Allow freqs at 62.5 Hz */
 
 843                                 vt->rangelow = radio_range[0] * 16000;
 
 844                                 vt->rangehigh = radio_range[1] * 16000;
 
 847                                 vt->rangelow = tv_range[0] * 16;
 
 848                                 vt->rangehigh = tv_range[1] * 16;
 
 855                         struct video_audio *va = arg;
 
 857                         if (check_mode(t, "VIDIOCGAUDIO") == EINVAL)
 
 859                         if (check_v4l2(t) == EINVAL)
 
 862                         if (V4L2_TUNER_RADIO == t->mode) {
 
 863                                 if (fe_tuner_ops->get_status) {
 
 866                                         fe_tuner_ops->get_status(&t->fe, &tuner_status);
 
 867                                         va->mode = (tuner_status & TUNER_STATUS_STEREO)
 
 868                                             ? VIDEO_SOUND_STEREO : VIDEO_SOUND_MONO;
 
 869                                 } else if (analog_ops->is_stereo)
 
 870                                         va->mode = analog_ops->is_stereo(&t->fe)
 
 871                                             ? VIDEO_SOUND_STEREO : VIDEO_SOUND_MONO;
 
 876         case TUNER_SET_CONFIG:
 
 878                 struct v4l2_priv_tun_config *cfg = arg;
 
 880                 if (t->type != cfg->tuner)
 
 883                 if (analog_ops->set_config) {
 
 884                         analog_ops->set_config(&t->fe, cfg->priv);
 
 888                 tuner_dbg("Tuner frontend module has no way to set config\n");
 
 891         /* --- v4l ioctls --- */
 
 892         /* take care: bttv does userspace copying, we'll get a
 
 893            kernel pointer here... */
 
 896                         v4l2_std_id *id = arg;
 
 898                         if (set_mode (client, t, V4L2_TUNER_ANALOG_TV, "VIDIOC_S_STD")
 
 907                                 set_freq(client, t->tv_freq);
 
 910         case VIDIOC_S_FREQUENCY:
 
 912                         struct v4l2_frequency *f = arg;
 
 914                         if (set_mode (client, t, f->type, "VIDIOC_S_FREQUENCY")
 
 918                         set_freq(client,f->frequency);
 
 922         case VIDIOC_G_FREQUENCY:
 
 924                         struct v4l2_frequency *f = arg;
 
 926                         if (check_mode(t, "VIDIOC_G_FREQUENCY") == EINVAL)
 
 930                         if (fe_tuner_ops->get_frequency) {
 
 933                                 fe_tuner_ops->get_frequency(&t->fe, &abs_freq);
 
 934                                 f->frequency = (V4L2_TUNER_RADIO == t->mode) ?
 
 935                                         (abs_freq * 2 + 125/2) / 125 :
 
 936                                         (abs_freq + 62500/2) / 62500;
 
 939                         f->frequency = (V4L2_TUNER_RADIO == t->mode) ?
 
 940                                 t->radio_freq : t->tv_freq;
 
 945                         struct v4l2_tuner *tuner = arg;
 
 947                         if (check_mode(t, "VIDIOC_G_TUNER") == EINVAL)
 
 951                         tuner->type = t->mode;
 
 952                         if (analog_ops->get_afc)
 
 953                                 tuner->afc = analog_ops->get_afc(&t->fe);
 
 954                         if (t->mode == V4L2_TUNER_ANALOG_TV)
 
 955                                 tuner->capability |= V4L2_TUNER_CAP_NORM;
 
 956                         if (t->mode != V4L2_TUNER_RADIO) {
 
 957                                 tuner->rangelow = tv_range[0] * 16;
 
 958                                 tuner->rangehigh = tv_range[1] * 16;
 
 964                                 V4L2_TUNER_SUB_MONO | V4L2_TUNER_SUB_STEREO;
 
 965                         if (fe_tuner_ops->get_status) {
 
 968                                 fe_tuner_ops->get_status(&t->fe, &tuner_status);
 
 970                                         (tuner_status & TUNER_STATUS_STEREO) ?
 
 971                                         V4L2_TUNER_SUB_STEREO :
 
 974                                 if (analog_ops->is_stereo) {
 
 976                                                 analog_ops->is_stereo(&t->fe) ?
 
 977                                                 V4L2_TUNER_SUB_STEREO :
 
 981                         if (analog_ops->has_signal)
 
 982                                 tuner->signal = analog_ops->has_signal(&t->fe);
 
 984                             V4L2_TUNER_CAP_LOW | V4L2_TUNER_CAP_STEREO;
 
 985                         tuner->audmode = t->audmode;
 
 986                         tuner->rangelow = radio_range[0] * 16000;
 
 987                         tuner->rangehigh = radio_range[1] * 16000;
 
 992                         struct v4l2_tuner *tuner = arg;
 
 994                         if (check_mode(t, "VIDIOC_S_TUNER") == EINVAL)
 
 999                         /* do nothing unless we're a radio tuner */
 
1000                         if (t->mode != V4L2_TUNER_RADIO)
 
1002                         t->audmode = tuner->audmode;
 
1003                         set_radio_freq(client, t->radio_freq);
 
1006         case VIDIOC_LOG_STATUS:
 
1007                 if (analog_ops->tuner_status)
 
1008                         analog_ops->tuner_status(&t->fe);
 
1015 static int tuner_suspend(struct i2c_client *c, pm_message_t state)
 
1017         struct tuner *t = i2c_get_clientdata(c);
 
1019         tuner_dbg("suspend\n");
 
1020         /* FIXME: power down ??? */
 
1024 static int tuner_resume(struct i2c_client *c)
 
1026         struct tuner *t = i2c_get_clientdata(c);
 
1028         tuner_dbg("resume\n");
 
1029         if (V4L2_TUNER_RADIO == t->mode) {
 
1031                         set_freq(c, t->radio_freq);
 
1034                         set_freq(c, t->tv_freq);
 
1039 /* ---------------------------------------------------------------------- */
 
1041 LIST_HEAD(tuner_list);
 
1043 /* Search for existing radio and/or TV tuners on the given I2C adapter.
 
1044    Note that when this function is called from tuner_probe you can be
 
1045    certain no other devices will be added/deleted at the same time, I2C
 
1046    core protects against that. */
 
1047 static void tuner_lookup(struct i2c_adapter *adap,
 
1048                 struct tuner **radio, struct tuner **tv)
 
1055         list_for_each_entry(pos, &tuner_list, list) {
 
1058                 if (pos->i2c->adapter != adap ||
 
1059                     pos->i2c->driver->id != I2C_DRIVERID_TUNER)
 
1062                 mode_mask = pos->mode_mask & ~T_STANDBY;
 
1063                 if (*radio == NULL && mode_mask == T_RADIO)
 
1065                 /* Note: currently TDA9887 is the only demod-only
 
1066                    device. If other devices appear then we need to
 
1067                    make this test more general. */
 
1068                 else if (*tv == NULL && pos->type != TUNER_TDA9887 &&
 
1069                          (pos->mode_mask & (T_ANALOG_TV | T_DIGITAL_TV)))
 
1074 /* During client attach, set_type is called by adapter's attach_inform callback.
 
1075    set_type must then be completed by tuner_probe.
 
1077 static int tuner_probe(struct i2c_client *client)
 
1080         struct tuner *radio;
 
1083         t = kzalloc(sizeof(struct tuner), GFP_KERNEL);
 
1087         strlcpy(client->name, "(tuner unset)", sizeof(client->name));
 
1088         i2c_set_clientdata(client, t);
 
1090         t->audmode = V4L2_TUNER_MODE_STEREO;
 
1091         t->mode_mask = T_UNINITIALIZED;
 
1094                 unsigned char buffer[16];
 
1097                 memset(buffer, 0, sizeof(buffer));
 
1098                 rc = i2c_master_recv(client, buffer, sizeof(buffer));
 
1099                 tuner_info("I2C RECV = ");
 
1100                 for (i = 0; i < rc; i++)
 
1101                         printk(KERN_CONT "%02x ", buffer[i]);
 
1104         /* HACK: This test was added to avoid tuner to probe tda9840 and
 
1105            tea6415c on the MXB card */
 
1106         if (client->adapter->id == I2C_HW_SAA7146 && client->addr < 0x4a) {
 
1111         /* autodetection code based on the i2c addr */
 
1112         if (!no_autodetect) {
 
1113                 switch (client->addr) {
 
1115                         if (tea5761_autodetection(t->i2c->adapter, t->i2c->addr)
 
1117                                 t->type = TUNER_TEA5761;
 
1118                                 t->mode_mask = T_RADIO;
 
1119                                 t->mode = T_STANDBY;
 
1120                                 /* Sets freq to FM range */
 
1121                                 t->radio_freq = 87.5 * 16000;
 
1122                                 tuner_lookup(t->i2c->adapter, &radio, &tv);
 
1124                                         tv->mode_mask &= ~T_RADIO;
 
1126                                 goto register_client;
 
1133                         /* If chip is not tda8290, don't register.
 
1134                            since it can be tda9887*/
 
1135                         if (tda829x_probe(t->i2c->adapter,
 
1136                                           t->i2c->addr) == 0) {
 
1137                                 tuner_dbg("tda829x detected\n");
 
1139                                 /* Default is being tda9887 */
 
1140                                 t->type = TUNER_TDA9887;
 
1141                                 t->mode_mask = T_RADIO | T_ANALOG_TV |
 
1143                                 t->mode = T_STANDBY;
 
1144                                 goto register_client;
 
1148                         if (tea5767_autodetection(t->i2c->adapter, t->i2c->addr)
 
1150                                 t->type = TUNER_TEA5767;
 
1151                                 t->mode_mask = T_RADIO;
 
1152                                 t->mode = T_STANDBY;
 
1153                                 /* Sets freq to FM range */
 
1154                                 t->radio_freq = 87.5 * 16000;
 
1155                                 tuner_lookup(t->i2c->adapter, &radio, &tv);
 
1157                                         tv->mode_mask &= ~T_RADIO;
 
1159                                 goto register_client;
 
1165         /* Initializes only the first TV tuner on this adapter. Why only the
 
1166            first? Because there are some devices (notably the ones with TI
 
1167            tuners) that have more than one i2c address for the *same* device.
 
1168            Experience shows that, except for just one case, the first
 
1169            address is the right one. The exception is a Russian tuner
 
1170            (ACORP_Y878F). So, the desired behavior is just to enable the
 
1171            first found TV tuner. */
 
1172         tuner_lookup(t->i2c->adapter, &radio, &tv);
 
1174                 t->mode_mask = T_ANALOG_TV | T_DIGITAL_TV;
 
1176                         t->mode_mask |= T_RADIO;
 
1177                 tuner_dbg("Setting mode_mask to 0x%02x\n", t->mode_mask);
 
1178                 t->tv_freq = 400 * 16; /* Sets freq to VHF High */
 
1179                 t->radio_freq = 87.5 * 16000; /* Sets freq to FM range */
 
1182         /* Should be just before return */
 
1184         tuner_info("chip found @ 0x%x (%s)\n", client->addr << 1,
 
1185                        client->adapter->name);
 
1187         /* Sets a default mode */
 
1188         if (t->mode_mask & T_ANALOG_TV) {
 
1189                 t->mode = V4L2_TUNER_ANALOG_TV;
 
1190         } else  if (t->mode_mask & T_RADIO) {
 
1191                 t->mode = V4L2_TUNER_RADIO;
 
1193                 t->mode = V4L2_TUNER_DIGITAL_TV;
 
1195         set_type(client, t->type, t->mode_mask, t->config, t->tuner_callback);
 
1196         list_add_tail(&t->list, &tuner_list);
 
1200 static int tuner_legacy_probe(struct i2c_adapter *adap)
 
1203                 normal_i2c[0] = addr;
 
1204                 normal_i2c[1] = I2C_CLIENT_END;
 
1207         if ((adap->class & I2C_CLASS_TV_ANALOG) == 0)
 
1210         /* HACK: Ignore 0x6b and 0x6f on cx88 boards.
 
1211          * FusionHDTV5 RT Gold has an ir receiver at 0x6b
 
1212          * and an RTC at 0x6f which can get corrupted if probed.
 
1214         if ((adap->id == I2C_HW_B_CX2388x) ||
 
1215             (adap->id == I2C_HW_B_CX23885)) {
 
1218                 while (i < I2C_CLIENT_MAX_OPTS && ignore[i] != I2C_CLIENT_END)
 
1220                 if (i + 4 < I2C_CLIENT_MAX_OPTS) {
 
1221                         ignore[i+0] = adap->nr;
 
1223                         ignore[i+2] = adap->nr;
 
1225                         ignore[i+4] = I2C_CLIENT_END;
 
1227                         printk(KERN_WARNING "tuner: "
 
1228                                "too many options specified "
 
1229                                "in i2c probe ignore list!\n");
 
1234 static int tuner_remove(struct i2c_client *client)
 
1236         struct tuner *t = i2c_get_clientdata(client);
 
1237         struct analog_demod_ops *analog_ops = &t->fe.ops.analog_ops;
 
1239         if (analog_ops->release)
 
1240                 analog_ops->release(&t->fe);
 
1247 /* ----------------------------------------------------------------------- */
 
1249 static struct v4l2_i2c_driver_data v4l2_i2c_data = {
 
1251         .driverid = I2C_DRIVERID_TUNER,
 
1252         .command = tuner_command,
 
1253         .probe = tuner_probe,
 
1254         .remove = tuner_remove,
 
1255         .suspend = tuner_suspend,
 
1256         .resume = tuner_resume,
 
1257         .legacy_probe = tuner_legacy_probe,
 
1262  * Overrides for Emacs so that we follow Linus's tabbing style.
 
1263  * ---------------------------------------------------------------------------