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