Commit ed59877c authored by Jean-Paul Saman's avatar Jean-Paul Saman

Fixes for DVB-C:

- Make sure that lnb-lof1 and lnb-lof2 can be overriden by the commandline syntax frequency=xx:lnb-lof1=xx:lnb-lof2=xx
- Added value {A,a} to polarization=xx to force INVERSION_AUTO
- Sanatized a few error messages
parent 916c69e3
...@@ -90,7 +90,7 @@ int E_(Open) ( vlc_object_t *p_this ) ...@@ -90,7 +90,7 @@ int E_(Open) ( vlc_object_t *p_this )
int i_guard = 0; int i_guard = 0;
int i_transmission = 0; int i_transmission = 0;
int i_hierarchy = 0; int i_hierarchy = 0;
vlc_bool_t b_polarisation = 0; int i_polarisation = 0;
int i_fec = 0; int i_fec = 0;
int i_code_rate_HP = 0; int i_code_rate_HP = 0;
int i_code_rate_LP = 0; int i_code_rate_LP = 0;
...@@ -130,7 +130,6 @@ int E_(Open) ( vlc_object_t *p_this ) ...@@ -130,7 +130,6 @@ int E_(Open) ( vlc_object_t *p_this )
i_guard = config_GetInt(p_input, "guard"); i_guard = config_GetInt(p_input, "guard");
i_hierarchy = config_GetInt(p_input, "hierarchy"); i_hierarchy = config_GetInt(p_input, "hierarchy");
/* Determine frontend device information and capabilities */ /* Determine frontend device information and capabilities */
b_probe = config_GetInt( p_input, "probe" ); b_probe = config_GetInt( p_input, "probe" );
if (b_probe) if (b_probe)
...@@ -162,9 +161,6 @@ int E_(Open) ( vlc_object_t *p_this ) ...@@ -162,9 +161,6 @@ int E_(Open) ( vlc_object_t *p_this )
else if (strncmp( p_input->psz_access, "terrestrial",11) ==0) else if (strncmp( p_input->psz_access, "terrestrial",11) ==0)
frontend_info.type = FE_OFDM; frontend_info.type = FE_OFDM;
// frontend_info.frequency_max = 12999000; /* in KHz, lnb_lof2 */
// frontend_info.frequency_min = 9750000; /* lnb_lof1 */
frontend_info.frequency_max = u_lnb_lof2; /* in KHz, lnb_lof2 */ frontend_info.frequency_max = u_lnb_lof2; /* in KHz, lnb_lof2 */
frontend_info.frequency_min = u_lnb_lof1; /* lnb_lof1 */ frontend_info.frequency_min = u_lnb_lof1; /* lnb_lof1 */
...@@ -205,7 +201,7 @@ int E_(Open) ( vlc_object_t *p_this ) ...@@ -205,7 +201,7 @@ int E_(Open) ( vlc_object_t *p_this )
(!strncmp( psz_parser_init, "V" , (!strncmp( psz_parser_init, "V" ,
psz_parser - psz_parser_init ) ) ) psz_parser - psz_parser_init ) ) )
{ {
b_polarisation = VLC_FALSE; i_polarisation = 0; //VLC_FALSE;
} }
else if ((!strncmp( psz_parser_init, "H" , else if ((!strncmp( psz_parser_init, "H" ,
psz_parser - psz_parser_init ) ) || psz_parser - psz_parser_init ) ) ||
...@@ -213,7 +209,15 @@ int E_(Open) ( vlc_object_t *p_this ) ...@@ -213,7 +209,15 @@ int E_(Open) ( vlc_object_t *p_this )
psz_parser - psz_parser_init ) ) ) psz_parser - psz_parser_init ) ) )
{ {
b_polarisation = VLC_TRUE; i_polarisation = 1; //VLC_TRUE;
}
else if ((!strncmp( psz_parser_init, "A" ,
psz_parser - psz_parser_init ) ) ||
(!strncmp( psz_parser_init, "a" ,
psz_parser - psz_parser_init ) ) )
{
i_polarisation = 2;
} }
} }
else if( !strncmp( psz_parser, "fec=", else if( !strncmp( psz_parser, "fec=",
...@@ -247,21 +251,23 @@ int E_(Open) ( vlc_object_t *p_this ) ...@@ -247,21 +251,23 @@ int E_(Open) ( vlc_object_t *p_this )
strlen( "lnb-lof1=" ) ) ) strlen( "lnb-lof1=" ) ) )
{ {
u_lnb_lof1 = u_lnb_lof1 =
(unsigned int)strtol( psz_parser + strlen( "lnb_lof1=" ), (unsigned int)strtol( psz_parser + strlen( "lnb-lof1=" ),
&psz_parser, 0 ); &psz_parser, 0 );
frontend_info.frequency_min = u_lnb_lof1; /* lnb_lof1 */
} }
else if( !strncmp( psz_parser, "lnb-lof2=", else if( !strncmp( psz_parser, "lnb-lof2=",
strlen( "lnb-lof2=" ) ) ) strlen( "lnb-lof2=" ) ) )
{ {
u_lnb_lof2 = u_lnb_lof2 =
(unsigned int)strtol( psz_parser + strlen( "lnb_lof2=" ), (unsigned int)strtol( psz_parser + strlen( "lnb-lof2=" ),
&psz_parser, 0 ); &psz_parser, 0 );
frontend_info.frequency_max = u_lnb_lof2; /* in KHz, lnb_lof2 */
} }
else if( !strncmp( psz_parser, "lnb-slof=", else if( !strncmp( psz_parser, "lnb-slof=",
strlen( "lnb-slof=" ) ) ) strlen( "lnb-slof=" ) ) )
{ {
u_lnb_slof = u_lnb_slof =
(unsigned int)strtol( psz_parser + strlen( "lnb_slof=" ), (unsigned int)strtol( psz_parser + strlen( "lnb-slof=" ),
&psz_parser, 0 ); &psz_parser, 0 );
} }
else if( !strncmp( psz_parser, "device=", else if( !strncmp( psz_parser, "device=",
...@@ -339,7 +345,7 @@ int E_(Open) ( vlc_object_t *p_this ) ...@@ -339,7 +345,7 @@ int E_(Open) ( vlc_object_t *p_this )
if( *psz_next ) if( *psz_next )
{ {
psz_parser = psz_next + 1; psz_parser = psz_next + 1;
b_polarisation = (vlc_bool_t)strtol( psz_parser, &psz_next, 10 ); i_polarisation = strtol( psz_parser, &psz_next, 10 );
if( *psz_next ) if( *psz_next )
{ {
psz_parser = psz_next + 1; psz_parser = psz_next + 1;
...@@ -378,7 +384,7 @@ int E_(Open) ( vlc_object_t *p_this ) ...@@ -378,7 +384,7 @@ int E_(Open) ( vlc_object_t *p_this )
((u_srate) < frontend_info.symbol_rate_min) ) ((u_srate) < frontend_info.symbol_rate_min) )
{ {
msg_Warn( p_input, "invalid symbol rate, using default one" ); msg_Warn( p_input, "invalid symbol rate, using default one" );
u_srate = config_GetInt( p_input, "symbol-rate" ); u_srate = config_GetInt( p_input, "symbol-rate"s );
if ( ((u_srate) > frontend_info.symbol_rate_max) || if ( ((u_srate) > frontend_info.symbol_rate_max) ||
((u_srate) < frontend_info.symbol_rate_min) ) ((u_srate) < frontend_info.symbol_rate_min) )
{ {
...@@ -387,17 +393,6 @@ int E_(Open) ( vlc_object_t *p_this ) ...@@ -387,17 +393,6 @@ int E_(Open) ( vlc_object_t *p_this )
} }
} }
if( b_polarisation && (b_polarisation != 1) )
{
msg_Warn( p_input, "invalid polarization, using default one" );
b_polarisation = config_GetInt( p_input, "polarization" );
if( b_polarisation && b_polarisation != 1 )
{
msg_Err( p_input, "invalid default polarization" );
return -1;
}
}
if( (i_fec > 9) || (i_fec < 1) ) if( (i_fec > 9) || (i_fec < 1) )
{ {
msg_Warn( p_input, "invalid FEC, using default one" ); msg_Warn( p_input, "invalid FEC, using default one" );
...@@ -416,16 +411,16 @@ int E_(Open) ( vlc_object_t *p_this ) ...@@ -416,16 +411,16 @@ int E_(Open) ( vlc_object_t *p_this )
/* DVB-S: satellite and budget cards (nova) */ /* DVB-S: satellite and budget cards (nova) */
case FE_QPSK: case FE_QPSK:
fep.frequency = u_freq; /* KHz */ fep.frequency = u_freq; /* KHz */
fep.inversion = dvb_DecodeInversion(p_input, (int) b_polarisation); fep.inversion = dvb_DecodeInversion(p_input, i_polarisation);
fep.u.qpsk.symbol_rate = u_srate; fep.u.qpsk.symbol_rate = u_srate;
fep.u.qpsk.fec_inner = dvb_DecodeFEC(p_input, i_fec); fep.u.qpsk.fec_inner = dvb_DecodeFEC(p_input, i_fec);
msg_Dbg( p_input, "satellite (QPSK) frontend found on %s", frontend_info.name ); msg_Dbg( p_input, "DVB-S: satellite (QPSK) frontend %s found", frontend_info.name );
if (ioctl_SetQPSKFrontend (p_input, fep, b_polarisation, if (ioctl_SetQPSKFrontend (p_input, fep, i_polarisation,
u_lnb_lof1, u_lnb_lof2, u_lnb_slof, u_lnb_lof1, u_lnb_lof2, u_lnb_slof,
u_adapter, u_device )<0) u_adapter, u_device )<0)
{ {
msg_Err( p_input, "DVB-S frontend returned a failure event" ); msg_Err( p_input, "DVB-S: tuning failed" );
return -1; return -1;
} }
break; break;
...@@ -433,14 +428,14 @@ int E_(Open) ( vlc_object_t *p_this ) ...@@ -433,14 +428,14 @@ int E_(Open) ( vlc_object_t *p_this )
/* DVB-C */ /* DVB-C */
case FE_QAM: case FE_QAM:
fep.frequency = u_freq; /* KHz */ fep.frequency = u_freq; /* KHz */
fep.inversion = dvb_DecodeInversion(p_input, (int) b_polarisation); fep.inversion = dvb_DecodeInversion(p_input, i_polarisation);
fep.u.qam.symbol_rate = u_srate; fep.u.qam.symbol_rate = u_srate;
fep.u.qam.fec_inner = dvb_DecodeFEC(p_input, i_fec); fep.u.qam.fec_inner = dvb_DecodeFEC(p_input, i_fec);
fep.u.qam.modulation = dvb_DecodeModulation(p_input, i_modulation); fep.u.qam.modulation = dvb_DecodeModulation(p_input, i_modulation);
msg_Dbg( p_input, "cable (QAM) frontend found on %s", frontend_info.name ); msg_Dbg( p_input, "DVB-C: cable (QAM) frontend %s found", frontend_info.name );
if (ioctl_SetQAMFrontend (p_input, fep, u_adapter, u_device )<0) if (ioctl_SetQAMFrontend (p_input, fep, u_adapter, u_device )<0)
{ {
msg_Err( p_input, "DVB-C frontend returned a failure event" ); msg_Err( p_input, "DVB-C: tuning failed" );
return -1; return -1;
} }
break; break;
...@@ -448,7 +443,7 @@ int E_(Open) ( vlc_object_t *p_this ) ...@@ -448,7 +443,7 @@ int E_(Open) ( vlc_object_t *p_this )
/* DVB-T */ /* DVB-T */
case FE_OFDM: case FE_OFDM:
fep.frequency = u_freq; /* KHz */ fep.frequency = u_freq; /* KHz */
fep.inversion = dvb_DecodeInversion(p_input, (int) b_polarisation); fep.inversion = dvb_DecodeInversion(p_input, i_polarisation);
fep.u.ofdm.bandwidth = dvb_DecodeBandwidth(p_input, i_bandwidth); fep.u.ofdm.bandwidth = dvb_DecodeBandwidth(p_input, i_bandwidth);
fep.u.ofdm.code_rate_HP = dvb_DecodeFEC(p_input, i_code_rate_HP); fep.u.ofdm.code_rate_HP = dvb_DecodeFEC(p_input, i_code_rate_HP);
fep.u.ofdm.code_rate_LP = dvb_DecodeFEC(p_input, i_code_rate_LP); fep.u.ofdm.code_rate_LP = dvb_DecodeFEC(p_input, i_code_rate_LP);
...@@ -456,10 +451,10 @@ int E_(Open) ( vlc_object_t *p_this ) ...@@ -456,10 +451,10 @@ int E_(Open) ( vlc_object_t *p_this )
fep.u.ofdm.transmission_mode = dvb_DecodeTransmission(p_input, i_transmission); fep.u.ofdm.transmission_mode = dvb_DecodeTransmission(p_input, i_transmission);
fep.u.ofdm.guard_interval = dvb_DecodeGuardInterval(p_input, i_guard); fep.u.ofdm.guard_interval = dvb_DecodeGuardInterval(p_input, i_guard);
fep.u.ofdm.hierarchy_information = dvb_DecodeHierarchy(p_input, i_hierarchy); fep.u.ofdm.hierarchy_information = dvb_DecodeHierarchy(p_input, i_hierarchy);
msg_Dbg( p_input, "terrestrial (OFDM) frontend found on %s", frontend_info.name ); msg_Dbg( p_input, "DVB-T: terrestrial (OFDM) frontend %s found", frontend_info.name );
if (ioctl_SetOFDMFrontend (p_input, fep,u_adapter, u_device )<0) if (ioctl_SetOFDMFrontend (p_input, fep,u_adapter, u_device )<0)
{ {
msg_Err( p_input, "DVB-T frontend returned a failure event" ); msg_Err( p_input, "DVB-T: tuning failed" );
return -1; return -1;
} }
break; break;
......
...@@ -430,14 +430,22 @@ int ioctl_SetQAMFrontend (input_thread_t * p_input, struct dvb_frontend_paramete ...@@ -430,14 +430,22 @@ int ioctl_SetQAMFrontend (input_thread_t * p_input, struct dvb_frontend_paramete
return -1; return -1;
} }
/* Show more info on the tuning parameters used. */
msg_Dbg(p_input, "DVB-C: Tuning with the following paramters:");
msg_Dbg(p_input, "DVB-C: Frequency %d KHz", fep.frequency );
msg_Dbg(p_input, "DVB-C: Inversion/polarisation: %d",fep.inversion);
msg_Dbg(p_input, "DVB-C: Symbolrate %d", fep.u.qam.symbol_rate);
msg_Dbg(p_input, "DVB-C: FEC Inner %d", fep.u.qam.fec_inner);
msg_Dbg(p_input, "DVB-C: Modulation %d", fep.u.qam.modulation);
/* Now send it all to the frontend device */ /* Now send it all to the frontend device */
if ((ret=ioctl(front, FE_SET_FRONTEND, &fep)) < 0) if ((ret=ioctl(front, FE_SET_FRONTEND, &fep)) < 0)
{ {
close(front); close(front);
# ifdef HAVE_ERRNO_H # ifdef HAVE_ERRNO_H
msg_Err(p_input, "DVB-C: setting frontend failed (%d) %s", ret, strerror(errno)); msg_Err(p_input, "DVB-C: tuning channel failed (frontend returned %d:%s)", ret, strerrror(errno));
# else # else
msg_Err(p_input, "DVB-C: setting frontend failed (%d)", ret); msg_Err(p_input, "DVB-C: tuning channel failed (frontend returned %d)", ret);
# endif # endif
return -1; return -1;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment