ip_encap.h revision 1.18 1 1.18 knakahar /* $NetBSD: ip_encap.h,v 1.18 2016/02/26 07:35:17 knakahara 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.16 knakahar struct encapsw {
43 1.16 knakahar union {
44 1.16 knakahar struct encapsw4 {
45 1.16 knakahar void (*pr_input) /* input to protocol (from below) */
46 1.17 knakahar (struct mbuf *, int, int);
47 1.18 knakahar void *(*pr_ctlinput) /* control input (from below) */
48 1.18 knakahar (int, const struct sockaddr *, void *, void *);
49 1.16 knakahar } _encapsw4;
50 1.16 knakahar struct encapsw6 {
51 1.16 knakahar int (*pr_input) /* input to protocol (from below) */
52 1.16 knakahar (struct mbuf **, int *, int);
53 1.18 knakahar void *(*pr_ctlinput) /* control input (from below) */
54 1.18 knakahar (int, const struct sockaddr *, void *, void *);
55 1.16 knakahar } _encapsw6;
56 1.16 knakahar } encapsw46;
57 1.16 knakahar };
58 1.16 knakahar
59 1.16 knakahar #define encapsw4 encapsw46._encapsw4
60 1.16 knakahar #define encapsw6 encapsw46._encapsw6
61 1.16 knakahar
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.16 knakahar 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.16 knakahar 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.16 knakahar 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.18 knakahar
109 1.18 knakahar void encap_lock_enter(void);
110 1.18 knakahar void encap_lock_exit(void);
111 1.18 knakahar
112 1.18 knakahar #define ENCAP_PR_WRAP_CTLINPUT(name) \
113 1.18 knakahar static void * \
114 1.18 knakahar name##_wrapper(int a, const struct sockaddr *b, void *c, void *d) \
115 1.18 knakahar { \
116 1.18 knakahar void *rv; \
117 1.18 knakahar KERNEL_LOCK(1, NULL); \
118 1.18 knakahar rv = name(a, b, c, d); \
119 1.18 knakahar KERNEL_UNLOCK_ONE(NULL); \
120 1.18 knakahar return rv; \
121 1.18 knakahar }
122 1.1 itojun #endif
123 1.1 itojun
124 1.10 elad #endif /* !_NETINET_IP_ENCAP_H_ */
125