/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License (the "License"). * You may not use this file except in compliance with the License. * * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE * or http://www.opensolaris.org/os/licensing. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at usr/src/OPENSOLARIS.LICENSE. * If applicable, add the following below this CDDL HEADER, with the * fields enclosed by brackets "[]" replaced with your own identifying * information: Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END */ /* * Copyright 2009 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. */ #include #include #include #include /* * This table provides a mapping of the DLPI data link types used in * Solaris to the BPF data link types. Providing this translation in * the kernel allows libpcap to be downloaded and used without any * need for change. * * Note that this table is not necessarily sorted. */ static uint_t dl_to_dlt[][3] = { { DL_CSMACD, DLT_EN10MB, 14 }, /* IEEE 802.3 CSMA/CD */ { DL_TPB, DLT_NULL, 0 }, /* IEEE 802.4 Token Bus */ { DL_TPR, DLT_IEEE802, 0 }, /* IEEE 802.5 Token Ring */ { DL_METRO, DLT_NULL, 0 }, /* IEEE 802.6 Metro Net */ { DL_ETHER, DLT_EN10MB, 14 }, /* Ethernet Bus */ { DL_HDLC, DLT_C_HDLC, 0 }, /* Cisco HDLC protocol */ { DL_CHAR, DLT_NULL, 0 }, /* Character Synchr. proto */ { DL_CTCA, DLT_NULL, 0 }, /* IBM Channel-to-Channel */ { DL_FDDI, DLT_FDDI, 24 }, /* Fiber Distributed data */ { DL_FC, DLT_NULL, 0 }, /* Fibre Channel interface */ { DL_ATM, DLT_SUNATM, 0 }, /* ATM */ { DL_IPATM, DLT_ATM_CLIP, 0 }, /* ATM CLIP */ { DL_X25, DLT_NULL, 0 }, /* X.25 LAPB interface */ { DL_ISDN, DLT_NULL, 0 }, /* ISDN interface */ { DL_HIPPI, DLT_HIPPI, 0 }, /* HIPPI interface */ { DL_100VG, DLT_EN10MB, 14 }, /* 100 Based VG Ethernet */ { DL_100VGTPR, DLT_IEEE802, 0 }, /* 100 Based VG Token Ring */ { DL_ETH_CSMA, DLT_EN10MB, 14 }, /* ISO 8802/3 and Ethernet */ { DL_100BT, DLT_EN10MB, 14 }, /* 100 Base T */ { DL_IB, DLT_IPOIB, 44 }, /* Solaris IPoIB (infini.) */ { DL_FRAME, DLT_FRELAY, 0 }, /* Frame Relay LAPF */ { DL_MPFRAME, DLT_NULL, 0 }, /* Multi-protocol Frame Relay */ { DL_ASYNC, DLT_NULL, 0 }, /* Character Asynch. Protocol */ { DL_IPX25, DLT_NULL, 0 }, /* X.25 Classical IP */ { DL_LOOP, DLT_NULL, 0 }, /* software loopback */ { DL_IPV4, DLT_RAW, 0 }, /* IPv4 Tunnel Link */ { DL_IPV6, DLT_RAW, 0 }, /* IPv6 Tunnel Link */ { SUNW_DL_VNI, DLT_NULL, 0 }, /* Virtual network interface */ { DL_WIFI, DLT_IEEE802_11, 0 }, /* IEEE 802.11 */ { DL_IPNET, DLT_IPNET, 24 }, /* Solaris IP Observability */ { DL_OTHER, DLT_NULL, 0 }, /* Mediums not listed above */ { 0, 0 } }; /* * Given a data link type number used with DLPI on Solaris, return * the equivalent data link type number for use with BPF. */ int bpf_dl_to_dlt(int dl) { int i; for (i = 0; i < sizeof (dl_to_dlt) / sizeof (dl_to_dlt[0]); i++) if (dl_to_dlt[i][0] == dl) return (dl_to_dlt[i][1]); return (0); } /* * Given a DLPI data link type for Solaris, return the expected header * size of the link layer. */ int bpf_dl_hdrsize(int dl) { int i; for (i = 0; i < sizeof (dl_to_dlt) / sizeof (dl_to_dlt[0]); i++) if (dl_to_dlt[i][0] == dl) return (dl_to_dlt[i][2]); return (0); }