summaryrefslogtreecommitdiff
path: root/usr.sbin/tcpdump/print-icmp.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin/tcpdump/print-icmp.c')
-rw-r--r--usr.sbin/tcpdump/print-icmp.c36
1 files changed, 16 insertions, 20 deletions
diff --git a/usr.sbin/tcpdump/print-icmp.c b/usr.sbin/tcpdump/print-icmp.c
index 13f4bfdf9bb..dbc1e32fc2e 100644
--- a/usr.sbin/tcpdump/print-icmp.c
+++ b/usr.sbin/tcpdump/print-icmp.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: print-icmp.c,v 1.12 2001/09/02 12:06:57 jakob Exp $ */
+/* $OpenBSD: print-icmp.c,v 1.13 2001/11/07 18:48:16 deraadt Exp $ */
/*
* Copyright (c) 1988, 1989, 1990, 1991, 1993, 1994, 1995, 1996
@@ -23,7 +23,7 @@
#ifndef lint
static const char rcsid[] =
- "@(#) $Header: /cvs/OpenBSD/src/usr.sbin/tcpdump/print-icmp.c,v 1.12 2001/09/02 12:06:57 jakob Exp $ (LBL)";
+ "@(#) $Header: /cvs/OpenBSD/src/usr.sbin/tcpdump/print-icmp.c,v 1.13 2001/11/07 18:48:16 deraadt Exp $ (LBL)";
#endif
#include <sys/param.h>
@@ -167,7 +167,6 @@ struct id_rdiscovery {
void
icmp_print(register const u_char *bp, register const u_char *bp2)
{
- register char *cp;
register const struct icmp *dp;
register const struct ip *ip;
register const char *str, *fmt;
@@ -175,6 +174,7 @@ icmp_print(register const u_char *bp, register const u_char *bp2)
register const struct udphdr *ouh;
register u_int hlen, dport, mtu;
char buf[MAXHOSTNAMELEN+256];
+ char buf2[MAXHOSTNAMELEN+256];
dp = (struct icmp *)bp;
ip = (struct ip *)bp2;
@@ -284,44 +284,40 @@ icmp_print(register const u_char *bp, register const u_char *bp2)
register const struct id_rdiscovery *idp;
u_int lifetime, num, size;
- (void)strncpy(buf, "router advertisement", sizeof buf-1);
- buf[sizeof buf-1] = '\0';
- cp = buf + strlen(buf);
+ (void)strlcpy(buf, "router advertisement", sizeof(buf));
ihp = (struct ih_rdiscovery *)&dp->icmp_void;
TCHECK(*ihp);
- (void)strcpy(cp, " lifetime ");
- cp = buf + strlen(buf);
+ (void)strlcat(buf, " lifetime ", sizeof(buf));
lifetime = EXTRACT_16BITS(&ihp->ird_lifetime);
if (lifetime < 60)
- (void)snprintf(cp, buf + sizeof buf - cp, "%u", lifetime);
+ (void)snprintf(buf2, sizeof(buf2), "%u", lifetime);
else if (lifetime < 60 * 60)
- (void)snprintf(cp, buf + sizeof buf - cp, "%u:%02u",
+ (void)snprintf(buf2, sizeof(buf2), "%u:%02u",
lifetime / 60, lifetime % 60);
else
- (void)snprintf(cp, buf + sizeof buf - cp, "%u:%02u:%02u",
- lifetime / 3600,
- (lifetime % 3600) / 60,
+ (void)snprintf(buf2, sizeof(buf2), "%u:%02u:%02u",
+ lifetime / 3600, (lifetime % 3600) / 60,
lifetime % 60);
- cp = buf + strlen(buf);
+ strlcat(buf, buf2, sizeof(buf));
num = ihp->ird_addrnum;
- (void)snprintf(cp, buf + sizeof buf - cp, " %d:", num);
- cp = buf + strlen(buf);
+ (void)snprintf(buf2, sizeof(buf2), " %d:", num);
+ strlcat(buf, buf2, sizeof(buf));
size = ihp->ird_addrsiz;
if (size != 2) {
- (void)snprintf(cp, buf - sizeof buf - cp,
- " [size %d]", size);
+ (void)snprintf(buf2, sizeof(buf2), " [size %d]", size);
+ strlcat(buf, buf2, sizeof(buf));
break;
}
idp = (struct id_rdiscovery *)&dp->icmp_data;
while (num-- > 0) {
TCHECK(*idp);
- (void)snprintf(cp, buf + sizeof buf - cp, " {%s %u}",
+ (void)snprintf(buf2, sizeof(buf2), " {%s %u}",
ipaddr_string(&idp->ird_addr),
EXTRACT_32BITS(&idp->ird_pref));
- cp = buf + strlen(buf);
+ strlcat(buf, buf2, sizeof(buf));
}
}
break;