]> git.saurik.com Git - apple/xnu.git/blobdiff - bsd/man/man4/bpf.4
xnu-1504.15.3.tar.gz
[apple/xnu.git] / bsd / man / man4 / bpf.4
index b79476efc8f7f51ef2c51652080b1e48f71fea96..289a59071aa7ccf5f67e96b0117c63e03819cf52 100644 (file)
@@ -82,10 +82,6 @@ and
 drivers have been modified to interact with
 .Nm .
 .Pp
-Since packet data is in network byte order, applications should use the
-.Xr byteorder 3
-macros to extract multi-byte values.
-.Pp
 A packet can be sent out on the network by writing to a
 .Nm
 file descriptor.  The writes are unbuffered, meaning only one
@@ -93,6 +89,10 @@ packet can be processed per write.
 Currently, only writes to Ethernets and
 .Tn SLIP
 links are supported.
+.Pp
+When the last minor device is opened, an additional minor device is 
+created on demand. The maximum number of devices that can be created is 
+controlled by the sysctl debug.bpf_maxdevices.
 .Sh IOCTLS
 The
 .Xr ioctl 2
@@ -151,6 +151,32 @@ The device types, prefixed with
 .Dq Li DLT_ ,
 are defined in
 .Aq Pa net/bpf.h .
+.It Dv BIOCSDLT
+.Pq Li u_int
+Used to specify the type of data link layer of the interface 
+attached to the bpf descriptor. If the current interface is 
+not of the given type then the descriptor will be reattached 
+to an interface of the given type. If the descriptor has 
+promiscuous mode set, the new interface will be moved to 
+promiscuous mode.
+.Er EINVAL
+is returned if no interface has been specified.
+The device types, prefixed with
+.Dq Li DLT_ ,
+are defined in
+.Aq Pa net/bpf.h .
+.It Dv BIOCGDLTLIST
+.Pq Li struct bpf_dltlist
+Returns a list of data link types of the the given interface. 
+A user allocated buffer to hold the list and length of expected 
+list should be provided in struct bpf_dltlist, defined in
+.Aq Pa net/bpf.h .
+.Er EINVAL
+is returned if no interface has been specified.
+The device types, prefixed with
+.Dq Li DLT_ ,
+are defined in
+.Aq Pa net/bpf.h .
 .It Dv BIOCPROMISC
 Forces the interface into promiscuous mode.
 All packets, not just those destined for the local host, are processed.
@@ -291,6 +317,12 @@ interface should be returned by BPF.  Set to zero to see only incoming
 packets on the interface.  Set to one to see packets originating
 locally and remotely on the interface.  This flag is initialized to one by
 default.
+.It Dv BIOCGRSIG
+.Pq Li u_int
+Returns the signal that will be sent to a process waiting on the bpf descriptor upon packet reception. The default is SIGIO.
+.It Dv BIOCSRSIG
+.Pq Li u_int
+Sets the signal that should be sent to a process waiting on bpf descriptor upon packet reception. The default is SIGIO.
 .El
 .Sh BPF HEADER
 The following structure is prepended to each packet returned by
@@ -690,9 +722,7 @@ struct bpf_insn insns[] = {
 .Ed
 .Sh SEE ALSO
 .Xr tcpdump 1 ,
-.Xr ioctl 2 ,
-.Xr byteorder 3 ,
-.Xr ng_bpf 4
+.Xr ioctl 2 
 .Rs
 .%A McCanne, S.
 .%A Jacobson V.