14edb46e9SPaul Traina /* 2699fc314SBill Fenner * Copyright (c) 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997 34edb46e9SPaul Traina * The Regents of the University of California. All rights reserved. 44edb46e9SPaul Traina * 54edb46e9SPaul Traina * Redistribution and use in source and binary forms, with or without 64edb46e9SPaul Traina * modification, are permitted provided that: (1) source code distributions 74edb46e9SPaul Traina * retain the above copyright notice and this paragraph in its entirety, (2) 84edb46e9SPaul Traina * distributions including binary code include the above copyright notice and 94edb46e9SPaul Traina * this paragraph in its entirety in the documentation or other materials 104edb46e9SPaul Traina * provided with the distribution, and (3) all advertising materials mentioning 114edb46e9SPaul Traina * features or use of this software display the following acknowledgement: 124edb46e9SPaul Traina * ``This product includes software developed by the University of California, 134edb46e9SPaul Traina * Lawrence Berkeley Laboratory and its contributors.'' Neither the name of 144edb46e9SPaul Traina * the University nor the names of its contributors may be used to endorse 154edb46e9SPaul Traina * or promote products derived from this software without specific prior 164edb46e9SPaul Traina * written permission. 174edb46e9SPaul Traina * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED 184edb46e9SPaul Traina * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF 194edb46e9SPaul Traina * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 204edb46e9SPaul Traina * 214edb46e9SPaul Traina * Internet, ethernet, port, and protocol string to address 224edb46e9SPaul Traina * and address to string conversion routines 23a88113a8SBill Fenner * 24a88113a8SBill Fenner * $FreeBSD$ 254edb46e9SPaul Traina */ 264edb46e9SPaul Traina #ifndef lint 27cc391cceSBruce M Simpson static const char rcsid[] _U_ = 28c1ad1296SSam Leffler "@(#) $Header: /tcpdump/master/tcpdump/addrtoname.c,v 1.108 2005/03/27 22:38:09 guy Exp $ (LBL)"; 29a88113a8SBill Fenner #endif 30a88113a8SBill Fenner 31a88113a8SBill Fenner #ifdef HAVE_CONFIG_H 32a88113a8SBill Fenner #include "config.h" 334edb46e9SPaul Traina #endif 344edb46e9SPaul Traina 35cc391cceSBruce M Simpson #include <tcpdump-stdinc.h> 360e0def19SBill Fenner 370e0def19SBill Fenner #ifdef USE_ETHER_NTOHOST 38943ee2b1SBill Fenner #ifdef HAVE_NETINET_IF_ETHER_H 390e0def19SBill Fenner struct mbuf; /* Squelch compiler warnings on some platforms for */ 400e0def19SBill Fenner struct rtentry; /* declarations in <net/if.h> */ 410e0def19SBill Fenner #include <net/if.h> /* for "struct ifnet" in "struct arpcom" on Solaris */ 42943ee2b1SBill Fenner #include <netinet/if_ether.h> 430e0def19SBill Fenner #endif /* HAVE_NETINET_IF_ETHER_H */ 44c1ad1296SSam Leffler #ifdef NETINET_ETHER_H_DECLARES_ETHER_NTOHOST 45c1ad1296SSam Leffler #include <netinet/ether.h> 46c1ad1296SSam Leffler #endif /* NETINET_ETHER_H_DECLARES_ETHER_NTOHOST */ 470e0def19SBill Fenner #endif /* USE_ETHER_NTOHOST */ 48a88113a8SBill Fenner 49c1ad1296SSam Leffler #if !defined(HAVE_DECL_ETHER_NTOHOST) || !HAVE_DECL_ETHER_NTOHOST 50c1ad1296SSam Leffler extern int ether_ntohost(char *, const struct ether_addr *); 51c1ad1296SSam Leffler #endif 52c1ad1296SSam Leffler 534edb46e9SPaul Traina #include <pcap.h> 544edb46e9SPaul Traina #include <pcap-namedb.h> 554edb46e9SPaul Traina #include <signal.h> 564edb46e9SPaul Traina #include <stdio.h> 574edb46e9SPaul Traina #include <string.h> 584edb46e9SPaul Traina #include <stdlib.h> 594edb46e9SPaul Traina 604edb46e9SPaul Traina #include "interface.h" 614edb46e9SPaul Traina #include "addrtoname.h" 624edb46e9SPaul Traina #include "llc.h" 63699fc314SBill Fenner #include "setsignal.h" 644edb46e9SPaul Traina 654edb46e9SPaul Traina /* 664edb46e9SPaul Traina * hash tables for whatever-to-name translations 67cc391cceSBruce M Simpson * 68cc391cceSBruce M Simpson * XXX there has to be error checks against strdup(3) failure 694edb46e9SPaul Traina */ 704edb46e9SPaul Traina 714edb46e9SPaul Traina #define HASHNAMESIZE 4096 724edb46e9SPaul Traina 734edb46e9SPaul Traina struct hnamemem { 744edb46e9SPaul Traina u_int32_t addr; 75a1c2090eSBill Fenner const char *name; 764edb46e9SPaul Traina struct hnamemem *nxt; 774edb46e9SPaul Traina }; 784edb46e9SPaul Traina 794edb46e9SPaul Traina struct hnamemem hnametable[HASHNAMESIZE]; 804edb46e9SPaul Traina struct hnamemem tporttable[HASHNAMESIZE]; 814edb46e9SPaul Traina struct hnamemem uporttable[HASHNAMESIZE]; 824edb46e9SPaul Traina struct hnamemem eprototable[HASHNAMESIZE]; 834edb46e9SPaul Traina struct hnamemem dnaddrtable[HASHNAMESIZE]; 844edb46e9SPaul Traina struct hnamemem llcsaptable[HASHNAMESIZE]; 85cc391cceSBruce M Simpson struct hnamemem ipxsaptable[HASHNAMESIZE]; 86cc391cceSBruce M Simpson 87cc391cceSBruce M Simpson #if defined(INET6) && defined(WIN32) 88cc391cceSBruce M Simpson /* 89cc391cceSBruce M Simpson * fake gethostbyaddr for Win2k/XP 90cc391cceSBruce M Simpson * gethostbyaddr() returns incorrect value when AF_INET6 is passed 91cc391cceSBruce M Simpson * to 3rd argument. 92cc391cceSBruce M Simpson * 93cc391cceSBruce M Simpson * h_name in struct hostent is only valid. 94cc391cceSBruce M Simpson */ 95cc391cceSBruce M Simpson static struct hostent * 96cc391cceSBruce M Simpson win32_gethostbyaddr(const char *addr, int len, int type) 97cc391cceSBruce M Simpson { 98cc391cceSBruce M Simpson static struct hostent host; 99cc391cceSBruce M Simpson static char hostbuf[NI_MAXHOST]; 100cc391cceSBruce M Simpson char hname[NI_MAXHOST]; 101cc391cceSBruce M Simpson struct sockaddr_in6 addr6; 102cc391cceSBruce M Simpson 103cc391cceSBruce M Simpson host.h_name = hostbuf; 104cc391cceSBruce M Simpson switch (type) { 105cc391cceSBruce M Simpson case AF_INET: 106cc391cceSBruce M Simpson return gethostbyaddr(addr, len, type); 107cc391cceSBruce M Simpson break; 108cc391cceSBruce M Simpson case AF_INET6: 109cc391cceSBruce M Simpson memset(&addr6, 0, sizeof(addr6)); 110cc391cceSBruce M Simpson addr6.sin6_family = AF_INET6; 111cc391cceSBruce M Simpson memcpy(&addr6.sin6_addr, addr, len); 112cc391cceSBruce M Simpson if (getnameinfo((struct sockaddr *)&addr6, sizeof(addr6), 113cc391cceSBruce M Simpson hname, sizeof(hname), NULL, 0, 0)) { 114cc391cceSBruce M Simpson return NULL; 115cc391cceSBruce M Simpson } else { 116cc391cceSBruce M Simpson strcpy(host.h_name, hname); 117cc391cceSBruce M Simpson return &host; 118cc391cceSBruce M Simpson } 119cc391cceSBruce M Simpson break; 120cc391cceSBruce M Simpson default: 121cc391cceSBruce M Simpson return NULL; 122cc391cceSBruce M Simpson } 123cc391cceSBruce M Simpson } 124cc391cceSBruce M Simpson #define gethostbyaddr win32_gethostbyaddr 125cc391cceSBruce M Simpson #endif /* INET6 & WIN32 */ 1264edb46e9SPaul Traina 127a88113a8SBill Fenner #ifdef INET6 128a88113a8SBill Fenner struct h6namemem { 129a88113a8SBill Fenner struct in6_addr addr; 130a88113a8SBill Fenner char *name; 131a88113a8SBill Fenner struct h6namemem *nxt; 132a88113a8SBill Fenner }; 133a88113a8SBill Fenner 134a88113a8SBill Fenner struct h6namemem h6nametable[HASHNAMESIZE]; 135a88113a8SBill Fenner #endif /* INET6 */ 136a88113a8SBill Fenner 1374edb46e9SPaul Traina struct enamemem { 1384edb46e9SPaul Traina u_short e_addr0; 1394edb46e9SPaul Traina u_short e_addr1; 1404edb46e9SPaul Traina u_short e_addr2; 141a1c2090eSBill Fenner const char *e_name; 1424edb46e9SPaul Traina u_char *e_nsap; /* used only for nsaptable[] */ 143a1c2090eSBill Fenner #define e_bs e_nsap /* for bytestringtable */ 1444edb46e9SPaul Traina struct enamemem *e_nxt; 1454edb46e9SPaul Traina }; 1464edb46e9SPaul Traina 1474edb46e9SPaul Traina struct enamemem enametable[HASHNAMESIZE]; 1484edb46e9SPaul Traina struct enamemem nsaptable[HASHNAMESIZE]; 149a1c2090eSBill Fenner struct enamemem bytestringtable[HASHNAMESIZE]; 1504edb46e9SPaul Traina 1514edb46e9SPaul Traina struct protoidmem { 1524edb46e9SPaul Traina u_int32_t p_oui; 1534edb46e9SPaul Traina u_short p_proto; 154a1c2090eSBill Fenner const char *p_name; 1554edb46e9SPaul Traina struct protoidmem *p_nxt; 1564edb46e9SPaul Traina }; 1574edb46e9SPaul Traina 1584edb46e9SPaul Traina struct protoidmem protoidtable[HASHNAMESIZE]; 1594edb46e9SPaul Traina 1604edb46e9SPaul Traina /* 1614edb46e9SPaul Traina * A faster replacement for inet_ntoa(). 1624edb46e9SPaul Traina */ 163a1c2090eSBill Fenner const char * 1644edb46e9SPaul Traina intoa(u_int32_t addr) 1654edb46e9SPaul Traina { 1664edb46e9SPaul Traina register char *cp; 1674edb46e9SPaul Traina register u_int byte; 1684edb46e9SPaul Traina register int n; 1694edb46e9SPaul Traina static char buf[sizeof(".xxx.xxx.xxx.xxx")]; 1704edb46e9SPaul Traina 1714edb46e9SPaul Traina NTOHL(addr); 1724edb46e9SPaul Traina cp = &buf[sizeof buf]; 1734edb46e9SPaul Traina *--cp = '\0'; 1744edb46e9SPaul Traina 1754edb46e9SPaul Traina n = 4; 1764edb46e9SPaul Traina do { 1774edb46e9SPaul Traina byte = addr & 0xff; 1784edb46e9SPaul Traina *--cp = byte % 10 + '0'; 1794edb46e9SPaul Traina byte /= 10; 1804edb46e9SPaul Traina if (byte > 0) { 1814edb46e9SPaul Traina *--cp = byte % 10 + '0'; 1824edb46e9SPaul Traina byte /= 10; 1834edb46e9SPaul Traina if (byte > 0) 1844edb46e9SPaul Traina *--cp = byte + '0'; 1854edb46e9SPaul Traina } 1864edb46e9SPaul Traina *--cp = '.'; 1874edb46e9SPaul Traina addr >>= 8; 1884edb46e9SPaul Traina } while (--n > 0); 1894edb46e9SPaul Traina 1904edb46e9SPaul Traina return cp + 1; 1914edb46e9SPaul Traina } 1924edb46e9SPaul Traina 1934edb46e9SPaul Traina static u_int32_t f_netmask; 1944edb46e9SPaul Traina static u_int32_t f_localnet; 1954edb46e9SPaul Traina 1964edb46e9SPaul Traina /* 1974edb46e9SPaul Traina * Return a name for the IP address pointed to by ap. This address 1984edb46e9SPaul Traina * is assumed to be in network byte order. 199cc391cceSBruce M Simpson * 200cc391cceSBruce M Simpson * NOTE: ap is *NOT* necessarily part of the packet data (not even if 201cc391cceSBruce M Simpson * this is being called with the "ipaddr_string()" macro), so you 202cc391cceSBruce M Simpson * *CANNOT* use the TCHECK{2}/TTEST{2} macros on it. Furthermore, 203cc391cceSBruce M Simpson * even in cases where it *is* part of the packet data, the caller 204cc391cceSBruce M Simpson * would still have to check for a null return value, even if it's 205cc391cceSBruce M Simpson * just printing the return value with "%s" - not all versions of 206cc391cceSBruce M Simpson * printf print "(null)" with "%s" and a null pointer, some of them 207cc391cceSBruce M Simpson * don't check for a null pointer and crash in that case. 208cc391cceSBruce M Simpson * 209cc391cceSBruce M Simpson * The callers of this routine should, before handing this routine 210cc391cceSBruce M Simpson * a pointer to packet data, be sure that the data is present in 211cc391cceSBruce M Simpson * the packet buffer. They should probably do those checks anyway, 212cc391cceSBruce M Simpson * as other data at that layer might not be IP addresses, and it 213cc391cceSBruce M Simpson * also needs to check whether they're present in the packet buffer. 2144edb46e9SPaul Traina */ 215a1c2090eSBill Fenner const char * 2164edb46e9SPaul Traina getname(const u_char *ap) 2174edb46e9SPaul Traina { 2184edb46e9SPaul Traina register struct hostent *hp; 2194edb46e9SPaul Traina u_int32_t addr; 2204edb46e9SPaul Traina static struct hnamemem *p; /* static for longjmp() */ 2214edb46e9SPaul Traina 222a88113a8SBill Fenner memcpy(&addr, ap, sizeof(addr)); 2234edb46e9SPaul Traina p = &hnametable[addr & (HASHNAMESIZE-1)]; 2244edb46e9SPaul Traina for (; p->nxt; p = p->nxt) { 2254edb46e9SPaul Traina if (p->addr == addr) 2264edb46e9SPaul Traina return (p->name); 2274edb46e9SPaul Traina } 2284edb46e9SPaul Traina p->addr = addr; 2294edb46e9SPaul Traina p->nxt = newhnamemem(); 2304edb46e9SPaul Traina 2314edb46e9SPaul Traina /* 232cc391cceSBruce M Simpson * Print names unless: 233cc391cceSBruce M Simpson * (1) -n was given. 234699fc314SBill Fenner * (2) Address is foreign and -f was given. (If -f was not 235cc391cceSBruce M Simpson * given, f_netmask and f_localnet are 0 and the test 236699fc314SBill Fenner * evaluates to true) 2374edb46e9SPaul Traina */ 238699fc314SBill Fenner if (!nflag && 239cc391cceSBruce M Simpson (addr & f_netmask) == f_localnet) { 2404edb46e9SPaul Traina hp = gethostbyaddr((char *)&addr, 4, AF_INET); 2414edb46e9SPaul Traina if (hp) { 2424edb46e9SPaul Traina char *dotp; 2434edb46e9SPaul Traina 244a1c2090eSBill Fenner p->name = strdup(hp->h_name); 2454edb46e9SPaul Traina if (Nflag) { 2464edb46e9SPaul Traina /* Remove domain qualifications */ 2474edb46e9SPaul Traina dotp = strchr(p->name, '.'); 2484edb46e9SPaul Traina if (dotp) 2494edb46e9SPaul Traina *dotp = '\0'; 2504edb46e9SPaul Traina } 2514edb46e9SPaul Traina return (p->name); 2524edb46e9SPaul Traina } 2534edb46e9SPaul Traina } 254a1c2090eSBill Fenner p->name = strdup(intoa(addr)); 2554edb46e9SPaul Traina return (p->name); 2564edb46e9SPaul Traina } 2574edb46e9SPaul Traina 258a88113a8SBill Fenner #ifdef INET6 259a88113a8SBill Fenner /* 260a88113a8SBill Fenner * Return a name for the IP6 address pointed to by ap. This address 261a88113a8SBill Fenner * is assumed to be in network byte order. 262a88113a8SBill Fenner */ 263a1c2090eSBill Fenner const char * 264a88113a8SBill Fenner getname6(const u_char *ap) 265a88113a8SBill Fenner { 266a88113a8SBill Fenner register struct hostent *hp; 267a88113a8SBill Fenner struct in6_addr addr; 268a88113a8SBill Fenner static struct h6namemem *p; /* static for longjmp() */ 269a1c2090eSBill Fenner register const char *cp; 270a88113a8SBill Fenner char ntop_buf[INET6_ADDRSTRLEN]; 271a88113a8SBill Fenner 272a88113a8SBill Fenner memcpy(&addr, ap, sizeof(addr)); 273a88113a8SBill Fenner p = &h6nametable[*(u_int16_t *)&addr.s6_addr[14] & (HASHNAMESIZE-1)]; 274a88113a8SBill Fenner for (; p->nxt; p = p->nxt) { 275a88113a8SBill Fenner if (memcmp(&p->addr, &addr, sizeof(addr)) == 0) 276a88113a8SBill Fenner return (p->name); 277a88113a8SBill Fenner } 278a88113a8SBill Fenner p->addr = addr; 279a88113a8SBill Fenner p->nxt = newh6namemem(); 280a88113a8SBill Fenner 281a88113a8SBill Fenner /* 282cc391cceSBruce M Simpson * Do not print names if -n was given. 283a88113a8SBill Fenner */ 284cc391cceSBruce M Simpson if (!nflag) { 285a88113a8SBill Fenner hp = gethostbyaddr((char *)&addr, sizeof(addr), AF_INET6); 286a88113a8SBill Fenner if (hp) { 287a88113a8SBill Fenner char *dotp; 288a88113a8SBill Fenner 289a1c2090eSBill Fenner p->name = strdup(hp->h_name); 290a88113a8SBill Fenner if (Nflag) { 291a88113a8SBill Fenner /* Remove domain qualifications */ 292a88113a8SBill Fenner dotp = strchr(p->name, '.'); 293a88113a8SBill Fenner if (dotp) 294a88113a8SBill Fenner *dotp = '\0'; 295a88113a8SBill Fenner } 296a88113a8SBill Fenner return (p->name); 297a88113a8SBill Fenner } 298a88113a8SBill Fenner } 299a1c2090eSBill Fenner cp = inet_ntop(AF_INET6, &addr, ntop_buf, sizeof(ntop_buf)); 300a1c2090eSBill Fenner p->name = strdup(cp); 301a88113a8SBill Fenner return (p->name); 302a88113a8SBill Fenner } 303a88113a8SBill Fenner #endif /* INET6 */ 304a88113a8SBill Fenner 3054edb46e9SPaul Traina static char hex[] = "0123456789abcdef"; 3064edb46e9SPaul Traina 3074edb46e9SPaul Traina 3084edb46e9SPaul Traina /* Find the hash node that corresponds the ether address 'ep' */ 3094edb46e9SPaul Traina 3104edb46e9SPaul Traina static inline struct enamemem * 3114edb46e9SPaul Traina lookup_emem(const u_char *ep) 3124edb46e9SPaul Traina { 3134edb46e9SPaul Traina register u_int i, j, k; 3144edb46e9SPaul Traina struct enamemem *tp; 3154edb46e9SPaul Traina 3164edb46e9SPaul Traina k = (ep[0] << 8) | ep[1]; 3174edb46e9SPaul Traina j = (ep[2] << 8) | ep[3]; 3184edb46e9SPaul Traina i = (ep[4] << 8) | ep[5]; 3194edb46e9SPaul Traina 3204edb46e9SPaul Traina tp = &enametable[(i ^ j) & (HASHNAMESIZE-1)]; 3214edb46e9SPaul Traina while (tp->e_nxt) 3224edb46e9SPaul Traina if (tp->e_addr0 == i && 3234edb46e9SPaul Traina tp->e_addr1 == j && 3244edb46e9SPaul Traina tp->e_addr2 == k) 3254edb46e9SPaul Traina return tp; 3264edb46e9SPaul Traina else 3274edb46e9SPaul Traina tp = tp->e_nxt; 3284edb46e9SPaul Traina tp->e_addr0 = i; 3294edb46e9SPaul Traina tp->e_addr1 = j; 3304edb46e9SPaul Traina tp->e_addr2 = k; 3314edb46e9SPaul Traina tp->e_nxt = (struct enamemem *)calloc(1, sizeof(*tp)); 3324edb46e9SPaul Traina if (tp->e_nxt == NULL) 3334edb46e9SPaul Traina error("lookup_emem: calloc"); 3344edb46e9SPaul Traina 3354edb46e9SPaul Traina return tp; 3364edb46e9SPaul Traina } 3374edb46e9SPaul Traina 338a1c2090eSBill Fenner /* 339a1c2090eSBill Fenner * Find the hash node that corresponds to the bytestring 'bs' 340a1c2090eSBill Fenner * with length 'nlen' 341a1c2090eSBill Fenner */ 342a1c2090eSBill Fenner 343a1c2090eSBill Fenner static inline struct enamemem * 344a1c2090eSBill Fenner lookup_bytestring(register const u_char *bs, const unsigned int nlen) 345a1c2090eSBill Fenner { 346a1c2090eSBill Fenner struct enamemem *tp; 347a1c2090eSBill Fenner register u_int i, j, k; 348a1c2090eSBill Fenner 349a1c2090eSBill Fenner if (nlen >= 6) { 350a1c2090eSBill Fenner k = (bs[0] << 8) | bs[1]; 351a1c2090eSBill Fenner j = (bs[2] << 8) | bs[3]; 352a1c2090eSBill Fenner i = (bs[4] << 8) | bs[5]; 353a1c2090eSBill Fenner } else if (nlen >= 4) { 354a1c2090eSBill Fenner k = (bs[0] << 8) | bs[1]; 355a1c2090eSBill Fenner j = (bs[2] << 8) | bs[3]; 356a1c2090eSBill Fenner i = 0; 357a1c2090eSBill Fenner } else 358a1c2090eSBill Fenner i = j = k = 0; 359a1c2090eSBill Fenner 360a1c2090eSBill Fenner tp = &bytestringtable[(i ^ j) & (HASHNAMESIZE-1)]; 361a1c2090eSBill Fenner while (tp->e_nxt) 362a1c2090eSBill Fenner if (tp->e_addr0 == i && 363a1c2090eSBill Fenner tp->e_addr1 == j && 364a1c2090eSBill Fenner tp->e_addr2 == k && 365a1c2090eSBill Fenner memcmp((const char *)bs, (const char *)(tp->e_bs), nlen) == 0) 366a1c2090eSBill Fenner return tp; 367a1c2090eSBill Fenner else 368a1c2090eSBill Fenner tp = tp->e_nxt; 369a1c2090eSBill Fenner 370a1c2090eSBill Fenner tp->e_addr0 = i; 371a1c2090eSBill Fenner tp->e_addr1 = j; 372a1c2090eSBill Fenner tp->e_addr2 = k; 373a1c2090eSBill Fenner 374a1c2090eSBill Fenner tp->e_bs = (u_char *) calloc(1, nlen + 1); 375a1c2090eSBill Fenner memcpy(tp->e_bs, bs, nlen); 376a1c2090eSBill Fenner tp->e_nxt = (struct enamemem *)calloc(1, sizeof(*tp)); 377a1c2090eSBill Fenner if (tp->e_nxt == NULL) 378a1c2090eSBill Fenner error("lookup_bytestring: calloc"); 379a1c2090eSBill Fenner 380a1c2090eSBill Fenner return tp; 381a1c2090eSBill Fenner } 382a1c2090eSBill Fenner 3834edb46e9SPaul Traina /* Find the hash node that corresponds the NSAP 'nsap' */ 3844edb46e9SPaul Traina 3854edb46e9SPaul Traina static inline struct enamemem * 3864edb46e9SPaul Traina lookup_nsap(register const u_char *nsap) 3874edb46e9SPaul Traina { 3884edb46e9SPaul Traina register u_int i, j, k; 389a1c2090eSBill Fenner unsigned int nlen = *nsap; 3904edb46e9SPaul Traina struct enamemem *tp; 3914edb46e9SPaul Traina const u_char *ensap = nsap + nlen - 6; 3924edb46e9SPaul Traina 3934edb46e9SPaul Traina if (nlen > 6) { 3944edb46e9SPaul Traina k = (ensap[0] << 8) | ensap[1]; 3954edb46e9SPaul Traina j = (ensap[2] << 8) | ensap[3]; 3964edb46e9SPaul Traina i = (ensap[4] << 8) | ensap[5]; 3974edb46e9SPaul Traina } 3984edb46e9SPaul Traina else 3994edb46e9SPaul Traina i = j = k = 0; 4004edb46e9SPaul Traina 4014edb46e9SPaul Traina tp = &nsaptable[(i ^ j) & (HASHNAMESIZE-1)]; 4024edb46e9SPaul Traina while (tp->e_nxt) 4034edb46e9SPaul Traina if (tp->e_addr0 == i && 4044edb46e9SPaul Traina tp->e_addr1 == j && 4054edb46e9SPaul Traina tp->e_addr2 == k && 4064edb46e9SPaul Traina tp->e_nsap[0] == nlen && 407a1c2090eSBill Fenner memcmp((const char *)&(nsap[1]), 4084edb46e9SPaul Traina (char *)&(tp->e_nsap[1]), nlen) == 0) 4094edb46e9SPaul Traina return tp; 4104edb46e9SPaul Traina else 4114edb46e9SPaul Traina tp = tp->e_nxt; 4124edb46e9SPaul Traina tp->e_addr0 = i; 4134edb46e9SPaul Traina tp->e_addr1 = j; 4144edb46e9SPaul Traina tp->e_addr2 = k; 4154edb46e9SPaul Traina tp->e_nsap = (u_char *)malloc(nlen + 1); 4164edb46e9SPaul Traina if (tp->e_nsap == NULL) 4174edb46e9SPaul Traina error("lookup_nsap: malloc"); 418a1c2090eSBill Fenner memcpy((char *)tp->e_nsap, (const char *)nsap, nlen + 1); 4194edb46e9SPaul Traina tp->e_nxt = (struct enamemem *)calloc(1, sizeof(*tp)); 4204edb46e9SPaul Traina if (tp->e_nxt == NULL) 4214edb46e9SPaul Traina error("lookup_nsap: calloc"); 4224edb46e9SPaul Traina 4234edb46e9SPaul Traina return tp; 4244edb46e9SPaul Traina } 4254edb46e9SPaul Traina 4264edb46e9SPaul Traina /* Find the hash node that corresponds the protoid 'pi'. */ 4274edb46e9SPaul Traina 4284edb46e9SPaul Traina static inline struct protoidmem * 4294edb46e9SPaul Traina lookup_protoid(const u_char *pi) 4304edb46e9SPaul Traina { 4314edb46e9SPaul Traina register u_int i, j; 4324edb46e9SPaul Traina struct protoidmem *tp; 4334edb46e9SPaul Traina 4344edb46e9SPaul Traina /* 5 octets won't be aligned */ 4354edb46e9SPaul Traina i = (((pi[0] << 8) + pi[1]) << 8) + pi[2]; 4364edb46e9SPaul Traina j = (pi[3] << 8) + pi[4]; 4374edb46e9SPaul Traina /* XXX should be endian-insensitive, but do big-endian testing XXX */ 4384edb46e9SPaul Traina 4394edb46e9SPaul Traina tp = &protoidtable[(i ^ j) & (HASHNAMESIZE-1)]; 4404edb46e9SPaul Traina while (tp->p_nxt) 4414edb46e9SPaul Traina if (tp->p_oui == i && tp->p_proto == j) 4424edb46e9SPaul Traina return tp; 4434edb46e9SPaul Traina else 4444edb46e9SPaul Traina tp = tp->p_nxt; 4454edb46e9SPaul Traina tp->p_oui = i; 4464edb46e9SPaul Traina tp->p_proto = j; 4474edb46e9SPaul Traina tp->p_nxt = (struct protoidmem *)calloc(1, sizeof(*tp)); 4484edb46e9SPaul Traina if (tp->p_nxt == NULL) 4494edb46e9SPaul Traina error("lookup_protoid: calloc"); 4504edb46e9SPaul Traina 4514edb46e9SPaul Traina return tp; 4524edb46e9SPaul Traina } 4534edb46e9SPaul Traina 454a1c2090eSBill Fenner const char * 4554edb46e9SPaul Traina etheraddr_string(register const u_char *ep) 4564edb46e9SPaul Traina { 457cc391cceSBruce M Simpson register u_int i; 4584edb46e9SPaul Traina register char *cp; 4594edb46e9SPaul Traina register struct enamemem *tp; 4604edb46e9SPaul Traina char buf[sizeof("00:00:00:00:00:00")]; 4614edb46e9SPaul Traina 4624edb46e9SPaul Traina tp = lookup_emem(ep); 4634edb46e9SPaul Traina if (tp->e_name) 4644edb46e9SPaul Traina return (tp->e_name); 465a1c2090eSBill Fenner #ifdef USE_ETHER_NTOHOST 4664edb46e9SPaul Traina if (!nflag) { 467cc391cceSBruce M Simpson char buf2[128]; 468c1ad1296SSam Leffler 469c1ad1296SSam Leffler /* 470c1ad1296SSam Leffler * We don't cast it to "const struct ether_addr *" 471c1ad1296SSam Leffler * because some systems don't modify the Ethernet 472c1ad1296SSam Leffler * address but fail to declare the second argument 473c1ad1296SSam Leffler * as a "const" pointer. 474c1ad1296SSam Leffler */ 475c1ad1296SSam Leffler if (ether_ntohost(buf2, (struct ether_addr *)ep) == 0) { 476cc391cceSBruce M Simpson tp->e_name = strdup(buf2); 4774edb46e9SPaul Traina return (tp->e_name); 4784edb46e9SPaul Traina } 4794edb46e9SPaul Traina } 4804edb46e9SPaul Traina #endif 4814edb46e9SPaul Traina cp = buf; 482cc391cceSBruce M Simpson *cp++ = hex[*ep >> 4 ]; 4834edb46e9SPaul Traina *cp++ = hex[*ep++ & 0xf]; 4844edb46e9SPaul Traina for (i = 5; (int)--i >= 0;) { 4854edb46e9SPaul Traina *cp++ = ':'; 486cc391cceSBruce M Simpson *cp++ = hex[*ep >> 4 ]; 4874edb46e9SPaul Traina *cp++ = hex[*ep++ & 0xf]; 4884edb46e9SPaul Traina } 4894edb46e9SPaul Traina *cp = '\0'; 490a1c2090eSBill Fenner tp->e_name = strdup(buf); 4914edb46e9SPaul Traina return (tp->e_name); 4924edb46e9SPaul Traina } 4934edb46e9SPaul Traina 494a1c2090eSBill Fenner const char * 495a1c2090eSBill Fenner linkaddr_string(const u_char *ep, const unsigned int len) 496a1c2090eSBill Fenner { 497c1ad1296SSam Leffler register u_int i; 498a1c2090eSBill Fenner register char *cp; 499a1c2090eSBill Fenner register struct enamemem *tp; 500a1c2090eSBill Fenner 501a1c2090eSBill Fenner if (len == 6) /* XXX not totally correct... */ 502a1c2090eSBill Fenner return etheraddr_string(ep); 503a1c2090eSBill Fenner 504a1c2090eSBill Fenner tp = lookup_bytestring(ep, len); 505a1c2090eSBill Fenner if (tp->e_name) 506a1c2090eSBill Fenner return (tp->e_name); 507a1c2090eSBill Fenner 508a1c2090eSBill Fenner tp->e_name = cp = (char *)malloc(len*3); 509a1c2090eSBill Fenner if (tp->e_name == NULL) 510a1c2090eSBill Fenner error("linkaddr_string: malloc"); 511c1ad1296SSam Leffler *cp++ = hex[*ep >> 4]; 512a1c2090eSBill Fenner *cp++ = hex[*ep++ & 0xf]; 513a1c2090eSBill Fenner for (i = len-1; i > 0 ; --i) { 514a1c2090eSBill Fenner *cp++ = ':'; 515c1ad1296SSam Leffler *cp++ = hex[*ep >> 4]; 516a1c2090eSBill Fenner *cp++ = hex[*ep++ & 0xf]; 517a1c2090eSBill Fenner } 518a1c2090eSBill Fenner *cp = '\0'; 519a1c2090eSBill Fenner return (tp->e_name); 520a1c2090eSBill Fenner } 521a1c2090eSBill Fenner 522a1c2090eSBill Fenner const char * 5234edb46e9SPaul Traina etherproto_string(u_short port) 5244edb46e9SPaul Traina { 5254edb46e9SPaul Traina register char *cp; 5264edb46e9SPaul Traina register struct hnamemem *tp; 5274edb46e9SPaul Traina register u_int32_t i = port; 5284edb46e9SPaul Traina char buf[sizeof("0000")]; 5294edb46e9SPaul Traina 5304edb46e9SPaul Traina for (tp = &eprototable[i & (HASHNAMESIZE-1)]; tp->nxt; tp = tp->nxt) 5314edb46e9SPaul Traina if (tp->addr == i) 5324edb46e9SPaul Traina return (tp->name); 5334edb46e9SPaul Traina 5344edb46e9SPaul Traina tp->addr = i; 5354edb46e9SPaul Traina tp->nxt = newhnamemem(); 5364edb46e9SPaul Traina 5374edb46e9SPaul Traina cp = buf; 5384edb46e9SPaul Traina NTOHS(port); 5394edb46e9SPaul Traina *cp++ = hex[port >> 12 & 0xf]; 5404edb46e9SPaul Traina *cp++ = hex[port >> 8 & 0xf]; 5414edb46e9SPaul Traina *cp++ = hex[port >> 4 & 0xf]; 5424edb46e9SPaul Traina *cp++ = hex[port & 0xf]; 5434edb46e9SPaul Traina *cp++ = '\0'; 544a1c2090eSBill Fenner tp->name = strdup(buf); 5454edb46e9SPaul Traina return (tp->name); 5464edb46e9SPaul Traina } 5474edb46e9SPaul Traina 548a1c2090eSBill Fenner const char * 5494edb46e9SPaul Traina protoid_string(register const u_char *pi) 5504edb46e9SPaul Traina { 5514edb46e9SPaul Traina register u_int i, j; 5524edb46e9SPaul Traina register char *cp; 5534edb46e9SPaul Traina register struct protoidmem *tp; 5544edb46e9SPaul Traina char buf[sizeof("00:00:00:00:00")]; 5554edb46e9SPaul Traina 5564edb46e9SPaul Traina tp = lookup_protoid(pi); 5574edb46e9SPaul Traina if (tp->p_name) 5584edb46e9SPaul Traina return tp->p_name; 5594edb46e9SPaul Traina 5604edb46e9SPaul Traina cp = buf; 5614edb46e9SPaul Traina if ((j = *pi >> 4) != 0) 5624edb46e9SPaul Traina *cp++ = hex[j]; 5634edb46e9SPaul Traina *cp++ = hex[*pi++ & 0xf]; 5644edb46e9SPaul Traina for (i = 4; (int)--i >= 0;) { 5654edb46e9SPaul Traina *cp++ = ':'; 5664edb46e9SPaul Traina if ((j = *pi >> 4) != 0) 5674edb46e9SPaul Traina *cp++ = hex[j]; 5684edb46e9SPaul Traina *cp++ = hex[*pi++ & 0xf]; 5694edb46e9SPaul Traina } 5704edb46e9SPaul Traina *cp = '\0'; 571a1c2090eSBill Fenner tp->p_name = strdup(buf); 5724edb46e9SPaul Traina return (tp->p_name); 5734edb46e9SPaul Traina } 5744edb46e9SPaul Traina 575a1c2090eSBill Fenner const char * 5764edb46e9SPaul Traina llcsap_string(u_char sap) 5774edb46e9SPaul Traina { 5784edb46e9SPaul Traina register struct hnamemem *tp; 5794edb46e9SPaul Traina register u_int32_t i = sap; 5804edb46e9SPaul Traina char buf[sizeof("sap 00")]; 5814edb46e9SPaul Traina 5824edb46e9SPaul Traina for (tp = &llcsaptable[i & (HASHNAMESIZE-1)]; tp->nxt; tp = tp->nxt) 5834edb46e9SPaul Traina if (tp->addr == i) 5844edb46e9SPaul Traina return (tp->name); 5854edb46e9SPaul Traina 5864edb46e9SPaul Traina tp->addr = i; 5874edb46e9SPaul Traina tp->nxt = newhnamemem(); 5884edb46e9SPaul Traina 589943ee2b1SBill Fenner snprintf(buf, sizeof(buf), "sap %02x", sap & 0xff); 590a1c2090eSBill Fenner tp->name = strdup(buf); 5914edb46e9SPaul Traina return (tp->name); 5924edb46e9SPaul Traina } 5934edb46e9SPaul Traina 594c1ad1296SSam Leffler #define ISONSAP_MAX_LENGTH 20 595a1c2090eSBill Fenner const char * 596c1ad1296SSam Leffler isonsap_string(const u_char *nsap, register u_int nsap_length) 5974edb46e9SPaul Traina { 598c1ad1296SSam Leffler register u_int nsap_idx; 5994edb46e9SPaul Traina register char *cp; 6004edb46e9SPaul Traina register struct enamemem *tp; 6014edb46e9SPaul Traina 602c1ad1296SSam Leffler if (nsap_length < 1 || nsap_length > ISONSAP_MAX_LENGTH) 603c1ad1296SSam Leffler error("isonsap_string: illegal length"); 604c1ad1296SSam Leffler 6054edb46e9SPaul Traina tp = lookup_nsap(nsap); 6064edb46e9SPaul Traina if (tp->e_name) 6074edb46e9SPaul Traina return tp->e_name; 6084edb46e9SPaul Traina 609c1ad1296SSam Leffler tp->e_name = cp = (char *)malloc(sizeof("xx.xxxx.xxxx.xxxx.xxxx.xxxx.xxxx.xxxx.xxxx.xxxx.xx")); 6104edb46e9SPaul Traina if (cp == NULL) 6114edb46e9SPaul Traina error("isonsap_string: malloc"); 6124edb46e9SPaul Traina 613c1ad1296SSam Leffler for (nsap_idx = 0; nsap_idx < nsap_length; nsap_idx++) { 6144edb46e9SPaul Traina *cp++ = hex[*nsap >> 4]; 6154edb46e9SPaul Traina *cp++ = hex[*nsap++ & 0xf]; 616c1ad1296SSam Leffler if (((nsap_idx & 1) == 0) && 617c1ad1296SSam Leffler (nsap_idx + 1 < nsap_length)) { 61801bd0dbcSPaul Traina *cp++ = '.'; 6194edb46e9SPaul Traina } 620c1ad1296SSam Leffler } 6214edb46e9SPaul Traina *cp = '\0'; 6224edb46e9SPaul Traina return (tp->e_name); 6234edb46e9SPaul Traina } 6244edb46e9SPaul Traina 625a1c2090eSBill Fenner const char * 6264edb46e9SPaul Traina tcpport_string(u_short port) 6274edb46e9SPaul Traina { 6284edb46e9SPaul Traina register struct hnamemem *tp; 6294edb46e9SPaul Traina register u_int32_t i = port; 6304edb46e9SPaul Traina char buf[sizeof("00000")]; 6314edb46e9SPaul Traina 6324edb46e9SPaul Traina for (tp = &tporttable[i & (HASHNAMESIZE-1)]; tp->nxt; tp = tp->nxt) 6334edb46e9SPaul Traina if (tp->addr == i) 6344edb46e9SPaul Traina return (tp->name); 6354edb46e9SPaul Traina 6364edb46e9SPaul Traina tp->addr = i; 6374edb46e9SPaul Traina tp->nxt = newhnamemem(); 6384edb46e9SPaul Traina 6397524a079SKris Kennaway (void)snprintf(buf, sizeof(buf), "%u", i); 640a1c2090eSBill Fenner tp->name = strdup(buf); 6414edb46e9SPaul Traina return (tp->name); 6424edb46e9SPaul Traina } 6434edb46e9SPaul Traina 644a1c2090eSBill Fenner const char * 6454edb46e9SPaul Traina udpport_string(register u_short port) 6464edb46e9SPaul Traina { 6474edb46e9SPaul Traina register struct hnamemem *tp; 6484edb46e9SPaul Traina register u_int32_t i = port; 6494edb46e9SPaul Traina char buf[sizeof("00000")]; 6504edb46e9SPaul Traina 6514edb46e9SPaul Traina for (tp = &uporttable[i & (HASHNAMESIZE-1)]; tp->nxt; tp = tp->nxt) 6524edb46e9SPaul Traina if (tp->addr == i) 6534edb46e9SPaul Traina return (tp->name); 6544edb46e9SPaul Traina 6554edb46e9SPaul Traina tp->addr = i; 6564edb46e9SPaul Traina tp->nxt = newhnamemem(); 6574edb46e9SPaul Traina 6587524a079SKris Kennaway (void)snprintf(buf, sizeof(buf), "%u", i); 659a1c2090eSBill Fenner tp->name = strdup(buf); 6604edb46e9SPaul Traina return (tp->name); 6614edb46e9SPaul Traina } 6624edb46e9SPaul Traina 663cc391cceSBruce M Simpson const char * 664cc391cceSBruce M Simpson ipxsap_string(u_short port) 665cc391cceSBruce M Simpson { 666cc391cceSBruce M Simpson register char *cp; 667cc391cceSBruce M Simpson register struct hnamemem *tp; 668cc391cceSBruce M Simpson register u_int32_t i = port; 669cc391cceSBruce M Simpson char buf[sizeof("0000")]; 670cc391cceSBruce M Simpson 671cc391cceSBruce M Simpson for (tp = &ipxsaptable[i & (HASHNAMESIZE-1)]; tp->nxt; tp = tp->nxt) 672cc391cceSBruce M Simpson if (tp->addr == i) 673cc391cceSBruce M Simpson return (tp->name); 674cc391cceSBruce M Simpson 675cc391cceSBruce M Simpson tp->addr = i; 676cc391cceSBruce M Simpson tp->nxt = newhnamemem(); 677cc391cceSBruce M Simpson 678cc391cceSBruce M Simpson cp = buf; 679cc391cceSBruce M Simpson NTOHS(port); 680cc391cceSBruce M Simpson *cp++ = hex[port >> 12 & 0xf]; 681cc391cceSBruce M Simpson *cp++ = hex[port >> 8 & 0xf]; 682cc391cceSBruce M Simpson *cp++ = hex[port >> 4 & 0xf]; 683cc391cceSBruce M Simpson *cp++ = hex[port & 0xf]; 684cc391cceSBruce M Simpson *cp++ = '\0'; 685cc391cceSBruce M Simpson tp->name = strdup(buf); 686cc391cceSBruce M Simpson return (tp->name); 687cc391cceSBruce M Simpson } 688cc391cceSBruce M Simpson 6894edb46e9SPaul Traina static void 6904edb46e9SPaul Traina init_servarray(void) 6914edb46e9SPaul Traina { 6924edb46e9SPaul Traina struct servent *sv; 6934edb46e9SPaul Traina register struct hnamemem *table; 6944edb46e9SPaul Traina register int i; 6954edb46e9SPaul Traina char buf[sizeof("0000000000")]; 6964edb46e9SPaul Traina 6974edb46e9SPaul Traina while ((sv = getservent()) != NULL) { 6984edb46e9SPaul Traina int port = ntohs(sv->s_port); 6994edb46e9SPaul Traina i = port & (HASHNAMESIZE-1); 7004edb46e9SPaul Traina if (strcmp(sv->s_proto, "tcp") == 0) 7014edb46e9SPaul Traina table = &tporttable[i]; 7024edb46e9SPaul Traina else if (strcmp(sv->s_proto, "udp") == 0) 7034edb46e9SPaul Traina table = &uporttable[i]; 7044edb46e9SPaul Traina else 7054edb46e9SPaul Traina continue; 7064edb46e9SPaul Traina 7074edb46e9SPaul Traina while (table->name) 7084edb46e9SPaul Traina table = table->nxt; 7094edb46e9SPaul Traina if (nflag) { 7107524a079SKris Kennaway (void)snprintf(buf, sizeof(buf), "%d", port); 711a1c2090eSBill Fenner table->name = strdup(buf); 7124edb46e9SPaul Traina } else 713a1c2090eSBill Fenner table->name = strdup(sv->s_name); 7144edb46e9SPaul Traina table->addr = port; 7154edb46e9SPaul Traina table->nxt = newhnamemem(); 7164edb46e9SPaul Traina } 7174edb46e9SPaul Traina endservent(); 7184edb46e9SPaul Traina } 7194edb46e9SPaul Traina 720c1ad1296SSam Leffler /* in libpcap.a (nametoaddr.c) */ 721c1ad1296SSam Leffler #if defined(WIN32) && !defined(USE_STATIC_LIBPCAP) 722c1ad1296SSam Leffler __declspec(dllimport) 723cc391cceSBruce M Simpson #else 724c1ad1296SSam Leffler extern 725cc391cceSBruce M Simpson #endif 726c1ad1296SSam Leffler const struct eproto { 727c1ad1296SSam Leffler const char *s; 7284edb46e9SPaul Traina u_short p; 7294edb46e9SPaul Traina } eproto_db[]; 7304edb46e9SPaul Traina 7314edb46e9SPaul Traina static void 7324edb46e9SPaul Traina init_eprotoarray(void) 7334edb46e9SPaul Traina { 7344edb46e9SPaul Traina register int i; 7354edb46e9SPaul Traina register struct hnamemem *table; 7364edb46e9SPaul Traina 7374edb46e9SPaul Traina for (i = 0; eproto_db[i].s; i++) { 738cc391cceSBruce M Simpson int j = htons(eproto_db[i].p) & (HASHNAMESIZE-1); 7394edb46e9SPaul Traina table = &eprototable[j]; 7404edb46e9SPaul Traina while (table->name) 7414edb46e9SPaul Traina table = table->nxt; 7424edb46e9SPaul Traina table->name = eproto_db[i].s; 743cc391cceSBruce M Simpson table->addr = htons(eproto_db[i].p); 7444edb46e9SPaul Traina table->nxt = newhnamemem(); 7454edb46e9SPaul Traina } 7464edb46e9SPaul Traina } 7474edb46e9SPaul Traina 748a1c2090eSBill Fenner static struct protoidlist { 749a1c2090eSBill Fenner const u_char protoid[5]; 750a1c2090eSBill Fenner const char *name; 751a1c2090eSBill Fenner } protoidlist[] = { 752a1c2090eSBill Fenner {{ 0x00, 0x00, 0x0c, 0x01, 0x07 }, "CiscoMLS" }, 753a1c2090eSBill Fenner {{ 0x00, 0x00, 0x0c, 0x20, 0x00 }, "CiscoCDP" }, 754a1c2090eSBill Fenner {{ 0x00, 0x00, 0x0c, 0x20, 0x01 }, "CiscoCGMP" }, 755a1c2090eSBill Fenner {{ 0x00, 0x00, 0x0c, 0x20, 0x03 }, "CiscoVTP" }, 756a1c2090eSBill Fenner {{ 0x00, 0xe0, 0x2b, 0x00, 0xbb }, "ExtremeEDP" }, 757a1c2090eSBill Fenner {{ 0x00, 0x00, 0x00, 0x00, 0x00 }, NULL } 758a1c2090eSBill Fenner }; 759a1c2090eSBill Fenner 7604edb46e9SPaul Traina /* 7614edb46e9SPaul Traina * SNAP proto IDs with org code 0:0:0 are actually encapsulated Ethernet 7624edb46e9SPaul Traina * types. 7634edb46e9SPaul Traina */ 7644edb46e9SPaul Traina static void 7654edb46e9SPaul Traina init_protoidarray(void) 7664edb46e9SPaul Traina { 7674edb46e9SPaul Traina register int i; 7684edb46e9SPaul Traina register struct protoidmem *tp; 769a1c2090eSBill Fenner struct protoidlist *pl; 7704edb46e9SPaul Traina u_char protoid[5]; 7714edb46e9SPaul Traina 7724edb46e9SPaul Traina protoid[0] = 0; 7734edb46e9SPaul Traina protoid[1] = 0; 7744edb46e9SPaul Traina protoid[2] = 0; 7754edb46e9SPaul Traina for (i = 0; eproto_db[i].s; i++) { 7764edb46e9SPaul Traina u_short etype = htons(eproto_db[i].p); 7774edb46e9SPaul Traina 7784edb46e9SPaul Traina memcpy((char *)&protoid[3], (char *)&etype, 2); 7794edb46e9SPaul Traina tp = lookup_protoid(protoid); 780a1c2090eSBill Fenner tp->p_name = strdup(eproto_db[i].s); 781a1c2090eSBill Fenner } 782a1c2090eSBill Fenner /* Hardwire some SNAP proto ID names */ 783a1c2090eSBill Fenner for (pl = protoidlist; pl->name != NULL; ++pl) { 784a1c2090eSBill Fenner tp = lookup_protoid(pl->protoid); 785a1c2090eSBill Fenner /* Don't override existing name */ 786a1c2090eSBill Fenner if (tp->p_name != NULL) 787a1c2090eSBill Fenner continue; 788a1c2090eSBill Fenner 789a1c2090eSBill Fenner tp->p_name = pl->name; 7904edb46e9SPaul Traina } 7914edb46e9SPaul Traina } 7924edb46e9SPaul Traina 7934edb46e9SPaul Traina static struct etherlist { 794a1c2090eSBill Fenner const u_char addr[6]; 795a1c2090eSBill Fenner const char *name; 7964edb46e9SPaul Traina } etherlist[] = { 7974edb46e9SPaul Traina {{ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }, "Broadcast" }, 7984edb46e9SPaul Traina {{ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, NULL } 7994edb46e9SPaul Traina }; 8004edb46e9SPaul Traina 8014edb46e9SPaul Traina /* 8024edb46e9SPaul Traina * Initialize the ethers hash table. We take two different approaches 8034edb46e9SPaul Traina * depending on whether or not the system provides the ethers name 8044edb46e9SPaul Traina * service. If it does, we just wire in a few names at startup, 8054edb46e9SPaul Traina * and etheraddr_string() fills in the table on demand. If it doesn't, 8064edb46e9SPaul Traina * then we suck in the entire /etc/ethers file at startup. The idea 8074edb46e9SPaul Traina * is that parsing the local file will be fast, but spinning through 8084edb46e9SPaul Traina * all the ethers entries via NIS & next_etherent might be very slow. 8094edb46e9SPaul Traina * 8104edb46e9SPaul Traina * XXX pcap_next_etherent doesn't belong in the pcap interface, but 8114edb46e9SPaul Traina * since the pcap module already does name-to-address translation, 8124edb46e9SPaul Traina * it's already does most of the work for the ethernet address-to-name 8134edb46e9SPaul Traina * translation, so we just pcap_next_etherent as a convenience. 8144edb46e9SPaul Traina */ 8154edb46e9SPaul Traina static void 8164edb46e9SPaul Traina init_etherarray(void) 8174edb46e9SPaul Traina { 8184edb46e9SPaul Traina register struct etherlist *el; 8194edb46e9SPaul Traina register struct enamemem *tp; 820a1c2090eSBill Fenner #ifdef USE_ETHER_NTOHOST 8214edb46e9SPaul Traina char name[256]; 8224edb46e9SPaul Traina #else 8234edb46e9SPaul Traina register struct pcap_etherent *ep; 8244edb46e9SPaul Traina register FILE *fp; 8254edb46e9SPaul Traina 8264edb46e9SPaul Traina /* Suck in entire ethers file */ 8274edb46e9SPaul Traina fp = fopen(PCAP_ETHERS_FILE, "r"); 8284edb46e9SPaul Traina if (fp != NULL) { 8294edb46e9SPaul Traina while ((ep = pcap_next_etherent(fp)) != NULL) { 8304edb46e9SPaul Traina tp = lookup_emem(ep->addr); 831a1c2090eSBill Fenner tp->e_name = strdup(ep->name); 8324edb46e9SPaul Traina } 8334edb46e9SPaul Traina (void)fclose(fp); 8344edb46e9SPaul Traina } 8354edb46e9SPaul Traina #endif 8364edb46e9SPaul Traina 8374edb46e9SPaul Traina /* Hardwire some ethernet names */ 8384edb46e9SPaul Traina for (el = etherlist; el->name != NULL; ++el) { 8394edb46e9SPaul Traina tp = lookup_emem(el->addr); 8404edb46e9SPaul Traina /* Don't override existing name */ 8414edb46e9SPaul Traina if (tp->e_name != NULL) 8424edb46e9SPaul Traina continue; 8434edb46e9SPaul Traina 844a1c2090eSBill Fenner #ifdef USE_ETHER_NTOHOST 845c1ad1296SSam Leffler /* 846c1ad1296SSam Leffler * Use YP/NIS version of name if available. 847c1ad1296SSam Leffler * 848c1ad1296SSam Leffler * We don't cast it to "const struct ether_addr *" 849c1ad1296SSam Leffler * because some systems don't modify the Ethernet 850c1ad1296SSam Leffler * address but fail to declare the second argument 851c1ad1296SSam Leffler * as a "const" pointer. 852c1ad1296SSam Leffler */ 853c1ad1296SSam Leffler if (ether_ntohost(name, (struct ether_addr *)el->addr) == 0) { 854a1c2090eSBill Fenner tp->e_name = strdup(name); 8554edb46e9SPaul Traina continue; 8564edb46e9SPaul Traina } 8574edb46e9SPaul Traina #endif 8584edb46e9SPaul Traina tp->e_name = el->name; 8594edb46e9SPaul Traina } 8604edb46e9SPaul Traina } 8614edb46e9SPaul Traina 8624edb46e9SPaul Traina static struct tok llcsap_db[] = { 8634edb46e9SPaul Traina { LLCSAP_NULL, "null" }, 8644edb46e9SPaul Traina { LLCSAP_8021B_I, "802.1b-gsap" }, 8654edb46e9SPaul Traina { LLCSAP_8021B_G, "802.1b-isap" }, 8664edb46e9SPaul Traina { LLCSAP_IP, "ip-sap" }, 8674edb46e9SPaul Traina { LLCSAP_PROWAYNM, "proway-nm" }, 8684edb46e9SPaul Traina { LLCSAP_8021D, "802.1d" }, 8694edb46e9SPaul Traina { LLCSAP_RS511, "eia-rs511" }, 8704edb46e9SPaul Traina { LLCSAP_ISO8208, "x.25/llc2" }, 8714edb46e9SPaul Traina { LLCSAP_PROWAY, "proway" }, 872a1c2090eSBill Fenner { LLCSAP_SNAP, "snap" }, 873a1c2090eSBill Fenner { LLCSAP_IPX, "IPX" }, 874a1c2090eSBill Fenner { LLCSAP_NETBEUI, "netbeui" }, 8754edb46e9SPaul Traina { LLCSAP_ISONS, "iso-clns" }, 8764edb46e9SPaul Traina { LLCSAP_GLOBAL, "global" }, 8774edb46e9SPaul Traina { 0, NULL } 8784edb46e9SPaul Traina }; 8794edb46e9SPaul Traina 8804edb46e9SPaul Traina static void 8814edb46e9SPaul Traina init_llcsaparray(void) 8824edb46e9SPaul Traina { 8834edb46e9SPaul Traina register int i; 8844edb46e9SPaul Traina register struct hnamemem *table; 8854edb46e9SPaul Traina 8864edb46e9SPaul Traina for (i = 0; llcsap_db[i].s != NULL; i++) { 8874edb46e9SPaul Traina table = &llcsaptable[llcsap_db[i].v]; 8884edb46e9SPaul Traina while (table->name) 8894edb46e9SPaul Traina table = table->nxt; 8904edb46e9SPaul Traina table->name = llcsap_db[i].s; 8914edb46e9SPaul Traina table->addr = llcsap_db[i].v; 8924edb46e9SPaul Traina table->nxt = newhnamemem(); 8934edb46e9SPaul Traina } 8944edb46e9SPaul Traina } 8954edb46e9SPaul Traina 896cc391cceSBruce M Simpson static struct tok ipxsap_db[] = { 897cc391cceSBruce M Simpson { 0x0000, "Unknown" }, 898cc391cceSBruce M Simpson { 0x0001, "User" }, 899cc391cceSBruce M Simpson { 0x0002, "User Group" }, 900cc391cceSBruce M Simpson { 0x0003, "PrintQueue" }, 901cc391cceSBruce M Simpson { 0x0004, "FileServer" }, 902cc391cceSBruce M Simpson { 0x0005, "JobServer" }, 903cc391cceSBruce M Simpson { 0x0006, "Gateway" }, 904cc391cceSBruce M Simpson { 0x0007, "PrintServer" }, 905cc391cceSBruce M Simpson { 0x0008, "ArchiveQueue" }, 906cc391cceSBruce M Simpson { 0x0009, "ArchiveServer" }, 907cc391cceSBruce M Simpson { 0x000a, "JobQueue" }, 908cc391cceSBruce M Simpson { 0x000b, "Administration" }, 909cc391cceSBruce M Simpson { 0x000F, "Novell TI-RPC" }, 910cc391cceSBruce M Simpson { 0x0017, "Diagnostics" }, 911cc391cceSBruce M Simpson { 0x0020, "NetBIOS" }, 912cc391cceSBruce M Simpson { 0x0021, "NAS SNA Gateway" }, 913cc391cceSBruce M Simpson { 0x0023, "NACS AsyncGateway" }, 914cc391cceSBruce M Simpson { 0x0024, "RemoteBridge/RoutingService" }, 915cc391cceSBruce M Simpson { 0x0026, "BridgeServer" }, 916cc391cceSBruce M Simpson { 0x0027, "TCP/IP Gateway" }, 917cc391cceSBruce M Simpson { 0x0028, "Point-to-point X.25 BridgeServer" }, 918cc391cceSBruce M Simpson { 0x0029, "3270 Gateway" }, 919cc391cceSBruce M Simpson { 0x002a, "CHI Corp" }, 920cc391cceSBruce M Simpson { 0x002c, "PC Chalkboard" }, 921cc391cceSBruce M Simpson { 0x002d, "TimeSynchServer" }, 922cc391cceSBruce M Simpson { 0x002e, "ARCserve5.0/PalindromeBackup" }, 923cc391cceSBruce M Simpson { 0x0045, "DI3270 Gateway" }, 924cc391cceSBruce M Simpson { 0x0047, "AdvertisingPrintServer" }, 925cc391cceSBruce M Simpson { 0x004a, "NetBlazerModems" }, 926cc391cceSBruce M Simpson { 0x004b, "BtrieveVAP" }, 927cc391cceSBruce M Simpson { 0x004c, "NetwareSQL" }, 928cc391cceSBruce M Simpson { 0x004d, "XtreeNetwork" }, 929cc391cceSBruce M Simpson { 0x0050, "BtrieveVAP4.11" }, 930cc391cceSBruce M Simpson { 0x0052, "QuickLink" }, 931cc391cceSBruce M Simpson { 0x0053, "PrintQueueUser" }, 932cc391cceSBruce M Simpson { 0x0058, "Multipoint X.25 Router" }, 933cc391cceSBruce M Simpson { 0x0060, "STLB/NLM" }, 934cc391cceSBruce M Simpson { 0x0064, "ARCserve" }, 935cc391cceSBruce M Simpson { 0x0066, "ARCserve3.0" }, 936cc391cceSBruce M Simpson { 0x0072, "WAN CopyUtility" }, 937cc391cceSBruce M Simpson { 0x007a, "TES-NetwareVMS" }, 938cc391cceSBruce M Simpson { 0x0092, "WATCOM Debugger/EmeraldTapeBackupServer" }, 939cc391cceSBruce M Simpson { 0x0095, "DDA OBGYN" }, 940cc391cceSBruce M Simpson { 0x0098, "NetwareAccessServer" }, 941cc391cceSBruce M Simpson { 0x009a, "Netware for VMS II/NamedPipeServer" }, 942cc391cceSBruce M Simpson { 0x009b, "NetwareAccessServer" }, 943cc391cceSBruce M Simpson { 0x009e, "PortableNetwareServer/SunLinkNVT" }, 944cc391cceSBruce M Simpson { 0x00a1, "PowerchuteAPC UPS" }, 945cc391cceSBruce M Simpson { 0x00aa, "LAWserve" }, 946cc391cceSBruce M Simpson { 0x00ac, "CompaqIDA StatusMonitor" }, 947cc391cceSBruce M Simpson { 0x0100, "PIPE STAIL" }, 948cc391cceSBruce M Simpson { 0x0102, "LAN ProtectBindery" }, 949cc391cceSBruce M Simpson { 0x0103, "OracleDataBaseServer" }, 950cc391cceSBruce M Simpson { 0x0107, "Netware386/RSPX RemoteConsole" }, 951cc391cceSBruce M Simpson { 0x010f, "NovellSNA Gateway" }, 952cc391cceSBruce M Simpson { 0x0111, "TestServer" }, 953cc391cceSBruce M Simpson { 0x0112, "HP PrintServer" }, 954cc391cceSBruce M Simpson { 0x0114, "CSA MUX" }, 955cc391cceSBruce M Simpson { 0x0115, "CSA LCA" }, 956cc391cceSBruce M Simpson { 0x0116, "CSA CM" }, 957cc391cceSBruce M Simpson { 0x0117, "CSA SMA" }, 958cc391cceSBruce M Simpson { 0x0118, "CSA DBA" }, 959cc391cceSBruce M Simpson { 0x0119, "CSA NMA" }, 960cc391cceSBruce M Simpson { 0x011a, "CSA SSA" }, 961cc391cceSBruce M Simpson { 0x011b, "CSA STATUS" }, 962cc391cceSBruce M Simpson { 0x011e, "CSA APPC" }, 963cc391cceSBruce M Simpson { 0x0126, "SNA TEST SSA Profile" }, 964cc391cceSBruce M Simpson { 0x012a, "CSA TRACE" }, 965cc391cceSBruce M Simpson { 0x012b, "NetwareSAA" }, 966cc391cceSBruce M Simpson { 0x012e, "IKARUS VirusScan" }, 967cc391cceSBruce M Simpson { 0x0130, "CommunicationsExecutive" }, 968cc391cceSBruce M Simpson { 0x0133, "NNS DomainServer/NetwareNamingServicesDomain" }, 969cc391cceSBruce M Simpson { 0x0135, "NetwareNamingServicesProfile" }, 970cc391cceSBruce M Simpson { 0x0137, "Netware386 PrintQueue/NNS PrintQueue" }, 971cc391cceSBruce M Simpson { 0x0141, "LAN SpoolServer" }, 972cc391cceSBruce M Simpson { 0x0152, "IRMALAN Gateway" }, 973cc391cceSBruce M Simpson { 0x0154, "NamedPipeServer" }, 974cc391cceSBruce M Simpson { 0x0166, "NetWareManagement" }, 975cc391cceSBruce M Simpson { 0x0168, "Intel PICKIT CommServer/Intel CAS TalkServer" }, 976cc391cceSBruce M Simpson { 0x0173, "Compaq" }, 977cc391cceSBruce M Simpson { 0x0174, "Compaq SNMP Agent" }, 978cc391cceSBruce M Simpson { 0x0175, "Compaq" }, 979cc391cceSBruce M Simpson { 0x0180, "XTreeServer/XTreeTools" }, 980cc391cceSBruce M Simpson { 0x018A, "NASI ServicesBroadcastServer" }, 981cc391cceSBruce M Simpson { 0x01b0, "GARP Gateway" }, 982cc391cceSBruce M Simpson { 0x01b1, "Binfview" }, 983cc391cceSBruce M Simpson { 0x01bf, "IntelLanDeskManager" }, 984cc391cceSBruce M Simpson { 0x01ca, "AXTEC" }, 985cc391cceSBruce M Simpson { 0x01cb, "ShivaNetModem/E" }, 986cc391cceSBruce M Simpson { 0x01cc, "ShivaLanRover/E" }, 987cc391cceSBruce M Simpson { 0x01cd, "ShivaLanRover/T" }, 988cc391cceSBruce M Simpson { 0x01ce, "ShivaUniversal" }, 989cc391cceSBruce M Simpson { 0x01d8, "CastelleFAXPressServer" }, 990cc391cceSBruce M Simpson { 0x01da, "CastelleLANPressPrintServer" }, 991cc391cceSBruce M Simpson { 0x01dc, "CastelleFAX/Xerox7033 FaxServer/ExcelLanFax" }, 992cc391cceSBruce M Simpson { 0x01f0, "LEGATO" }, 993cc391cceSBruce M Simpson { 0x01f5, "LEGATO" }, 994cc391cceSBruce M Simpson { 0x0233, "NMS Agent/NetwareManagementAgent" }, 995cc391cceSBruce M Simpson { 0x0237, "NMS IPX Discovery/LANternReadWriteChannel" }, 996cc391cceSBruce M Simpson { 0x0238, "NMS IP Discovery/LANternTrapAlarmChannel" }, 997cc391cceSBruce M Simpson { 0x023a, "LANtern" }, 998cc391cceSBruce M Simpson { 0x023c, "MAVERICK" }, 999cc391cceSBruce M Simpson { 0x023f, "NovellSMDR" }, 1000cc391cceSBruce M Simpson { 0x024e, "NetwareConnect" }, 1001cc391cceSBruce M Simpson { 0x024f, "NASI ServerBroadcast Cisco" }, 1002cc391cceSBruce M Simpson { 0x026a, "NMS ServiceConsole" }, 1003cc391cceSBruce M Simpson { 0x026b, "TimeSynchronizationServer Netware 4.x" }, 1004cc391cceSBruce M Simpson { 0x0278, "DirectoryServer Netware 4.x" }, 1005cc391cceSBruce M Simpson { 0x027b, "NetwareManagementAgent" }, 1006cc391cceSBruce M Simpson { 0x0280, "Novell File and Printer Sharing Service for PC" }, 1007cc391cceSBruce M Simpson { 0x0304, "NovellSAA Gateway" }, 1008cc391cceSBruce M Simpson { 0x0308, "COM/VERMED" }, 1009cc391cceSBruce M Simpson { 0x030a, "GalacticommWorldgroupServer" }, 1010cc391cceSBruce M Simpson { 0x030c, "IntelNetport2/HP JetDirect/HP Quicksilver" }, 1011cc391cceSBruce M Simpson { 0x0320, "AttachmateGateway" }, 1012cc391cceSBruce M Simpson { 0x0327, "MicrosoftDiagnostiocs" }, 1013cc391cceSBruce M Simpson { 0x0328, "WATCOM SQL Server" }, 1014cc391cceSBruce M Simpson { 0x0335, "MultiTechSystems MultisynchCommServer" }, 1015cc391cceSBruce M Simpson { 0x0343, "Xylogics RemoteAccessServer/LANModem" }, 1016cc391cceSBruce M Simpson { 0x0355, "ArcadaBackupExec" }, 1017cc391cceSBruce M Simpson { 0x0358, "MSLCD1" }, 1018cc391cceSBruce M Simpson { 0x0361, "NETINELO" }, 1019cc391cceSBruce M Simpson { 0x037e, "Powerchute UPS Monitoring" }, 1020cc391cceSBruce M Simpson { 0x037f, "ViruSafeNotify" }, 1021cc391cceSBruce M Simpson { 0x0386, "HP Bridge" }, 1022cc391cceSBruce M Simpson { 0x0387, "HP Hub" }, 1023cc391cceSBruce M Simpson { 0x0394, "NetWare SAA Gateway" }, 1024cc391cceSBruce M Simpson { 0x039b, "LotusNotes" }, 1025cc391cceSBruce M Simpson { 0x03b7, "CertusAntiVirus" }, 1026cc391cceSBruce M Simpson { 0x03c4, "ARCserve4.0" }, 1027cc391cceSBruce M Simpson { 0x03c7, "LANspool3.5" }, 1028cc391cceSBruce M Simpson { 0x03d7, "LexmarkPrinterServer" }, 1029cc391cceSBruce M Simpson { 0x03d8, "LexmarkXLE PrinterServer" }, 1030cc391cceSBruce M Simpson { 0x03dd, "BanyanENS NetwareClient" }, 1031cc391cceSBruce M Simpson { 0x03de, "GuptaSequelBaseServer/NetWareSQL" }, 1032cc391cceSBruce M Simpson { 0x03e1, "UnivelUnixware" }, 1033cc391cceSBruce M Simpson { 0x03e4, "UnivelUnixware" }, 1034cc391cceSBruce M Simpson { 0x03fc, "IntelNetport" }, 1035cc391cceSBruce M Simpson { 0x03fd, "PrintServerQueue" }, 1036cc391cceSBruce M Simpson { 0x040A, "ipnServer" }, 1037cc391cceSBruce M Simpson { 0x040D, "LVERRMAN" }, 1038cc391cceSBruce M Simpson { 0x040E, "LVLIC" }, 1039cc391cceSBruce M Simpson { 0x0414, "NET Silicon (DPI)/Kyocera" }, 1040cc391cceSBruce M Simpson { 0x0429, "SiteLockVirus" }, 1041cc391cceSBruce M Simpson { 0x0432, "UFHELPR???" }, 1042cc391cceSBruce M Simpson { 0x0433, "Synoptics281xAdvancedSNMPAgent" }, 1043cc391cceSBruce M Simpson { 0x0444, "MicrosoftNT SNA Server" }, 1044cc391cceSBruce M Simpson { 0x0448, "Oracle" }, 1045cc391cceSBruce M Simpson { 0x044c, "ARCserve5.01" }, 1046cc391cceSBruce M Simpson { 0x0457, "CanonGP55" }, 1047cc391cceSBruce M Simpson { 0x045a, "QMS Printers" }, 1048cc391cceSBruce M Simpson { 0x045b, "DellSCSI Array" }, 1049cc391cceSBruce M Simpson { 0x0491, "NetBlazerModems" }, 1050cc391cceSBruce M Simpson { 0x04ac, "OnTimeScheduler" }, 1051cc391cceSBruce M Simpson { 0x04b0, "CD-Net" }, 1052cc391cceSBruce M Simpson { 0x0513, "EmulexNQA" }, 1053cc391cceSBruce M Simpson { 0x0520, "SiteLockChecks" }, 1054cc391cceSBruce M Simpson { 0x0529, "SiteLockChecks" }, 1055cc391cceSBruce M Simpson { 0x052d, "CitrixOS2 AppServer" }, 1056cc391cceSBruce M Simpson { 0x0535, "Tektronix" }, 1057cc391cceSBruce M Simpson { 0x0536, "Milan" }, 1058cc391cceSBruce M Simpson { 0x055d, "Attachmate SNA gateway" }, 1059cc391cceSBruce M Simpson { 0x056b, "IBM8235 ModemServer" }, 1060cc391cceSBruce M Simpson { 0x056c, "ShivaLanRover/E PLUS" }, 1061cc391cceSBruce M Simpson { 0x056d, "ShivaLanRover/T PLUS" }, 1062cc391cceSBruce M Simpson { 0x0580, "McAfeeNetShield" }, 1063cc391cceSBruce M Simpson { 0x05B8, "NLM to workstation communication (Revelation Software)" }, 1064cc391cceSBruce M Simpson { 0x05BA, "CompatibleSystemsRouters" }, 1065cc391cceSBruce M Simpson { 0x05BE, "CheyenneHierarchicalStorageManager" }, 1066cc391cceSBruce M Simpson { 0x0606, "JCWatermarkImaging" }, 1067cc391cceSBruce M Simpson { 0x060c, "AXISNetworkPrinter" }, 1068cc391cceSBruce M Simpson { 0x0610, "AdaptecSCSIManagement" }, 1069cc391cceSBruce M Simpson { 0x0621, "IBM AntiVirus" }, 1070cc391cceSBruce M Simpson { 0x0640, "Windows95 RemoteRegistryService" }, 1071cc391cceSBruce M Simpson { 0x064e, "MicrosoftIIS" }, 1072cc391cceSBruce M Simpson { 0x067b, "Microsoft Win95/98 File and Print Sharing for NetWare" }, 1073cc391cceSBruce M Simpson { 0x067c, "Microsoft Win95/98 File and Print Sharing for NetWare" }, 1074cc391cceSBruce M Simpson { 0x076C, "Xerox" }, 1075cc391cceSBruce M Simpson { 0x079b, "ShivaLanRover/E 115" }, 1076cc391cceSBruce M Simpson { 0x079c, "ShivaLanRover/T 115" }, 1077cc391cceSBruce M Simpson { 0x07B4, "CubixWorldDesk" }, 1078cc391cceSBruce M Simpson { 0x07c2, "Quarterdeck IWare Connect V2.x NLM" }, 1079cc391cceSBruce M Simpson { 0x07c1, "Quarterdeck IWare Connect V3.x NLM" }, 1080cc391cceSBruce M Simpson { 0x0810, "ELAN License Server Demo" }, 1081cc391cceSBruce M Simpson { 0x0824, "ShivaLanRoverAccessSwitch/E" }, 1082cc391cceSBruce M Simpson { 0x086a, "ISSC Collector" }, 1083cc391cceSBruce M Simpson { 0x087f, "ISSC DAS AgentAIX" }, 1084cc391cceSBruce M Simpson { 0x0880, "Intel Netport PRO" }, 1085cc391cceSBruce M Simpson { 0x0881, "Intel Netport PRO" }, 1086cc391cceSBruce M Simpson { 0x0b29, "SiteLock" }, 1087cc391cceSBruce M Simpson { 0x0c29, "SiteLockApplications" }, 1088cc391cceSBruce M Simpson { 0x0c2c, "LicensingServer" }, 1089cc391cceSBruce M Simpson { 0x2101, "PerformanceTechnologyInstantInternet" }, 1090cc391cceSBruce M Simpson { 0x2380, "LAI SiteLock" }, 1091cc391cceSBruce M Simpson { 0x238c, "MeetingMaker" }, 1092cc391cceSBruce M Simpson { 0x4808, "SiteLockServer/SiteLockMetering" }, 1093cc391cceSBruce M Simpson { 0x5555, "SiteLockUser" }, 1094cc391cceSBruce M Simpson { 0x6312, "Tapeware" }, 1095cc391cceSBruce M Simpson { 0x6f00, "RabbitGateway" }, 1096cc391cceSBruce M Simpson { 0x7703, "MODEM" }, 1097cc391cceSBruce M Simpson { 0x8002, "NetPortPrinters" }, 1098cc391cceSBruce M Simpson { 0x8008, "WordPerfectNetworkVersion" }, 1099cc391cceSBruce M Simpson { 0x85BE, "Cisco EIGRP" }, 1100cc391cceSBruce M Simpson { 0x8888, "WordPerfectNetworkVersion/QuickNetworkManagement" }, 1101cc391cceSBruce M Simpson { 0x9000, "McAfeeNetShield" }, 1102cc391cceSBruce M Simpson { 0x9604, "CSA-NT_MON" }, 1103cc391cceSBruce M Simpson { 0xb6a8, "OceanIsleReachoutRemoteControl" }, 1104cc391cceSBruce M Simpson { 0xf11f, "SiteLockMetering" }, 1105cc391cceSBruce M Simpson { 0xf1ff, "SiteLock" }, 1106cc391cceSBruce M Simpson { 0xf503, "Microsoft SQL Server" }, 1107cc391cceSBruce M Simpson { 0xF905, "IBM TimeAndPlace" }, 1108cc391cceSBruce M Simpson { 0xfbfb, "TopCallIII FaxServer" }, 1109cc391cceSBruce M Simpson { 0xffff, "AnyService/Wildcard" }, 1110cc391cceSBruce M Simpson { 0, (char *)0 } 1111cc391cceSBruce M Simpson }; 1112cc391cceSBruce M Simpson 1113cc391cceSBruce M Simpson static void 1114cc391cceSBruce M Simpson init_ipxsaparray(void) 1115cc391cceSBruce M Simpson { 1116cc391cceSBruce M Simpson register int i; 1117cc391cceSBruce M Simpson register struct hnamemem *table; 1118cc391cceSBruce M Simpson 1119cc391cceSBruce M Simpson for (i = 0; ipxsap_db[i].s != NULL; i++) { 1120cc391cceSBruce M Simpson int j = htons(ipxsap_db[i].v) & (HASHNAMESIZE-1); 1121cc391cceSBruce M Simpson table = &ipxsaptable[j]; 1122cc391cceSBruce M Simpson while (table->name) 1123cc391cceSBruce M Simpson table = table->nxt; 1124cc391cceSBruce M Simpson table->name = ipxsap_db[i].s; 1125cc391cceSBruce M Simpson table->addr = htons(ipxsap_db[i].v); 1126cc391cceSBruce M Simpson table->nxt = newhnamemem(); 1127cc391cceSBruce M Simpson } 1128cc391cceSBruce M Simpson } 1129cc391cceSBruce M Simpson 11304edb46e9SPaul Traina /* 11314edb46e9SPaul Traina * Initialize the address to name translation machinery. We map all 11324edb46e9SPaul Traina * non-local IP addresses to numeric addresses if fflag is true (i.e., 11334edb46e9SPaul Traina * to prevent blocking on the nameserver). localnet is the IP address 11344edb46e9SPaul Traina * of the local network. mask is its subnet mask. 11354edb46e9SPaul Traina */ 11364edb46e9SPaul Traina void 1137699fc314SBill Fenner init_addrtoname(u_int32_t localnet, u_int32_t mask) 11384edb46e9SPaul Traina { 11394edb46e9SPaul Traina if (fflag) { 11404edb46e9SPaul Traina f_localnet = localnet; 11414edb46e9SPaul Traina f_netmask = mask; 11424edb46e9SPaul Traina } 11434edb46e9SPaul Traina if (nflag) 11444edb46e9SPaul Traina /* 11454edb46e9SPaul Traina * Simplest way to suppress names. 11464edb46e9SPaul Traina */ 11474edb46e9SPaul Traina return; 11484edb46e9SPaul Traina 11494edb46e9SPaul Traina init_etherarray(); 11504edb46e9SPaul Traina init_servarray(); 11514edb46e9SPaul Traina init_eprotoarray(); 11524edb46e9SPaul Traina init_llcsaparray(); 11534edb46e9SPaul Traina init_protoidarray(); 1154cc391cceSBruce M Simpson init_ipxsaparray(); 11554edb46e9SPaul Traina } 11564edb46e9SPaul Traina 1157a1c2090eSBill Fenner const char * 11584edb46e9SPaul Traina dnaddr_string(u_short dnaddr) 11594edb46e9SPaul Traina { 11604edb46e9SPaul Traina register struct hnamemem *tp; 11614edb46e9SPaul Traina 11624edb46e9SPaul Traina for (tp = &dnaddrtable[dnaddr & (HASHNAMESIZE-1)]; tp->nxt != 0; 11634edb46e9SPaul Traina tp = tp->nxt) 11644edb46e9SPaul Traina if (tp->addr == dnaddr) 11654edb46e9SPaul Traina return (tp->name); 11664edb46e9SPaul Traina 11674edb46e9SPaul Traina tp->addr = dnaddr; 11684edb46e9SPaul Traina tp->nxt = newhnamemem(); 11694edb46e9SPaul Traina if (nflag) 11704edb46e9SPaul Traina tp->name = dnnum_string(dnaddr); 11714edb46e9SPaul Traina else 11724edb46e9SPaul Traina tp->name = dnname_string(dnaddr); 11734edb46e9SPaul Traina 11744edb46e9SPaul Traina return(tp->name); 11754edb46e9SPaul Traina } 11764edb46e9SPaul Traina 11774edb46e9SPaul Traina /* Return a zero'ed hnamemem struct and cuts down on calloc() overhead */ 11784edb46e9SPaul Traina struct hnamemem * 11792ebf6c05SBill Fenner newhnamemem(void) 11804edb46e9SPaul Traina { 11814edb46e9SPaul Traina register struct hnamemem *p; 11824edb46e9SPaul Traina static struct hnamemem *ptr = NULL; 11834edb46e9SPaul Traina static u_int num = 0; 11844edb46e9SPaul Traina 11854edb46e9SPaul Traina if (num <= 0) { 11864edb46e9SPaul Traina num = 64; 11874edb46e9SPaul Traina ptr = (struct hnamemem *)calloc(num, sizeof (*ptr)); 11884edb46e9SPaul Traina if (ptr == NULL) 11894edb46e9SPaul Traina error("newhnamemem: calloc"); 11904edb46e9SPaul Traina } 11914edb46e9SPaul Traina --num; 11924edb46e9SPaul Traina p = ptr++; 11934edb46e9SPaul Traina return (p); 11944edb46e9SPaul Traina } 1195a88113a8SBill Fenner 1196a88113a8SBill Fenner #ifdef INET6 1197a88113a8SBill Fenner /* Return a zero'ed h6namemem struct and cuts down on calloc() overhead */ 1198a88113a8SBill Fenner struct h6namemem * 1199a88113a8SBill Fenner newh6namemem(void) 1200a88113a8SBill Fenner { 1201a88113a8SBill Fenner register struct h6namemem *p; 1202a88113a8SBill Fenner static struct h6namemem *ptr = NULL; 1203a88113a8SBill Fenner static u_int num = 0; 1204a88113a8SBill Fenner 1205a88113a8SBill Fenner if (num <= 0) { 1206a88113a8SBill Fenner num = 64; 1207a88113a8SBill Fenner ptr = (struct h6namemem *)calloc(num, sizeof (*ptr)); 1208a88113a8SBill Fenner if (ptr == NULL) 1209a88113a8SBill Fenner error("newh6namemem: calloc"); 1210a88113a8SBill Fenner } 1211a88113a8SBill Fenner --num; 1212a88113a8SBill Fenner p = ptr++; 1213a88113a8SBill Fenner return (p); 1214a88113a8SBill Fenner } 1215a88113a8SBill Fenner #endif /* INET6 */ 1216