Commit a4dc58c8 authored by Henri Fallon's avatar Henri Fallon

- Moved 2 local network functions
- Removed old code
- Broadcast should work. I'm not detecting broadcast address, i'm
binding 0.0.0.0
parent 335d7364
...@@ -6,6 +6,7 @@ ...@@ -6,6 +6,7 @@
* Copyright (C) 1999, 2000 VideoLAN * Copyright (C) 1999, 2000 VideoLAN
* *
* Authors: Vincent Seguin <seguin@via.ecp.fr> * Authors: Vincent Seguin <seguin@via.ecp.fr>
* Henri Fallon <henri@videolan.org>
* *
* This program is free software; you can redistribute it and/or modify * 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 * it under the terms of the GNU General Public License as published by
...@@ -22,53 +23,8 @@ ...@@ -22,53 +23,8 @@
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/ *****************************************************************************/
/*****************************************************************************
* Required headers:
* <netinet/in.h>
* <sys/socket.h>
*****************************************************************************/
/*****************************************************************************
* if_descr_t: describes a network interface.
*****************************************************************************
* Note that if the interface is a point to point one, the broadcast address is
* set to the destination address of that interface
*****************************************************************************/
typedef struct
{
/* Interface device name (e.g. "eth0") */
char* psz_ifname;
/* Interface physical address */
struct sockaddr sa_phys_addr;
/* Interface network address */
struct sockaddr_in sa_net_addr;
/* Interface broadcast address */
struct sockaddr_in sa_bcast_addr;
/* Interface flags: see if.h for their description) */
u16 i_flags;
} if_descr_t;
/*****************************************************************************
* net_descr_t: describes all the interfaces of the computer
*****************************************************************************
* Nothing special to say :)
*****************************************************************************/
typedef struct
{
/* Number of networks interfaces described below */
int i_if_number;
/* Table of if_descr_t describing each interface */
if_descr_t* a_if;
} net_descr_t;
/***************************************************************************** /*****************************************************************************
* Prototypes * Prototypes
*****************************************************************************/ *****************************************************************************/
int ReadIfConf (int i_sockfd, if_descr_t* p_ifdescr, char* psz_name); int input_BuildLocalAddr( struct sockaddr_in *, int, boolean_t );
int ReadNetConf (int i_sockfd, net_descr_t* p_net_descr); int input_BuildRemoteAddr(struct sockaddr_in *, char * );
int BuildInetAddr ( struct sockaddr_in *p_sa_in, char *psz_in_addr, int i_port );
int ServerPort ( char *psz_addr );
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
* decoders. * decoders.
***************************************************************************** *****************************************************************************
* Copyright (C) 1998, 1999, 2000 VideoLAN * Copyright (C) 1998, 1999, 2000 VideoLAN
* $Id: input.c,v 1.91 2001/03/07 10:31:10 stef Exp $ * $Id: input.c,v 1.92 2001/03/11 19:00:18 henri Exp $
* *
* Authors: Christophe Massiot <massiot@via.ecp.fr> * Authors: Christophe Massiot <massiot@via.ecp.fr>
* *
...@@ -69,6 +69,9 @@ ...@@ -69,6 +69,9 @@
#include "main.h" #include "main.h"
/* #include <netutils.h> */
/***************************************************************************** /*****************************************************************************
* Local prototypes * Local prototypes
*****************************************************************************/ *****************************************************************************/
...@@ -508,76 +511,19 @@ void input_FileClose( input_thread_t * p_input ) ...@@ -508,76 +511,19 @@ void input_FileClose( input_thread_t * p_input )
return; return;
} }
#ifndef SYS_BEOS #ifndef SYS_BEOS
/***************************************************************************** /*****************************************************************************
* input_BuildLocalAddr : fill a sockaddr_in structure for local binding * input_NetworkOpen : open a network socket
*****************************************************************************/ *****************************************************************************/
int input_BuildLocalAddr( struct sockaddr_in * p_socket, int i_port, void input_NetworkOpen( input_thread_t * p_input )
boolean_t b_broadcast )
{ {
char psz_hostname[INPUT_MAX_SOURCE_LENGTH];
struct hostent * p_hostent;
/* Reset struct */
memset( p_socket, 0, sizeof( struct sockaddr_in ) );
p_socket->sin_family = AF_INET; /* family */
p_socket->sin_port = htons( i_port );
if( !b_broadcast )
{
/* Try to get our own IP */
if( gethostname( psz_hostname, sizeof(psz_hostname) ) )
{
intf_ErrMsg( "BuildLocalAddr : unable to resolve local name : %s",
strerror( errno ) );
return( -1 );
}
}
else
{
/* Using broadcast address. There are many ways of doing it, one of
* the simpliest being a #define ...
* FIXME : this is ugly */
strncpy( psz_hostname, INPUT_BCAST_ADDR,INPUT_MAX_SOURCE_LENGTH );
}
/* Try to convert address directly from in_addr - this will work if
* psz_in_addr is dotted decimal. */
#ifdef HAVE_ARPA_INET_H
if( !inet_aton( psz_hostname, &p_socket->sin_addr) )
#else
if( (p_socket->sin_addr.s_addr = inet_addr( psz_hostname )) == -1 )
#endif
{
/* We have a fqdn, try to find its address */
if ( (p_hostent = gethostbyname( psz_hostname )) == NULL )
{
intf_ErrMsg( "BuildLocalAddr: unknown host %s", psz_hostname );
return( -1 );
}
/* Copy the first address of the host in the socket address */ int i_option_value, i_port;
memcpy( &p_socket->sin_addr, p_hostent->h_addr_list[0], struct sockaddr_in s_socket;
p_hostent->h_length ); boolean_t b_broadcast;
}
return( 0 );
}
/*****************************************************************************
* input_BuildRemoteAddr : fill a sockaddr_in structure for remote host
*****************************************************************************/
int input_BuildRemoteAddr( input_thread_t * p_input,
struct sockaddr_in * p_socket )
{
struct hostent * p_hostent;
/* Reset structure */ /* FIXME : we don't handle channels for the moment */
memset( p_socket, 0, sizeof( struct sockaddr_in ) );
p_socket->sin_family = AF_INET; /* family */
p_socket->sin_port = htons( 0 ); /* This is for remote end */
/* Get the remote server */ /* Get the remote server */
if( p_input->p_source == NULL ) if( p_input->p_source == NULL )
...@@ -586,42 +532,6 @@ int input_BuildRemoteAddr( input_thread_t * p_input, ...@@ -586,42 +532,6 @@ int input_BuildRemoteAddr( input_thread_t * p_input,
INPUT_SERVER_DEFAULT ); INPUT_SERVER_DEFAULT );
} }
/* Try to convert address directly from in_addr - this will work if
* psz_in_addr is dotted decimal. */
#ifdef HAVE_ARPA_INET_H
if( !inet_aton( p_input->p_source, &p_socket->sin_addr) )
#else
if( (p_socket->sin_addr.s_addr = inet_addr( p_input->p_source )) == -1 )
#endif
{
/* We have a fqdn, try to find its address */
if ( (p_hostent = gethostbyname(p_input->p_source)) == NULL )
{
intf_ErrMsg( "BuildRemoteAddr: unknown host %s",
p_input->p_source );
return( -1 );
}
/* Copy the first address of the host in the socket address */
memcpy( &p_socket->sin_addr, p_hostent->h_addr_list[0],
p_hostent->h_length );
}
return( 0 );
}
/*****************************************************************************
* input_NetworkOpen : open a network socket
*****************************************************************************/
void input_NetworkOpen( input_thread_t * p_input )
{
int i_option_value, i_port;
struct sockaddr_in s_socket;
boolean_t b_broadcast;
/* FIXME : we don't handle channels for the moment */
/* Open a SOCK_DGRAM (UDP) socket, in the AF_INET domain, automatic (0) /* Open a SOCK_DGRAM (UDP) socket, in the AF_INET domain, automatic (0)
* protocol */ * protocol */
p_input->i_handle = socket( AF_INET, SOCK_DGRAM, 0 ); p_input->i_handle = socket( AF_INET, SOCK_DGRAM, 0 );
...@@ -644,7 +554,6 @@ void input_NetworkOpen( input_thread_t * p_input ) ...@@ -644,7 +554,6 @@ void input_NetworkOpen( input_thread_t * p_input )
return; return;
} }
#ifndef SYS_BEOS
/* Increase the receive buffer size to 1/2MB (8Mb/s during 1/2s) to avoid /* Increase the receive buffer size to 1/2MB (8Mb/s during 1/2s) to avoid
* packet loss caused by scheduling problems */ * packet loss caused by scheduling problems */
i_option_value = 524288; i_option_value = 524288;
...@@ -657,7 +566,6 @@ void input_NetworkOpen( input_thread_t * p_input ) ...@@ -657,7 +566,6 @@ void input_NetworkOpen( input_thread_t * p_input )
p_input->b_error = 1; p_input->b_error = 1;
return; return;
} }
#endif /* SYS_BEOS */
/* Get details about what we are supposed to do */ /* Get details about what we are supposed to do */
b_broadcast = (boolean_t)main_GetIntVariable( INPUT_BROADCAST_VAR, 0 ); b_broadcast = (boolean_t)main_GetIntVariable( INPUT_BROADCAST_VAR, 0 );
...@@ -685,7 +593,7 @@ void input_NetworkOpen( input_thread_t * p_input ) ...@@ -685,7 +593,7 @@ void input_NetworkOpen( input_thread_t * p_input )
} }
/* Build socket for remote connection */ /* Build socket for remote connection */
if ( input_BuildRemoteAddr( p_input, &s_socket ) if ( input_BuildRemoteAddr( &s_socket, p_input->p_source )
== -1 ) == -1 )
{ {
close( p_input->i_handle ); close( p_input->i_handle );
......
This diff is collapsed.
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