1df8bae1dSRodney W. Grimes /* 2df8bae1dSRodney W. Grimes * Copyright (c) 1982, 1986, 1989, 1993 3df8bae1dSRodney W. Grimes * The Regents of the University of California. All rights reserved. 4df8bae1dSRodney W. Grimes * 5df8bae1dSRodney W. Grimes * Redistribution and use in source and binary forms, with or without 6df8bae1dSRodney W. Grimes * modification, are permitted provided that the following conditions 7df8bae1dSRodney W. Grimes * are met: 8df8bae1dSRodney W. Grimes * 1. Redistributions of source code must retain the above copyright 9df8bae1dSRodney W. Grimes * notice, this list of conditions and the following disclaimer. 10df8bae1dSRodney W. Grimes * 2. Redistributions in binary form must reproduce the above copyright 11df8bae1dSRodney W. Grimes * notice, this list of conditions and the following disclaimer in the 12df8bae1dSRodney W. Grimes * documentation and/or other materials provided with the distribution. 13df8bae1dSRodney W. Grimes * 3. All advertising materials mentioning features or use of this software 14df8bae1dSRodney W. Grimes * must display the following acknowledgement: 15df8bae1dSRodney W. Grimes * This product includes software developed by the University of 16df8bae1dSRodney W. Grimes * California, Berkeley and its contributors. 17df8bae1dSRodney W. Grimes * 4. Neither the name of the University nor the names of its contributors 18df8bae1dSRodney W. Grimes * may be used to endorse or promote products derived from this software 19df8bae1dSRodney W. Grimes * without specific prior written permission. 20df8bae1dSRodney W. Grimes * 21df8bae1dSRodney W. Grimes * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 22df8bae1dSRodney W. Grimes * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 23df8bae1dSRodney W. Grimes * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 24df8bae1dSRodney W. Grimes * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 25df8bae1dSRodney W. Grimes * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 26df8bae1dSRodney W. Grimes * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 27df8bae1dSRodney W. Grimes * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 28df8bae1dSRodney W. Grimes * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 29df8bae1dSRodney W. Grimes * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 30df8bae1dSRodney W. Grimes * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 31df8bae1dSRodney W. Grimes * SUCH DAMAGE. 32df8bae1dSRodney W. Grimes * 33df8bae1dSRodney W. Grimes * @(#)if.h 8.1 (Berkeley) 6/10/93 34c3aac50fSPeter Wemm * $FreeBSD$ 35df8bae1dSRodney W. Grimes */ 36df8bae1dSRodney W. Grimes 37cea1da3bSPaul Richards #ifndef _NET_IF_H_ 38cea1da3bSPaul Richards #define _NET_IF_H_ 39cea1da3bSPaul Richards 4030aad87dSBrooks Davis #include <sys/queue.h> 4130aad87dSBrooks Davis 42df8bae1dSRodney W. Grimes /* 4309410d0fSPeter Wemm * <net/if.h> does not depend on <sys/time.h> on most other systems. This 442fa72ea7SJeroen Ruigrok van der Werven * helps userland compatibility. (struct timeval ifi_lastchange) 4509410d0fSPeter Wemm */ 46664a31e4SPeter Wemm #ifndef _KERNEL 4709410d0fSPeter Wemm #include <sys/time.h> 4809410d0fSPeter Wemm #endif 4909410d0fSPeter Wemm 5030aad87dSBrooks Davis struct ifnet; 5130aad87dSBrooks Davis 5230aad87dSBrooks Davis /* 5330aad87dSBrooks Davis * Length of interface external name, including terminating '\0'. 5430aad87dSBrooks Davis * Note: this is the same size as a generic device's external name. 5530aad87dSBrooks Davis */ 5630aad87dSBrooks Davis #define IFNAMSIZ 16 5730aad87dSBrooks Davis #define IF_NAMESIZE IFNAMSIZ 5830aad87dSBrooks Davis 5930aad87dSBrooks Davis /* 6030aad87dSBrooks Davis * Structure describing a `cloning' interface. 6130aad87dSBrooks Davis */ 6230aad87dSBrooks Davis struct if_clone { 6330aad87dSBrooks Davis LIST_ENTRY(if_clone) ifc_list; /* on list of cloners */ 6430aad87dSBrooks Davis const char *ifc_name; /* name of device, e.g. `gif' */ 6530aad87dSBrooks Davis size_t ifc_namelen; /* length of name */ 6630aad87dSBrooks Davis 6730aad87dSBrooks Davis int (*ifc_create)(struct if_clone *, int *); 6830aad87dSBrooks Davis void (*ifc_destroy)(struct ifnet *); 6930aad87dSBrooks Davis }; 7030aad87dSBrooks Davis 7130aad87dSBrooks Davis #define IF_CLONE_INITIALIZER(name, create, destroy) \ 7230aad87dSBrooks Davis { { 0 }, name, sizeof(name) - 1, create, destroy } 7330aad87dSBrooks Davis 7430aad87dSBrooks Davis /* 7530aad87dSBrooks Davis * Structure used to query names of interface cloners. 7630aad87dSBrooks Davis */ 7730aad87dSBrooks Davis 7830aad87dSBrooks Davis struct if_clonereq { 7930aad87dSBrooks Davis int ifcr_total; /* total cloners (out) */ 8030aad87dSBrooks Davis int ifcr_count; /* room for this many in user buffer */ 8130aad87dSBrooks Davis char *ifcr_buffer; /* buffer for cloner names */ 8230aad87dSBrooks Davis }; 8330aad87dSBrooks Davis 8409410d0fSPeter Wemm /* 85a73356a1SBill Fenner * Structure describing information about an interface 86a73356a1SBill Fenner * which may be of interest to management entities. 87a73356a1SBill Fenner */ 88df8bae1dSRodney W. Grimes struct if_data { 89df8bae1dSRodney W. Grimes /* generic interface information */ 90df8bae1dSRodney W. Grimes u_char ifi_type; /* ethernet, tokenring, etc */ 91995add1aSGarrett Wollman u_char ifi_physical; /* e.g., AUI, Thinnet, 10base-T, etc */ 92df8bae1dSRodney W. Grimes u_char ifi_addrlen; /* media address length */ 93df8bae1dSRodney W. Grimes u_char ifi_hdrlen; /* media header length */ 94bbd17bf8SGarrett Wollman u_char ifi_recvquota; /* polling quota for receive intrs */ 95bbd17bf8SGarrett Wollman u_char ifi_xmitquota; /* polling quota for xmit intrs */ 96df8bae1dSRodney W. Grimes u_long ifi_mtu; /* maximum transmission unit */ 97df8bae1dSRodney W. Grimes u_long ifi_metric; /* routing metric (external only) */ 98df8bae1dSRodney W. Grimes u_long ifi_baudrate; /* linespeed */ 99df8bae1dSRodney W. Grimes /* volatile statistics */ 100df8bae1dSRodney W. Grimes u_long ifi_ipackets; /* packets received on interface */ 101df8bae1dSRodney W. Grimes u_long ifi_ierrors; /* input errors on interface */ 102df8bae1dSRodney W. Grimes u_long ifi_opackets; /* packets sent on interface */ 103df8bae1dSRodney W. Grimes u_long ifi_oerrors; /* output errors on interface */ 104df8bae1dSRodney W. Grimes u_long ifi_collisions; /* collisions on csma interfaces */ 105df8bae1dSRodney W. Grimes u_long ifi_ibytes; /* total number of octets received */ 106df8bae1dSRodney W. Grimes u_long ifi_obytes; /* total number of octets sent */ 107df8bae1dSRodney W. Grimes u_long ifi_imcasts; /* packets received via multicast */ 108df8bae1dSRodney W. Grimes u_long ifi_omcasts; /* packets sent via multicast */ 109df8bae1dSRodney W. Grimes u_long ifi_iqdrops; /* dropped on input, this interface */ 110df8bae1dSRodney W. Grimes u_long ifi_noproto; /* destined for unsupported protocol */ 111db4f9cc7SJonathan Lemon u_long ifi_hwassist; /* HW offload capabilities */ 112db4f9cc7SJonathan Lemon u_long ifi_unused; /* XXX was ifi_xmittiming */ 113e39a0280SGary Palmer struct timeval ifi_lastchange; /* time of last administrative change */ 1146f64074eSJoerg Wunsch }; 1156f64074eSJoerg Wunsch 116df8bae1dSRodney W. Grimes #define IFF_UP 0x1 /* interface is up */ 117df8bae1dSRodney W. Grimes #define IFF_BROADCAST 0x2 /* broadcast address valid */ 118df8bae1dSRodney W. Grimes #define IFF_DEBUG 0x4 /* turn on debugging */ 119df8bae1dSRodney W. Grimes #define IFF_LOOPBACK 0x8 /* is a loopback net */ 120df8bae1dSRodney W. Grimes #define IFF_POINTOPOINT 0x10 /* interface is point-to-point link */ 121cf4b9371SPoul-Henning Kamp #define IFF_SMART 0x20 /* interface manages own routes */ 122df8bae1dSRodney W. Grimes #define IFF_RUNNING 0x40 /* resources allocated */ 123df8bae1dSRodney W. Grimes #define IFF_NOARP 0x80 /* no address resolution protocol */ 124df8bae1dSRodney W. Grimes #define IFF_PROMISC 0x100 /* receive all packets */ 125df8bae1dSRodney W. Grimes #define IFF_ALLMULTI 0x200 /* receive all multicast packets */ 126df8bae1dSRodney W. Grimes #define IFF_OACTIVE 0x400 /* transmission in progress */ 127df8bae1dSRodney W. Grimes #define IFF_SIMPLEX 0x800 /* can't hear own transmissions */ 128df8bae1dSRodney W. Grimes #define IFF_LINK0 0x1000 /* per link layer defined bit */ 129df8bae1dSRodney W. Grimes #define IFF_LINK1 0x2000 /* per link layer defined bit */ 130df8bae1dSRodney W. Grimes #define IFF_LINK2 0x4000 /* per link layer defined bit */ 13137be1da8SGarrett Wollman #define IFF_ALTPHYS IFF_LINK2 /* use alternate physical connection */ 132df8bae1dSRodney W. Grimes #define IFF_MULTICAST 0x8000 /* supports multicast */ 133df8bae1dSRodney W. Grimes 134df8bae1dSRodney W. Grimes /* flags set internally only: */ 135df8bae1dSRodney W. Grimes #define IFF_CANTCHANGE \ 136df8bae1dSRodney W. Grimes (IFF_BROADCAST|IFF_POINTOPOINT|IFF_RUNNING|IFF_OACTIVE|\ 137cf4b9371SPoul-Henning Kamp IFF_SIMPLEX|IFF_MULTICAST|IFF_ALLMULTI|IFF_SMART) 138df8bae1dSRodney W. Grimes 139df8bae1dSRodney W. Grimes #define IFQ_MAXLEN 50 140df8bae1dSRodney W. Grimes #define IFNET_SLOWHZ 1 /* granularity is 1 second */ 141df8bae1dSRodney W. Grimes 142df8bae1dSRodney W. Grimes /* 143df8bae1dSRodney W. Grimes * Message format for use in obtaining information about interfaces 144df8bae1dSRodney W. Grimes * from getkerninfo and the routing socket 145df8bae1dSRodney W. Grimes */ 146df8bae1dSRodney W. Grimes struct if_msghdr { 147df8bae1dSRodney W. Grimes u_short ifm_msglen; /* to skip over non-understood messages */ 1482fa72ea7SJeroen Ruigrok van der Werven u_char ifm_version; /* future binary compatibility */ 149df8bae1dSRodney W. Grimes u_char ifm_type; /* message type */ 150df8bae1dSRodney W. Grimes int ifm_addrs; /* like rtm_addrs */ 151df8bae1dSRodney W. Grimes int ifm_flags; /* value of if_flags */ 152df8bae1dSRodney W. Grimes u_short ifm_index; /* index for associated ifp */ 153df8bae1dSRodney W. Grimes struct if_data ifm_data;/* statistics and other data about if */ 154df8bae1dSRodney W. Grimes }; 155df8bae1dSRodney W. Grimes 156df8bae1dSRodney W. Grimes /* 157df8bae1dSRodney W. Grimes * Message format for use in obtaining information about interface addresses 158df8bae1dSRodney W. Grimes * from getkerninfo and the routing socket 159df8bae1dSRodney W. Grimes */ 160df8bae1dSRodney W. Grimes struct ifa_msghdr { 161df8bae1dSRodney W. Grimes u_short ifam_msglen; /* to skip over non-understood messages */ 1622fa72ea7SJeroen Ruigrok van der Werven u_char ifam_version; /* future binary compatibility */ 163df8bae1dSRodney W. Grimes u_char ifam_type; /* message type */ 164df8bae1dSRodney W. Grimes int ifam_addrs; /* like rtm_addrs */ 165df8bae1dSRodney W. Grimes int ifam_flags; /* value of ifa_flags */ 166df8bae1dSRodney W. Grimes u_short ifam_index; /* index for associated ifp */ 167df8bae1dSRodney W. Grimes int ifam_metric; /* value of ifa_metric */ 168df8bae1dSRodney W. Grimes }; 169df8bae1dSRodney W. Grimes 170df8bae1dSRodney W. Grimes /* 171477180fbSGarrett Wollman * Message format for use in obtaining information about multicast addresses 172477180fbSGarrett Wollman * from the routing socket 173477180fbSGarrett Wollman */ 174477180fbSGarrett Wollman struct ifma_msghdr { 175477180fbSGarrett Wollman u_short ifmam_msglen; /* to skip over non-understood messages */ 1762fa72ea7SJeroen Ruigrok van der Werven u_char ifmam_version; /* future binary compatibility */ 177477180fbSGarrett Wollman u_char ifmam_type; /* message type */ 178477180fbSGarrett Wollman int ifmam_addrs; /* like rtm_addrs */ 179477180fbSGarrett Wollman int ifmam_flags; /* value of ifa_flags */ 180477180fbSGarrett Wollman u_short ifmam_index; /* index for associated ifp */ 181477180fbSGarrett Wollman }; 182477180fbSGarrett Wollman 183477180fbSGarrett Wollman /* 184df8bae1dSRodney W. Grimes * Interface request structure used for socket 185df8bae1dSRodney W. Grimes * ioctl's. All interface ioctl's must have parameter 186df8bae1dSRodney W. Grimes * definitions which begin with ifr_name. The 187df8bae1dSRodney W. Grimes * remainder may be interface specific. 188df8bae1dSRodney W. Grimes */ 189df8bae1dSRodney W. Grimes struct ifreq { 190df8bae1dSRodney W. Grimes char ifr_name[IFNAMSIZ]; /* if name, e.g. "en0" */ 191df8bae1dSRodney W. Grimes union { 192df8bae1dSRodney W. Grimes struct sockaddr ifru_addr; 193df8bae1dSRodney W. Grimes struct sockaddr ifru_dstaddr; 194df8bae1dSRodney W. Grimes struct sockaddr ifru_broadaddr; 1954add131eSPoul-Henning Kamp short ifru_flags[2]; 196df8bae1dSRodney W. Grimes int ifru_metric; 197a7028af7SDavid Greenman int ifru_mtu; 198074c4a4eSGarrett Wollman int ifru_phys; 199a912e453SPeter Wemm int ifru_media; 200df8bae1dSRodney W. Grimes caddr_t ifru_data; 201df8bae1dSRodney W. Grimes } ifr_ifru; 202df8bae1dSRodney W. Grimes #define ifr_addr ifr_ifru.ifru_addr /* address */ 203df8bae1dSRodney W. Grimes #define ifr_dstaddr ifr_ifru.ifru_dstaddr /* other end of p-to-p link */ 204df8bae1dSRodney W. Grimes #define ifr_broadaddr ifr_ifru.ifru_broadaddr /* broadcast address */ 2054add131eSPoul-Henning Kamp #define ifr_flags ifr_ifru.ifru_flags[0] /* flags */ 2064add131eSPoul-Henning Kamp #define ifr_prevflags ifr_ifru.ifru_flags[1] /* flags */ 207df8bae1dSRodney W. Grimes #define ifr_metric ifr_ifru.ifru_metric /* metric */ 208a7028af7SDavid Greenman #define ifr_mtu ifr_ifru.ifru_mtu /* mtu */ 209511cdd16SDavid Greenman #define ifr_phys ifr_ifru.ifru_phys /* physical wire */ 210a912e453SPeter Wemm #define ifr_media ifr_ifru.ifru_media /* physical media */ 211df8bae1dSRodney W. Grimes #define ifr_data ifr_ifru.ifru_data /* for use by interface */ 212df8bae1dSRodney W. Grimes }; 213df8bae1dSRodney W. Grimes 214906f09bcSGarrett Wollman #define _SIZEOF_ADDR_IFREQ(ifr) \ 215906f09bcSGarrett Wollman ((ifr).ifr_addr.sa_len > sizeof(struct sockaddr) ? \ 216906f09bcSGarrett Wollman (sizeof(struct ifreq) - sizeof(struct sockaddr) + \ 217906f09bcSGarrett Wollman (ifr).ifr_addr.sa_len) : sizeof(struct ifreq)) 218906f09bcSGarrett Wollman 219df8bae1dSRodney W. Grimes struct ifaliasreq { 220df8bae1dSRodney W. Grimes char ifra_name[IFNAMSIZ]; /* if name, e.g. "en0" */ 221df8bae1dSRodney W. Grimes struct sockaddr ifra_addr; 222df8bae1dSRodney W. Grimes struct sockaddr ifra_broadaddr; 223df8bae1dSRodney W. Grimes struct sockaddr ifra_mask; 224df8bae1dSRodney W. Grimes }; 225df8bae1dSRodney W. Grimes 226a912e453SPeter Wemm struct ifmediareq { 227a912e453SPeter Wemm char ifm_name[IFNAMSIZ]; /* if name, e.g. "en0" */ 228a912e453SPeter Wemm int ifm_current; /* current media options */ 229a912e453SPeter Wemm int ifm_mask; /* don't care mask */ 230a912e453SPeter Wemm int ifm_status; /* media status */ 231a912e453SPeter Wemm int ifm_active; /* active options */ 232a912e453SPeter Wemm int ifm_count; /* # entries in ifm_ulist array */ 233a912e453SPeter Wemm int *ifm_ulist; /* media words */ 234a912e453SPeter Wemm }; 235413dd0baSPoul-Henning Kamp 236413dd0baSPoul-Henning Kamp /* 237413dd0baSPoul-Henning Kamp * Structure used to retrieve aux status data from interfaces. 238712020a1SBruce Evans * Kernel suppliers to this interface should respect the formatting 239413dd0baSPoul-Henning Kamp * needed by ifconfig(8): each line starts with a TAB and ends with 240712020a1SBruce Evans * a newline. The canonical example to copy and paste is in if_tun.c. 241413dd0baSPoul-Henning Kamp */ 242413dd0baSPoul-Henning Kamp 243413dd0baSPoul-Henning Kamp #define IFSTATMAX 800 /* 10 lines of text */ 244413dd0baSPoul-Henning Kamp struct ifstat { 245413dd0baSPoul-Henning Kamp char ifs_name[IFNAMSIZ]; /* if name, e.g. "en0" */ 246413dd0baSPoul-Henning Kamp char ascii[IFSTATMAX + 1]; 247413dd0baSPoul-Henning Kamp }; 248413dd0baSPoul-Henning Kamp 249df8bae1dSRodney W. Grimes /* 250df8bae1dSRodney W. Grimes * Structure used in SIOCGIFCONF request. 251df8bae1dSRodney W. Grimes * Used to retrieve interface configuration 252df8bae1dSRodney W. Grimes * for machine (useful for programs which 253df8bae1dSRodney W. Grimes * must know all networks accessible). 254df8bae1dSRodney W. Grimes */ 255df8bae1dSRodney W. Grimes struct ifconf { 256df8bae1dSRodney W. Grimes int ifc_len; /* size of associated buffer */ 257df8bae1dSRodney W. Grimes union { 258df8bae1dSRodney W. Grimes caddr_t ifcu_buf; 259df8bae1dSRodney W. Grimes struct ifreq *ifcu_req; 260df8bae1dSRodney W. Grimes } ifc_ifcu; 261df8bae1dSRodney W. Grimes #define ifc_buf ifc_ifcu.ifcu_buf /* buffer address */ 262df8bae1dSRodney W. Grimes #define ifc_req ifc_ifcu.ifcu_req /* array of structures returned */ 263df8bae1dSRodney W. Grimes }; 264df8bae1dSRodney W. Grimes 26576429de4SYoshinobu Inoue 26676429de4SYoshinobu Inoue /* 26776429de4SYoshinobu Inoue * Structure for SIOC[AGD]LIFADDR 26876429de4SYoshinobu Inoue */ 26976429de4SYoshinobu Inoue struct if_laddrreq { 27076429de4SYoshinobu Inoue char iflr_name[IFNAMSIZ]; 27176429de4SYoshinobu Inoue u_int flags; 27276429de4SYoshinobu Inoue #define IFLR_PREFIX 0x8000 /* in: prefix given out: kernel fills id */ 27376429de4SYoshinobu Inoue u_int prefixlen; /* in/out */ 27476429de4SYoshinobu Inoue struct sockaddr_storage addr; /* in/out */ 27576429de4SYoshinobu Inoue struct sockaddr_storage dstaddr; /* out */ 27676429de4SYoshinobu Inoue }; 27776429de4SYoshinobu Inoue 278664a31e4SPeter Wemm #ifdef _KERNEL 279a1c995b6SPoul-Henning Kamp #ifdef MALLOC_DECLARE 280a1c995b6SPoul-Henning Kamp MALLOC_DECLARE(M_IFADDR); 281a1c995b6SPoul-Henning Kamp MALLOC_DECLARE(M_IFMADDR); 282a1c995b6SPoul-Henning Kamp #endif 283a1c995b6SPoul-Henning Kamp #endif 284a1c995b6SPoul-Henning Kamp 285664a31e4SPeter Wemm #ifndef _KERNEL 28676429de4SYoshinobu Inoue struct if_nameindex { 28776429de4SYoshinobu Inoue u_int if_index; /* 1, 2, ... */ 28876429de4SYoshinobu Inoue char *if_name; /* null terminated name: "le0", ... */ 28976429de4SYoshinobu Inoue }; 29076429de4SYoshinobu Inoue 29176429de4SYoshinobu Inoue __BEGIN_DECLS 29276429de4SYoshinobu Inoue u_int if_nametoindex __P((const char *)); 29376429de4SYoshinobu Inoue char *if_indextoname __P((u_int, char *)); 29476429de4SYoshinobu Inoue struct if_nameindex *if_nameindex __P((void)); 29576429de4SYoshinobu Inoue void if_freenameindex __P((struct if_nameindex *)); 29676429de4SYoshinobu Inoue __END_DECLS 29776429de4SYoshinobu Inoue #endif 29876429de4SYoshinobu Inoue 299664a31e4SPeter Wemm #ifdef _KERNEL 300cb40a67fSPoul-Henning Kamp struct proc; 301712020a1SBruce Evans 302712020a1SBruce Evans /* XXX - this should go away soon. */ 30319ff91c6SGarrett Wollman #include <net/if_var.h> 304df8bae1dSRodney W. Grimes #endif 305cea1da3bSPaul Richards 306df708ff1SBruce Evans #endif /* !_NET_IF_H_ */ 307