X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/3cd171317f54bc968808d49e3ca87b6c49ccdcdd..7c4458eb6a0cd2a617adb9a3bbca44e9f59f3937:/print-ether.c diff --git a/print-ether.c b/print-ether.c index 573fdba8..0711cca9 100644 --- a/print-ether.c +++ b/print-ether.c @@ -20,7 +20,7 @@ */ #ifndef lint static const char rcsid[] = - "@(#) $Header: /tcpdump/master/tcpdump/print-ether.c,v 1.51 2000-07-01 03:39:02 assar Exp $ (LBL)"; + "@(#) $Header: /tcpdump/master/tcpdump/print-ether.c,v 1.60 2000-12-18 05:41:59 guy Exp $ (LBL)"; #endif #ifdef HAVE_CONFIG_H @@ -33,28 +33,18 @@ static const char rcsid[] = struct mbuf; struct rtentry; -#include #include -#include -#include -#include -#include -#include -#include -#include #include #include -#ifdef INET6 -#include -#endif - #include "interface.h" #include "addrtoname.h" #include "ethertype.h" +#include "ether.h" + const u_char *packetp; const u_char *snapend; @@ -77,8 +67,6 @@ ether_print(register const u_char *bp, u_int length) length); } -static u_short extracted_ethertype; - /* * This is the top level routine of the printer. 'p' is the points * to the ether header of the packet, 'h->tv' is the timestamp, @@ -92,10 +80,11 @@ ether_if_print(u_char *user, const struct pcap_pkthdr *h, const u_char *p) u_int length = h->len; struct ether_header *ep; u_short ether_type; + u_short extracted_ethertype; ts_print(&h->ts); - if (caplen < sizeof(struct ether_header)) { + if (caplen < ETHER_HDRLEN) { printf("[|ether]"); goto out; } @@ -111,10 +100,10 @@ ether_if_print(u_char *user, const struct pcap_pkthdr *h, const u_char *p) packetp = p; snapend = p + caplen; - length -= sizeof(struct ether_header); - caplen -= sizeof(struct ether_header); + length -= ETHER_HDRLEN; + caplen -= ETHER_HDRLEN; ep = (struct ether_header *)p; - p += sizeof(struct ether_header); + p += ETHER_HDRLEN; ether_type = ntohs(ep->ether_type); @@ -124,7 +113,8 @@ ether_if_print(u_char *user, const struct pcap_pkthdr *h, const u_char *p) extracted_ethertype = 0; if (ether_type <= ETHERMTU) { /* Try to print the LLC-layer header & higher layers */ - if (llc_print(p, length, caplen, ESRC(ep), EDST(ep)) == 0) { + if (llc_print(p, length, caplen, ESRC(ep), EDST(ep), + &extracted_ethertype) == 0) { /* ether_type not known, print raw packet */ if (!eflag) ether_print((u_char *)ep, length); @@ -135,10 +125,11 @@ ether_if_print(u_char *user, const struct pcap_pkthdr *h, const u_char *p) if (!xflag && !qflag) default_print(p, caplen); } - } else if (ether_encap_print(ether_type, p, length, caplen) == 0) { + } else if (ether_encap_print(ether_type, p, length, caplen, + &extracted_ethertype) == 0) { /* ether_type not known, print raw packet */ if (!eflag) - ether_print((u_char *)ep, length + sizeof(*ep)); + ether_print((u_char *)ep, length + ETHER_HDRLEN); if (!xflag && !qflag) default_print(p, caplen); } @@ -154,16 +145,18 @@ ether_if_print(u_char *user, const struct pcap_pkthdr *h, const u_char *p) * * Returns non-zero if it can do so, zero if the ethertype is unknown. * - * Stuffs the ether type into a global for the benefit of lower layers - * that might want to know what it is. + * The Ethernet type code is passed through a pointer; if it was + * ETHERTYPE_8021Q, it gets updated to be the Ethernet type of + * the 802.1Q payload, for the benefit of lower layers that might + * want to know what it is. */ int ether_encap_print(u_short ethertype, const u_char *p, - u_int length, u_int caplen) + u_int length, u_int caplen, u_short *extracted_ethertype) { recurse: - extracted_ethertype = ethertype; + *extracted_ethertype = ethertype; switch (ethertype) { @@ -201,7 +194,7 @@ ether_encap_print(u_short ethertype, const u_char *p, return (1); case ETHERTYPE_8021Q: - printf("802.1Q vlan#%d P%d%s", + printf("802.1Q vlan#%d P%d%s ", ntohs(*(u_int16_t *)p) & 0xfff, ntohs(*(u_int16_t *)p) >> 13, (ntohs(*(u_int16_t *)p) & 0x1000) ? " CFI" : ""); @@ -212,15 +205,16 @@ ether_encap_print(u_short ethertype, const u_char *p, if (ethertype > ETHERMTU) goto recurse; - extracted_ethertype = 0; + *extracted_ethertype = 0; - if (llc_print(p, length, caplen, p - 18, p - 12) == 0) { + if (llc_print(p, length, caplen, p - 18, p - 12, + extracted_ethertype) == 0) { /* ether_type not known, print raw packet */ if (!eflag) ether_print(p - 18, length + 4); - if (extracted_ethertype) { + if (*extracted_ethertype) { printf("(LLC %s) ", - etherproto_string(htons(extracted_ethertype))); + etherproto_string(htons(*extracted_ethertype))); } if (!xflag && !qflag) default_print(p - 18, caplen + 4);