Commit 31456021 authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

Force RTP for UDP-Lite, as we have no legacy issue (suggestion from Md)

parent 97577c7b
...@@ -95,7 +95,6 @@ vlc_module_begin(); ...@@ -95,7 +95,6 @@ vlc_module_begin();
add_shortcut( "rtp4" ); add_shortcut( "rtp4" );
add_shortcut( "rtp6" ); add_shortcut( "rtp6" );
add_shortcut( "udplite" ); add_shortcut( "udplite" );
add_shortcut( "rtplite" );
set_callbacks( Open, Close ); set_callbacks( Open, Close );
vlc_module_end(); vlc_module_end();
...@@ -136,7 +135,7 @@ static int Open( vlc_object_t *p_this ) ...@@ -136,7 +135,7 @@ static int Open( vlc_object_t *p_this )
char *psz_parser; char *psz_parser;
const char *psz_server_addr, *psz_bind_addr = ""; const char *psz_server_addr, *psz_bind_addr = "";
int i_bind_port, i_server_port = 0; int i_bind_port, i_server_port = 0;
int fam = AF_UNSPEC, proto = IPPROTO_UDP, cscov = 8; int fam = AF_UNSPEC, proto = IPPROTO_UDP;
if (strlen (p_access->psz_access) >= 3) if (strlen (p_access->psz_access) >= 3)
{ {
...@@ -152,11 +151,7 @@ static int Open( vlc_object_t *p_this ) ...@@ -152,11 +151,7 @@ static int Open( vlc_object_t *p_this )
} }
if (strcmp (p_access->psz_access + 3, "lite") == 0) if (strcmp (p_access->psz_access + 3, "lite") == 0)
proto = IPPROTO_UDPLITE; proto = IPPROTO_UDPLITE;
} }
if (strncmp (p_access->psz_access, "rtp", 3) == 0)
/* Checksum coverage: RTP header is AT LEAST 12 bytes
* in addition to UDP header (8 bytes) */
cscov += 12;
i_bind_port = var_CreateGetInteger( p_access, "server-port" ); i_bind_port = var_CreateGetInteger( p_access, "server-port" );
...@@ -222,7 +217,9 @@ static int Open( vlc_object_t *p_this ) ...@@ -222,7 +217,9 @@ static int Open( vlc_object_t *p_this )
#ifdef UDPLITE_RECV_CSCOV #ifdef UDPLITE_RECV_CSCOV
if (proto == IPPROTO_UDPLITE) if (proto == IPPROTO_UDPLITE)
setsockopt (p_sys->fd, SOL_UDPLITE, UDPLITE_RECV_CSCOV, &cscov, sizeof (cscov)); /* UDP header: 8 bytes + RTP header: 12 bytes (or more) */
setsockopt (p_sys->fd, SOL_UDPLITE, UDPLITE_RECV_CSCOV,
&(int){ 20 }, sizeof (int));
#endif #endif
/* FIXME */ /* FIXME */
......
...@@ -117,7 +117,6 @@ vlc_module_begin(); ...@@ -117,7 +117,6 @@ vlc_module_begin();
add_shortcut( "udp" ); add_shortcut( "udp" );
add_shortcut( "rtp" ); // Will work only with ts muxer add_shortcut( "rtp" ); // Will work only with ts muxer
add_shortcut( "udplite" ); add_shortcut( "udplite" );
add_shortcut( "rtplite" );
set_callbacks( Open, Close ); set_callbacks( Open, Close );
vlc_module_end(); vlc_module_end();
...@@ -205,25 +204,26 @@ static int Open( vlc_object_t *p_this ) ...@@ -205,25 +204,26 @@ static int Open( vlc_object_t *p_this )
config_ChainParse( p_access, "", config_ChainParse( p_access, "",
ppsz_core_options, p_access->p_cfg ); ppsz_core_options, p_access->p_cfg );
if( !( p_sys = malloc( sizeof( sout_access_out_sys_t ) ) ) ) if( !( p_sys = calloc ( 1, sizeof( sout_access_out_sys_t ) ) ) )
{ {
msg_Err( p_access, "not enough memory" ); msg_Err( p_access, "not enough memory" );
return VLC_EGENERIC; return VLC_EGENERIC;
} }
memset( p_sys, 0, sizeof(sout_access_out_sys_t) );
p_access->p_sys = p_sys; p_access->p_sys = p_sys;
if( p_access->psz_access != NULL ) if( p_access->psz_access != NULL )
{ {
if (strncmp (p_access->psz_access, "rtp", 3) == 0) if (strcmp (p_access->psz_access, "rtp") == 0)
p_sys->b_rtpts = VLC_TRUE;
if (strcmp (p_access->psz_access, "udplite") == 0)
{ {
p_sys->b_rtpts = 1; protoname = "UDP-Lite";
cscov += RTP_HEADER_LENGTH;
}
if ((strlen (p_access->psz_access) >= 3)
&& (strcmp (p_access->psz_access + 3, "lite") == 0))
proto = IPPROTO_UDPLITE; proto = IPPROTO_UDPLITE;
p_sys->b_rtpts = VLC_TRUE;
}
} }
if (p_sys->b_rtpts)
cscov += RTP_HEADER_LENGTH;
psz_parser = strdup( p_access->psz_name ); psz_parser = strdup( p_access->psz_name );
...@@ -270,7 +270,7 @@ static int Open( vlc_object_t *p_this ) ...@@ -270,7 +270,7 @@ static int Open( vlc_object_t *p_this )
i_handle = net_ConnectDgram( p_this, psz_dst_addr, i_dst_port, -1, proto ); i_handle = net_ConnectDgram( p_this, psz_dst_addr, i_dst_port, -1, proto );
if( i_handle == -1 ) if( i_handle == -1 )
{ {
msg_Err( p_access, "failed to create UDP socket" ); msg_Err( p_access, "failed to create %s socket", protoname );
return VLC_EGENERIC; return VLC_EGENERIC;
} }
...@@ -310,8 +310,8 @@ static int Open( vlc_object_t *p_this ) ...@@ -310,8 +310,8 @@ static int Open( vlc_object_t *p_this )
p_access->pf_seek = Seek; p_access->pf_seek = Seek;
msg_Dbg( p_access, "udp access output opened(%s:%d)", msg_Dbg( p_access, "%s access output opened(%s:%d)",
psz_dst_addr, i_dst_port ); protoname, psz_dst_addr, i_dst_port );
free( psz_dst_addr ); free( psz_dst_addr );
...@@ -354,7 +354,7 @@ static void Close( vlc_object_t * p_this ) ...@@ -354,7 +354,7 @@ static void Close( vlc_object_t * p_this )
/* update p_sout->i_out_pace_nocontrol */ /* update p_sout->i_out_pace_nocontrol */
p_access->p_sout->i_out_pace_nocontrol--; p_access->p_sout->i_out_pace_nocontrol--;
msg_Dbg( p_access, "udp access output closed" ); msg_Dbg( p_access, "UDP access output closed" );
free( p_sys ); free( p_sys );
} }
...@@ -383,7 +383,7 @@ static int Write( sout_access_out_t *p_access, block_t *p_buffer ) ...@@ -383,7 +383,7 @@ static int Write( sout_access_out_t *p_access, block_t *p_buffer )
{ {
if( p_sys->p_buffer->i_dts + p_sys->p_thread->i_caching < mdate() ) if( p_sys->p_buffer->i_dts + p_sys->p_thread->i_caching < mdate() )
{ {
msg_Dbg( p_access, "late packet for udp input (" I64Fd ")", msg_Dbg( p_access, "late packet for UDP input (" I64Fd ")",
mdate() - p_sys->p_buffer->i_dts mdate() - p_sys->p_buffer->i_dts
- p_sys->p_thread->i_caching ); - p_sys->p_thread->i_caching );
} }
......
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