]> git.saurik.com Git - apple/xnu.git/blame - bsd/net/bpf.h
xnu-792.10.96.tar.gz
[apple/xnu.git] / bsd / net / bpf.h
CommitLineData
1c79356b 1/*
91447636 2 * Copyright (c) 2000-2005 Apple Computer, Inc. All rights reserved.
1c79356b
A
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
37839358
A
6 * The contents of this file constitute Original Code as defined in and
7 * are subject to the Apple Public Source License Version 1.1 (the
8 * "License"). You may not use this file except in compliance with the
9 * License. Please obtain a copy of the License at
10 * http://www.apple.com/publicsource and read it before using this file.
1c79356b 11 *
37839358
A
12 * This Original Code and all software distributed under the License are
13 * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
1c79356b
A
14 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
15 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
37839358
A
16 * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
17 * License for the specific language governing rights and limitations
18 * under the License.
1c79356b
A
19 *
20 * @APPLE_LICENSE_HEADER_END@
21 */
22/*
23 * Copyright (c) 1990, 1991, 1993
24 * The Regents of the University of California. All rights reserved.
25 *
26 * This code is derived from the Stanford/CMU enet packet filter,
27 * (net/enet.c) distributed as part of 4.3BSD, and code contributed
28 * to Berkeley by Steven McCanne and Van Jacobson both of Lawrence
29 * Berkeley Laboratory.
30 *
31 * Redistribution and use in source and binary forms, with or without
32 * modification, are permitted provided that the following conditions
33 * are met:
34 * 1. Redistributions of source code must retain the above copyright
35 * notice, this list of conditions and the following disclaimer.
36 * 2. Redistributions in binary form must reproduce the above copyright
37 * notice, this list of conditions and the following disclaimer in the
38 * documentation and/or other materials provided with the distribution.
39 * 3. All advertising materials mentioning features or use of this software
40 * must display the following acknowledgement:
41 * This product includes software developed by the University of
42 * California, Berkeley and its contributors.
43 * 4. Neither the name of the University nor the names of its contributors
44 * may be used to endorse or promote products derived from this software
45 * without specific prior written permission.
46 *
47 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
48 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
49 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
50 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
51 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
52 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
53 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
54 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
55 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
56 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
57 * SUCH DAMAGE.
58 *
59 * @(#)bpf.h 8.1 (Berkeley) 6/10/93
60 * @(#)bpf.h 1.34 (LBL) 6/16/96
61 *
9bccf70c 62 * $FreeBSD: src/sys/net/bpf.h,v 1.21.2.3 2001/08/01 00:23:13 fenner Exp $
1c79356b
A
63 */
64
65#ifndef _NET_BPF_H_
66#define _NET_BPF_H_
9bccf70c
A
67#include <sys/appleapiopts.h>
68#include <sys/types.h>
69#include <sys/time.h>
91447636
A
70#include <sys/cdefs.h>
71
72#ifdef KERNEL
73#include <sys/kernel_types.h>
74#endif
1c79356b
A
75
76/* BSD style release date */
77#define BPF_RELEASE 199606
78
79typedef int32_t bpf_int32;
80typedef u_int32_t bpf_u_int32;
81
82/*
83 * Alignment macros. BPF_WORDALIGN rounds up to the next
84 * even multiple of BPF_ALIGNMENT.
85 */
86#define BPF_ALIGNMENT sizeof(long)
87#define BPF_WORDALIGN(x) (((x)+(BPF_ALIGNMENT-1))&~(BPF_ALIGNMENT-1))
88
89#define BPF_MAXINSNS 512
91447636 90#define BPF_MAXBUFSIZE 0x80000
1c79356b
A
91#define BPF_MINBUFSIZE 32
92
1c79356b
A
93/*
94 * Structure for BIOCSETF.
95 */
96struct bpf_program {
97 u_int bf_len;
98 struct bpf_insn *bf_insns;
99};
100
91447636
A
101#ifdef KERNEL
102/* LP64 version of bpf_program. all pointers
103 * grow when we're dealing with a 64-bit process.
104 * WARNING - keep in sync with bpf_program
105 */
91447636
A
106struct user_bpf_program {
107 u_int bf_len;
c0fea474 108 user_addr_t bf_insns __attribute__((aligned(8)));
91447636
A
109};
110
91447636
A
111#endif // KERNEL
112
1c79356b
A
113/*
114 * Struct returned by BIOCGSTATS.
115 */
116struct bpf_stat {
117 u_int bs_recv; /* number of packets received */
118 u_int bs_drop; /* number of packets dropped */
119};
120
121/*
122 * Struct return by BIOCVERSION. This represents the version number of
123 * the filter language described by the instruction encodings below.
124 * bpf understands a program iff kernel_major == filter_major &&
125 * kernel_minor >= filter_minor, that is, if the value returned by the
126 * running kernel has the same major number and a minor number equal
127 * equal to or less than the filter being downloaded. Otherwise, the
128 * results are undefined, meaning an error may be returned or packets
129 * may be accepted haphazardly.
130 * It has nothing to do with the source code version.
131 */
132struct bpf_version {
133 u_short bv_major;
134 u_short bv_minor;
135};
136/* Current version number of filter architecture. */
137#define BPF_MAJOR_VERSION 1
138#define BPF_MINOR_VERSION 1
139
140#define BIOCGBLEN _IOR('B',102, u_int)
141#define BIOCSBLEN _IOWR('B',102, u_int)
142#define BIOCSETF _IOW('B',103, struct bpf_program)
143#define BIOCFLUSH _IO('B',104)
144#define BIOCPROMISC _IO('B',105)
145#define BIOCGDLT _IOR('B',106, u_int)
146#define BIOCGETIF _IOR('B',107, struct ifreq)
147#define BIOCSETIF _IOW('B',108, struct ifreq)
148#define BIOCSRTIMEOUT _IOW('B',109, struct timeval)
149#define BIOCGRTIMEOUT _IOR('B',110, struct timeval)
150#define BIOCGSTATS _IOR('B',111, struct bpf_stat)
151#define BIOCIMMEDIATE _IOW('B',112, u_int)
152#define BIOCVERSION _IOR('B',113, struct bpf_version)
153#define BIOCGRSIG _IOR('B',114, u_int)
154#define BIOCSRSIG _IOW('B',115, u_int)
9bccf70c
A
155#define BIOCGHDRCMPLT _IOR('B',116, u_int)
156#define BIOCSHDRCMPLT _IOW('B',117, u_int)
157#define BIOCGSEESENT _IOR('B',118, u_int)
158#define BIOCSSEESENT _IOW('B',119, u_int)
1c79356b
A
159
160/*
161 * Structure prepended to each packet.
162 */
163struct bpf_hdr {
164 struct timeval bh_tstamp; /* time stamp */
165 bpf_u_int32 bh_caplen; /* length of captured portion */
166 bpf_u_int32 bh_datalen; /* original length of packet */
167 u_short bh_hdrlen; /* length of bpf header (this struct
168 plus alignment padding) */
169};
170/*
171 * Because the structure above is not a multiple of 4 bytes, some compilers
172 * will insist on inserting padding; hence, sizeof(struct bpf_hdr) won't work.
173 * Only the kernel needs to know about it; applications use bh_hdrlen.
174 */
175#ifdef KERNEL
176#define SIZEOF_BPF_HDR (sizeof(struct bpf_hdr) <= 20 ? 18 : \
177 sizeof(struct bpf_hdr))
178#endif
179
180/*
181 * Data-link level type codes.
182 */
183#define DLT_NULL 0 /* no link-layer encapsulation */
184#define DLT_EN10MB 1 /* Ethernet (10Mb) */
185#define DLT_EN3MB 2 /* Experimental Ethernet (3Mb) */
186#define DLT_AX25 3 /* Amateur Radio AX.25 */
187#define DLT_PRONET 4 /* Proteon ProNET Token Ring */
188#define DLT_CHAOS 5 /* Chaos */
189#define DLT_IEEE802 6 /* IEEE 802 Networks */
190#define DLT_ARCNET 7 /* ARCNET */
191#define DLT_SLIP 8 /* Serial Line IP */
192#define DLT_PPP 9 /* Point-to-point Protocol */
193#define DLT_FDDI 10 /* FDDI */
194#define DLT_ATM_RFC1483 11 /* LLC/SNAP encapsulated atm */
195#define DLT_RAW 12 /* raw IP */
55e303ae 196#define DLT_APPLE_IP_OVER_IEEE1394 138
9bccf70c
A
197
198/*
199 * These are values from BSD/OS's "bpf.h".
200 * These are not the same as the values from the traditional libpcap
201 * "bpf.h"; however, these values shouldn't be generated by any
202 * OS other than BSD/OS, so the correct values to use here are the
203 * BSD/OS values.
204 *
205 * Platforms that have already assigned these values to other
206 * DLT_ codes, however, should give these codes the values
207 * from that platform, so that programs that use these codes will
208 * continue to compile - even though they won't correctly read
209 * files of these types.
210 */
211#define DLT_SLIP_BSDOS 15 /* BSD/OS Serial Line IP */
212#define DLT_PPP_BSDOS 16 /* BSD/OS Point-to-point Protocol */
213
214#define DLT_ATM_CLIP 19 /* Linux Classical-IP over ATM */
215
216/*
217 * This value is defined by NetBSD; other platforms should refrain from
218 * using it for other purposes, so that NetBSD savefiles with a link
219 * type of 50 can be read as this type on all platforms.
220 */
221#define DLT_PPP_SERIAL 50 /* PPP over serial with HDLC encapsulation */
222
223/*
224 * This value was defined by libpcap 0.5; platforms that have defined
225 * it with a different value should define it here with that value -
226 * a link type of 104 in a save file will be mapped to DLT_C_HDLC,
227 * whatever value that happens to be, so programs will correctly
228 * handle files with that link type regardless of the value of
229 * DLT_C_HDLC.
230 *
231 * The name DLT_C_HDLC was used by BSD/OS; we use that name for source
232 * compatibility with programs written for BSD/OS.
233 *
234 * libpcap 0.5 defined it as DLT_CHDLC; we define DLT_CHDLC as well,
235 * for source compatibility with programs written for libpcap 0.5.
236 */
237#define DLT_C_HDLC 104 /* Cisco HDLC */
238#define DLT_CHDLC DLT_C_HDLC
239
240/*
241 * Reserved for future use.
242 * Do not pick other numerical value for these unless you have also
243 * picked up the tcpdump.org top-of-CVS-tree version of "savefile.c",
244 * which will arrange that capture files for these DLT_ types have
245 * the same "network" value on all platforms, regardless of what
246 * value is chosen for their DLT_ type (thus allowing captures made
247 * on one platform to be read on other platforms, even if the two
248 * platforms don't use the same numerical values for all DLT_ types).
249 */
250#define DLT_IEEE802_11 105 /* IEEE 802.11 wireless */
251
252/*
253 * Values between 106 and 107 are used in capture file headers as
254 * link-layer types corresponding to DLT_ types that might differ
255 * between platforms; don't use those values for new DLT_ new types.
256 */
257
258/*
259 * OpenBSD DLT_LOOP, for loopback devices; it's like DLT_NULL, except
260 * that the AF_ type in the link-layer header is in network byte order.
261 *
262 * OpenBSD defines it as 12, but that collides with DLT_RAW, so we
263 * define it as 108 here. If OpenBSD picks up this file, it should
264 * define DLT_LOOP as 12 in its version, as per the comment above -
265 * and should not use 108 for any purpose.
266 */
267#define DLT_LOOP 108
268
269/*
270 * Values between 109 and 112 are used in capture file headers as
271 * link-layer types corresponding to DLT_ types that might differ
272 * between platforms; don't use those values for new DLT_ new types.
273 */
274
275/*
276 * This is for Linux cooked sockets.
277 */
278#define DLT_LINUX_SLL 113
1c79356b
A
279
280/*
281 * The instruction encodings.
282 */
283/* instruction classes */
284#define BPF_CLASS(code) ((code) & 0x07)
285#define BPF_LD 0x00
286#define BPF_LDX 0x01
287#define BPF_ST 0x02
288#define BPF_STX 0x03
289#define BPF_ALU 0x04
290#define BPF_JMP 0x05
291#define BPF_RET 0x06
292#define BPF_MISC 0x07
293
294/* ld/ldx fields */
295#define BPF_SIZE(code) ((code) & 0x18)
296#define BPF_W 0x00
297#define BPF_H 0x08
298#define BPF_B 0x10
299#define BPF_MODE(code) ((code) & 0xe0)
300#define BPF_IMM 0x00
301#define BPF_ABS 0x20
302#define BPF_IND 0x40
303#define BPF_MEM 0x60
304#define BPF_LEN 0x80
305#define BPF_MSH 0xa0
306
307/* alu/jmp fields */
308#define BPF_OP(code) ((code) & 0xf0)
309#define BPF_ADD 0x00
310#define BPF_SUB 0x10
311#define BPF_MUL 0x20
312#define BPF_DIV 0x30
313#define BPF_OR 0x40
314#define BPF_AND 0x50
315#define BPF_LSH 0x60
316#define BPF_RSH 0x70
317#define BPF_NEG 0x80
318#define BPF_JA 0x00
319#define BPF_JEQ 0x10
320#define BPF_JGT 0x20
321#define BPF_JGE 0x30
322#define BPF_JSET 0x40
323#define BPF_SRC(code) ((code) & 0x08)
324#define BPF_K 0x00
325#define BPF_X 0x08
326
327/* ret - BPF_K and BPF_X also apply */
328#define BPF_RVAL(code) ((code) & 0x18)
329#define BPF_A 0x10
330
331/* misc */
332#define BPF_MISCOP(code) ((code) & 0xf8)
333#define BPF_TAX 0x00
334#define BPF_TXA 0x80
335
336/*
337 * The instruction data structure.
338 */
339struct bpf_insn {
340 u_short code;
341 u_char jt;
342 u_char jf;
343 bpf_u_int32 k;
344};
345
346/*
347 * Macros for insn array initializers.
348 */
349#define BPF_STMT(code, k) { (u_short)(code), 0, 0, k }
350#define BPF_JUMP(code, k, jt, jf) { (u_short)(code), jt, jf, k }
351
91447636 352#ifdef KERNEL_PRIVATE
9bccf70c
A
353/* Forward declerations */
354struct ifnet;
355struct mbuf;
356
91447636
A
357int bpf_validate(const struct bpf_insn *, int);
358void bpf_tap(struct ifnet *, u_char *, u_int);
359void bpf_mtap(struct ifnet *, struct mbuf *);
360
361void bpfdetach(struct ifnet *);
9bccf70c 362
91447636
A
363void bpfilterattach(int);
364u_int bpf_filter(const struct bpf_insn *, u_char *, u_int, u_int);
9bccf70c
A
365
366#ifdef __APPLE__
367#define BPF_TAP(x, y, z) bpf_tap(x,y,z)
368#define BPF_MTAP(x, y) bpf_mtap(x, y)
369#endif /* __APPLE__ */
91447636
A
370
371#endif /* KERNEL_PRIVATE */
372
373#ifdef KERNEL
374/*!
375 @function bpfattach
376 @discussion Registers an interface with BPF. This allows bpf devices
377 to attach to your interface to capture packets. Your interface
378 will be unregistered automatically when your interface is
379 detached.
380 @param interface The interface to register with BPF.
381 @param data_link_type The data link type of the interface. See the
382 DLT_* defines in bpf.h.
383 @param header_length The length, in bytes, of the data link header.
384 */
385void bpfattach(ifnet_t interface, u_int data_link_type, u_int header_length);
9bccf70c 386#endif /* KERNEL */
1c79356b
A
387
388/*
389 * Number of scratch memory words (for BPF_LD|BPF_MEM and BPF_ST).
390 */
391#define BPF_MEMWORDS 16
392
1c79356b 393#endif