Home | History | Annotate | Line # | Download | only in netinet
ip_encap.h revision 1.13.44.1
      1  1.13.44.1   skrll /*	$NetBSD: ip_encap.h,v 1.13.44.1 2016/03/19 11:30:33 skrll Exp $	*/
      2        1.1  itojun /*	$KAME: ip_encap.h,v 1.7 2000/03/25 07:23:37 sumikawa Exp $	*/
      3        1.1  itojun 
      4        1.1  itojun /*
      5        1.1  itojun  * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
      6        1.1  itojun  * All rights reserved.
      7        1.1  itojun  *
      8        1.1  itojun  * Redistribution and use in source and binary forms, with or without
      9        1.1  itojun  * modification, are permitted provided that the following conditions
     10        1.1  itojun  * are met:
     11        1.1  itojun  * 1. Redistributions of source code must retain the above copyright
     12        1.1  itojun  *    notice, this list of conditions and the following disclaimer.
     13        1.1  itojun  * 2. Redistributions in binary form must reproduce the above copyright
     14        1.1  itojun  *    notice, this list of conditions and the following disclaimer in the
     15        1.1  itojun  *    documentation and/or other materials provided with the distribution.
     16        1.1  itojun  * 3. Neither the name of the project nor the names of its contributors
     17        1.1  itojun  *    may be used to endorse or promote products derived from this software
     18        1.1  itojun  *    without specific prior written permission.
     19        1.1  itojun  *
     20        1.1  itojun  * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
     21        1.1  itojun  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     22        1.1  itojun  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     23        1.1  itojun  * ARE DISCLAIMED.  IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
     24        1.1  itojun  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     25        1.1  itojun  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     26        1.1  itojun  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     27        1.1  itojun  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     28        1.1  itojun  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     29        1.1  itojun  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     30        1.1  itojun  * SUCH DAMAGE.
     31        1.1  itojun  */
     32        1.1  itojun 
     33        1.1  itojun #ifndef _NETINET_IP_ENCAP_H_
     34        1.1  itojun #define _NETINET_IP_ENCAP_H_
     35        1.1  itojun 
     36        1.1  itojun #ifdef _KERNEL
     37        1.1  itojun 
     38        1.2  itojun #ifndef RNF_NORMAL
     39        1.2  itojun #include <net/radix.h>
     40        1.2  itojun #endif
     41        1.2  itojun 
     42  1.13.44.1   skrll struct encapsw {
     43  1.13.44.1   skrll 	union {
     44  1.13.44.1   skrll 		struct encapsw4 {
     45  1.13.44.1   skrll 			void	(*pr_input)	/* input to protocol (from below) */
     46  1.13.44.1   skrll 				(struct mbuf *, int, int);
     47  1.13.44.1   skrll 			void	*(*pr_ctlinput)		/* control input (from below) */
     48  1.13.44.1   skrll 				(int, const struct sockaddr *, void *, void *);
     49  1.13.44.1   skrll 		} _encapsw4;
     50  1.13.44.1   skrll 		struct encapsw6 {
     51  1.13.44.1   skrll 			int	(*pr_input)	/* input to protocol (from below) */
     52  1.13.44.1   skrll 				(struct mbuf **, int *, int);
     53  1.13.44.1   skrll 			void	*(*pr_ctlinput)		/* control input (from below) */
     54  1.13.44.1   skrll 				(int, const struct sockaddr *, void *, void *);
     55  1.13.44.1   skrll 		} _encapsw6;
     56  1.13.44.1   skrll 	} encapsw46;
     57  1.13.44.1   skrll };
     58  1.13.44.1   skrll 
     59  1.13.44.1   skrll #define encapsw4 encapsw46._encapsw4
     60  1.13.44.1   skrll #define encapsw6 encapsw46._encapsw6
     61  1.13.44.1   skrll 
     62        1.1  itojun struct encaptab {
     63        1.2  itojun 	struct radix_node nodes[2];
     64        1.1  itojun 	LIST_ENTRY(encaptab) chain;
     65        1.1  itojun 	int af;
     66        1.1  itojun 	int proto;			/* -1: don't care, I'll check myself */
     67        1.2  itojun 	struct sockaddr *addrpack;	/* malloc'ed, for radix lookup */
     68        1.2  itojun 	struct sockaddr *maskpack;	/* ditto */
     69        1.2  itojun 	struct sockaddr *src;		/* my addr */
     70        1.2  itojun 	struct sockaddr *srcmask;
     71        1.2  itojun 	struct sockaddr *dst;		/* remote addr */
     72        1.2  itojun 	struct sockaddr *dstmask;
     73        1.9  martin 	int (*func) (struct mbuf *, int, int, void *);
     74  1.13.44.1   skrll 	const struct encapsw *esw;
     75        1.3  itojun 	void *arg;			/* passed via PACKET_TAG_ENCAP */
     76        1.1  itojun };
     77        1.1  itojun 
     78       1.13   pooka /* to lookup a pair of address using radix tree */
     79       1.13   pooka struct sockaddr_pack {
     80       1.13   pooka 	u_int8_t sp_len;
     81       1.13   pooka 	u_int8_t sp_family;	/* not really used */
     82       1.13   pooka 	/* followed by variable-length data */
     83       1.13   pooka };
     84       1.13   pooka 
     85       1.13   pooka struct ip_pack4 {
     86       1.13   pooka 	struct sockaddr_pack p;
     87       1.13   pooka 	struct sockaddr_in mine;
     88       1.13   pooka 	struct sockaddr_in yours;
     89       1.13   pooka };
     90       1.13   pooka struct ip_pack6 {
     91       1.13   pooka 	struct sockaddr_pack p;
     92       1.13   pooka 	struct sockaddr_in6 mine;
     93       1.13   pooka 	struct sockaddr_in6 yours;
     94       1.13   pooka };
     95       1.13   pooka 
     96        1.6   perry void	encap_init(void);
     97        1.6   perry void	encap4_input(struct mbuf *, ...);
     98        1.6   perry int	encap6_input(struct mbuf **, int *, int);
     99        1.6   perry const struct encaptab *encap_attach(int, int, const struct sockaddr *,
    100        1.1  itojun 	const struct sockaddr *, const struct sockaddr *,
    101  1.13.44.1   skrll 	const struct sockaddr *, const struct encapsw *, void *);
    102        1.6   perry const struct encaptab *encap_attach_func(int, int,
    103        1.9  martin 	int (*)(struct mbuf *, int, int, void *),
    104  1.13.44.1   skrll 	const struct encapsw *, void *);
    105       1.12      ad void	*encap6_ctlinput(int, const struct sockaddr *, void *);
    106        1.6   perry int	encap_detach(const struct encaptab *);
    107        1.6   perry void	*encap_getarg(struct mbuf *);
    108  1.13.44.1   skrll 
    109  1.13.44.1   skrll #define	ENCAP_PR_WRAP_CTLINPUT(name)				\
    110  1.13.44.1   skrll static void *							\
    111  1.13.44.1   skrll name##_wrapper(int a, const struct sockaddr *b, void *c, void *d) \
    112  1.13.44.1   skrll {								\
    113  1.13.44.1   skrll 	void *rv;						\
    114  1.13.44.1   skrll 	KERNEL_LOCK(1, NULL);					\
    115  1.13.44.1   skrll 	rv = name(a, b, c, d);					\
    116  1.13.44.1   skrll 	KERNEL_UNLOCK_ONE(NULL);				\
    117  1.13.44.1   skrll 	return rv;						\
    118  1.13.44.1   skrll }
    119        1.1  itojun #endif
    120        1.1  itojun 
    121       1.10    elad #endif /* !_NETINET_IP_ENCAP_H_ */
    122