linux-media.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [V4L][SAA7134] fix tda9887 detection on cold and eeprom read corruption on warm Medion 7134
@ 2010-10-25 17:59 Maciej Szmigiero
  2010-11-09 10:53 ` Mauro Carvalho Chehab
  0 siblings, 1 reply; 3+ messages in thread
From: Maciej Szmigiero @ 2010-10-25 17:59 UTC (permalink / raw)
  To: Mauro Carvalho Chehab; +Cc: linux-media, linux-kernel

[V4L][SAA7134] fix tda9887 detection on cold and eeprom read corruption on warm Medion 7134

When Medion 7134 analog+DVB-T card is cold (after powerup) the tda9887 analog demodulator
won't show on i2c bus.
This results in no signal on analog TV. After loading driver for second time
eeprom (required for tuner autodetection) read is corrupted, but tda9987 is detected
properly and analog TV works when tuner model is forced.

Fix tda9887 problem by moving its detect code after tuner setup which unhides it.
The eeprom read issue is fixed by opening i2c gate in DVB-T demodulator.

Tested on Medion 7134 and also tested for reference on Typhoon Cardbus Hybrid
(which also uses saa7134 driver).

Signed-off-by: Maciej Szmigiero <mhej@o2.pl>

--- a/drivers/media/video/saa7134/saa7134-cards.c	2010-08-02 00:11:14.000000000 +0200
+++ b/drivers/media/video/saa7134/saa7134-cards.c	2010-10-25 19:19:08.000000000 +0200
@@ -7249,12 +7249,37 @@
 		break;
 	case SAA7134_BOARD_MD7134:
 	{
-		u8 subaddr;
+		u8 subaddr, dmdregval;
 		u8 data[3];
 		int ret, tuner_t;
+		struct i2c_msg i2cgatemsg_r[] = { {.addr = 0x08, .flags = 0,
+						.buf = &subaddr, .len = 1},
+						{.addr = 0x08,
+							.flags = I2C_M_RD,
+						.buf = &dmdregval, .len = 1} };
+		struct i2c_msg i2cgatemsg_w[] = { {.addr = 0x08, .flags = 0,
+						.buf = data, .len = 2} };
 		struct i2c_msg msg[] = {{.addr=0x50, .flags=0, .buf=&subaddr, .len = 1},
 					{.addr=0x50, .flags=I2C_M_RD, .buf=data, .len = 3}};
 
+		/* open i2c gate in DVB-T demod */
+		/* so eeprom read won't be corrupted */
+		subaddr = 0x7;
+		ret = i2c_transfer(&dev->i2c_adap, i2cgatemsg_r, 2);
+		if ((ret == 2) && (dmdregval & 0x2)) {
+			printk(KERN_NOTICE "%s DVB-T demod i2c gate was left"
+						    " closed\n", dev->name);
+			printk(KERN_NOTICE "%s previous informational"
+					    " EEPROM read might have been"
+					    " corrupted\n", dev->name);
+
+			data[0] = 0x7;
+			data[1] = (dmdregval & ~0x2);
+			if (i2c_transfer(&dev->i2c_adap, i2cgatemsg_w, 1) != 1)
+				printk(KERN_ERR "early i2c gate"
+						" open failure\n");
+		}
+
 		subaddr= 0x14;
 		tuner_t = 0;
 
@@ -7522,10 +7547,6 @@
 			v4l2_i2c_new_subdev(&dev->v4l2_dev,
 				&dev->i2c_adap, "tuner", "tuner",
 				dev->radio_addr, NULL);
-		if (has_demod)
-			v4l2_i2c_new_subdev(&dev->v4l2_dev,
-				&dev->i2c_adap, "tuner", "tuner",
-				0, v4l2_i2c_tuner_addrs(ADDRS_DEMOD));
 		if (dev->tuner_addr == ADDR_UNSET) {
 			enum v4l2_i2c_tuner_type type =
 				has_demod ? ADDRS_TV_WITH_DEMOD : ADDRS_TV;
@@ -7542,6 +7563,15 @@
 
 	saa7134_tuner_setup(dev);
 
+	/* some cards (Medion 7134 for example) needs tuner to be setup */
+	/* before tda9887 shows itself on i2c bus */
+	if ((TUNER_ABSENT != dev->tuner_type)
+			&& (dev->tda9887_conf & TDA9887_PRESENT)) {
+		v4l2_i2c_new_subdev(&dev->v4l2_dev,
+			&dev->i2c_adap, "tuner", "tuner",
+			0, v4l2_i2c_tuner_addrs(ADDRS_DEMOD));
+	}
+
 	switch (dev->board) {
 	case SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM:
 	case SAA7134_BOARD_AVERMEDIA_CARDBUS_501:



^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [V4L][SAA7134] fix tda9887 detection on cold and eeprom read corruption on warm Medion 7134
  2010-10-25 17:59 [V4L][SAA7134] fix tda9887 detection on cold and eeprom read corruption on warm Medion 7134 Maciej Szmigiero
@ 2010-11-09 10:53 ` Mauro Carvalho Chehab
  2010-11-09 15:02   ` Maciej Szmigiero
  0 siblings, 1 reply; 3+ messages in thread
From: Mauro Carvalho Chehab @ 2010-11-09 10:53 UTC (permalink / raw)
  To: Maciej Szmigiero; +Cc: linux-media, linux-kernel

Em 25-10-2010 15:59, Maciej Szmigiero escreveu:
> [V4L][SAA7134] fix tda9887 detection on cold and eeprom read corruption on warm Medion 7134
> 
> When Medion 7134 analog+DVB-T card is cold (after powerup) the tda9887 analog demodulator
> won't show on i2c bus.
> This results in no signal on analog TV. After loading driver for second time
> eeprom (required for tuner autodetection) read is corrupted, but tda9987 is detected
> properly and analog TV works when tuner model is forced.
> 
> Fix tda9887 problem by moving its detect code after tuner setup which unhides it.
> The eeprom read issue is fixed by opening i2c gate in DVB-T demodulator.
> 
> Tested on Medion 7134 and also tested for reference on Typhoon Cardbus Hybrid
> (which also uses saa7134 driver).
> 
> Signed-off-by: Maciej Szmigiero <mhej@o2.pl>
> 
> --- a/drivers/media/video/saa7134/saa7134-cards.c	2010-08-02 00:11:14.000000000 +0200
> +++ b/drivers/media/video/saa7134/saa7134-cards.c	2010-10-25 19:19:08.000000000 +0200
> @@ -7249,12 +7249,37 @@
>  		break;
>  	case SAA7134_BOARD_MD7134:
>  	{
> -		u8 subaddr;
> +		u8 subaddr, dmdregval;
>  		u8 data[3];
>  		int ret, tuner_t;
> +		struct i2c_msg i2cgatemsg_r[] = { {.addr = 0x08, .flags = 0,
> +						.buf = &subaddr, .len = 1},
> +						{.addr = 0x08,
> +							.flags = I2C_M_RD,
> +						.buf = &dmdregval, .len = 1} };
> +		struct i2c_msg i2cgatemsg_w[] = { {.addr = 0x08, .flags = 0,
> +						.buf = data, .len = 2} };
>  		struct i2c_msg msg[] = {{.addr=0x50, .flags=0, .buf=&subaddr, .len = 1},
>  					{.addr=0x50, .flags=I2C_M_RD, .buf=data, .len = 3}};
>  
> +		/* open i2c gate in DVB-T demod */
> +		/* so eeprom read won't be corrupted */
> +		subaddr = 0x7;
> +		ret = i2c_transfer(&dev->i2c_adap, i2cgatemsg_r, 2);
> +		if ((ret == 2) && (dmdregval & 0x2)) {
> +			printk(KERN_NOTICE "%s DVB-T demod i2c gate was left"
> +						    " closed\n", dev->name);
> +			printk(KERN_NOTICE "%s previous informational"
> +					    " EEPROM read might have been"
> +					    " corrupted\n", dev->name);

hmm... I don't think we need those debug messages on normal cases. Also, we want the log
shown as:
	saa7134: <foo>
and not as:
	saa7134 <foo>

> +
> +			data[0] = 0x7;
> +			data[1] = (dmdregval & ~0x2);
> +			if (i2c_transfer(&dev->i2c_adap, i2cgatemsg_w, 1) != 1)
> +				printk(KERN_ERR "early i2c gate"
> +						" open failure\n");

Gah. A message like that should really specify the dev->name, and the board.

> +		}
> +
>  		subaddr= 0x14;
>  		tuner_t = 0;
>  
> @@ -7522,10 +7547,6 @@
>  			v4l2_i2c_new_subdev(&dev->v4l2_dev,
>  				&dev->i2c_adap, "tuner", "tuner",
>  				dev->radio_addr, NULL);
> -		if (has_demod)
> -			v4l2_i2c_new_subdev(&dev->v4l2_dev,
> -				&dev->i2c_adap, "tuner", "tuner",
> -				0, v4l2_i2c_tuner_addrs(ADDRS_DEMOD));
>  		if (dev->tuner_addr == ADDR_UNSET) {
>  			enum v4l2_i2c_tuner_type type =
>  				has_demod ? ADDRS_TV_WITH_DEMOD : ADDRS_TV;
> @@ -7542,6 +7563,15 @@
>  
>  	saa7134_tuner_setup(dev);
>  
> +	/* some cards (Medion 7134 for example) needs tuner to be setup */
> +	/* before tda9887 shows itself on i2c bus */
> +	if ((TUNER_ABSENT != dev->tuner_type)
> +			&& (dev->tda9887_conf & TDA9887_PRESENT)) {
> +		v4l2_i2c_new_subdev(&dev->v4l2_dev,
> +			&dev->i2c_adap, "tuner", "tuner",
> +			0, v4l2_i2c_tuner_addrs(ADDRS_DEMOD));
> +	}
> +
>  	switch (dev->board) {
>  	case SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM:
>  	case SAA7134_BOARD_AVERMEDIA_CARDBUS_501:

The order change for the demod probe will likely break support for other boards.
If the problem is specific to Medion 7134, what you should do, instead, is to
change the order just for MD7134 (so, inside the switch(dev->board)).

Cheers,
Mauro.

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [V4L][SAA7134] fix tda9887 detection on cold and eeprom read corruption on warm Medion 7134
  2010-11-09 10:53 ` Mauro Carvalho Chehab
@ 2010-11-09 15:02   ` Maciej Szmigiero
  0 siblings, 0 replies; 3+ messages in thread
From: Maciej Szmigiero @ 2010-11-09 15:02 UTC (permalink / raw)
  To: Mauro Carvalho Chehab; +Cc: linux-media, linux-kernel

W dniu 09.11.2010 11:53, Mauro Carvalho Chehab pisze:
> Em 25-10-2010 15:59, Maciej Szmigiero escreveu:
>> +			printk(KERN_NOTICE "%s DVB-T demod i2c gate was left"
>> +						    " closed\n", dev->name);
>> +			printk(KERN_NOTICE "%s previous informational"
>> +					    " EEPROM read might have been"
>> +					    " corrupted\n", dev->name);
> 
> hmm... I don't think we need those debug messages on normal cases. 

I added this message because when the gate was left closed the eeprom content (printed out unconditionally in saa7134_i2c_eeprom) looks garbled in dmesg,
so it's better to inform user that he (or she) shouldn't be worried about this.
The eeprom dump is called from saa7134_i2c_register, before card-specific code has opportunity to run.

>>  	saa7134_tuner_setup(dev);
>>  
>> +	/* some cards (Medion 7134 for example) needs tuner to be setup */
>> +	/* before tda9887 shows itself on i2c bus */
>> +	if ((TUNER_ABSENT != dev->tuner_type)
>> +			&& (dev->tda9887_conf & TDA9887_PRESENT)) {
>> +		v4l2_i2c_new_subdev(&dev->v4l2_dev,
>> +			&dev->i2c_adap, "tuner", "tuner",
>> +			0, v4l2_i2c_tuner_addrs(ADDRS_DEMOD));
>> +	}
>> +
>>  	switch (dev->board) {
>>  	case SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM:
>>  	case SAA7134_BOARD_AVERMEDIA_CARDBUS_501:
> 
> The order change for the demod probe will likely break support for other boards.
> If the problem is specific to Medion 7134, what you should do, instead, is to
> change the order just for MD7134 (so, inside the switch(dev->board)).

It was done in that order (tuner first then tda9887) for a long time before it was changed.
For example ( http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=blob;f=drivers/media/video/saa7134/saa7134-core.c;hb=7a766f9ddd74b50d6069f054a3004ece0439f5c1 ) it used to look like that:
 942         /* load i2c helpers */
 943         if (TUNER_ABSENT != dev->tuner_type)
 944                 request_module("tuner");
 945         if (dev->tda9887_conf)
 946                 request_module("tda9887");
 947         if (card_is_empress(dev)) {
 948                 request_module("saa6752hs");
 949                 request_module_depend("saa7134-empress",&need_empress);
 950         }

But then the code for tda9887 was integrated into tuner module and later split out again, this time reversing the detection order (by accident I suppose).
 
> Cheers,
> Mauro.
> 

Best regards,
Maciej Szmigiero

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2010-11-09 15:03 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-10-25 17:59 [V4L][SAA7134] fix tda9887 detection on cold and eeprom read corruption on warm Medion 7134 Maciej Szmigiero
2010-11-09 10:53 ` Mauro Carvalho Chehab
2010-11-09 15:02   ` Maciej Szmigiero

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).