Changeset 4c14b88 in mainline for uspace/app/ping/ping.c


Ignore:
Timestamp:
2013-12-31T07:57:14Z (10 years ago)
Author:
Jan Vesely <jano.vesely@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
1b973dc
Parents:
6297465 (diff), 208b5f5 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
Message:

mainline changes

File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/app/ping/ping.c

    r6297465 r4c14b88  
    3737#include <errno.h>
    3838#include <fibril_synch.h>
    39 #include <net/socket_codes.h>
    4039#include <inet/dnsr.h>
    4140#include <inet/addr.h>
     
    7776};
    7877
    79 static addr32_t src;
    80 static addr32_t dest;
     78static inet_addr_t src_addr;
     79static inet_addr_t dest_addr;
    8180
    8281static bool repeat_forever = false;
    8382static size_t repeat_count = 1;
    8483
    85 static const char *short_options = "rn:";
     84static const char *short_options = "46rn:";
    8685
    8786static void print_syntax(void)
    8887{
    89         printf("Syntax: %s [-n <count>|-r] <host>\n", NAME);
     88        printf("Syntax: %s [<options>] <host>\n", NAME);
     89        printf("\t-n <count> Repeat the specified number of times\n");
     90        printf("\t-r         Repeat forever\n");
     91        printf("\t-4|-6      Use IPv4 or IPv6 destination host address\n");
    9092}
    9193
     
    108110static int ping_ev_recv(inetping_sdu_t *sdu)
    109111{
    110         inet_addr_t src_addr;
    111         inet_addr_set(sdu->src, &src_addr);
    112        
    113         inet_addr_t dest_addr;
    114         inet_addr_set(sdu->dest, &dest_addr);
    115        
    116112        char *asrc;
    117113        int rc = inet_addr_format(&src_addr, &asrc);
     
    140136        inetping_sdu_t sdu;
    141137       
    142         sdu.src = src;
    143         sdu.dest = dest;
     138        sdu.src = src_addr;
     139        sdu.dest = dest_addr;
    144140        sdu.seq_no = seq_no;
    145141        sdu.data = (void *) "foo";
     
    222218        char *adest = NULL;
    223219        char *sdest = NULL;
     220        ip_ver_t ip_ver = ip_any;
    224221       
    225222        int rc = inetping_init(&ev_ops);
     
    244241                        }
    245242                        break;
     243                case '4':
     244                        ip_ver = ip_v4;
     245                        break;
     246                case '6':
     247                        ip_ver = ip_v6;
     248                        break;
    246249                default:
    247250                        printf("Unknown option passed.\n");
     
    258261       
    259262        /* Parse destination address */
    260         inet_addr_t dest_addr;
    261263        rc = inet_addr_parse(argv[optind], &dest_addr);
    262264        if (rc != EOK) {
    263265                /* Try interpreting as a host name */
    264                 rc = dnsr_name2host(argv[optind], &hinfo, AF_INET);
     266                rc = dnsr_name2host(argv[optind], &hinfo, ip_ver);
    265267                if (rc != EOK) {
    266268                        printf("Error resolving host '%s'.\n", argv[optind]);
     
    271273        }
    272274       
    273         uint16_t af = inet_addr_get(&dest_addr, &dest, NULL);
    274         if (af != AF_INET) {
    275                 printf("Destination '%s' is not an IPv4 address.\n",
    276                     argv[optind]);
    277                 goto error;
    278         }
    279        
    280275        /* Determine source address */
    281         rc = inetping_get_srcaddr(dest, &src);
     276        rc = inetping_get_srcaddr(&dest_addr, &src_addr);
    282277        if (rc != EOK) {
    283278                printf("Failed determining source address.\n");
    284279                goto error;
    285280        }
    286        
    287         inet_addr_t src_addr;
    288         inet_addr_set(src, &src_addr);
    289281       
    290282        rc = inet_addr_format(&src_addr, &asrc);
Note: See TracChangeset for help on using the changeset viewer.