xref: /freebsd/sys/net/if_gif.h (revision dbe59260468858ff41276c815fdc723a96e55395)
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