diff mbox

tda18271-fe: Fix dvb-c standard selection

Message ID 5275690A.3080108@narod.ru (mailing list archive)
State New, archived
Headers show

Commit Message

CrazyCat Nov. 2, 2013, 9:05 p.m. UTC
Fix dvb-c standard selection - qam8 for ANNEX_AC

Signed-off-by: Evgeny Plehov <EvgenyPlehov@ukr.net>

--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Comments

Mauro Carvalho Chehab Nov. 2, 2013, 9:21 p.m. UTC | #1
Em Sat, 02 Nov 2013 23:05:14 +0200
CrazyCat <crazycat69@narod.ru> escreveu:

> Fix dvb-c standard selection - qam8 for ANNEX_AC
> 
> Signed-off-by: Evgeny Plehov <EvgenyPlehov@ukr.net>
> diff --git a/drivers/media/tuners/tda18271-fe.c b/drivers/media/tuners/tda18271-fe.c
> index 4995b89..6a385c8 100644
> --- a/drivers/media/tuners/tda18271-fe.c
> +++ b/drivers/media/tuners/tda18271-fe.c
> @@ -960,16 +960,12 @@ static int tda18271_set_params(struct dvb_frontend *fe)
>   		break;
>   	case SYS_DVBC_ANNEX_B:
>   		bw = 6000000;
> -		/* falltrough */
> +		map = &std_map->qam_6;
> +		break;
>   	case SYS_DVBC_ANNEX_A:
>   	case SYS_DVBC_ANNEX_C:
> -		if (bw <= 6000000) {
> -			map = &std_map->qam_6;
> -		} else if (bw <= 7000000) {
> -			map = &std_map->qam_7;
> -		} else {
> -			map = &std_map->qam_8;
> -		}
> +		bw = 8000000;
> +		map = &std_map->qam_8;

This is wrong, as it breaks for 6MHz-spaced channels, like what's used
in Brazil and Japan.

What happens here is that, if the tuner uses a too wide lowpass filter,
the interference will be higher at the demod, and it may not be able
to decode.

As the bandwidth is already estimated by the DVB frontend core, the
tuners should be adjusted to get the closest filter for a given
bandwidth.

So, the driver is correct (and it is tested under 6MHz spaced channels).

>   		break;
>   	default:
>   		tda_warn("modulation type not supported!\n");
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-media" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
Mauro Carvalho Chehab Nov. 3, 2013, 12:19 a.m. UTC | #2
Em Sat, 02 Nov 2013 23:31:58 +0200
CrazyCat <crazycat69@narod.ru> escreveu:

> Mauro Carvalho Chehab ?????:
> > This is wrong, as it breaks for 6MHz-spaced channels, like what's used
> > in Brazil and Japan.
> >
> > What happens here is that, if the tuner uses a too wide lowpass filter,
> > the interference will be higher at the demod, and it may not be able
> > to decode.
> >
> > As the bandwidth is already estimated by the DVB frontend core, the
> > tuners should be adjusted to get the closest filter for a given
> > bandwidth.
> >
> > So, the driver is correct (and it is tested under 6MHz spaced channels).
> 
> But usual applications only set cable standard (Annex A/C or B) and not set bandwidth. So for annex A/C default selected 6MHz ?

Usual applications set the symbol rate, and symbol rate is easily
converted into bandwidth. The DVB core does that. see 
dtv_set_frontend():

	switch (c->delivery_system) {
	case SYS_ATSC:
	case SYS_DVBC_ANNEX_B:
		c->bandwidth_hz = 6000000;
		break;
	case SYS_DVBC_ANNEX_A:
		rolloff = 115;
		break;
	case SYS_DVBC_ANNEX_C:
		rolloff = 113;
		break;
	default:
		break;
	}
	if (rolloff)
		c->bandwidth_hz = (c->symbol_rate * rolloff) / 100;
diff mbox

Patch

diff --git a/drivers/media/tuners/tda18271-fe.c b/drivers/media/tuners/tda18271-fe.c
index 4995b89..6a385c8 100644
--- a/drivers/media/tuners/tda18271-fe.c
+++ b/drivers/media/tuners/tda18271-fe.c
@@ -960,16 +960,12 @@  static int tda18271_set_params(struct dvb_frontend *fe)
  		break;
  	case SYS_DVBC_ANNEX_B:
  		bw = 6000000;
-		/* falltrough */
+		map = &std_map->qam_6;
+		break;
  	case SYS_DVBC_ANNEX_A:
  	case SYS_DVBC_ANNEX_C:
-		if (bw <= 6000000) {
-			map = &std_map->qam_6;
-		} else if (bw <= 7000000) {
-			map = &std_map->qam_7;
-		} else {
-			map = &std_map->qam_8;
-		}
+		bw = 8000000;
+		map = &std_map->qam_8;
  		break;
  	default:
  		tda_warn("modulation type not supported!\n");