ip_encap.h revision 1.27 1 1.27 knakahar /* $NetBSD: ip_encap.h,v 1.27 2022/12/07 08:28:46 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.21 knakahar #include <sys/pslist.h>
43 1.21 knakahar #include <sys/psref.h>
44 1.21 knakahar
45 1.16 knakahar struct encapsw {
46 1.16 knakahar union {
47 1.16 knakahar struct encapsw4 {
48 1.16 knakahar void (*pr_input) /* input to protocol (from below) */
49 1.23 knakahar (struct mbuf *, int, int, void *);
50 1.18 knakahar void *(*pr_ctlinput) /* control input (from below) */
51 1.18 knakahar (int, const struct sockaddr *, void *, void *);
52 1.16 knakahar } _encapsw4;
53 1.16 knakahar struct encapsw6 {
54 1.16 knakahar int (*pr_input) /* input to protocol (from below) */
55 1.23 knakahar (struct mbuf **, int *, int, void *);
56 1.18 knakahar void *(*pr_ctlinput) /* control input (from below) */
57 1.18 knakahar (int, const struct sockaddr *, void *, void *);
58 1.16 knakahar } _encapsw6;
59 1.16 knakahar } encapsw46;
60 1.16 knakahar };
61 1.16 knakahar
62 1.16 knakahar #define encapsw4 encapsw46._encapsw4
63 1.16 knakahar #define encapsw6 encapsw46._encapsw6
64 1.16 knakahar
65 1.26 knakahar typedef int encap_priofunc_t(struct mbuf *, int, int, void *);
66 1.26 knakahar
67 1.27 knakahar struct encap_key {
68 1.27 knakahar union {
69 1.27 knakahar struct sockaddr local_u_sa;
70 1.27 knakahar struct sockaddr_in local_u_sin;
71 1.27 knakahar struct sockaddr_in6 local_u_sin6;
72 1.27 knakahar } local_u;
73 1.27 knakahar #define local_sa local_u.local_u_sa
74 1.27 knakahar #define local_sin local_u.local_u_sin
75 1.27 knakahar #define local_sin6 local_u.local_u_sin6
76 1.27 knakahar
77 1.27 knakahar union {
78 1.27 knakahar struct sockaddr remote_u_sa;
79 1.27 knakahar struct sockaddr_in remote_u_sin;
80 1.27 knakahar struct sockaddr_in6 remote_u_sin6;
81 1.27 knakahar } remote_u;
82 1.27 knakahar #define remote_sa remote_u.remote_u_sa
83 1.27 knakahar #define remote_sin remote_u.remote_u_sin
84 1.27 knakahar #define remote_sin6 remote_u.remote_u_sin6
85 1.27 knakahar
86 1.27 knakahar u_int seq;
87 1.27 knakahar };
88 1.27 knakahar
89 1.1 itojun struct encaptab {
90 1.2 itojun struct radix_node nodes[2];
91 1.21 knakahar struct pslist_entry chain;
92 1.1 itojun int af;
93 1.1 itojun int proto; /* -1: don't care, I'll check myself */
94 1.2 itojun struct sockaddr *addrpack; /* malloc'ed, for radix lookup */
95 1.2 itojun struct sockaddr *maskpack; /* ditto */
96 1.2 itojun struct sockaddr *src; /* my addr */
97 1.2 itojun struct sockaddr *srcmask;
98 1.2 itojun struct sockaddr *dst; /* remote addr */
99 1.2 itojun struct sockaddr *dstmask;
100 1.26 knakahar encap_priofunc_t *func;
101 1.16 knakahar const struct encapsw *esw;
102 1.24 maxv void *arg;
103 1.27 knakahar struct encap_key key;
104 1.27 knakahar u_int flag;
105 1.21 knakahar struct psref_target psref;
106 1.1 itojun };
107 1.1 itojun
108 1.27 knakahar #define IP_ENCAP_ADDR_ENABLE __BIT(0)
109 1.27 knakahar
110 1.13 pooka /* to lookup a pair of address using radix tree */
111 1.13 pooka struct sockaddr_pack {
112 1.13 pooka u_int8_t sp_len;
113 1.13 pooka u_int8_t sp_family; /* not really used */
114 1.13 pooka /* followed by variable-length data */
115 1.13 pooka };
116 1.13 pooka
117 1.13 pooka struct ip_pack4 {
118 1.13 pooka struct sockaddr_pack p;
119 1.13 pooka struct sockaddr_in mine;
120 1.13 pooka struct sockaddr_in yours;
121 1.13 pooka };
122 1.13 pooka struct ip_pack6 {
123 1.13 pooka struct sockaddr_pack p;
124 1.13 pooka struct sockaddr_in6 mine;
125 1.13 pooka struct sockaddr_in6 yours;
126 1.13 pooka };
127 1.13 pooka
128 1.22 knakahar void encapinit(void);
129 1.22 knakahar
130 1.6 perry void encap_init(void);
131 1.25 maxv void encap4_input(struct mbuf *, int, int);
132 1.6 perry int encap6_input(struct mbuf **, int *, int);
133 1.6 perry const struct encaptab *encap_attach(int, int, const struct sockaddr *,
134 1.1 itojun const struct sockaddr *, const struct sockaddr *,
135 1.16 knakahar const struct sockaddr *, const struct encapsw *, void *);
136 1.6 perry const struct encaptab *encap_attach_func(int, int,
137 1.26 knakahar encap_priofunc_t *,
138 1.16 knakahar const struct encapsw *, void *);
139 1.27 knakahar const struct encaptab *encap_attach_addr(int, int,
140 1.27 knakahar const struct sockaddr *, const struct sockaddr *,
141 1.27 knakahar encap_priofunc_t *, const struct encapsw *, void *);
142 1.12 ad void *encap6_ctlinput(int, const struct sockaddr *, void *);
143 1.6 perry int encap_detach(const struct encaptab *);
144 1.18 knakahar
145 1.22 knakahar int encap_lock_enter(void);
146 1.20 knakahar void encap_lock_exit(void);
147 1.21 knakahar bool encap_lock_held(void);
148 1.20 knakahar
149 1.18 knakahar #define ENCAP_PR_WRAP_CTLINPUT(name) \
150 1.18 knakahar static void * \
151 1.18 knakahar name##_wrapper(int a, const struct sockaddr *b, void *c, void *d) \
152 1.18 knakahar { \
153 1.18 knakahar void *rv; \
154 1.18 knakahar KERNEL_LOCK(1, NULL); \
155 1.18 knakahar rv = name(a, b, c, d); \
156 1.18 knakahar KERNEL_UNLOCK_ONE(NULL); \
157 1.18 knakahar return rv; \
158 1.18 knakahar }
159 1.1 itojun #endif
160 1.1 itojun
161 1.10 elad #endif /* !_NETINET_IP_ENCAP_H_ */
162