FreeBSD kernel IPv4 code
ip_var.h
Go to the documentation of this file.
1/*-
2 * SPDX-License-Identifier: BSD-3-Clause
3 *
4 * Copyright (c) 1982, 1986, 1993
5 * The Regents of the University of California. All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. Neither the name of the University nor the names of its contributors
16 * may be used to endorse or promote products derived from this software
17 * without specific prior written permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 * SUCH DAMAGE.
30 *
31 * @(#)ip_var.h 8.2 (Berkeley) 1/9/95
32 * $FreeBSD$
33 */
34
35#ifndef _NETINET_IP_VAR_H_
36#define _NETINET_IP_VAR_H_
37
38#include <sys/epoch.h>
39#include <sys/queue.h>
40#include <sys/types.h>
41
42#include <netinet/in.h>
43
44/*
45 * Overlay for ip header used by other protocols (tcp, udp).
46 */
47struct ipovly {
48 u_char ih_x1[9]; /* (unused) */
49 u_char ih_pr; /* protocol */
50 u_short ih_len; /* protocol length */
51 struct in_addr ih_src; /* source internet address */
52 struct in_addr ih_dst; /* destination internet address */
53};
54
55#ifdef _KERNEL
56/*
57 * Ip reassembly queue structure. Each fragment
58 * being reassembled is attached to one of these structures.
59 * They are timed out after ipq_ttl drops to 0, and may also
60 * be reclaimed if memory becomes tight.
61 */
62struct ipq {
63 TAILQ_ENTRY(ipq) ipq_list; /* to other reass headers */
64 u_char ipq_ttl; /* time for reass q to live */
65 u_char ipq_p; /* protocol of this fragment */
66 u_short ipq_id; /* sequence id for reassembly */
67 int ipq_maxoff; /* total length of packet */
68 struct mbuf *ipq_frags; /* to ip headers of fragments */
69 struct in_addr ipq_src,ipq_dst;
70 u_char ipq_nfrags; /* # frags in this packet */
71 struct label *ipq_label; /* MAC label */
72};
73#endif /* _KERNEL */
74
75/*
76 * Structure stored in mbuf in inpcb.ip_options
77 * and passed to ip_output when ip options are in use.
78 * The actual length of the options (including ipopt_dst)
79 * is in m_len.
80 */
81#define MAX_IPOPTLEN 40
82
83struct ipoption {
84 struct in_addr ipopt_dst; /* first-hop dst if source routed */
85 char ipopt_list[MAX_IPOPTLEN]; /* options proper */
86};
87
88#if defined(_NETINET_IN_VAR_H_) && defined(_KERNEL)
89/*
90 * Structure attached to inpcb.ip_moptions and
91 * passed to ip_output when IP multicast options are in use.
92 * This structure is lazy-allocated.
93 */
94struct ip_moptions {
95 struct ifnet *imo_multicast_ifp; /* ifp for outgoing multicasts */
96 struct in_addr imo_multicast_addr; /* ifindex/addr on MULTICAST_IF */
97 u_long imo_multicast_vif; /* vif num outgoing multicasts */
98 u_char imo_multicast_ttl; /* TTL for outgoing multicasts */
99 u_char imo_multicast_loop; /* 1 => hear sends if a member */
100 struct ip_mfilter_head imo_head; /* group membership list */
101};
102#else
103struct ip_moptions;
104#endif
105
106struct ipstat {
107 uint64_t ips_total; /* total packets received */
108 uint64_t ips_badsum; /* checksum bad */
109 uint64_t ips_tooshort; /* packet too short */
110 uint64_t ips_toosmall; /* not enough data */
111 uint64_t ips_badhlen; /* ip header length < data size */
112 uint64_t ips_badlen; /* ip length < ip header length */
113 uint64_t ips_fragments; /* fragments received */
114 uint64_t ips_fragdropped; /* frags dropped (dups, out of space) */
115 uint64_t ips_fragtimeout; /* fragments timed out */
116 uint64_t ips_forward; /* packets forwarded */
117 uint64_t ips_fastforward; /* packets fast forwarded */
118 uint64_t ips_cantforward; /* packets rcvd for unreachable dest */
119 uint64_t ips_redirectsent; /* packets forwarded on same net */
120 uint64_t ips_noproto; /* unknown or unsupported protocol */
121 uint64_t ips_delivered; /* datagrams delivered to upper level*/
122 uint64_t ips_localout; /* total ip packets generated here */
123 uint64_t ips_odropped; /* lost packets due to nobufs, etc. */
124 uint64_t ips_reassembled; /* total packets reassembled ok */
125 uint64_t ips_fragmented; /* datagrams successfully fragmented */
126 uint64_t ips_ofragments; /* output fragments created */
127 uint64_t ips_cantfrag; /* don't fragment flag was set, etc. */
128 uint64_t ips_badoptions; /* error in option processing */
129 uint64_t ips_noroute; /* packets discarded due to no route */
130 uint64_t ips_badvers; /* ip version != 4 */
131 uint64_t ips_rawout; /* total raw ip packets generated */
132 uint64_t ips_toolong; /* ip length > max ip packet size */
133 uint64_t ips_notmember; /* multicasts for unregistered grps */
134 uint64_t ips_nogif; /* no match gif found */
135 uint64_t ips_badaddr; /* invalid address on header */
136};
137
138#ifdef _KERNEL
139
140#include <sys/counter.h>
141#include <net/vnet.h>
142
144/*
145 * In-kernel consumers can use these accessor macros directly to update
146 * stats.
147 */
148#define IPSTAT_ADD(name, val) \
149 VNET_PCPUSTAT_ADD(struct ipstat, ipstat, name, (val))
150#define IPSTAT_SUB(name, val) IPSTAT_ADD(name, -(val))
151#define IPSTAT_INC(name) IPSTAT_ADD(name, 1)
152#define IPSTAT_DEC(name) IPSTAT_SUB(name, 1)
153
154/*
155 * Kernel module consumers must use this accessor macro.
156 */
157void kmod_ipstat_inc(int statnum);
158#define KMOD_IPSTAT_INC(name) \
159 kmod_ipstat_inc(offsetof(struct ipstat, name) / sizeof(uint64_t))
160void kmod_ipstat_dec(int statnum);
161#define KMOD_IPSTAT_DEC(name) \
162 kmod_ipstat_dec(offsetof(struct ipstat, name) / sizeof(uint64_t))
163
164/* flags passed to ip_output as last parameter */
165#define IP_FORWARDING 0x1 /* most of ip header exists */
166#define IP_RAWOUTPUT 0x2 /* raw ip header exists */
167#define IP_SENDONES 0x4 /* send all-ones broadcast */
168#define IP_SENDTOIF 0x8 /* send on specific ifnet */
169#define IP_ROUTETOIF SO_DONTROUTE /* 0x10 bypass routing tables */
170#define IP_ALLOWBROADCAST SO_BROADCAST /* 0x20 can send broadcast packets */
171#define IP_NODEFAULTFLOWID 0x40 /* Don't set the flowid from inp */
172#define IP_NO_SND_TAG_RL 0x80 /* Don't send down the ratelimit tag */
173
174#ifdef __NO_STRICT_ALIGNMENT
175#define IP_HDR_ALIGNED_P(ip) 1
176#else
177#define IP_HDR_ALIGNED_P(ip) ((((intptr_t) (ip)) & 3) == 0)
178#endif
179
180struct ip;
181struct inpcb;
182struct route;
183struct sockopt;
184struct inpcbinfo;
185
186VNET_DECLARE(int, ip_defttl); /* default IP ttl */
187VNET_DECLARE(int, ipforwarding); /* ip forwarding */
188VNET_DECLARE(int, ipsendredirects);
189#ifdef IPSTEALTH
190VNET_DECLARE(int, ipstealth); /* stealth forwarding */
191#endif
192extern u_char ip_protox[];
193VNET_DECLARE(struct socket *, ip_rsvpd); /* reservation protocol daemon*/
194VNET_DECLARE(struct socket *, ip_mrouter); /* multicast routing daemon */
195extern int (*legal_vif_num)(int);
196extern u_long (*ip_mcast_src)(int);
197VNET_DECLARE(int, rsvp_on);
198VNET_DECLARE(int, drop_redirect);
199extern struct pr_usrreqs rip_usrreqs;
200
201#define V_ip_id VNET(ip_id)
202#define V_ip_defttl VNET(ip_defttl)
203#define V_ipforwarding VNET(ipforwarding)
204#define V_ipsendredirects VNET(ipsendredirects)
205#ifdef IPSTEALTH
206#define V_ipstealth VNET(ipstealth)
207#endif
208#define V_ip_rsvpd VNET(ip_rsvpd)
209#define V_ip_mrouter VNET(ip_mrouter)
210#define V_rsvp_on VNET(rsvp_on)
211#define V_drop_redirect VNET(drop_redirect)
212
213void inp_freemoptions(struct ip_moptions *);
214int inp_getmoptions(struct inpcb *, struct sockopt *);
215int inp_setmoptions(struct inpcb *, struct sockopt *);
216
217int ip_ctloutput(struct socket *, struct sockopt *sopt);
218void ip_drain(void);
219int ip_fragment(struct ip *ip, struct mbuf **m_frag, int mtu,
220 u_long if_hwassist_flags);
221void ip_forward(struct mbuf *m, int srcrt);
222extern int
223 (*ip_mforward)(struct ip *, struct ifnet *, struct mbuf *,
224 struct ip_moptions *);
225int ip_output(struct mbuf *,
226 struct mbuf *, struct route *, int, struct ip_moptions *,
227 struct inpcb *);
228int ipproto_register(short);
229int ipproto_unregister(short);
230struct mbuf *
231 ip_reass(struct mbuf *);
232void ip_savecontrol(struct inpcb *, struct mbuf **, struct ip *,
233 struct mbuf *);
234void ip_slowtimo(void);
235void ip_fillid(struct ip *);
236int rip_ctloutput(struct socket *, struct sockopt *);
237void rip_ctlinput(int, struct sockaddr *, void *);
238int rip_input(struct mbuf **, int *, int);
239int rip_output(struct mbuf *, struct socket *, ...);
240int ipip_input(struct mbuf **, int *, int);
241int rsvp_input(struct mbuf **, int *, int);
242int ip_rsvp_init(struct socket *);
243int ip_rsvp_done(void);
244extern int (*ip_rsvp_vif)(struct socket *, struct sockopt *);
245extern void (*ip_rsvp_force_done)(struct socket *);
246extern int (*rsvp_input_p)(struct mbuf **, int *, int);
247
248VNET_DECLARE(struct pfil_head *, inet_pfil_head);
249#define V_inet_pfil_head VNET(inet_pfil_head)
250#define PFIL_INET_NAME "inet"
251
252void in_delayed_cksum(struct mbuf *m);
253
254/* Hooks for ipfw, dummynet, divert etc. Most are declared in raw_ip.c */
255/*
256 * Reference to an ipfw or packet filter rule that can be carried
257 * outside critical sections.
258 * A rule is identified by rulenum:rule_id which is ordered.
259 * In version chain_id the rule can be found in slot 'slot', so
260 * we don't need a lookup if chain_id == chain->id.
261 *
262 * On exit from the firewall this structure refers to the rule after
263 * the matching one (slot points to the new rule; rulenum:rule_id-1
264 * is the matching rule), and additional info (e.g. info often contains
265 * the insn argument or tablearg in the low 16 bits, in host format).
266 * On entry, the structure is valid if slot>0, and refers to the starting
267 * rules. 'info' contains the reason for reinject, e.g. divert port,
268 * divert direction, and so on.
269 */
271 uint32_t slot; /* slot for matching rule */
272 uint32_t rulenum; /* matching rule number */
273 uint32_t rule_id; /* matching rule id */
274 uint32_t chain_id; /* ruleset id */
275 uint32_t info; /* see below */
276};
277
278enum {
279 IPFW_INFO_MASK = 0x0000ffff,
280 IPFW_INFO_OUT = 0x00000000, /* outgoing, just for convenience */
281 IPFW_INFO_IN = 0x80000000, /* incoming, overloads dir */
282 IPFW_ONEPASS = 0x40000000, /* One-pass, do not reinject */
283 IPFW_IS_MASK = 0x30000000, /* which source ? */
284 IPFW_IS_DIVERT = 0x20000000,
285 IPFW_IS_DUMMYNET =0x10000000,
286 IPFW_IS_PIPE = 0x08000000, /* pipe=1, queue = 0 */
287};
288#define MTAG_IPFW 1148380143 /* IPFW-tagged cookie */
289#define MTAG_IPFW_RULE 1262273568 /* rule reference */
290#define MTAG_IPFW_CALL 1308397630 /* call stack */
291
292struct ip_fw_args;
293typedef int (*ip_fw_chk_ptr_t)(struct ip_fw_args *args);
294typedef int (*ip_fw_ctl_ptr_t)(struct sockopt *);
296#define V_ip_fw_ctl_ptr VNET(ip_fw_ctl_ptr)
297
298/* Divert hooks. */
299extern void (*ip_divert_ptr)(struct mbuf *m, bool incoming);
300/* ng_ipfw hooks -- XXX make it the same as divert and dummynet */
301extern int (*ng_ipfw_input_p)(struct mbuf **, struct ip_fw_args *, bool);
302extern int (*ip_dn_ctl_ptr)(struct sockopt *);
303extern int (*ip_dn_io_ptr)(struct mbuf **, struct ip_fw_args *);
304#endif /* _KERNEL */
305
306#endif /* !_NETINET_IP_VAR_H_ */
__uint32_t uint32_t
Definition: in.h:62
int rip_output(struct mbuf *, struct socket *,...)
void kmod_ipstat_dec(int statnum)
Definition: ip_input.c:211
int(* ip_fw_ctl_ptr_t)(struct sockopt *)
Definition: ip_var.h:294
int(* ip_fw_chk_ptr_t)(struct ip_fw_args *args)
Definition: ip_var.h:293
int(* ip_dn_io_ptr)(struct mbuf **, struct ip_fw_args *)
Definition: raw_ip.c:102
struct pr_usrreqs rip_usrreqs
int(* ip_dn_ctl_ptr)(struct sockopt *)
Definition: raw_ip.c:101
int ip_output(struct mbuf *, struct mbuf *, struct route *, int, struct ip_moptions *, struct inpcb *)
Definition: ip_output.c:320
int(* ip_rsvp_vif)(struct socket *, struct sockopt *)
int inp_setmoptions(struct inpcb *, struct sockopt *)
Definition: in_mcast.c:2713
int(* rsvp_input_p)(struct mbuf **, int *, int)
int rsvp_input(struct mbuf **, int *, int)
Definition: ip_input.c:1406
void kmod_ipstat_inc(int statnum)
Definition: ip_input.c:204
void ip_fillid(struct ip *)
Definition: ip_id.c:243
int ipproto_register(short)
Definition: ip_input.c:884
void ip_drain(void)
Definition: ip_input.c:866
VNET_PCPUSTAT_DECLARE(struct ipstat, ipstat)
void ip_savecontrol(struct inpcb *, struct mbuf **, struct ip *, struct mbuf *)
Definition: ip_input.c:1150
struct mbuf * ip_reass(struct mbuf *)
Definition: ip_reass.c:183
int inp_getmoptions(struct inpcb *, struct sockopt *)
Definition: in_mcast.c:1743
int ip_fragment(struct ip *ip, struct mbuf **m_frag, int mtu, u_long if_hwassist_flags)
Definition: ip_output.c:859
int ipip_input(struct mbuf **, int *, int)
void ip_slowtimo(void)
Definition: ip_input.c:852
int(* legal_vif_num)(int)
void ip_forward(struct mbuf *m, int srcrt)
Definition: ip_input.c:959
int ip_rsvp_done(void)
Definition: ip_input.c:1390
void inp_freemoptions(struct ip_moptions *)
Definition: in_mcast.c:1593
void in_delayed_cksum(struct mbuf *m)
Definition: ip_output.c:1032
int ip_ctloutput(struct socket *, struct sockopt *sopt)
Definition: ip_output.c:1070
int ipproto_unregister(short)
Definition: ip_input.c:915
@ IPFW_INFO_OUT
Definition: ip_var.h:280
@ IPFW_IS_DUMMYNET
Definition: ip_var.h:285
@ IPFW_ONEPASS
Definition: ip_var.h:282
@ IPFW_INFO_IN
Definition: ip_var.h:281
@ IPFW_INFO_MASK
Definition: ip_var.h:279
@ IPFW_IS_PIPE
Definition: ip_var.h:286
@ IPFW_IS_DIVERT
Definition: ip_var.h:284
@ IPFW_IS_MASK
Definition: ip_var.h:283
VNET_DECLARE(int, ip_defttl)
#define MAX_IPOPTLEN
Definition: ip_var.h:81
int(* ip_mforward)(struct ip *, struct ifnet *, struct mbuf *, struct ip_moptions *)
void(* ip_rsvp_force_done)(struct socket *)
u_long(* ip_mcast_src)(int)
void rip_ctlinput(int, struct sockaddr *, void *)
u_char ip_protox[]
Definition: ip_input.c:167
int ip_rsvp_init(struct socket *)
Definition: ip_input.c:1366
int rip_ctloutput(struct socket *, struct sockopt *)
int rip_input(struct mbuf **, int *, int)
int(* ng_ipfw_input_p)(struct mbuf **, struct ip_fw_args *, bool)
Definition: raw_ip.c:104
void(* ip_divert_ptr)(struct mbuf *m, bool incoming)
Definition: raw_ip.c:103
Definition: in.h:83
Definition: in_pcb.h:217
Definition: ip.h:51
uint32_t rule_id
Definition: ip_var.h:273
uint32_t slot
Definition: ip_var.h:271
uint32_t info
Definition: ip_var.h:275
uint32_t chain_id
Definition: ip_var.h:274
uint32_t rulenum
Definition: ip_var.h:272
struct in_addr ipopt_dst
Definition: ip_var.h:84
char ipopt_list[MAX_IPOPTLEN]
Definition: ip_var.h:85
Definition: ip_var.h:47
u_short ih_len
Definition: ip_var.h:50
struct in_addr ih_dst
Definition: ip_var.h:52
struct in_addr ih_src
Definition: ip_var.h:51
u_char ih_x1[9]
Definition: ip_var.h:48
u_char ih_pr
Definition: ip_var.h:49
Definition: ip_var.h:62
struct mbuf * ipq_frags
Definition: ip_var.h:68
struct label * ipq_label
Definition: ip_var.h:71
int ipq_maxoff
Definition: ip_var.h:67
u_char ipq_p
Definition: ip_var.h:65
struct in_addr ipq_src ipq_dst
Definition: ip_var.h:69
u_short ipq_id
Definition: ip_var.h:66
u_char ipq_ttl
Definition: ip_var.h:64
u_char ipq_nfrags
Definition: ip_var.h:70
TAILQ_ENTRY(ipq) ipq_list
Definition: ip_var.h:106
uint64_t ips_delivered
Definition: ip_var.h:121
uint64_t ips_fragtimeout
Definition: ip_var.h:115
uint64_t ips_fastforward
Definition: ip_var.h:117
uint64_t ips_localout
Definition: ip_var.h:122
uint64_t ips_nogif
Definition: ip_var.h:134
uint64_t ips_rawout
Definition: ip_var.h:131
uint64_t ips_cantfrag
Definition: ip_var.h:127
uint64_t ips_notmember
Definition: ip_var.h:133
uint64_t ips_badsum
Definition: ip_var.h:108
uint64_t ips_toolong
Definition: ip_var.h:132
uint64_t ips_noroute
Definition: ip_var.h:129
uint64_t ips_reassembled
Definition: ip_var.h:124
uint64_t ips_redirectsent
Definition: ip_var.h:119
uint64_t ips_fragments
Definition: ip_var.h:113
uint64_t ips_tooshort
Definition: ip_var.h:109
uint64_t ips_noproto
Definition: ip_var.h:120
uint64_t ips_forward
Definition: ip_var.h:116
uint64_t ips_fragdropped
Definition: ip_var.h:114
uint64_t ips_total
Definition: ip_var.h:107
uint64_t ips_fragmented
Definition: ip_var.h:125
uint64_t ips_odropped
Definition: ip_var.h:123
uint64_t ips_badhlen
Definition: ip_var.h:111
uint64_t ips_toosmall
Definition: ip_var.h:110
uint64_t ips_badoptions
Definition: ip_var.h:128
uint64_t ips_badaddr
Definition: ip_var.h:135
uint64_t ips_cantforward
Definition: ip_var.h:118
uint64_t ips_ofragments
Definition: ip_var.h:126
uint64_t ips_badlen
Definition: ip_var.h:112
uint64_t ips_badvers
Definition: ip_var.h:130