Fwd: Re: [PATCH] DiSEqC bug fixed for stv0288 based interfaces

2010-10-28 Thread Josef Pavlik
Hi Mauro
can you try to insert it in your GIT please? 

> >> Fixed problem with DiSEqC communication. The message was wrongly 
> >> modulated, 
> >> so the DiSEqC switch was not work.
> >> 
> >> This patch fixes DiSEqC messages, simple tone burst and tone on/off. 
> >> I verified it with osciloscope against the DiSEqC documentation.
> >> 
> >> Interface: PCI DVB-S TV tuner TeVii S420
> >> Kernel: 2.6.32-24-generic (UBUNTU 10.4)
> >> 

Signed-off-by: Josef Pavlik 

------  Forwarded Message  --

Subject: Re: [PATCH] DiSEqC bug fixed for stv0288 based interfaces
Date: Sunday 26 September 2010
From: tvbox 
To: jo...@pavlik.it

Hi Josef

This patch does work and has been tested in my driver.

However, your patch was still corrupt, here is a cleaned up version.

I have had to shorten some quotes in some lines to within 80 characters

Tested-by: Malcolm Priestley 

It is also in my own hg tree at
http://mercurial.intuxication.org/hg/tvboxspy/rev/666fe763c5f6


diff --git a/drivers/media/dvb/frontends/stv0288.c 
b/drivers/media/dvb/frontends/stv0288.c
index 2930a5d..6cd442e 100644
--- a/drivers/media/dvb/frontends/stv0288.c
+++ b/drivers/media/dvb/frontends/stv0288.c
@@ -6,6 +6,8 @@
Copyright (C) 2008 Igor M. Liplianin 
Removed stb6000 specific tuner code and revised some
procedures.
+   2010-09-01 Josef Pavlik 
+   Fixed diseqc_msg, diseqc_burst and set_tone problems

This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -156,14 +158,13 @@ static int stv0288_send_diseqc_msg(struct dvb_frontend 
*fe,
 
stv0288_writeregI(state, 0x09, 0);
msleep(30);
-   stv0288_writeregI(state, 0x05, 0x16);
+   stv0288_writeregI(state, 0x05, 0x12);/* modulated mode, single shot */

for (i = 0; i < m->msg_len; i++) {
if (stv0288_writeregI(state, 0x06, m->msg[i]))
return -EREMOTEIO;
-   msleep(12);
}
-
+   msleep(m->msg_len*12);
return 0;
 }

@@ -174,13 +175,14 @@ static int stv0288_send_diseqc_burst(struct dvb_frontend 
*fe,

dprintk("%s\n", __func__);
 
-   if (stv0288_writeregI(state, 0x05, 0x16))/* burst mode */
-   return -EREMOTEIO;
-
-   if (stv0288_writeregI(state, 0x06, burst == SEC_MINI_A ? 0x00 : 0xff))
+   if (stv0288_writeregI(state, 0x05, 0x03))/* burst mode, single shot */
+   return -EREMOTEIO;
+
+   if (stv0288_writeregI(state, 0x06, burst == SEC_MINI_A ? 0x00 : 0xff))
return -EREMOTEIO;

-   if (stv0288_writeregI(state, 0x06, 0x12))
+   msleep(15);
+   if (stv0288_writeregI(state, 0x05, 0x12))
return -EREMOTEIO;
 
return 0;
@@ -192,18 +194,19 @@ static int stv0288_set_tone(struct dvb_frontend *fe, 
fe_sec_tone_mode_t tone)

switch (tone) {
case SEC_TONE_ON:
-   if (stv0288_writeregI(state, 0x05, 0x10))/* burst mode */
+   if (stv0288_writeregI(state, 0x05, 0x10))/* cont carrier */
return -EREMOTEIO;
-   return stv0288_writeregI(state, 0x06, 0xff);
+   break;
 
case SEC_TONE_OFF:
-   if (stv0288_writeregI(state, 0x05, 0x13))/* burst mode */
+   if (stv0288_writeregI(state, 0x05, 0x12))/* burst mode off*/
return -EREMOTEIO;
-   return stv0288_writeregI(state, 0x06, 0x00);
+   break;
 
default:
return -EINVAL;
}
+   return 0;
 }
 
 static u8 stv0288_inittab[] = {


> sorry, but something eats the leading spaces (but no the tabs) in the inlined 
> patch making it unusable, so please use the attached one.
> 
> 
> -
> on  Sep 12, 2010, at 13:30, I wrote:
> seems that the patch was corrupted by the kmail used for the post (missing 
> space before the last close bracket resulting corrupted patch)
> the corrected patch follows (and I'm sending it with another mail program)
> 
> Signed-off-by: Josef Pavlik 
> 
> -
> diff --git a/drivers/media/dvb/frontends/stv0288.c 
> b/drivers/media/dvb/frontends/stv0288.c
> index 2930a5d..6cd442e 100644
> --- a/drivers/media/dvb/frontends/stv0288.c
> +++ b/drivers/media/dvb/frontends/stv0288.c
> @@ -6,6 +6,8 @@
> Copyright (C) 2008 Igor M. Liplianin 
> Removed stb6000 specific tuner code and revised some
> procedures.
> +2010-09-01 Josef Pavlik 
> +Fixed diseqc_msg, diseqc_burst and set_tone problems
> 
> This program is free software; you can redistribute it and/or modify
> it under the terms of the

Re: [PATCH] DiSEqC bug fixed for stv0288 based interfaces

2010-09-26 Thread tvbox
Hi Josef

This patch does work and has been tested in my driver.

However, your patch was still corrupt, here is a cleaned up version.

I have had to shorten some quotes in some lines to within 80 characters

Tested-by: Malcolm Priestley 

It is also in my own hg tree at
http://mercurial.intuxication.org/hg/tvboxspy/rev/666fe763c5f6


diff --git a/drivers/media/dvb/frontends/stv0288.c 
b/drivers/media/dvb/frontends/stv0288.c
index 2930a5d..6cd442e 100644
--- a/drivers/media/dvb/frontends/stv0288.c
+++ b/drivers/media/dvb/frontends/stv0288.c
@@ -6,6 +6,8 @@
Copyright (C) 2008 Igor M. Liplianin 
Removed stb6000 specific tuner code and revised some
procedures.
+   2010-09-01 Josef Pavlik 
+   Fixed diseqc_msg, diseqc_burst and set_tone problems

This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -156,14 +158,13 @@ static int stv0288_send_diseqc_msg(struct dvb_frontend 
*fe,
 
stv0288_writeregI(state, 0x09, 0);
msleep(30);
-   stv0288_writeregI(state, 0x05, 0x16);
+   stv0288_writeregI(state, 0x05, 0x12);/* modulated mode, single shot */

for (i = 0; i < m->msg_len; i++) {
if (stv0288_writeregI(state, 0x06, m->msg[i]))
return -EREMOTEIO;
-   msleep(12);
}
-
+   msleep(m->msg_len*12);
return 0;
 }

@@ -174,13 +175,14 @@ static int stv0288_send_diseqc_burst(struct dvb_frontend 
*fe,

dprintk("%s\n", __func__);
 
-   if (stv0288_writeregI(state, 0x05, 0x16))/* burst mode */
-   return -EREMOTEIO;
-
-   if (stv0288_writeregI(state, 0x06, burst == SEC_MINI_A ? 0x00 : 0xff))
+   if (stv0288_writeregI(state, 0x05, 0x03))/* burst mode, single shot */
+   return -EREMOTEIO;
+
+   if (stv0288_writeregI(state, 0x06, burst == SEC_MINI_A ? 0x00 : 0xff))
return -EREMOTEIO;

-   if (stv0288_writeregI(state, 0x06, 0x12))
+   msleep(15);
+   if (stv0288_writeregI(state, 0x05, 0x12))
return -EREMOTEIO;
 
return 0;
@@ -192,18 +194,19 @@ static int stv0288_set_tone(struct dvb_frontend *fe, 
fe_sec_tone_mode_t tone)

switch (tone) {
case SEC_TONE_ON:
-   if (stv0288_writeregI(state, 0x05, 0x10))/* burst mode */
+   if (stv0288_writeregI(state, 0x05, 0x10))/* cont carrier */
return -EREMOTEIO;
-   return stv0288_writeregI(state, 0x06, 0xff);
+   break;
 
case SEC_TONE_OFF:
-   if (stv0288_writeregI(state, 0x05, 0x13))/* burst mode */
+   if (stv0288_writeregI(state, 0x05, 0x12))/* burst mode off*/
return -EREMOTEIO;
-   return stv0288_writeregI(state, 0x06, 0x00);
+   break;
 
default:
return -EINVAL;
}
+   return 0;
 }
 
 static u8 stv0288_inittab[] = {


> sorry, but something eats the leading spaces (but no the tabs) in the inlined 
> patch making it unusable, so please use the attached one.
> 
> 
> -
> on  Sep 12, 2010, at 13:30, I wrote:
> seems that the patch was corrupted by the kmail used for the post (missing 
> space before the last close bracket resulting corrupted patch)
> the corrected patch follows (and I'm sending it with another mail program)
> 
> Signed-off-by: Josef Pavlik 
> 
> -
> diff --git a/drivers/media/dvb/frontends/stv0288.c 
> b/drivers/media/dvb/frontends/stv0288.c
> index 2930a5d..6cd442e 100644
> --- a/drivers/media/dvb/frontends/stv0288.c
> +++ b/drivers/media/dvb/frontends/stv0288.c
> @@ -6,6 +6,8 @@
> Copyright (C) 2008 Igor M. Liplianin 
> Removed stb6000 specific tuner code and revised some
> procedures.
> +2010-09-01 Josef Pavlik 
> +Fixed diseqc_msg, diseqc_burst and set_tone problems
> 
> This program is free software; you can redistribute it and/or modify
> it under the terms of the GNU General Public License as published by
> @@ -156,14 +158,13 @@ static int stv0288_send_diseqc_msg(struct dvb_frontend 
> *fe,
> 
> stv0288_writeregI(state, 0x09, 0);
> msleep(30);
> -   stv0288_writeregI(state, 0x05, 0x16);
> +   stv0288_writeregI(state, 0x05, 0x12); /* modulated mode, single shot 
> */
> 
> for (i = 0; i < m->msg_len; i++) {
> if (stv0288_writeregI(state, 0x06, m->msg[i]))
> return -EREMOTEIO;
> -   msleep(12);
> }
> -
> +msleep(m->msg_len*12); 
> return 0;
> }
> 
> @@ -174,13 +175,14 @@ static int stv0288_send_diseqc_burst(struct 
> dvb_frontend 
> *fe,
> 
> dprintk("%s\n", __func__);
> 
> -   if (stv0288_writeregI(state, 0x05, 0x16))/* burst mode */
> -   return -EREMOTEIO;
> -
> -   i

Re: [PATCH] DiSEqC bug fixed for stv0288 based interfaces

2010-09-12 Thread Josef Pavlik
sorry, but something eats the leading spaces (but no the tabs) in the inlined 
patch making it unusable, so please use the attached one.


-
on  Sep 12, 2010, at 13:30, I wrote:
seems that the patch was corrupted by the kmail used for the post (missing 
space before the last close bracket resulting corrupted patch)
the corrected patch follows (and I'm sending it with another mail program)

Signed-off-by: Josef Pavlik 

-
diff --git a/drivers/media/dvb/frontends/stv0288.c 
b/drivers/media/dvb/frontends/stv0288.c
index 2930a5d..6cd442e 100644
--- a/drivers/media/dvb/frontends/stv0288.c
+++ b/drivers/media/dvb/frontends/stv0288.c
@@ -6,6 +6,8 @@
Copyright (C) 2008 Igor M. Liplianin 
Removed stb6000 specific tuner code and revised some
procedures.
+2010-09-01 Josef Pavlik 
+Fixed diseqc_msg, diseqc_burst and set_tone problems

This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -156,14 +158,13 @@ static int stv0288_send_diseqc_msg(struct dvb_frontend 
*fe,

stv0288_writeregI(state, 0x09, 0);
msleep(30);
-   stv0288_writeregI(state, 0x05, 0x16);
+   stv0288_writeregI(state, 0x05, 0x12); /* modulated mode, single shot */

for (i = 0; i < m->msg_len; i++) {
if (stv0288_writeregI(state, 0x06, m->msg[i]))
return -EREMOTEIO;
-   msleep(12);
}
-
+msleep(m->msg_len*12); 
return 0;
}

@@ -174,13 +175,14 @@ static int stv0288_send_diseqc_burst(struct dvb_frontend 
*fe,

dprintk("%s\n", __func__);

-   if (stv0288_writeregI(state, 0x05, 0x16))/* burst mode */
-   return -EREMOTEIO;
-
-   if (stv0288_writeregI(state, 0x06, burst == SEC_MINI_A ? 0x00 : 0xff))
+if (stv0288_writeregI(state, 0x05, 0x03)) /* simple tone burst mode, 
single shot */
+return -EREMOTEIO;
+   
+if (stv0288_writeregI(state, 0x06, burst == SEC_MINI_A ? 0x00 : 0xff))
return -EREMOTEIO;

-   if (stv0288_writeregI(state, 0x06, 0x12))
+msleep(15);
+   if (stv0288_writeregI(state, 0x05, 0x12))
return -EREMOTEIO;

return 0;
@@ -192,18 +194,19 @@ static int stv0288_set_tone(struct dvb_frontend *fe, 
fe_sec_tone_mode_t tone)

switch (tone) {
case SEC_TONE_ON:
-   if (stv0288_writeregI(state, 0x05, 0x10))/* burst mode */
+   if (stv0288_writeregI(state, 0x05, 0x10))/* burst mode, 
continuous carrier */
return -EREMOTEIO;
-   return stv0288_writeregI(state, 0x06, 0xff);
+break;

case SEC_TONE_OFF:
-   if (stv0288_writeregI(state, 0x05, 0x13))/* burst mode */
+   if (stv0288_writeregI(state, 0x05, 0x12))/* burst mode off*/
return -EREMOTEIO;
-   return stv0288_writeregI(state, 0x06, 0x00);
+break;

default:
return -EINVAL;
}
+return 0;
}

static u8 stv0288_inittab[] = {
-



On Sep 8, 2010, at 21:16 , Mauro Carvalho Chehab wrote:

> Em 01-09-2010 09:35, Josef Pavlik escreveu:
>> Fixed problem with DiSEqC communication. The message was wrongly modulated, 
>> so the DiSEqC switch was not work.
>> 
>> This patch fixes DiSEqC messages, simple tone burst and tone on/off. 
>> I verified it with osciloscope against the DiSEqC documentation.
>> 
>> Interface: PCI DVB-S TV tuner TeVii S420
>> Kernel: 2.6.32-24-generic (UBUNTU 10.4)
>> 
>> Signed-off-by: Josef Pavlik 
> 
> Patch doesn't apply against the latest version, at my -git tree. 
> Not sure if the bugs you're pointing were already fixed.
> 
> Cheers,
> Mauro.
>> 
>> 
>> 
>> 
>> diff --git a/drivers/media/dvb/frontends/stv0288.c 
>> b/drivers/media/dvb/frontends/stv0288.c
>> index 2930a5d..6a32535 100644
>> --- a/drivers/media/dvb/frontends/stv0288.c
>> +++ b/drivers/media/dvb/frontends/stv0288.c
>> @@ -6,6 +6,8 @@
>>   Copyright (C) 2008 Igor M. Liplianin 
>>   Removed stb6000 specific tuner code and revised some
>>   procedures.
>> +   2010-09-01 Josef Pavlik 
>> +   Fixed diseqc_msg, diseqc_burst and set_tone problems
>> 
>>   This program is free software; you can redistribute it and/or modify
>>   it under the terms of the GNU General Public License as published by
>> @@ -156,14 +158,13 @@ static int stv0288_send_diseqc_msg(struct dvb_frontend 
>> *fe,
>> 
>>   stv0288_writeregI(state, 0x09, 0);
>>   msleep(30);
>> -   stv0288_writeregI(state, 0x05, 0x16);
>> +   stv0288_writeregI(state, 0x05, 0x12); /* modulated mode, single shot 
>> */
>> 
>>   for (i = 0; i < m->msg_len; i++) {
>>   if (stv0288_writeregI(state, 0x06, m->msg[i]))
>>   return

Re: [PATCH] DiSEqC bug fixed for stv0288 based interfaces

2010-09-12 Thread Josef Pavlik
seems that the patch was corrupted by the kmail used for the post (missing 
space before the last close bracket resulting corrupted patch)
the corrected patch follows (and I'm sending it with another mail program)

Signed-off-by: Josef Pavlik 

-
diff --git a/drivers/media/dvb/frontends/stv0288.c 
b/drivers/media/dvb/frontends/stv0288.c
index 2930a5d..6cd442e 100644
--- a/drivers/media/dvb/frontends/stv0288.c
+++ b/drivers/media/dvb/frontends/stv0288.c
@@ -6,6 +6,8 @@
Copyright (C) 2008 Igor M. Liplianin 
Removed stb6000 specific tuner code and revised some
procedures.
+2010-09-01 Josef Pavlik 
+Fixed diseqc_msg, diseqc_burst and set_tone problems
 
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -156,14 +158,13 @@ static int stv0288_send_diseqc_msg(struct dvb_frontend 
*fe,
 
stv0288_writeregI(state, 0x09, 0);
msleep(30);
-   stv0288_writeregI(state, 0x05, 0x16);
+   stv0288_writeregI(state, 0x05, 0x12); /* modulated mode, single shot */
 
for (i = 0; i < m->msg_len; i++) {
if (stv0288_writeregI(state, 0x06, m->msg[i]))
return -EREMOTEIO;
-   msleep(12);
}
-
+msleep(m->msg_len*12); 
return 0;
 }
 
@@ -174,13 +175,14 @@ static int stv0288_send_diseqc_burst(struct dvb_frontend 
*fe,
 
dprintk("%s\n", __func__);
 
-   if (stv0288_writeregI(state, 0x05, 0x16))/* burst mode */
-   return -EREMOTEIO;
-
-   if (stv0288_writeregI(state, 0x06, burst == SEC_MINI_A ? 0x00 : 0xff))
+if (stv0288_writeregI(state, 0x05, 0x03)) /* simple tone burst mode, 
single shot */
+return -EREMOTEIO;
+   
+if (stv0288_writeregI(state, 0x06, burst == SEC_MINI_A ? 0x00 : 0xff))
return -EREMOTEIO;
 
-   if (stv0288_writeregI(state, 0x06, 0x12))
+msleep(15);
+   if (stv0288_writeregI(state, 0x05, 0x12))
return -EREMOTEIO;
 
return 0;
@@ -192,18 +194,19 @@ static int stv0288_set_tone(struct dvb_frontend *fe, 
fe_sec_tone_mode_t tone)
 
switch (tone) {
case SEC_TONE_ON:
-   if (stv0288_writeregI(state, 0x05, 0x10))/* burst mode */
+   if (stv0288_writeregI(state, 0x05, 0x10))/* burst mode, 
continuous carrier */
return -EREMOTEIO;
-   return stv0288_writeregI(state, 0x06, 0xff);
+break;
 
case SEC_TONE_OFF:
-   if (stv0288_writeregI(state, 0x05, 0x13))/* burst mode */
+   if (stv0288_writeregI(state, 0x05, 0x12))/* burst mode off*/
return -EREMOTEIO;
-   return stv0288_writeregI(state, 0x06, 0x00);
+break;
 
default:
return -EINVAL;
}
+return 0;
 }
 
 static u8 stv0288_inittab[] = {
-



On Sep 8, 2010, at 21:16 , Mauro Carvalho Chehab wrote:

> Em 01-09-2010 09:35, Josef Pavlik escreveu:
>> Fixed problem with DiSEqC communication. The message was wrongly modulated, 
>> so the DiSEqC switch was not work.
>> 
>> This patch fixes DiSEqC messages, simple tone burst and tone on/off. 
>> I verified it with osciloscope against the DiSEqC documentation.
>> 
>> Interface: PCI DVB-S TV tuner TeVii S420
>> Kernel: 2.6.32-24-generic (UBUNTU 10.4)
>> 
>> Signed-off-by: Josef Pavlik 
> 
> Patch doesn't apply against the latest version, at my -git tree. 
> Not sure if the bugs you're pointing were already fixed.
> 
> Cheers,
> Mauro.
>> 
>> 
>> 
>> 
>> diff --git a/drivers/media/dvb/frontends/stv0288.c 
>> b/drivers/media/dvb/frontends/stv0288.c
>> index 2930a5d..6a32535 100644
>> --- a/drivers/media/dvb/frontends/stv0288.c
>> +++ b/drivers/media/dvb/frontends/stv0288.c
>> @@ -6,6 +6,8 @@
>>Copyright (C) 2008 Igor M. Liplianin 
>>Removed stb6000 specific tuner code and revised some
>>procedures.
>> +   2010-09-01 Josef Pavlik 
>> +   Fixed diseqc_msg, diseqc_burst and set_tone problems
>> 
>>This program is free software; you can redistribute it and/or modify
>>it under the terms of the GNU General Public License as published by
>> @@ -156,14 +158,13 @@ static int stv0288_send_diseqc_msg(struct dvb_frontend 
>> *fe,
>> 
>>stv0288_writeregI(state, 0x09, 0);
>>msleep(30);
>> -   stv0288_writeregI(state, 0x05, 0x16);
>> +   stv0288_writeregI(state, 0x05, 0x12); /* modulated mode, single shot 
>> */
>> 
>>for (i = 0; i < m->msg_len; i++) {
>>if (stv0288_writeregI(state, 0x06, m->msg[i]))
>>return -EREMOTEIO;
>> -   msleep(12);
>>}
>> -
>> +   msleep(m->msg_len*12);
>>return 0;
>> }
>> 
>> @@ -174,13 +175,14 @@ static int stv0288_send_

Re: [PATCH] DiSEqC bug fixed for stv0288 based interfaces

2010-09-08 Thread Mauro Carvalho Chehab
Em 01-09-2010 09:35, Josef Pavlik escreveu:
> Fixed problem with DiSEqC communication. The message was wrongly modulated, 
> so the DiSEqC switch was not work.
> 
> This patch fixes DiSEqC messages, simple tone burst and tone on/off. 
> I verified it with osciloscope against the DiSEqC documentation.
> 
> Interface: PCI DVB-S TV tuner TeVii S420
> Kernel: 2.6.32-24-generic (UBUNTU 10.4)
> 
> Signed-off-by: Josef Pavlik 

Patch doesn't apply against the latest version, at my -git tree. 
Not sure if the bugs you're pointing were already fixed.

Cheers,
Mauro.
> 
> 
> 
> 
> diff --git a/drivers/media/dvb/frontends/stv0288.c 
> b/drivers/media/dvb/frontends/stv0288.c
> index 2930a5d..6a32535 100644
> --- a/drivers/media/dvb/frontends/stv0288.c
> +++ b/drivers/media/dvb/frontends/stv0288.c
> @@ -6,6 +6,8 @@
> Copyright (C) 2008 Igor M. Liplianin 
> Removed stb6000 specific tuner code and revised some
> procedures.
> +   2010-09-01 Josef Pavlik 
> +   Fixed diseqc_msg, diseqc_burst and set_tone problems
> 
> This program is free software; you can redistribute it and/or modify
> it under the terms of the GNU General Public License as published by
> @@ -156,14 +158,13 @@ static int stv0288_send_diseqc_msg(struct dvb_frontend 
> *fe,
> 
> stv0288_writeregI(state, 0x09, 0);
> msleep(30);
> -   stv0288_writeregI(state, 0x05, 0x16);
> +   stv0288_writeregI(state, 0x05, 0x12); /* modulated mode, single shot 
> */
> 
> for (i = 0; i < m->msg_len; i++) {
> if (stv0288_writeregI(state, 0x06, m->msg[i]))
> return -EREMOTEIO;
> -   msleep(12);
> }
> -
> +   msleep(m->msg_len*12);
> return 0;
>  }
> 
> @@ -174,13 +175,14 @@ static int stv0288_send_diseqc_burst(struct 
> dvb_frontend *fe,
> 
> dprintk("%s\n", __func__);
> 
> -   if (stv0288_writeregI(state, 0x05, 0x16))/* burst mode */
> +   if (stv0288_writeregI(state, 0x05, 0x03)) /* "simple tone burst" 
> mode, single shot */
> return -EREMOTEIO;
> 
> if (stv0288_writeregI(state, 0x06, burst == SEC_MINI_A ? 0x00 : 0xff))
> return -EREMOTEIO;
> 
> -   if (stv0288_writeregI(state, 0x06, 0x12))
> +   msleep(15);
> +   if (stv0288_writeregI(state, 0x05, 0x12))
> return -EREMOTEIO;
> 
> return 0;
> @@ -192,18 +194,19 @@ static int stv0288_set_tone(struct dvb_frontend *fe, 
> fe_sec_tone_mode_t tone)
> 
> switch (tone) {
> case SEC_TONE_ON:
> -   if (stv0288_writeregI(state, 0x05, 0x10))/* burst mode */
> +   if (stv0288_writeregI(state, 0x05, 0x10))/* burst mode, 
> continuous carrier */
> return -EREMOTEIO;
> -   return stv0288_writeregI(state, 0x06, 0xff);
> +   break;
> 
> case SEC_TONE_OFF:
> -   if (stv0288_writeregI(state, 0x05, 0x13))/* burst mode */
> +   if (stv0288_writeregI(state, 0x05, 0x12))/* burst mode off*/
> return -EREMOTEIO;
> -   return stv0288_writeregI(state, 0x06, 0x00);
> +   break;
> 
> default:
> return -EINVAL;
> }
> +   return 0;
>  }
> 
>  static u8 stv0288_inittab[] = {
> --
> To unsubscribe from this list: send the line "unsubscribe linux-media" in
> the body of a message to majord...@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html

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


[PATCH] DiSEqC bug fixed for stv0288 based interfaces

2010-09-01 Thread Josef Pavlik
Fixed problem with DiSEqC communication. The message was wrongly modulated, 
so the DiSEqC switch was not work.

This patch fixes DiSEqC messages, simple tone burst and tone on/off. 
I verified it with osciloscope against the DiSEqC documentation.

Interface: PCI DVB-S TV tuner TeVii S420
Kernel: 2.6.32-24-generic (UBUNTU 10.4)

Signed-off-by: Josef Pavlik 




diff --git a/drivers/media/dvb/frontends/stv0288.c 
b/drivers/media/dvb/frontends/stv0288.c
index 2930a5d..6a32535 100644
--- a/drivers/media/dvb/frontends/stv0288.c
+++ b/drivers/media/dvb/frontends/stv0288.c
@@ -6,6 +6,8 @@
Copyright (C) 2008 Igor M. Liplianin 
Removed stb6000 specific tuner code and revised some
procedures.
+   2010-09-01 Josef Pavlik 
+   Fixed diseqc_msg, diseqc_burst and set_tone problems

This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -156,14 +158,13 @@ static int stv0288_send_diseqc_msg(struct dvb_frontend 
*fe,

stv0288_writeregI(state, 0x09, 0);
msleep(30);
-   stv0288_writeregI(state, 0x05, 0x16);
+   stv0288_writeregI(state, 0x05, 0x12); /* modulated mode, single shot */

for (i = 0; i < m->msg_len; i++) {
if (stv0288_writeregI(state, 0x06, m->msg[i]))
return -EREMOTEIO;
-   msleep(12);
}
-
+   msleep(m->msg_len*12);
return 0;
 }

@@ -174,13 +175,14 @@ static int stv0288_send_diseqc_burst(struct dvb_frontend 
*fe,

dprintk("%s\n", __func__);

-   if (stv0288_writeregI(state, 0x05, 0x16))/* burst mode */
+   if (stv0288_writeregI(state, 0x05, 0x03)) /* "simple tone burst" mode, 
single shot */
return -EREMOTEIO;

if (stv0288_writeregI(state, 0x06, burst == SEC_MINI_A ? 0x00 : 0xff))
return -EREMOTEIO;

-   if (stv0288_writeregI(state, 0x06, 0x12))
+   msleep(15);
+   if (stv0288_writeregI(state, 0x05, 0x12))
return -EREMOTEIO;

return 0;
@@ -192,18 +194,19 @@ static int stv0288_set_tone(struct dvb_frontend *fe, 
fe_sec_tone_mode_t tone)

switch (tone) {
case SEC_TONE_ON:
-   if (stv0288_writeregI(state, 0x05, 0x10))/* burst mode */
+   if (stv0288_writeregI(state, 0x05, 0x10))/* burst mode, 
continuous carrier */
return -EREMOTEIO;
-   return stv0288_writeregI(state, 0x06, 0xff);
+   break;

case SEC_TONE_OFF:
-   if (stv0288_writeregI(state, 0x05, 0x13))/* burst mode */
+   if (stv0288_writeregI(state, 0x05, 0x12))/* burst mode off*/
return -EREMOTEIO;
-   return stv0288_writeregI(state, 0x06, 0x00);
+   break;

default:
return -EINVAL;
}
+   return 0;
 }

 static u8 stv0288_inittab[] = {
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html