diff options
-rw-r--r-- | drivers/media/video/tuner-driver.h | 1 | ||||
-rw-r--r-- | drivers/media/video/tuner-simple.c | 29 |
2 files changed, 25 insertions, 5 deletions
diff --git a/drivers/media/video/tuner-driver.h b/drivers/media/video/tuner-driver.h index 0334a9125077..fa51b7cec691 100644 --- a/drivers/media/video/tuner-driver.h +++ b/drivers/media/video/tuner-driver.h | |||
@@ -49,7 +49,6 @@ struct tuner { | |||
49 | 49 | ||
50 | unsigned int tv_freq; /* keep track of the current settings */ | 50 | unsigned int tv_freq; /* keep track of the current settings */ |
51 | unsigned int radio_freq; | 51 | unsigned int radio_freq; |
52 | u16 last_div; | ||
53 | unsigned int audmode; | 52 | unsigned int audmode; |
54 | v4l2_std_id std; | 53 | v4l2_std_id std; |
55 | 54 | ||
diff --git a/drivers/media/video/tuner-simple.c b/drivers/media/video/tuner-simple.c index 10a7d36a2646..572f22423b98 100644 --- a/drivers/media/video/tuner-simple.c +++ b/drivers/media/video/tuner-simple.c | |||
@@ -82,6 +82,10 @@ MODULE_PARM_DESC(offset,"Allows to specify an offset for tuner"); | |||
82 | #define TUNER_PLL_LOCKED 0x40 | 82 | #define TUNER_PLL_LOCKED 0x40 |
83 | #define TUNER_STEREO_MK3 0x04 | 83 | #define TUNER_STEREO_MK3 0x04 |
84 | 84 | ||
85 | struct tuner_simple_priv { | ||
86 | u16 last_div; | ||
87 | }; | ||
88 | |||
85 | /* ---------------------------------------------------------------------- */ | 89 | /* ---------------------------------------------------------------------- */ |
86 | 90 | ||
87 | static int tuner_getstatus(struct i2c_client *c) | 91 | static int tuner_getstatus(struct i2c_client *c) |
@@ -126,6 +130,7 @@ static int tuner_stereo(struct i2c_client *c) | |||
126 | static void default_set_tv_freq(struct i2c_client *c, unsigned int freq) | 130 | static void default_set_tv_freq(struct i2c_client *c, unsigned int freq) |
127 | { | 131 | { |
128 | struct tuner *t = i2c_get_clientdata(c); | 132 | struct tuner *t = i2c_get_clientdata(c); |
133 | struct tuner_simple_priv *priv = t->priv; | ||
129 | u8 config, cb, tuneraddr; | 134 | u8 config, cb, tuneraddr; |
130 | u16 div; | 135 | u16 div; |
131 | struct tunertype *tun; | 136 | struct tunertype *tun; |
@@ -291,7 +296,7 @@ static void default_set_tv_freq(struct i2c_client *c, unsigned int freq) | |||
291 | break; | 296 | break; |
292 | } | 297 | } |
293 | 298 | ||
294 | if (params->cb_first_if_lower_freq && div < t->last_div) { | 299 | if (params->cb_first_if_lower_freq && div < priv->last_div) { |
295 | buffer[0] = config; | 300 | buffer[0] = config; |
296 | buffer[1] = cb; | 301 | buffer[1] = cb; |
297 | buffer[2] = (div>>8) & 0x7f; | 302 | buffer[2] = (div>>8) & 0x7f; |
@@ -302,7 +307,7 @@ static void default_set_tv_freq(struct i2c_client *c, unsigned int freq) | |||
302 | buffer[2] = config; | 307 | buffer[2] = config; |
303 | buffer[3] = cb; | 308 | buffer[3] = cb; |
304 | } | 309 | } |
305 | t->last_div = div; | 310 | priv->last_div = div; |
306 | if (params->has_tda9887) { | 311 | if (params->has_tda9887) { |
307 | int config = 0; | 312 | int config = 0; |
308 | int is_secam_l = (t->std & (V4L2_STD_SECAM_L | V4L2_STD_SECAM_LC)) && | 313 | int is_secam_l = (t->std & (V4L2_STD_SECAM_L | V4L2_STD_SECAM_LC)) && |
@@ -399,6 +404,7 @@ static void default_set_radio_freq(struct i2c_client *c, unsigned int freq) | |||
399 | { | 404 | { |
400 | struct tunertype *tun; | 405 | struct tunertype *tun; |
401 | struct tuner *t = i2c_get_clientdata(c); | 406 | struct tuner *t = i2c_get_clientdata(c); |
407 | struct tuner_simple_priv *priv = t->priv; | ||
402 | u8 buffer[4]; | 408 | u8 buffer[4]; |
403 | u16 div; | 409 | u16 div; |
404 | int rc, j; | 410 | int rc, j; |
@@ -464,7 +470,7 @@ static void default_set_radio_freq(struct i2c_client *c, unsigned int freq) | |||
464 | freq * (1/800) */ | 470 | freq * (1/800) */ |
465 | div = (freq + 400) / 800; | 471 | div = (freq + 400) / 800; |
466 | 472 | ||
467 | if (params->cb_first_if_lower_freq && div < t->last_div) { | 473 | if (params->cb_first_if_lower_freq && div < priv->last_div) { |
468 | buffer[0] = buffer[2]; | 474 | buffer[0] = buffer[2]; |
469 | buffer[1] = buffer[3]; | 475 | buffer[1] = buffer[3]; |
470 | buffer[2] = (div>>8) & 0x7f; | 476 | buffer[2] = (div>>8) & 0x7f; |
@@ -476,7 +482,7 @@ static void default_set_radio_freq(struct i2c_client *c, unsigned int freq) | |||
476 | 482 | ||
477 | tuner_dbg("radio 0x%02x 0x%02x 0x%02x 0x%02x\n", | 483 | tuner_dbg("radio 0x%02x 0x%02x 0x%02x 0x%02x\n", |
478 | buffer[0],buffer[1],buffer[2],buffer[3]); | 484 | buffer[0],buffer[1],buffer[2],buffer[3]); |
479 | t->last_div = div; | 485 | priv->last_div = div; |
480 | 486 | ||
481 | if (params->has_tda9887) { | 487 | if (params->has_tda9887) { |
482 | int config = 0; | 488 | int config = 0; |
@@ -498,16 +504,31 @@ static void default_set_radio_freq(struct i2c_client *c, unsigned int freq) | |||
498 | tuner_warn("i2c i/o error: rc == %d (should be 4)\n",rc); | 504 | tuner_warn("i2c i/o error: rc == %d (should be 4)\n",rc); |
499 | } | 505 | } |
500 | 506 | ||
507 | static void tuner_release(struct i2c_client *c) | ||
508 | { | ||
509 | struct tuner *t = i2c_get_clientdata(c); | ||
510 | |||
511 | kfree(t->priv); | ||
512 | t->priv = NULL; | ||
513 | } | ||
514 | |||
501 | static struct tuner_operations simple_tuner_ops = { | 515 | static struct tuner_operations simple_tuner_ops = { |
502 | .set_tv_freq = default_set_tv_freq, | 516 | .set_tv_freq = default_set_tv_freq, |
503 | .set_radio_freq = default_set_radio_freq, | 517 | .set_radio_freq = default_set_radio_freq, |
504 | .has_signal = tuner_signal, | 518 | .has_signal = tuner_signal, |
505 | .is_stereo = tuner_stereo, | 519 | .is_stereo = tuner_stereo, |
520 | .release = tuner_release, | ||
506 | }; | 521 | }; |
507 | 522 | ||
508 | int default_tuner_init(struct i2c_client *c) | 523 | int default_tuner_init(struct i2c_client *c) |
509 | { | 524 | { |
510 | struct tuner *t = i2c_get_clientdata(c); | 525 | struct tuner *t = i2c_get_clientdata(c); |
526 | struct tuner_simple_priv *priv = NULL; | ||
527 | |||
528 | priv = kzalloc(sizeof(struct tuner_simple_priv), GFP_KERNEL); | ||
529 | if (priv == NULL) | ||
530 | return -ENOMEM; | ||
531 | t->priv = priv; | ||
511 | 532 | ||
512 | tuner_info("type set to %d (%s)\n", | 533 | tuner_info("type set to %d (%s)\n", |
513 | t->type, tuners[t->type].name); | 534 | t->type, tuners[t->type].name); |