o Be ready to get a reply with length up to IP_MAXPACKET.

o Warn when recieved packet length is not equal to length of the
packet we sent out. Idea from NetBSD.
o Fit the dump of packet with wrong data to 80 columns (from NetBSD).

Comments from:	bde
This commit is contained in:
maxim 2003-07-14 12:37:03 +00:00
parent 661c94feb0
commit 3fd6e6089e

View File

@ -168,6 +168,7 @@ int uid; /* cached uid for micro-optimization */
u_char icmp_type = ICMP_ECHO; u_char icmp_type = ICMP_ECHO;
u_char icmp_type_rsp = ICMP_ECHOREPLY; u_char icmp_type_rsp = ICMP_ECHOREPLY;
int phdr_len = 0; int phdr_len = 0;
int send_len;
/* counters */ /* counters */
long nmissedmax; /* max value of ntransmitted - nreceived - 1 */ long nmissedmax; /* max value of ntransmitted - nreceived - 1 */
@ -227,7 +228,7 @@ main(argc, argv)
struct sockaddr_in *to; struct sockaddr_in *to;
double t; double t;
u_long alarmtimeout, ultmp; u_long alarmtimeout, ultmp;
int almost_done, ch, df, hold, i, mib[4], packlen, preload, sockerrno, int almost_done, ch, df, hold, i, icmp_len, mib[4], preload, sockerrno,
tos, ttl; tos, ttl;
char ctrl[CMSG_SPACE(sizeof(struct timeval))]; char ctrl[CMSG_SPACE(sizeof(struct timeval))];
char hnamebuf[MAXHOSTNAMELEN], snamebuf[MAXHOSTNAMELEN]; char hnamebuf[MAXHOSTNAMELEN], snamebuf[MAXHOSTNAMELEN];
@ -458,12 +459,14 @@ main(argc, argv)
errx(EX_USAGE, "ICMP_TSTAMP and ICMP_MASKREQ are exclusive."); errx(EX_USAGE, "ICMP_TSTAMP and ICMP_MASKREQ are exclusive.");
break; break;
} }
maxpayload = IP_MAXPACKET - sizeof(struct ip) - MINICMPLEN - phdr_len; icmp_len = sizeof(struct ip) + MINICMPLEN + phdr_len;
if (options & F_RROUTE) if (options & F_RROUTE)
maxpayload -= MAX_IPOPTLEN; icmp_len += MAX_IPOPTLEN;
maxpayload = IP_MAXPACKET - icmp_len;
if (datalen > maxpayload) if (datalen > maxpayload)
errx(EX_USAGE, "packet size too large: %d > %d", datalen, errx(EX_USAGE, "packet size too large: %d > %d", datalen,
maxpayload); maxpayload);
send_len = icmp_len + datalen;
datap = &outpack[MINICMPLEN + phdr_len + TIMEVAL_LEN]; datap = &outpack[MINICMPLEN + phdr_len + TIMEVAL_LEN];
if (options & F_PINGFILLED) { if (options & F_PINGFILLED) {
fill((char *)datap, payload); fill((char *)datap, payload);
@ -527,8 +530,6 @@ main(argc, argv)
if (datalen >= TIMEVAL_LEN) /* can we time transfer */ if (datalen >= TIMEVAL_LEN) /* can we time transfer */
timing = 1; timing = 1;
packlen = MAXIPLEN + MAXICMPLEN + datalen;
packlen = packlen > IP_MAXPACKET ? IP_MAXPACKET : packlen;
if (!(options & F_PINGFILLED)) if (!(options & F_PINGFILLED))
for (i = TIMEVAL_LEN; i < datalen; ++i) for (i = TIMEVAL_LEN; i < datalen; ++i)
@ -706,7 +707,7 @@ main(argc, argv)
msg.msg_control = (caddr_t)ctrl; msg.msg_control = (caddr_t)ctrl;
#endif #endif
iov.iov_base = packet; iov.iov_base = packet;
iov.iov_len = packlen; iov.iov_len = IP_MAXPACKET;
if (tcgetattr(STDOUT_FILENO, &ts) != -1) { if (tcgetattr(STDOUT_FILENO, &ts) != -1) {
reset_kerninfo = !(ts.c_lflag & NOKERNINFO); reset_kerninfo = !(ts.c_lflag & NOKERNINFO);
@ -924,13 +925,14 @@ pr_pack(buf, cc, from, tv)
struct ip *ip; struct ip *ip;
const void *tp; const void *tp;
double triptime; double triptime;
int dupflag, hlen, i, j, seq; int dupflag, hlen, i, j, recv_len, seq;
static int old_rrlen; static int old_rrlen;
static char old_rr[MAX_IPOPTLEN]; static char old_rr[MAX_IPOPTLEN];
/* Check the IP header */ /* Check the IP header */
ip = (struct ip *)buf; ip = (struct ip *)buf;
hlen = ip->ip_hl << 2; hlen = ip->ip_hl << 2;
recv_len = cc;
if (cc < hlen + ICMP_MINLEN) { if (cc < hlen + ICMP_MINLEN) {
if (options & F_VERBOSE) if (options & F_VERBOSE)
warn("packet too short (%d bytes) from %s", cc, warn("packet too short (%d bytes) from %s", cc,
@ -1008,6 +1010,11 @@ pr_pack(buf, cc, from, tv)
(void)printf(" tsr=%s", pr_ntime(icp->icmp_rtime)); (void)printf(" tsr=%s", pr_ntime(icp->icmp_rtime));
(void)printf(" tst=%s", pr_ntime(icp->icmp_ttime)); (void)printf(" tst=%s", pr_ntime(icp->icmp_ttime));
} }
if (recv_len != send_len) {
(void)printf(
"\nwrong total length %d instead of %d",
recv_len, send_len);
}
/* check the data */ /* check the data */
cp = (u_char*)&icp->icmp_data[phdr_len]; cp = (u_char*)&icp->icmp_data[phdr_len];
dp = &outpack[MINICMPLEN + phdr_len]; dp = &outpack[MINICMPLEN + phdr_len];
@ -1026,16 +1033,16 @@ pr_pack(buf, cc, from, tv)
(void)printf("\ncp:"); (void)printf("\ncp:");
cp = (u_char*)&icp->icmp_data[0]; cp = (u_char*)&icp->icmp_data[0];
for (i = 0; i < datalen; ++i, ++cp) { for (i = 0; i < datalen; ++i, ++cp) {
if ((i % 32) == 8) if ((i % 16) == 8)
(void)printf("\n\t"); (void)printf("\n\t");
(void)printf("%x ", *cp); (void)printf("%2x ", *cp);
} }
(void)printf("\ndp:"); (void)printf("\ndp:");
cp = &outpack[MINICMPLEN]; cp = &outpack[MINICMPLEN];
for (i = 0; i < datalen; ++i, ++cp) { for (i = 0; i < datalen; ++i, ++cp) {
if ((i % 32) == 8) if ((i % 16) == 8)
(void)printf("\n\t"); (void)printf("\n\t");
(void)printf("%x ", *cp); (void)printf("%2x ", *cp);
} }
break; break;
} }