Subversion Repositories HelenOS

Compare Revisions

Ignore whitespace Rev 4720 → Rev 4719

/branches/network/uspace/srv/net/app/print_error.c
File deleted
Property changes:
Deleted: svn:eol-style
-native
\ No newline at end of property
/branches/network/uspace/srv/net/app/print_error.h
File deleted
Property changes:
Deleted: svn:eol-style
-native
\ No newline at end of property
/branches/network/uspace/srv/net/app/ping/Makefile
40,7 → 40,6
SOURCES = \
$(NAME).c \
$(NET_BASE)app/parse.c \
$(NET_BASE)app/print_error.c \
$(NET_BASE)inet.c \
$(NET_BASE)modules.c \
$(NET_BASE)tl/icmp/icmp_api.c \
/branches/network/uspace/srv/net/app/ping/ping.c
42,15 → 42,13
 
#include "../../include/icmp_api.h"
#include "../../include/in.h"
#include "../../include/in6.h"
#include "../../include/inet.h"
#include "../../include/ip_codes.h"
#include "../../include/socket_errno.h"
#include "../../include/socket_codes.h"
 
#include "../../err.h"
 
#include "../parse.h"
#include "../print_error.h"
 
/** Echo module name.
*/
71,9 → 69,8
/** Translates the character string to the address family number.
* @param name The address family name. Input parameter.
* @returns The corresponding address family number.
* @returns EAFNOSUPPORTED if the address family is not supported.
*/
int parse_address_family( const char * name );
int parse_address_family( const char * name );
 
void print_help( void ){
printf(
88,7 → 85,7
"\tDisable packet fragmentation.\n"
"\n" \
"-f address_family | --family=address_family\n" \
"\tThe given address family. Only the AF_INET and AF_INET6 are supported.\n"
"\tThe given address family. Only the AF_INET is supported.\n"
"\n" \
"-h | --help\n" \
"\tShow this application help.\n"
113,10 → 110,8
int parse_address_family( const char * name ){
if( str_lcmp( name, "AF_INET", 7 ) == 0 ){
return AF_INET;
}else if( str_lcmp( name, "AF_INET6", 8 ) == 0 ){
return AF_INET6;
}
return EAFNOSUPPORT;
return ENOENT;
}
 
int main( int argc, char * argv[] ){
129,16 → 124,8
ip_tos_t tos = 0;
int count = 3;
suseconds_t timeout = 3000;
int family = AF_INET;
struct sockaddr_in address = { .sin_family = AF_INET, .sin_port = 7 };
 
socklen_t max_length = sizeof( struct sockaddr_in6 );
uint8_t address_data[ max_length ];
struct sockaddr * address = ( struct sockaddr * ) address_data;
struct sockaddr_in * address_in = ( struct sockaddr_in * ) address;
struct sockaddr_in6 * address_in6 = ( struct sockaddr_in6 * ) address;
socklen_t addrlen;
char address_string[ INET6_ADDRSTRLEN ];
uint8_t * address_start;
int icmp_phone;
struct timeval time_before;
struct timeval time_after;
154,7 → 141,8
switch( argv[ index ][ 1 ] ){
case 'c': ERROR_PROPAGATE( parse_parameter_int( argc, argv, & index, & count, "count", 0 ));
break;
case 'f': ERROR_PROPAGATE( parse_parameter_name_int( argc, argv, & index, & family, "address family", 0, parse_address_family ));
case 'f': ERROR_PROPAGATE( parse_parameter_name_int( argc, argv, & index, & value, "address family", 0, parse_address_family ));
address.sin_family = ( uint16_t ) value;
break;
case 'h': print_help();
return EOK;
172,7 → 160,8
}else if( str_lcmp( argv[ index ] + 2, "dont_fragment", 13 ) == 0 ){
dont_fragment = 1;
}else if( str_lcmp( argv[ index ] + 2, "family=", 7 ) == 0 ){
ERROR_PROPAGATE( parse_parameter_name_int( argc, argv, & index, & family, "address family", 9, parse_address_family ));
ERROR_PROPAGATE( parse_parameter_name_int( argc, argv, & index, & value, "address family", 9, parse_address_family ));
address.sin_family = ( uint16_t ) value;
}else if( str_lcmp( argv[ index ] + 2, "help", 5 ) == 0 ){
print_help();
return EOK;
208,24 → 197,7
}
}
 
bzero( address_data, max_length );
switch( family ){
case AF_INET:
address_in->sin_family = AF_INET;
address_start = ( uint8_t * ) & address_in->sin_addr.s_addr;
addrlen = sizeof( struct sockaddr_in );
break;
case AF_INET6:
address_in6->sin6_family = AF_INET6;
address_start = ( uint8_t * ) & address_in6->sin6_addr.s6_addr;
addrlen = sizeof( struct sockaddr_in6 );
break;
default:
fprintf( stderr, "Protocol family is not supported\n" );
return EAFNOSUPPORT;
}
 
if( ERROR_OCCURRED( inet_pton( family, argv[ argc - 1 ], address_start ))){
if( ERROR_OCCURRED( inet_pton( address.sin_family, argv[ argc - 1 ], ( uint8_t * ) & address.sin_addr ))){
fprintf( stderr, "Address parse error %d\n", ERROR_CODE );
return ERROR_CODE;
}
236,11 → 208,6
}
 
printf( "PING %d bytes of data\n", size );
if( ERROR_OCCURRED( inet_ntop( address->sa_family, address_start, address_string, sizeof( address_string )))){
fprintf( stderr, "Address error %d\n", ERROR_CODE );
}else{
printf( "Address %s:\n", address_string );
}
 
while( count > 0 ){
if( ERROR_OCCURRED( gettimeofday( & time_before, NULL ))){
247,7 → 214,7
fprintf( stderr, "Get time of day error %d\n", ERROR_CODE );
return ERROR_CODE;
}
result = icmp_echo_msg( icmp_phone, size, timeout, ttl, tos, dont_fragment, address, addrlen );
result = icmp_echo_msg( icmp_phone, size, timeout, ttl, tos, dont_fragment, ( struct sockaddr * ) & address, sizeof( address ));
if( ERROR_OCCURRED( gettimeofday( & time_after, NULL ))){
fprintf( stderr, "Get time of day error %d\n", ERROR_CODE );
return ERROR_CODE;
256,11 → 223,11
case ICMP_ECHO:
printf( "Ping round trip time %d microseconds\n", tv_sub( & time_after, & time_before ));
break;
case ETIMEOUT:
case ELIMIT:
printf( "Timeouted.\n" );
break;
default:
print_error( stdout, result, NULL, "\n" );
printf( "Error %d.\n", result );
}
-- count;
}
/branches/network/uspace/srv/net/app/echo/echo.c
41,7 → 41,6
#include <task.h>
 
#include "../../include/in.h"
#include "../../include/in6.h"
#include "../../include/inet.h"
#include "../../include/socket.h"
 
48,7 → 47,6
#include "../../err.h"
 
#include "../parse.h"
#include "../print_error.h"
 
/** Echo module name.
*/
69,16 → 67,14
/** Translates the character string to the protocol family number.
* @param name The protocol family name. Input parameter.
* @returns The corresponding protocol family number.
* @returns EPFNOSUPPORTED if the protocol family is not supported.
*/
int parse_protocol_family( const char * name );
int parse_protocol_family( const char * name );
 
/** Translates the character string to the socket type number.
* @param name The socket type name. Input parameter.
* @returns The corresponding socket type number.
* @returns ESOCKNOSUPPORTED if the socket type is not supported.
*/
int parse_socket_type( const char * name );
int parse_socket_type( const char * name );
 
void print_help( void ){
printf(
89,7 → 85,7
"\tThe number of received messages to handle. A negative number means infinity. The default is infinity.\n" \
"\n" \
"-f protocol_family | --family=protocol_family\n" \
"\tThe listenning socket protocol family. Only the PF_INET and PF_INET6 are supported.\n"
"\tThe listenning socket protocol family. Only the PF_INET is supported.\n"
"\n" \
"-h | --help\n" \
"\tShow this application help.\n"
114,10 → 110,8
int parse_protocol_family( const char * name ){
if( str_lcmp( name, "PF_INET", 7 ) == 0 ){
return PF_INET;
}else if( str_lcmp( name, "PF_INET6", 8 ) == 0 ){
return PF_INET6;
}
return EPFNOSUPPORT;
return ENOENT;
}
 
int parse_socket_type( const char * name ){
124,7 → 118,7
if( str_lcmp( name, "SOCK_DGRAM", 11 ) == 0 ){
return SOCK_DGRAM;
}
return ESOCKTNOSUPPORT;
return ENOENT;
}
 
int main( int argc, char * argv[] ){
135,18 → 129,12
char * reply = NULL;
sock_type_t type = SOCK_DGRAM;
int count = -1;
struct sockaddr_in address = { .sin_family = AF_INET, .sin_port = 7 };
int family = PF_INET;
uint16_t port = 7;
 
socklen_t max_length = sizeof( struct sockaddr_in6 );
uint8_t address_data[ max_length ];
struct sockaddr * address = ( struct sockaddr * ) address_data;
struct sockaddr_in * address_in = ( struct sockaddr_in * ) address;
struct sockaddr_in6 * address_in6 = ( struct sockaddr_in6 * ) address;
socklen_t addrlen;
char address_string[ INET6_ADDRSTRLEN ];
uint8_t * address_start;
int socket_id;
int address_length;
char address_string[ INET_ADDRSTRLEN ];
char * data;
size_t length;
int index;
161,13 → 149,21
switch( argv[ index ][ 1 ] ){
case 'c': ERROR_PROPAGATE( parse_parameter_int( argc, argv, & index, & count, "count", 0 ));
break;
case 'f': ERROR_PROPAGATE( parse_parameter_name_int( argc, argv, & index, & family, "protocol family", 0, parse_protocol_family ));
case 'f': ERROR_PROPAGATE( parse_parameter_name_int( argc, argv, & index, & value, "protocol family", 0, parse_protocol_family ));
family = value;
switch( family ){
case PF_INET:
address.sin_family = AF_INET;
break;
default:
return ENOENT;
}
break;
case 'h': print_help();
return EOK;
break;
case 'p': ERROR_PROPAGATE( parse_parameter_int( argc, argv, & index, & value, "port number", 0 ));
port = ( uint16_t ) value;
address.sin_port = ( uint16_t ) value;
break;
case 'r': ERROR_PROPAGATE( parse_parameter_string( argc, argv, & index, & reply, "reply string", 0 ));
break;
182,13 → 178,22
case '-': if( str_lcmp( argv[ index ] + 2, "count=", 6 ) == 0 ){
ERROR_PROPAGATE( parse_parameter_int( argc, argv, & index, & count, "received count", 8 ))
}else if( str_lcmp( argv[ index ] + 2, "family=", 7 ) == 0 ){
ERROR_PROPAGATE( parse_parameter_name_int( argc, argv, & index, & family, "protocol family", 9, parse_protocol_family ));
ERROR_PROPAGATE( parse_parameter_name_int( argc, argv, & index, & value, "protocol family", 9, parse_protocol_family ));
family = value;
switch( family ){
case PF_INET:
address.sin_family = AF_INET;
break;
default:
return ENOENT;
}
break;
}else if( str_lcmp( argv[ index ] + 2, "help", 5 ) == 0 ){
print_help();
return EOK;
}else if( str_lcmp( argv[ index ] + 2, "port=", 5 ) == 0 ){
ERROR_PROPAGATE( parse_parameter_int( argc, argv, & index, & value, "port number", 7 ));
port = ( uint16_t ) value;
address.sin_port = ( uint16_t ) value;
}else if( str_lcmp( argv[ index ] + 2, "reply=", 6 ) == 0 ){
ERROR_PROPAGATE( parse_parameter_string( argc, argv, & index, & reply, "reply string", 8 ));
}else if( str_lcmp( argv[ index ] + 2, "size=", 5 ) == 0 ){
234,62 → 239,31
fprintf( stderr, "Socket create error %d\n", socket_id );
return socket_id;
}
 
bzero( address_data, max_length );
switch( family ){
case PF_INET:
address_in->sin_family = AF_INET;
address_in->sin_port = port;
addrlen = sizeof( struct sockaddr_in );
break;
case PF_INET6:
address_in6->sin6_family = AF_INET6;
address_in6->sin6_port = port;
addrlen = sizeof( struct sockaddr_in6 );
break;
default:
fprintf( stderr, "Protocol family is not supported\n" );
return EAFNOSUPPORT;
}
if( ERROR_OCCURRED( bind( socket_id, address, addrlen ))){
socket_print_error( stderr, ERROR_CODE, "Socket bind: ", "\n" );
if( ERROR_OCCURRED( bind( socket_id, ( struct sockaddr * ) & address, sizeof( address )))){
fprintf( stderr, "Socket bind error %d\n", ERROR_CODE );
return ERROR_CODE;
}
 
if( verbose ) printf( "Listenning at %d\n", port );
if( verbose ) printf( "Listenning at %d\n", address.sin_port );
 
while( count ){
addrlen = max_length;
value = recvfrom( socket_id, data, size, 0, address, & addrlen );
address_length = sizeof( address );
value = recvfrom( socket_id, data, size, 0, ( struct sockaddr * ) & address, & address_length );
if( value < 0 ){
socket_print_error( stderr, value, "Socket receive: ", "\n" );
fprintf( stderr, "Socket receive error %d\n", value );
}else{
length = ( size_t ) value;
if( verbose ){
address_start = NULL;
switch( address->sa_family ){
case AF_INET:
port = address_in->sin_port;
address_start = ( uint8_t * ) & address_in->sin_addr.s_addr;
break;
case AF_INET6:
port = address_in6->sin6_port;
address_start = ( uint8_t * ) & address_in6->sin6_addr.s6_addr;
break;
default:
fprintf( stderr, "Address family %d (0x%X) is not supported.\n", address->sa_family );
if( ERROR_OCCURRED( inet_ntop( address.sin_family, ( uint8_t * ) & address.sin_addr.s_addr, address_string, sizeof( address_string )))){
fprintf( stderr, "Received address error %d\n", ERROR_CODE );
continue;
}else{
data[ length ] = '\0';
printf( "Received from %s:%d\n%s\n", address_string, address.sin_port, data );
}
if( address_start ){
if( ERROR_OCCURRED( inet_ntop( address->sa_family, address_start, address_string, sizeof( address_string )))){
fprintf( stderr, "Received address error %d\n", ERROR_CODE );
}else{
data[ length ] = '\0';
printf( "Received from %s:%d\n%s\n", address_string, port, data );
}
}
}
if( ERROR_OCCURRED( sendto( socket_id, reply ? reply : data, reply ? reply_length : length, 0, address, addrlen ))){
socket_print_error( stderr, ERROR_CODE, "Socket send: ", "\n" );
if( ERROR_OCCURRED( sendto( socket_id, reply ? reply : data, reply ? reply_length : length, 0, ( struct sockaddr * ) & address, sizeof( address )))){
fprintf( stderr, "Socket send error %d\n", ERROR_CODE );
}
}
if( count > 0 ){
301,7 → 275,7
if( verbose ) printf( "Closing the socket\n" );
 
if( ERROR_OCCURRED( closesocket( socket_id ))){
socket_print_error( stderr, ERROR_CODE, "Close socket: ", "\n" );
fprintf( stderr, "Close socket error %d\n", ERROR_CODE );
return ERROR_CODE;
}
 
/branches/network/uspace/srv/net/app/echo/Makefile
39,8 → 39,7
OUTPUT = $(NAME)
SOURCES = \
$(NAME).c \
$(NET_BASE)app/parse.c \
$(NET_BASE)app/print_error.c
$(NET_BASE)app/parse.c
 
LIBS += ../../socket/libsocket.a