summaryrefslogtreecommitdiff
path: root/usr.sbin
diff options
context:
space:
mode:
authorRafael Zalamena <rzalamena@cvs.openbsd.org>2016-11-25 09:37:22 +0000
committerRafael Zalamena <rzalamena@cvs.openbsd.org>2016-11-25 09:37:22 +0000
commitf0c7ed10b7576c5b0935bae2a7001a00298bc5bf (patch)
treea8968910c0c44c3084346f32861eba4b80409836 /usr.sbin
parentf64820aa8450c6cc2c546493cbfef43c86fda048 (diff)
Fix some bad copy paste bits and simplify the ethernet printing function.
ok reyk@
Diffstat (limited to 'usr.sbin')
-rw-r--r--usr.sbin/tcpdump/print-ofp.c22
1 files changed, 8 insertions, 14 deletions
diff --git a/usr.sbin/tcpdump/print-ofp.c b/usr.sbin/tcpdump/print-ofp.c
index a1e47f10b7e..0846139382e 100644
--- a/usr.sbin/tcpdump/print-ofp.c
+++ b/usr.sbin/tcpdump/print-ofp.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: print-ofp.c,v 1.9 2016/11/22 13:01:32 rzalamena Exp $ */
+/* $OpenBSD: print-ofp.c,v 1.10 2016/11/25 09:37:21 rzalamena Exp $ */
/*
* Copyright (c) 2016 Rafael Zalamena <rzalamena@openbsd.org>
@@ -668,7 +668,7 @@ oxm_print_byte(const u_char *bp, u_int length, int hasmask, int hex)
bp += sizeof(*b);
length -= sizeof(*b);
printf(" mask ");
- oxm_print_word(bp, length, 0, 1);
+ oxm_print_byte(bp, length, 0, 1);
}
}
@@ -692,7 +692,7 @@ oxm_print_halfword(const u_char *bp, u_int length, int hasmask, int hex)
bp += sizeof(*h);
length -= sizeof(*h);
printf(" mask ");
- oxm_print_word(bp, length, 0, 1);
+ oxm_print_halfword(bp, length, 0, 1);
}
}
@@ -747,23 +747,17 @@ oxm_print_quad(const u_char *bp, u_int length, int hasmask, int hex)
void
oxm_print_ether(const u_char *bp, u_int length, int hasmask)
{
- uint8_t *ptr;
- int i;
- char hex[8];
+ char *mac;
if (length < ETHER_HDR_LEN) {
printf("[|OpenFlow]");
return;
}
- ptr = (uint8_t *)bp;
- for (i = 0; i < ETHER_ADDR_LEN; i++) {
- if (i)
- printf(":");
-
- snprintf(hex, sizeof(hex), "%02x", ptr[i]);
- printf("%s", hex);
- }
+ if ((mac = ether_ntoa((void *)bp)) == NULL)
+ printf("invalid");
+ else
+ printf("%s", mac);
if (hasmask) {
bp += ETHER_ADDR_LEN;