aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/tuner-xc2028.c
diff options
context:
space:
mode:
authorMauro Carvalho Chehab <mchehab@infradead.org>2007-11-05 07:07:13 -0500
committerMauro Carvalho Chehab <mchehab@infradead.org>2008-01-25 16:02:01 -0500
commit80b522085a2c870ba0c0bdf2415cc925d7c86ca5 (patch)
treeefcf9cc4690afb00c636c100ad15aec85baa5a82 /drivers/media/video/tuner-xc2028.c
parentf8b6030ccca06bf0d45d9b0908caac9b624a9beb (diff)
V4L/DVB (6561): Fix xc2028 get register functions and calls
The status registers require a dword for setting register. Fix it on all occurrences, and at xc3028_get_reg. Also, improves the hardware/firmware detection printk. Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
Diffstat (limited to 'drivers/media/video/tuner-xc2028.c')
-rw-r--r--drivers/media/video/tuner-xc2028.c25
1 files changed, 16 insertions, 9 deletions
diff --git a/drivers/media/video/tuner-xc2028.c b/drivers/media/video/tuner-xc2028.c
index b4c88ed12a8a..ecfc39036f90 100644
--- a/drivers/media/video/tuner-xc2028.c
+++ b/drivers/media/video/tuner-xc2028.c
@@ -91,16 +91,17 @@ struct xc2028_data {
91 msleep(10); \ 91 msleep(10); \
92} while (0) 92} while (0)
93 93
94static int xc2028_get_reg(struct xc2028_data *priv, u16 reg) 94static unsigned int xc2028_get_reg(struct xc2028_data *priv, u16 reg)
95{ 95{
96 int rc; 96 int rc;
97 unsigned char buf[2]; 97 unsigned char buf[2];
98 98
99 tuner_info("%s called\n", __FUNCTION__); 99 tuner_info("%s called\n", __FUNCTION__);
100 100
101 buf[0] = reg; 101 buf[0] = reg>>8;
102 buf[1] = (unsigned char) reg;
102 103
103 i2c_send(rc, priv, buf, 1); 104 i2c_send(rc, priv, buf, 2);
104 if (rc < 0) 105 if (rc < 0)
105 return rc; 106 return rc;
106 107
@@ -372,7 +373,7 @@ static int check_firmware(struct dvb_frontend *fe, enum tuner_mode new_mode,
372 v4l2_std_id std, fe_bandwidth_t bandwidth) 373 v4l2_std_id std, fe_bandwidth_t bandwidth)
373{ 374{
374 struct xc2028_data *priv = fe->tuner_priv; 375 struct xc2028_data *priv = fe->tuner_priv;
375 int rc, version; 376 int rc, version, hwmodel;
376 v4l2_std_id std0 = 0; 377 v4l2_std_id std0 = 0;
377 unsigned int type0 = 0, type = 0; 378 unsigned int type0 = 0, type = 0;
378 int change_digital_bandwidth; 379 int change_digital_bandwidth;
@@ -484,9 +485,13 @@ static int check_firmware(struct dvb_frontend *fe, enum tuner_mode new_mode,
484 if (rc < 0) 485 if (rc < 0)
485 return rc; 486 return rc;
486 487
487 version = xc2028_get_reg(priv, 0x4); 488 version = xc2028_get_reg(priv, 0x0004);
488 tuner_info("Firmware version is %d.%d\n", 489 hwmodel = xc2028_get_reg(priv, 0x0008);
489 (version >> 4) & 0x0f, (version) & 0x0f); 490
491 tuner_info("Device is Xceive %d version %d.%d, "
492 "firmware version %d.%d\n",
493 hwmodel, (version & 0xf000) >> 12, (version & 0xf00) >> 8,
494 (version & 0xf0) >> 4, version & 0xf);
490 495
491 priv->firm_type = std; 496 priv->firm_type = std;
492 497
@@ -504,13 +509,15 @@ static int xc2028_signal(struct dvb_frontend *fe, u16 *strength)
504 509
505 *strength = 0; 510 *strength = 0;
506 511
507 frq_lock = xc2028_get_reg(priv, 0x2); 512 /* Sync Lock Indicator */
513 frq_lock = xc2028_get_reg(priv, 0x0002);
508 if (frq_lock <= 0) 514 if (frq_lock <= 0)
509 goto ret; 515 goto ret;
510 516
511 /* Frequency is locked. Return signal quality */ 517 /* Frequency is locked. Return signal quality */
512 518
513 signal = xc2028_get_reg(priv, 0x40); 519 /* Get SNR of the video signal */
520 signal = xc2028_get_reg(priv, 0x0040);
514 521
515 if (signal <= 0) 522 if (signal <= 0)
516 signal = frq_lock; 523 signal = frq_lock;