|
|
@ -1901,57 +1901,59 @@ int handle_random_icmp( FPING_ICMPHDR *p, int psize, FPING_SOCKADDR *addr )
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
{
|
|
|
|
{
|
|
|
|
case ICMP_UNREACH:
|
|
|
|
case ICMP_UNREACH:
|
|
|
|
sent_icmp = ( FPING_ICMPHDR* )( c + 28 );
|
|
|
|
if( !quiet_flag ) {
|
|
|
|
|
|
|
|
sent_icmp = ( FPING_ICMPHDR* )( c + 28 );
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef IPV6
|
|
|
|
#ifndef IPV6
|
|
|
|
sent_icmp = ( struct icmp* )( c + 28 );
|
|
|
|
sent_icmp = ( struct icmp* )( c + 28 );
|
|
|
|
|
|
|
|
|
|
|
|
if( ( sent_icmp->icmp_type == ICMP_ECHO ) &&
|
|
|
|
if( ( sent_icmp->icmp_type == ICMP_ECHO ) &&
|
|
|
|
( ntohs(sent_icmp->icmp_id) == ident ) &&
|
|
|
|
( ntohs(sent_icmp->icmp_id) == ident ) &&
|
|
|
|
( ntohs(sent_icmp->icmp_seq) <= ( n_short )max_seq_sent ) )
|
|
|
|
( ntohs(sent_icmp->icmp_seq) <= ( n_short )max_seq_sent ) )
|
|
|
|
{
|
|
|
|
|
|
|
|
/* this is a response to a ping we sent */
|
|
|
|
|
|
|
|
h = table[ntohs(sent_icmp->icmp_seq) % num_hosts];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if( p->icmp_code > ICMP_UNREACH_MAXTYPE )
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
fprintf( stderr, "ICMP Unreachable (Invalid Code) from %s for ICMP Echo sent to %s",
|
|
|
|
/* this is a response to a ping we sent */
|
|
|
|
inet_ntoa( addr->sin_addr ), h->host );
|
|
|
|
h = table[ntohs(sent_icmp->icmp_seq) % num_hosts];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if( p->icmp_code > ICMP_UNREACH_MAXTYPE )
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
fprintf( stderr, "ICMP Unreachable (Invalid Code) from %s for ICMP Echo sent to %s",
|
|
|
|
|
|
|
|
inet_ntoa( addr->sin_addr ), h->host );
|
|
|
|
|
|
|
|
|
|
|
|
#else
|
|
|
|
#else
|
|
|
|
if( ( sent_icmp->icmp6_type == ICMP_ECHO ) &&
|
|
|
|
if( ( sent_icmp->icmp6_type == ICMP_ECHO ) &&
|
|
|
|
( ntohs(sent_icmp->icmp6_id) == ident ) &&
|
|
|
|
( ntohs(sent_icmp->icmp6_id) == ident ) &&
|
|
|
|
( ntohs(sent_icmp->icmp6_seq) <= ( n_short )max_seq_sent ) )
|
|
|
|
( ntohs(sent_icmp->icmp6_seq) <= ( n_short )max_seq_sent ) )
|
|
|
|
{
|
|
|
|
|
|
|
|
/* this is a response to a ping we sent */
|
|
|
|
|
|
|
|
h = table[ntohs(sent_icmp->icmp6_seq) % num_hosts];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if( p->icmp6_code > ICMP_UNREACH_MAXTYPE )
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
fprintf( stderr, "ICMP Unreachable (Invalid Code) from %s for ICMP Echo sent to %s",
|
|
|
|
/* this is a response to a ping we sent */
|
|
|
|
addr_ascii, h->host );
|
|
|
|
h = table[ntohs(sent_icmp->icmp6_seq) % num_hosts];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if( p->icmp6_code > ICMP_UNREACH_MAXTYPE )
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
fprintf( stderr, "ICMP Unreachable (Invalid Code) from %s for ICMP Echo sent to %s",
|
|
|
|
|
|
|
|
addr_ascii, h->host );
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
}/* IF */
|
|
|
|
}/* IF */
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
fprintf( stderr, "%s from %s for ICMP Echo sent to %s",
|
|
|
|
fprintf( stderr, "%s from %s for ICMP Echo sent to %s",
|
|
|
|
#ifndef IPV6
|
|
|
|
#ifndef IPV6
|
|
|
|
icmp_unreach_str[p->icmp_code], inet_ntoa( addr->sin_addr ), h->host );
|
|
|
|
icmp_unreach_str[p->icmp_code], inet_ntoa( addr->sin_addr ), h->host );
|
|
|
|
#else
|
|
|
|
#else
|
|
|
|
icmp_unreach_str[p->icmp6_code], addr_ascii, h->host );
|
|
|
|
icmp_unreach_str[p->icmp6_code], addr_ascii, h->host );
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
}/* ELSE */
|
|
|
|
}/* ELSE */
|
|
|
|
|
|
|
|
|
|
|
|
if( inet_addr( h->host ) == -1 )
|
|
|
|
if( inet_addr( h->host ) == -1 )
|
|
|
|
#ifndef IPV6
|
|
|
|
#ifndef IPV6
|
|
|
|
fprintf( stderr, " (%s)", inet_ntoa( h->saddr.sin_addr ) );
|
|
|
|
fprintf( stderr, " (%s)", inet_ntoa( h->saddr.sin_addr ) );
|
|
|
|
#else
|
|
|
|
#else
|
|
|
|
fprintf( stderr, " (%s)", addr_ascii);
|
|
|
|
fprintf( stderr, " (%s)", addr_ascii);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
fprintf( stderr, "\n" );
|
|
|
|
fprintf( stderr, "\n" );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}/* IF */
|
|
|
|
}/* IF */
|
|
|
|
}/* IF */
|
|
|
|
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
return 1;
|
|
|
@ -1960,35 +1962,37 @@ int handle_random_icmp( FPING_ICMPHDR *p, int psize, FPING_SOCKADDR *addr )
|
|
|
|
case ICMP_REDIRECT:
|
|
|
|
case ICMP_REDIRECT:
|
|
|
|
case ICMP_TIMXCEED:
|
|
|
|
case ICMP_TIMXCEED:
|
|
|
|
case ICMP_PARAMPROB:
|
|
|
|
case ICMP_PARAMPROB:
|
|
|
|
sent_icmp = ( FPING_ICMPHDR* )( c + 28 );
|
|
|
|
if( !quiet_flag ) {
|
|
|
|
|
|
|
|
sent_icmp = ( FPING_ICMPHDR* )( c + 28 );
|
|
|
|
#ifndef IPV6
|
|
|
|
#ifndef IPV6
|
|
|
|
if( ( sent_icmp->icmp_type == ICMP_ECHO ) &&
|
|
|
|
if( ( sent_icmp->icmp_type == ICMP_ECHO ) &&
|
|
|
|
( ntohs(sent_icmp->icmp_id) == ident ) &&
|
|
|
|
( ntohs(sent_icmp->icmp_id) == ident ) &&
|
|
|
|
( ntohs(sent_icmp->icmp_seq) <= ( n_short )max_seq_sent ) )
|
|
|
|
( ntohs(sent_icmp->icmp_seq) <= ( n_short )max_seq_sent ) )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
/* this is a response to a ping we sent */
|
|
|
|
/* this is a response to a ping we sent */
|
|
|
|
h = table[ntohs(sent_icmp->icmp_seq) % num_hosts];
|
|
|
|
h = table[ntohs(sent_icmp->icmp_seq) % num_hosts];
|
|
|
|
fprintf( stderr, "%s from %s for ICMP Echo sent to %s",
|
|
|
|
fprintf( stderr, "%s from %s for ICMP Echo sent to %s",
|
|
|
|
icmp_type_str[p->icmp_type], inet_ntoa( addr->sin_addr ), h->host );
|
|
|
|
icmp_type_str[p->icmp_type], inet_ntoa( addr->sin_addr ), h->host );
|
|
|
|
|
|
|
|
|
|
|
|
if( inet_addr( h->host ) == -1 )
|
|
|
|
if( inet_addr( h->host ) == -1 )
|
|
|
|
fprintf( stderr, " (%s)", inet_ntoa( h->saddr.sin_addr ) );
|
|
|
|
fprintf( stderr, " (%s)", inet_ntoa( h->saddr.sin_addr ) );
|
|
|
|
#else
|
|
|
|
#else
|
|
|
|
if( ( sent_icmp->icmp6_type == ICMP_ECHO ) &&
|
|
|
|
if( ( sent_icmp->icmp6_type == ICMP_ECHO ) &&
|
|
|
|
( ntohs(sent_icmp->icmp6_id) == ident ) &&
|
|
|
|
( ntohs(sent_icmp->icmp6_id) == ident ) &&
|
|
|
|
( ntohs(sent_icmp->icmp6_seq) <= ( n_short )max_seq_sent ) )
|
|
|
|
( ntohs(sent_icmp->icmp6_seq) <= ( n_short )max_seq_sent ) )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
/* this is a response to a ping we sent */
|
|
|
|
/* this is a response to a ping we sent */
|
|
|
|
h = table[ntohs(sent_icmp->icmp6_seq) % num_hosts];
|
|
|
|
h = table[ntohs(sent_icmp->icmp6_seq) % num_hosts];
|
|
|
|
fprintf( stderr, "%s from %s for ICMP Echo sent to %s",
|
|
|
|
fprintf( stderr, "%s from %s for ICMP Echo sent to %s",
|
|
|
|
icmp_type_str[p->icmp6_type], addr_ascii, h->host );
|
|
|
|
icmp_type_str[p->icmp6_type], addr_ascii, h->host );
|
|
|
|
|
|
|
|
|
|
|
|
if( inet_addr( h->host ) == -1 )
|
|
|
|
if( inet_addr( h->host ) == -1 )
|
|
|
|
fprintf( stderr, " (%s)", addr_ascii );
|
|
|
|
fprintf( stderr, " (%s)", addr_ascii );
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
fprintf( stderr, "\n" );
|
|
|
|
fprintf( stderr, "\n" );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}/* IF */
|
|
|
|
}/* IF */
|
|
|
|
}/* IF */
|
|
|
|
|
|
|
|
|
|
|
|
return 2;
|
|
|
|
return 2;
|
|
|
|