Commit b861cc00 authored by Clément Stenac's avatar Clément Stenac

* sap.c: Improved IPv6 multicast detection

* announce.c:
	- coding style fixes
	- fixed port detection in IPv6 addresses (with ':' inside)
parent 09496f19
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* announce.h : Session announcement * announce.h : Session announcement
***************************************************************************** *****************************************************************************
* Copyright (C) 2002 VideoLAN * Copyright (C) 2002 VideoLAN
* $Id: announce.h,v 1.5 2003/06/25 21:03:16 zorglub Exp $ * $Id: announce.h,v 1.6 2003/07/05 15:00:28 zorglub Exp $
* *
* Authors: Clment Stenac <zorglub@via.ecp.fr> * Authors: Clment Stenac <zorglub@via.ecp.fr>
* *
...@@ -61,6 +61,6 @@ struct sap_session_t ...@@ -61,6 +61,6 @@ struct sap_session_t
/***************************************************************************** /*****************************************************************************
* Prototypes * Prototypes
*****************************************************************************/ *****************************************************************************/
VLC_EXPORT( sap_session_t *, sout_SAPNew, ( sout_instance_t *,char * , char * , char * ,int , char *) ); VLC_EXPORT( sap_session_t *, sout_SAPNew, ( sout_instance_t *,char * , char * , int , char *) );
VLC_EXPORT( void, sout_SAPSend, ( sout_instance_t *,sap_session_t *) ); VLC_EXPORT( void, sout_SAPSend, ( sout_instance_t *,sap_session_t *) );
VLC_EXPORT( void, sout_SAPDelete, ( sout_instance_t *,sap_session_t * ) ); VLC_EXPORT( void, sout_SAPDelete, ( sout_instance_t *,sap_session_t * ) );
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* sap.c : SAP interface module * sap.c : SAP interface module
***************************************************************************** *****************************************************************************
* Copyright (C) 2001 VideoLAN * Copyright (C) 2001 VideoLAN
* $Id: sap.c,v 1.17 2003/07/02 18:44:27 zorglub Exp $ * $Id: sap.c,v 1.18 2003/07/05 15:00:28 zorglub Exp $
* *
* Authors: Arnaud Schauly <gitan@via.ecp.fr> * Authors: Arnaud Schauly <gitan@via.ecp.fr>
* Clment Stenac <zorglub@via.ecp.fr> * Clment Stenac <zorglub@via.ecp.fr>
...@@ -754,7 +754,8 @@ static int ismult( char *psz_uri ) ...@@ -754,7 +754,8 @@ static int ismult( char *psz_uri )
/* IPv6 */ /* IPv6 */
if( psz_uri[0] == '[') if( psz_uri[0] == '[')
{ {
if( strncasecmp( &psz_uri[1], "FF0" , 3) ) if( strncasecmp( &psz_uri[1], "FF0" , 3) ||
strncasecmp( &psz_uri[2], "FF0" , 3))
return( VLC_TRUE ); return( VLC_TRUE );
else else
return( VLC_FALSE ); return( VLC_FALSE );
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* standard.c * standard.c
***************************************************************************** *****************************************************************************
* Copyright (C) 2001, 2002 VideoLAN * Copyright (C) 2001, 2002 VideoLAN
* $Id: standard.c,v 1.6 2003/06/23 13:45:30 zorglub Exp $ * $Id: standard.c,v 1.7 2003/07/05 15:00:28 zorglub Exp $
* *
* Authors: Laurent Aimar <fenrir@via.ecp.fr> * Authors: Laurent Aimar <fenrir@via.ecp.fr>
* *
...@@ -81,8 +81,6 @@ static int Open( vlc_object_t *p_this ) ...@@ -81,8 +81,6 @@ static int Open( vlc_object_t *p_this )
char *psz_sap = NULL; char *psz_sap = NULL;
char *psz_port = "1234";
sap_session_t *p_sap = NULL; sap_session_t *p_sap = NULL;
sout_access_out_t *p_access; sout_access_out_t *p_access;
...@@ -142,7 +140,7 @@ static int Open( vlc_object_t *p_this ) ...@@ -142,7 +140,7 @@ static int Open( vlc_object_t *p_this )
if(p_sys->b_sap) if(p_sys->b_sap)
{ {
msg_Dbg( p_sout , "Creating SAP with IPv%i",atoi(psz_ipv) ); msg_Dbg( p_sout , "Creating SAP with IPv%i",atoi(psz_ipv) );
p_sap = sout_SAPNew( p_sout , psz_url , psz_port , psz_sap, atoi(psz_ipv), psz_v6_scope ); p_sap = sout_SAPNew( p_sout , psz_url , psz_sap, atoi(psz_ipv), psz_v6_scope );
if(!p_sap) if(!p_sap)
{ {
msg_Err( p_sout,"Unable to initialize SAP. SAP disabled"); msg_Err( p_sout,"Unable to initialize SAP. SAP disabled");
......
...@@ -46,71 +46,75 @@ ...@@ -46,71 +46,75 @@
#define SAP_IPV6_ADDR_1 "FF0" #define SAP_IPV6_ADDR_1 "FF0"
#define SAP_IPV6_ADDR_2 "::2:7FFE" #define SAP_IPV6_ADDR_2 "::2:7FFE"
#define DEFAULT_PORT "1234"
/**************************************************************************** /****************************************************************************
* Split : split a string into two parts: the one which is before the delim * Split : split a string into two parts: the one which is before the delim
* and the one which is after. * and the one which is after.
* NULL is returned if delim is not found * NULL is returned if delim is not found
****************************************************************************/ ****************************************************************************/
static char * split( char *p_in, char *p_out1, char *p_out2, char delim) static char * split( char *psz_in, char *psz_out1, char *psz_out2, char delim)
{ {
unsigned int i_count=0; /*pos in input string*/ unsigned int i_count = 0; /*pos in input string*/
unsigned int i_pos1=0; /*pos in out2 string */ unsigned int i_pos1 = 0; /*pos in out2 string */
unsigned int i_pos2=0; unsigned int i_pos2 = 0;
char *p_cur; /*store the pos of the first delim found */ char *psz_cur; /*store the pos of the first delim found */
/*skip spaces at the beginning*/ /*skip spaces at the beginning*/
while(p_in[i_count] == ' ' && i_count < strlen(p_in)) while(psz_in[i_count] == ' ' && i_count < strlen(psz_in))
{ {
i_count++; i_count++;
} }
if(i_count == strlen(p_in)) if(i_count == strlen(psz_in))
return NULL; return NULL;
/*Look for delim*/ /*Look for delim*/
while(p_in[i_count] != delim && i_count < strlen(p_in)) while(psz_in[i_count] != delim && i_count < strlen(psz_in))
{ {
p_out1[i_pos1] = p_in[i_count]; psz_out1[i_pos1] = psz_in[i_count];
i_count++; i_count++;
i_pos1++; i_pos1++;
} }
/* Mark the end of out1 */ /* Mark the end of out1 */
p_out1[i_pos1] = 0; psz_out1[i_pos1] = 0;
if(i_count == strlen(p_in)) if(i_count == strlen(psz_in))
return NULL; return NULL;
/*store pos of the first delim*/ /*store pos of the first delim*/
p_cur = &p_in[i_count]; psz_cur = &psz_in[i_count];
/*skip all delim and all spaces*/ /*skip all delim and all spaces*/
while((p_in[i_count] == ' ' || p_in[i_count] == delim) && i_count < strlen(p_in)) while( (psz_in[i_count] == ' ' ||
psz_in[i_count] == delim)
&& i_count < strlen(psz_in))
{ {
i_count++; i_count++;
} }
if(i_count == strlen(p_in)) if(i_count == strlen(psz_in))
return p_cur; return psz_cur;
/*Store the second string*/ /*Store the second string*/
while(i_count < strlen(p_in)) while(i_count < strlen(psz_in))
{ {
p_out2[i_pos2] = p_in[i_count]; psz_out2[i_pos2] = psz_in[i_count];
i_pos2++; i_pos2++;
i_count++; i_count++;
} }
p_out2[i_pos2] = 0; psz_out2[i_pos2] = 0;
return p_cur; return psz_cur;
} }
/***************************************************************************** /*****************************************************************************
* sout_SAPNew: Creates a SAP Session * sout_SAPNew: Creates a SAP Session
*****************************************************************************/ *****************************************************************************/
sap_session_t * sout_SAPNew ( sout_instance_t *p_sout , sap_session_t * sout_SAPNew ( sout_instance_t *p_sout ,
char * psz_url_arg , char *psz_port_arg , char * psz_url_arg,
char * psz_name_arg, int ip_version, char * psz_name_arg, int ip_version,
char * psz_v6_scope ) char * psz_v6_scope )
{ {
...@@ -119,7 +123,9 @@ sap_session_t * sout_SAPNew ( sout_instance_t *p_sout , ...@@ -119,7 +123,9 @@ sap_session_t * sout_SAPNew ( sout_instance_t *p_sout ,
network_socket_t socket_desc; /* Socket descriptor */ network_socket_t socket_desc; /* Socket descriptor */
char psz_network[6]; /* IPv4 or IPv6 */ char psz_network[6]; /* IPv4 or IPv6 */
char *sap_ipv6_addr=NULL; /* IPv6 built address */ char *sap_ipv6_addr=NULL; /* IPv6 built address */
char *psz_eol; /* Used to parse IPv6 URIs */
int i_port; /* Port in numerical format */
/* Allocate the SAP structure */ /* Allocate the SAP structure */
p_new = (sap_session_t *)malloc( sizeof ( sap_session_t ) ) ; p_new = (sap_session_t *)malloc( sizeof ( sap_session_t ) ) ;
if ( !p_new ) if ( !p_new )
...@@ -129,12 +135,55 @@ sap_session_t * sout_SAPNew ( sout_instance_t *p_sout , ...@@ -129,12 +135,55 @@ sap_session_t * sout_SAPNew ( sout_instance_t *p_sout ,
} }
/* Fill the information in the structure */ /* Fill the information in the structure */
split(psz_url_arg,p_new->psz_url,p_new->psz_port,':'); if( strstr( psz_url_arg , "[" ) )
// sprintf ( p_new->psz_url , "%s" , psz_url_arg ); { /* We have an IPv6 address. Do not use ':' as the port separator */
sprintf ( p_new->psz_name , "%s" , psz_name_arg ); psz_eol = strchr( psz_url_arg, ']' );
if( !psz_eol ) /* No matching ] ! Aborting */
{
msg_Warn( p_sout , "No matching ]. Unable to parse URI");
return NULL;
}
if(!psz_eol++)
{
sprintf (p_new->psz_url, "%s", psz_url_arg);
sprintf (p_new->psz_port, "%s", DEFAULT_PORT);
}
else
{
*psz_eol = '\0';
sprintf (p_new->psz_url, "%s", psz_url_arg);
psz_eol++;
if(psz_eol)
{
sprintf (p_new->psz_port, "%s", psz_eol);
}
}
}
else
{
split(psz_url_arg,p_new->psz_url,p_new->psz_port,':');
}
/* Check if we have a port */
if( !strlen(p_new->psz_port) )
{
sprintf (p_new->psz_port, "%s", DEFAULT_PORT);
}
/* Make sure our port is valid and atoi it*/
i_port = atoi( p_new->psz_port );
if( !i_port )
{
sprintf (p_new->psz_port, "%s", DEFAULT_PORT);
}
else
{
sprintf (p_new->psz_port, "%i", i_port);
}
/* Port is not implemented in sout */ /* The name that we send */
//sprintf ( p_new->psz_port, "%s" , psz_port_arg ); sprintf ( p_new->psz_name , "%s" , psz_name_arg );
p_new->i_ip_version = ip_version; p_new->i_ip_version = ip_version;
...@@ -226,7 +275,7 @@ sap_session_t * sout_SAPNew ( sout_instance_t *p_sout , ...@@ -226,7 +275,7 @@ sap_session_t * sout_SAPNew ( sout_instance_t *p_sout ,
*****************************************************************************/ *****************************************************************************/
void sout_SAPDelete( sout_instance_t *p_sout , sap_session_t * p_this ) void sout_SAPDelete( sout_instance_t *p_sout , sap_session_t * p_this )
{ {
if( close(p_this->socket) ) if( close( p_this->socket ) )
{ {
msg_Err ( p_sout, "Unable to close SAP socket"); msg_Err ( p_sout, "Unable to close SAP socket");
} }
...@@ -287,7 +336,6 @@ void sout_SAPSend( sout_instance_t *p_sout, sap_session_t * p_this) ...@@ -287,7 +336,6 @@ void sout_SAPSend( sout_instance_t *p_sout, sap_session_t * p_this)
"a=type:test\n", "a=type:test\n",
p_this->psz_name , p_this->psz_port , p_this->psz_url ); p_this->psz_name , p_this->psz_port , p_this->psz_url );
fprintf(stderr,"Sending : <%s>\n",sap_msg);
i_msg_size = strlen( sap_msg ); i_msg_size = strlen( sap_msg );
i_size = i_msg_size + i_header_size; i_size = i_msg_size + i_header_size;
......
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