Blame include/uapi/linux/filter.h

Packit d3f73b
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
Packit d3f73b
/*
Packit d3f73b
 * Linux Socket Filter Data Structures
Packit d3f73b
 */
Packit d3f73b
Packit d3f73b
#ifndef __LINUX_FILTER_H__
Packit d3f73b
#define __LINUX_FILTER_H__
Packit d3f73b
Packit d3f73b
Packit d3f73b
#include <linux/types.h>
Packit d3f73b
#include <linux/bpf_common.h>
Packit d3f73b
Packit d3f73b
/*
Packit d3f73b
 * Current version of the filter code architecture.
Packit d3f73b
 */
Packit d3f73b
#define BPF_MAJOR_VERSION 1
Packit d3f73b
#define BPF_MINOR_VERSION 1
Packit d3f73b
Packit d3f73b
/*
Packit d3f73b
 *	Try and keep these values and structures similar to BSD, especially
Packit d3f73b
 *	the BPF code definitions which need to match so you can share filters
Packit d3f73b
 */
Packit d3f73b
 
Packit d3f73b
struct sock_filter {	/* Filter block */
Packit d3f73b
	__u16	code;   /* Actual filter code */
Packit d3f73b
	__u8	jt;	/* Jump true */
Packit d3f73b
	__u8	jf;	/* Jump false */
Packit d3f73b
	__u32	k;      /* Generic multiuse field */
Packit d3f73b
};
Packit d3f73b
Packit d3f73b
struct sock_fprog {	/* Required for SO_ATTACH_FILTER. */
Packit d3f73b
	unsigned short		len;	/* Number of filter blocks */
Packit d3f73b
	struct sock_filter *filter;
Packit d3f73b
};
Packit d3f73b
Packit d3f73b
/* ret - BPF_K and BPF_X also apply */
Packit d3f73b
#define BPF_RVAL(code)  ((code) & 0x18)
Packit d3f73b
#define         BPF_A           0x10
Packit d3f73b
Packit d3f73b
/* misc */
Packit d3f73b
#define BPF_MISCOP(code) ((code) & 0xf8)
Packit d3f73b
#define         BPF_TAX         0x00
Packit d3f73b
#define         BPF_TXA         0x80
Packit d3f73b
Packit d3f73b
/*
Packit d3f73b
 * Macros for filter block array initializers.
Packit d3f73b
 */
Packit d3f73b
#ifndef BPF_STMT
Packit d3f73b
#define BPF_STMT(code, k) { (unsigned short)(code), 0, 0, k }
Packit d3f73b
#endif
Packit d3f73b
#ifndef BPF_JUMP
Packit d3f73b
#define BPF_JUMP(code, k, jt, jf) { (unsigned short)(code), jt, jf, k }
Packit d3f73b
#endif
Packit d3f73b
Packit d3f73b
/*
Packit d3f73b
 * Number of scratch memory words for: BPF_ST and BPF_STX
Packit d3f73b
 */
Packit d3f73b
#define BPF_MEMWORDS 16
Packit d3f73b
Packit d3f73b
/* RATIONALE. Negative offsets are invalid in BPF.
Packit d3f73b
   We use them to reference ancillary data.
Packit d3f73b
   Unlike introduction new instructions, it does not break
Packit d3f73b
   existing compilers/optimizers.
Packit d3f73b
 */
Packit d3f73b
#define SKF_AD_OFF    (-0x1000)
Packit d3f73b
#define SKF_AD_PROTOCOL 0
Packit d3f73b
#define SKF_AD_PKTTYPE 	4
Packit d3f73b
#define SKF_AD_IFINDEX 	8
Packit d3f73b
#define SKF_AD_NLATTR	12
Packit d3f73b
#define SKF_AD_NLATTR_NEST	16
Packit d3f73b
#define SKF_AD_MARK 	20
Packit d3f73b
#define SKF_AD_QUEUE	24
Packit d3f73b
#define SKF_AD_HATYPE	28
Packit d3f73b
#define SKF_AD_RXHASH	32
Packit d3f73b
#define SKF_AD_CPU	36
Packit d3f73b
#define SKF_AD_ALU_XOR_X	40
Packit d3f73b
#define SKF_AD_VLAN_TAG	44
Packit d3f73b
#define SKF_AD_VLAN_TAG_PRESENT 48
Packit d3f73b
#define SKF_AD_PAY_OFFSET	52
Packit d3f73b
#define SKF_AD_RANDOM	56
Packit d3f73b
#define SKF_AD_VLAN_TPID	60
Packit d3f73b
#define SKF_AD_MAX	64
Packit d3f73b
Packit d3f73b
#define SKF_NET_OFF	(-0x100000)
Packit d3f73b
#define SKF_LL_OFF	(-0x200000)
Packit d3f73b
Packit d3f73b
#define BPF_NET_OFF	SKF_NET_OFF
Packit d3f73b
#define BPF_LL_OFF	SKF_LL_OFF
Packit d3f73b
Packit d3f73b
#endif /* __LINUX_FILTER_H__ */