1b0453382SBill Fenner /* 2b0453382SBill Fenner * Copyright (c) 1990, 1991, 1993, 1994, 1995, 1996, 1997 3b0453382SBill Fenner * The Regents of the University of California. All rights reserved. 4b0453382SBill Fenner * 5b0453382SBill Fenner * Redistribution and use in source and binary forms, with or without 6b0453382SBill Fenner * modification, are permitted provided that: (1) source code distributions 7b0453382SBill Fenner * retain the above copyright notice and this paragraph in its entirety, (2) 8b0453382SBill Fenner * distributions including binary code include the above copyright notice and 9b0453382SBill Fenner * this paragraph in its entirety in the documentation or other materials 10b0453382SBill Fenner * provided with the distribution, and (3) all advertising materials mentioning 11b0453382SBill Fenner * features or use of this software display the following acknowledgement: 12b0453382SBill Fenner * ``This product includes software developed by the University of California, 13b0453382SBill Fenner * Lawrence Berkeley Laboratory and its contributors.'' Neither the name of 14b0453382SBill Fenner * the University nor the names of its contributors may be used to endorse 15b0453382SBill Fenner * or promote products derived from this software without specific prior 16b0453382SBill Fenner * written permission. 17b0453382SBill Fenner * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED 18b0453382SBill Fenner * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF 19b0453382SBill Fenner * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 20b0453382SBill Fenner */ 21b0453382SBill Fenner 22*3c602fabSXin LI #define NETDISSECT_REWORKED 23b0453382SBill Fenner #ifdef HAVE_CONFIG_H 24b0453382SBill Fenner #include "config.h" 25b0453382SBill Fenner #endif 26b0453382SBill Fenner 275b0fe478SBruce M Simpson #include <tcpdump-stdinc.h> 28b0453382SBill Fenner 29b0453382SBill Fenner #include "interface.h" 30b0453382SBill Fenner #include "addrtoname.h" 31685295f4SBill Fenner #include "ethertype.h" 32a90e161bSBill Fenner #include "extract.h" 33685295f4SBill Fenner #include "chdlc.h" 34b0453382SBill Fenner 35*3c602fabSXin LI static void chdlc_slarp_print(netdissect_options *, const u_char *, u_int); 36b0453382SBill Fenner 37*3c602fabSXin LI static const struct tok chdlc_cast_values[] = { 38b5bfcb5dSMax Laier { CHDLC_UNICAST, "unicast" }, 39b5bfcb5dSMax Laier { CHDLC_BCAST, "bcast" }, 40b5bfcb5dSMax Laier { 0, NULL} 41b5bfcb5dSMax Laier }; 42b5bfcb5dSMax Laier 43b5bfcb5dSMax Laier 44b0453382SBill Fenner /* Standard CHDLC printer */ 455b0fe478SBruce M Simpson u_int 46*3c602fabSXin LI chdlc_if_print(netdissect_options *ndo, const struct pcap_pkthdr *h, register const u_char *p) 47b0453382SBill Fenner { 48b0453382SBill Fenner register u_int length = h->len; 49b0453382SBill Fenner register u_int caplen = h->caplen; 50a90e161bSBill Fenner 51a90e161bSBill Fenner if (caplen < CHDLC_HDRLEN) { 52*3c602fabSXin LI ND_PRINT((ndo, "[|chdlc]")); 535b0fe478SBruce M Simpson return (caplen); 54a90e161bSBill Fenner } 55*3c602fabSXin LI return (chdlc_print(ndo, p,length)); 562ebc47dbSSam Leffler } 572ebc47dbSSam Leffler 582ebc47dbSSam Leffler u_int 59*3c602fabSXin LI chdlc_print(netdissect_options *ndo, register const u_char *p, u_int length) { 602ebc47dbSSam Leffler u_int proto; 61a90e161bSBill Fenner 62a90e161bSBill Fenner proto = EXTRACT_16BITS(&p[2]); 63*3c602fabSXin LI if (ndo->ndo_eflag) { 64*3c602fabSXin LI ND_PRINT((ndo, "%s, ethertype %s (0x%04x), length %u: ", 65b5bfcb5dSMax Laier tok2str(chdlc_cast_values, "0x%02x", p[0]), 66b5bfcb5dSMax Laier tok2str(ethertype_values, "Unknown", proto), 67b5bfcb5dSMax Laier proto, 68*3c602fabSXin LI length)); 69b0453382SBill Fenner } 70b0453382SBill Fenner 71b0453382SBill Fenner length -= CHDLC_HDRLEN; 72b5bfcb5dSMax Laier p += CHDLC_HDRLEN; 73b5bfcb5dSMax Laier 74b0453382SBill Fenner switch (proto) { 75b0453382SBill Fenner case ETHERTYPE_IP: 76*3c602fabSXin LI ip_print(ndo, p, length); 77b0453382SBill Fenner break; 78b0453382SBill Fenner #ifdef INET6 79b0453382SBill Fenner case ETHERTYPE_IPV6: 80*3c602fabSXin LI ip6_print(ndo, p, length); 81b0453382SBill Fenner break; 82b0453382SBill Fenner #endif 83b0453382SBill Fenner case CHDLC_TYPE_SLARP: 84*3c602fabSXin LI chdlc_slarp_print(ndo, p, length); 85b0453382SBill Fenner break; 86b0453382SBill Fenner #if 0 87b0453382SBill Fenner case CHDLC_TYPE_CDP: 88b5bfcb5dSMax Laier chdlc_cdp_print(p, length); 89b0453382SBill Fenner break; 90b0453382SBill Fenner #endif 915b0fe478SBruce M Simpson case ETHERTYPE_MPLS: 925b0fe478SBruce M Simpson case ETHERTYPE_MPLS_MULTI: 93*3c602fabSXin LI mpls_print(ndo, p, length); 945b0fe478SBruce M Simpson break; 955b0fe478SBruce M Simpson case ETHERTYPE_ISO: 965b0fe478SBruce M Simpson /* is the fudge byte set ? lets verify by spotting ISO headers */ 97b5bfcb5dSMax Laier if (*(p+1) == 0x81 || 98b5bfcb5dSMax Laier *(p+1) == 0x82 || 99b5bfcb5dSMax Laier *(p+1) == 0x83) 100*3c602fabSXin LI isoclns_print(ndo, p + 1, length - 1, length - 1); 1015b0fe478SBruce M Simpson else 102*3c602fabSXin LI isoclns_print(ndo, p, length, length); 1035b0fe478SBruce M Simpson break; 1045b0fe478SBruce M Simpson default: 105*3c602fabSXin LI if (!ndo->ndo_eflag) 106*3c602fabSXin LI ND_PRINT((ndo, "unknown CHDLC protocol (0x%04x)", proto)); 1075b0fe478SBruce M Simpson break; 108b0453382SBill Fenner } 1095b0fe478SBruce M Simpson 1105b0fe478SBruce M Simpson return (CHDLC_HDRLEN); 111b0453382SBill Fenner } 112b0453382SBill Fenner 113f4d0c64aSSam Leffler /* 114f4d0c64aSSam Leffler * The fixed-length portion of a SLARP packet. 115f4d0c64aSSam Leffler */ 116b0453382SBill Fenner struct cisco_slarp { 117*3c602fabSXin LI uint8_t code[4]; 118b0453382SBill Fenner #define SLARP_REQUEST 0 119b0453382SBill Fenner #define SLARP_REPLY 1 120b0453382SBill Fenner #define SLARP_KEEPALIVE 2 121b0453382SBill Fenner union { 122b0453382SBill Fenner struct { 123*3c602fabSXin LI uint8_t addr[4]; 124*3c602fabSXin LI uint8_t mask[4]; 125b0453382SBill Fenner } addr; 126b0453382SBill Fenner struct { 127*3c602fabSXin LI uint8_t myseq[4]; 128*3c602fabSXin LI uint8_t yourseq[4]; 129*3c602fabSXin LI uint8_t rel[2]; 130b0453382SBill Fenner } keep; 131b0453382SBill Fenner } un; 132b0453382SBill Fenner }; 133b0453382SBill Fenner 134f4d0c64aSSam Leffler #define SLARP_MIN_LEN 14 135f4d0c64aSSam Leffler #define SLARP_MAX_LEN 18 136b0453382SBill Fenner 137b0453382SBill Fenner static void 138*3c602fabSXin LI chdlc_slarp_print(netdissect_options *ndo, const u_char *cp, u_int length) 139b0453382SBill Fenner { 140a90e161bSBill Fenner const struct cisco_slarp *slarp; 141f4d0c64aSSam Leffler u_int sec,min,hrs,days; 142b0453382SBill Fenner 143*3c602fabSXin LI ND_PRINT((ndo, "SLARP (length: %u), ",length)); 144f4d0c64aSSam Leffler if (length < SLARP_MIN_LEN) 1455b0fe478SBruce M Simpson goto trunc; 146b0453382SBill Fenner 147a90e161bSBill Fenner slarp = (const struct cisco_slarp *)cp; 148*3c602fabSXin LI ND_TCHECK2(*slarp, SLARP_MIN_LEN); 1495b0fe478SBruce M Simpson switch (EXTRACT_32BITS(&slarp->code)) { 150b0453382SBill Fenner case SLARP_REQUEST: 151*3c602fabSXin LI ND_PRINT((ndo, "request")); 152f4d0c64aSSam Leffler /* 153f4d0c64aSSam Leffler * At least according to William "Chops" Westfield's 154f4d0c64aSSam Leffler * message in 155f4d0c64aSSam Leffler * 156f4d0c64aSSam Leffler * http://www.nethelp.no/net/cisco-hdlc.txt 157f4d0c64aSSam Leffler * 158f4d0c64aSSam Leffler * the address and mask aren't used in requests - 159f4d0c64aSSam Leffler * they're just zero. 160f4d0c64aSSam Leffler */ 161b0453382SBill Fenner break; 162b0453382SBill Fenner case SLARP_REPLY: 163*3c602fabSXin LI ND_PRINT((ndo, "reply %s/%s", 164*3c602fabSXin LI ipaddr_string(ndo, &slarp->un.addr.addr), 165*3c602fabSXin LI ipaddr_string(ndo, &slarp->un.addr.mask))); 166b0453382SBill Fenner break; 167b0453382SBill Fenner case SLARP_KEEPALIVE: 168*3c602fabSXin LI ND_PRINT((ndo, "keepalive: mineseen=0x%08x, yourseen=0x%08x, reliability=0x%04x", 1695b0fe478SBruce M Simpson EXTRACT_32BITS(&slarp->un.keep.myseq), 170f4d0c64aSSam Leffler EXTRACT_32BITS(&slarp->un.keep.yourseq), 171*3c602fabSXin LI EXTRACT_16BITS(&slarp->un.keep.rel))); 172f4d0c64aSSam Leffler 173f4d0c64aSSam Leffler if (length >= SLARP_MAX_LEN) { /* uptime-stamp is optional */ 174f4d0c64aSSam Leffler cp += SLARP_MIN_LEN; 175*3c602fabSXin LI ND_TCHECK2(*cp, 4); 176f4d0c64aSSam Leffler sec = EXTRACT_32BITS(cp) / 1000; 177f4d0c64aSSam Leffler min = sec / 60; sec -= min * 60; 178f4d0c64aSSam Leffler hrs = min / 60; min -= hrs * 60; 179f4d0c64aSSam Leffler days = hrs / 24; hrs -= days * 24; 180*3c602fabSXin LI ND_PRINT((ndo, ", link uptime=%ud%uh%um%us",days,hrs,min,sec)); 181f4d0c64aSSam Leffler } 182b0453382SBill Fenner break; 183b0453382SBill Fenner default: 184*3c602fabSXin LI ND_PRINT((ndo, "0x%02x unknown", EXTRACT_32BITS(&slarp->code))); 185*3c602fabSXin LI if (ndo->ndo_vflag <= 1) 186*3c602fabSXin LI print_unknown_data(ndo,cp+4,"\n\t",length-4); 187b0453382SBill Fenner break; 188b0453382SBill Fenner } 189b0453382SBill Fenner 190*3c602fabSXin LI if (SLARP_MAX_LEN < length && ndo->ndo_vflag) 191*3c602fabSXin LI ND_PRINT((ndo, ", (trailing junk: %d bytes)", length - SLARP_MAX_LEN)); 192*3c602fabSXin LI if (ndo->ndo_vflag > 1) 193*3c602fabSXin LI print_unknown_data(ndo,cp+4,"\n\t",length-4); 1945b0fe478SBruce M Simpson return; 1955b0fe478SBruce M Simpson 1965b0fe478SBruce M Simpson trunc: 197*3c602fabSXin LI ND_PRINT((ndo, "[|slarp]")); 198b0453382SBill Fenner } 1991de50e9fSSam Leffler 2001de50e9fSSam Leffler 2011de50e9fSSam Leffler /* 2021de50e9fSSam Leffler * Local Variables: 2031de50e9fSSam Leffler * c-style: whitesmith 2041de50e9fSSam Leffler * c-basic-offset: 8 2051de50e9fSSam Leffler * End: 2061de50e9fSSam Leffler */ 207