/* vi: set sw=4 ts=4: */
/*
- * $Id: ping.c,v 1.34 2001/01/24 18:44:54 andersen Exp $
+ * $Id: ping.c,v 1.38 2001/02/20 06:14:08 andersen Exp $
* Mini ping implementation for busybox
*
* Copyright (C) 1999 by Randolph Chung <tausq@debian.org>
* Original copyright notice is retained at the end of this file.
*/
-#include "busybox.h"
#include <sys/param.h>
#include <sys/socket.h>
#include <sys/file.h>
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
+#include <unistd.h>
+#include <string.h>
+#include <stdlib.h>
+#include "busybox.h"
/* It turns out that libc5 doesn't have proper icmp support
pingaddr.sin_family = AF_INET;
if (!(h = gethostbyname(host))) {
- error_msg("unknown host %s\n", host);
+ error_msg("unknown host %s", host);
exit(1);
}
memcpy(&pingaddr.sin_addr, h->h_addr, sizeof(pingaddr.sin_addr));
argc--;
argv++;
if (argc < 1)
- usage(ping_usage);
+ show_usage();
ping(*argv);
return EXIT_SUCCESS;
}
if (i < 0)
perror_msg_and_die("sendto");
else if ((size_t)i != sizeof(packet))
- error_msg_and_die("ping wrote %d chars; %d expected\n", i,
+ error_msg_and_die("ping wrote %d chars; %d expected", i,
(int)sizeof(packet));
signal(SIGALRM, sendping);
printf("\n");
} else
if (icmppkt->icmp_type != ICMP_ECHO)
- error_msg("Warning: Got ICMP %d (%s)\n",
+ error_msg("Warning: Got ICMP %d (%s)",
icmppkt->icmp_type, icmp_type_name (icmppkt->icmp_type));
}
if ((pingsock = socket(AF_INET, SOCK_RAW,
(proto ? proto->p_proto : 1))) < 0) { /* 1 == ICMP */
if (errno == EPERM)
- error_msg_and_die("permission denied. (are you root?)\n");
+ error_msg_and_die("permission denied. (are you root?)");
else
perror_msg_and_die("creating a raw socket");
}
pingaddr.sin_family = AF_INET;
if (!(h = gethostbyname(host))) {
- error_msg("unknown host %s\n", host);
+ error_msg("unknown host %s", host);
exit(1);
}
if (h->h_addrtype != AF_INET) {
- error_msg("unknown address type; only AF_INET is currently supported.\n");
+ error_msg("unknown address type; only AF_INET is currently supported.");
exit(1);
}
break;
case 'c':
if (--argc <= 0)
- usage(ping_usage);
+ show_usage();
argv++;
pingcount = atoi(*argv);
break;
case 's':
if (--argc <= 0)
- usage(ping_usage);
+ show_usage();
argv++;
datalen = atoi(*argv);
break;
default:
- usage(ping_usage);
+ show_usage();
}
argc--;
argv++;
}
if (argc < 1)
- usage(ping_usage);
+ show_usage();
myid = getpid() & 0xFFFF;
ping(*argv);