1686cdd19SJun-ichiro itojun Hagino /* $FreeBSD$ */ 233841545SHajimu UMEMOTO /* $KAME: if_gif.h,v 1.17 2000/09/11 11:36:41 sumikawa Exp $ */ 3686cdd19SJun-ichiro itojun Hagino 4c398230bSWarner Losh /*- 582cd038dSYoshinobu Inoue * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project. 682cd038dSYoshinobu Inoue * All rights reserved. 782cd038dSYoshinobu Inoue * 882cd038dSYoshinobu Inoue * Redistribution and use in source and binary forms, with or without 982cd038dSYoshinobu Inoue * modification, are permitted provided that the following conditions 1082cd038dSYoshinobu Inoue * are met: 1182cd038dSYoshinobu Inoue * 1. Redistributions of source code must retain the above copyright 1282cd038dSYoshinobu Inoue * notice, this list of conditions and the following disclaimer. 1382cd038dSYoshinobu Inoue * 2. Redistributions in binary form must reproduce the above copyright 1482cd038dSYoshinobu Inoue * notice, this list of conditions and the following disclaimer in the 1582cd038dSYoshinobu Inoue * documentation and/or other materials provided with the distribution. 1682cd038dSYoshinobu Inoue * 3. Neither the name of the project nor the names of its contributors 1782cd038dSYoshinobu Inoue * may be used to endorse or promote products derived from this software 1882cd038dSYoshinobu Inoue * without specific prior written permission. 1982cd038dSYoshinobu Inoue * 2082cd038dSYoshinobu Inoue * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND 2182cd038dSYoshinobu Inoue * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 2282cd038dSYoshinobu Inoue * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 2382cd038dSYoshinobu Inoue * ARE DISCLAIMED. IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE 2482cd038dSYoshinobu Inoue * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 2582cd038dSYoshinobu Inoue * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 2682cd038dSYoshinobu Inoue * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 2782cd038dSYoshinobu Inoue * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 2882cd038dSYoshinobu Inoue * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 2982cd038dSYoshinobu Inoue * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 3082cd038dSYoshinobu Inoue * SUCH DAMAGE. 3182cd038dSYoshinobu Inoue */ 3282cd038dSYoshinobu Inoue 3382cd038dSYoshinobu Inoue /* 3482cd038dSYoshinobu Inoue * if_gif.h 3582cd038dSYoshinobu Inoue */ 3682cd038dSYoshinobu Inoue 3782cd038dSYoshinobu Inoue #ifndef _NET_IF_GIF_H_ 3882cd038dSYoshinobu Inoue #define _NET_IF_GIF_H_ 3982cd038dSYoshinobu Inoue 40686cdd19SJun-ichiro itojun Hagino 4120af0ffaSBrooks Davis #ifdef _KERNEL 42686cdd19SJun-ichiro itojun Hagino #include "opt_inet.h" 4320af0ffaSBrooks Davis #include "opt_inet6.h" 44686cdd19SJun-ichiro itojun Hagino 45686cdd19SJun-ichiro itojun Hagino #include <netinet/in.h> 46686cdd19SJun-ichiro itojun Hagino /* xxx sigh, why route have struct route instead of pointer? */ 47686cdd19SJun-ichiro itojun Hagino 48686cdd19SJun-ichiro itojun Hagino struct encaptab; 49686cdd19SJun-ichiro itojun Hagino 5094408d94SBrooks Davis extern void (*ng_gif_input_p)(struct ifnet *ifp, struct mbuf **mp, 5194408d94SBrooks Davis int af); 5294408d94SBrooks Davis extern void (*ng_gif_input_orphan_p)(struct ifnet *ifp, struct mbuf *m, 5394408d94SBrooks Davis int af); 5494408d94SBrooks Davis extern int (*ng_gif_output_p)(struct ifnet *ifp, struct mbuf **mp); 5594408d94SBrooks Davis extern void (*ng_gif_attach_p)(struct ifnet *ifp); 5694408d94SBrooks Davis extern void (*ng_gif_detach_p)(struct ifnet *ifp); 5794408d94SBrooks Davis 5882cd038dSYoshinobu Inoue struct gif_softc { 59fc74a9f9SBrooks Davis struct ifnet *gif_ifp; 6025af0bb5SGleb Smirnoff struct mtx gif_mtx; 6182cd038dSYoshinobu Inoue struct sockaddr *gif_psrc; /* Physical src addr */ 6282cd038dSYoshinobu Inoue struct sockaddr *gif_pdst; /* Physical dst addr */ 6382cd038dSYoshinobu Inoue union { 6482cd038dSYoshinobu Inoue struct route gifscr_ro; /* xxx */ 65686cdd19SJun-ichiro itojun Hagino #ifdef INET6 6682cd038dSYoshinobu Inoue struct route_in6 gifscr_ro6; /* xxx */ 67686cdd19SJun-ichiro itojun Hagino #endif 6882cd038dSYoshinobu Inoue } gifsc_gifscr; 6982cd038dSYoshinobu Inoue int gif_flags; 708b07e49aSJulian Elischer u_int gif_fibnum; 71686cdd19SJun-ichiro itojun Hagino const struct encaptab *encap_cookie4; 72686cdd19SJun-ichiro itojun Hagino const struct encaptab *encap_cookie6; 7394408d94SBrooks Davis void *gif_netgraph; /* ng_gif(4) netgraph node info */ 74dbe59260SHiroki Sato u_int gif_options; 759426aedfSHajimu UMEMOTO LIST_ENTRY(gif_softc) gif_list; /* all gif's are linked */ 7682cd038dSYoshinobu Inoue }; 77fc74a9f9SBrooks Davis #define GIF2IFP(sc) ((sc)->gif_ifp) 7825af0bb5SGleb Smirnoff #define GIF_LOCK_INIT(sc) mtx_init(&(sc)->gif_mtx, "gif softc", \ 7925af0bb5SGleb Smirnoff NULL, MTX_DEF) 8025af0bb5SGleb Smirnoff #define GIF_LOCK_DESTROY(sc) mtx_destroy(&(sc)->gif_mtx) 8125af0bb5SGleb Smirnoff #define GIF_LOCK(sc) mtx_lock(&(sc)->gif_mtx) 8225af0bb5SGleb Smirnoff #define GIF_UNLOCK(sc) mtx_unlock(&(sc)->gif_mtx) 8325af0bb5SGleb Smirnoff #define GIF_LOCK_ASSERT(sc) mtx_assert(&(sc)->gif_mtx, MA_OWNED) 8482cd038dSYoshinobu Inoue 8582cd038dSYoshinobu Inoue #define gif_ro gifsc_gifscr.gifscr_ro 86686cdd19SJun-ichiro itojun Hagino #ifdef INET6 8782cd038dSYoshinobu Inoue #define gif_ro6 gifsc_gifscr.gifscr_ro6 88686cdd19SJun-ichiro itojun Hagino #endif 8982cd038dSYoshinobu Inoue 9082cd038dSYoshinobu Inoue #define GIF_MTU (1280) /* Default MTU */ 9182cd038dSYoshinobu Inoue #define GIF_MTU_MIN (1280) /* Minimum MTU */ 9282cd038dSYoshinobu Inoue #define GIF_MTU_MAX (8192) /* Maximum MTU */ 9382cd038dSYoshinobu Inoue 948c7e1947SRuslan Ermilov #define MTAG_GIF 1080679712 958c7e1947SRuslan Ermilov #define MTAG_GIF_CALLED 0 968c7e1947SRuslan Ermilov 9773ff045cSAndrew Thompson struct etherip_header { 98dbe59260SHiroki Sato #if BYTE_ORDER == LITTLE_ENDIAN 99dbe59260SHiroki Sato u_int eip_resvl:4, /* reserved */ 100dbe59260SHiroki Sato eip_ver:4; /* version */ 101dbe59260SHiroki Sato #endif 102dbe59260SHiroki Sato #if BYTE_ORDER == BIG_ENDIAN 103dbe59260SHiroki Sato u_int eip_ver:4, /* version */ 104dbe59260SHiroki Sato eip_resvl:4; /* reserved */ 105dbe59260SHiroki Sato #endif 106dbe59260SHiroki Sato u_int8_t eip_resvh; /* reserved */ 107dbe59260SHiroki Sato } __packed; 108dbe59260SHiroki Sato 109dbe59260SHiroki Sato #define ETHERIP_VERSION 0x3 110c89c8a10SMarius Strobl /* mbuf adjust factor to force 32-bit alignment of IP header */ 111c89c8a10SMarius Strobl #define ETHERIP_ALIGN 2 11273ff045cSAndrew Thompson 11382cd038dSYoshinobu Inoue /* Prototypes */ 114929ddbbbSAlfred Perlstein void gif_input(struct mbuf *, int, struct ifnet *); 11534fe62c7SBruce Evans int gif_output(struct ifnet *, struct mbuf *, struct sockaddr *, 116279aa3d4SKip Macy struct route *); 117929ddbbbSAlfred Perlstein int gif_ioctl(struct ifnet *, u_long, caddr_t); 1189426aedfSHajimu UMEMOTO int gif_set_tunnel(struct ifnet *, struct sockaddr *, struct sockaddr *); 1199426aedfSHajimu UMEMOTO void gif_delete_tunnel(struct ifnet *); 1209426aedfSHajimu UMEMOTO int gif_encapcheck(const struct mbuf *, int, int, void *); 12182cd038dSYoshinobu Inoue 1228b615593SMarko Zec /* 1238b615593SMarko Zec * Virtualization support 1248b615593SMarko Zec */ 125385195c0SMarko Zec 1268b615593SMarko Zec struct vnet_gif { 1278b615593SMarko Zec LIST_HEAD(, gif_softc) _gif_softc_list; 1288b615593SMarko Zec int _max_gif_nesting; 1298b615593SMarko Zec int _parallel_tunnels; 1308b615593SMarko Zec int _ip_gif_ttl; 1318b615593SMarko Zec int _ip6_gif_hlim; 1328b615593SMarko Zec }; 133385195c0SMarko Zec 134385195c0SMarko Zec #ifndef VIMAGE 135385195c0SMarko Zec #ifndef VIMAGE_GLOBALS 136385195c0SMarko Zec extern struct vnet_gif vnet_gif_0; 137385195c0SMarko Zec #endif 1388b615593SMarko Zec #endif 1398b615593SMarko Zec 1408b615593SMarko Zec #define INIT_VNET_GIF(vnet) \ 1418b615593SMarko Zec INIT_FROM_VNET(vnet, VNET_MOD_GIF, struct vnet_gif, vnet_gif) 1428b615593SMarko Zec 1438b615593SMarko Zec #define VNET_GIF(sym) VSYM(vnet_gif, sym) 1448b615593SMarko Zec 1458b615593SMarko Zec #define V_gif_softc_list VNET_GIF(gif_softc_list) 1468b615593SMarko Zec #define V_max_gif_nesting VNET_GIF(max_gif_nesting) 1478b615593SMarko Zec #define V_parallel_tunnels VNET_GIF(parallel_tunnels) 1488b615593SMarko Zec #define V_ip_gif_ttl VNET_GIF(ip_gif_ttl) 1498b615593SMarko Zec #define V_ip6_gif_hlim VNET_GIF(ip6_gif_hlim) 1508b615593SMarko Zec 15120af0ffaSBrooks Davis #endif /* _KERNEL */ 15220af0ffaSBrooks Davis 153dbe59260SHiroki Sato #define GIFGOPTS _IOR('i', 150, struct ifreq) 154dbe59260SHiroki Sato #define GIFSOPTS _IOW('i', 151, struct ifreq) 155dbe59260SHiroki Sato 156dbe59260SHiroki Sato #define GIF_ACCEPT_REVETHIP 0x0001 157dbe59260SHiroki Sato #define GIF_SEND_REVETHIP 0x0010 158dbe59260SHiroki Sato #define GIF_FULLOPTS (GIF_ACCEPT_REVETHIP|GIF_SEND_REVETHIP) 159dbe59260SHiroki Sato 16082cd038dSYoshinobu Inoue #endif /* _NET_IF_GIF_H_ */ 161