2  * Linux Socket Filter Data Structures
 
   5 #ifndef __LINUX_FILTER_H__
 
   6 #define __LINUX_FILTER_H__
 
   8 #include <linux/compiler.h>
 
   9 #include <linux/types.h>
 
  12 #include <asm/atomic.h>
 
  16  * Current version of the filter code architecture.
 
  18 #define BPF_MAJOR_VERSION 1
 
  19 #define BPF_MINOR_VERSION 1
 
  22  *      Try and keep these values and structures similar to BSD, especially
 
  23  *      the BPF code definitions which need to match so you can share filters
 
  26 struct sock_filter      /* Filter block */
 
  28         __u16   code;   /* Actual filter code */
 
  29         __u8    jt;     /* Jump true */
 
  30         __u8    jf;     /* Jump false */
 
  31         __u32   k;      /* Generic multiuse field */
 
  34 struct sock_fprog       /* Required for SO_ATTACH_FILTER. */
 
  36         unsigned short          len;    /* Number of filter blocks */
 
  37         struct sock_filter __user *filter;
 
  44         unsigned int            len;    /* Number of filter blocks */
 
  46         struct sock_filter      insns[0];
 
  49 static inline unsigned int sk_filter_len(struct sk_filter *fp)
 
  51         return fp->len*sizeof(struct sock_filter) + sizeof(*fp);
 
  59 #define BPF_CLASS(code) ((code) & 0x07)
 
  70 #define BPF_SIZE(code)  ((code) & 0x18)
 
  74 #define BPF_MODE(code)  ((code) & 0xe0)
 
  83 #define BPF_OP(code)    ((code) & 0xf0)
 
  98 #define BPF_SRC(code)   ((code) & 0x08)
 
 102 /* ret - BPF_K and BPF_X also apply */
 
 103 #define BPF_RVAL(code)  ((code) & 0x18)
 
 107 #define BPF_MISCOP(code) ((code) & 0xf8)
 
 112 #define BPF_MAXINSNS 4096
 
 116  * Macros for filter block array initializers.
 
 119 #define BPF_STMT(code, k) { (unsigned short)(code), 0, 0, k }
 
 122 #define BPF_JUMP(code, k, jt, jf) { (unsigned short)(code), jt, jf, k }
 
 126  * Number of scratch memory words for: BPF_ST and BPF_STX
 
 128 #define BPF_MEMWORDS 16
 
 130 /* RATIONALE. Negative offsets are invalid in BPF.
 
 131    We use them to reference ancillary data.
 
 132    Unlike introduction new instructions, it does not break
 
 133    existing compilers/optimizers.
 
 135 #define SKF_AD_OFF    (-0x1000)
 
 136 #define SKF_AD_PROTOCOL 0
 
 137 #define SKF_AD_PKTTYPE  4
 
 138 #define SKF_AD_IFINDEX  8
 
 139 #define SKF_AD_MAX      12
 
 140 #define SKF_NET_OFF   (-0x100000)
 
 141 #define SKF_LL_OFF    (-0x200000)
 
 147 extern unsigned int sk_run_filter(struct sk_buff *skb, struct sock_filter *filter, int flen);
 
 148 extern int sk_attach_filter(struct sock_fprog *fprog, struct sock *sk);
 
 149 extern int sk_detach_filter(struct sock *sk);
 
 150 extern int sk_chk_filter(struct sock_filter *filter, int flen);
 
 151 #endif /* __KERNEL__ */
 
 153 #endif /* __LINUX_FILTER_H__ */