Release 4.18 include/uapi/linux/netfilter/nfnetlink_queue.h
  
  
  
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
#ifndef _NFNETLINK_QUEUE_H
#define _NFNETLINK_QUEUE_H
#include <linux/types.h>
#include <linux/netfilter/nfnetlink.h>
enum nfqnl_msg_types {
	
NFQNL_MSG_PACKET,		/* packet from kernel to userspace */
	
NFQNL_MSG_VERDICT,		/* verdict from userspace to kernel */
	
NFQNL_MSG_CONFIG,		/* connect to a particular queue */
	
NFQNL_MSG_VERDICT_BATCH,	/* batchv from userspace to kernel */
	
NFQNL_MSG_MAX
};
struct nfqnl_msg_packet_hdr {
	
__be32		packet_id;	/* unique ID of packet in queue */
	
__be16		hw_protocol;	/* hw protocol (network order) */
	
__u8	hook;		/* netfilter hook */
} __attribute__ ((packed));
struct nfqnl_msg_packet_hw {
	
__be16		hw_addrlen;
	
__u16	_pad;
	
__u8	hw_addr[8];
};
struct nfqnl_msg_packet_timestamp {
	
__aligned_be64	sec;
	
__aligned_be64	usec;
};
enum nfqnl_vlan_attr {
	
NFQA_VLAN_UNSPEC,
	
NFQA_VLAN_PROTO,		/* __be16 skb vlan_proto */
	
NFQA_VLAN_TCI,			/* __be16 skb htons(vlan_tci) */
	
__NFQA_VLAN_MAX,
};
#define NFQA_VLAN_MAX (__NFQA_VLAN_MAX - 1)
enum nfqnl_attr_type {
	
NFQA_UNSPEC,
	
NFQA_PACKET_HDR,
	
NFQA_VERDICT_HDR,		/* nfqnl_msg_verdict_hrd */
	
NFQA_MARK,			/* __u32 nfmark */
	
NFQA_TIMESTAMP,			/* nfqnl_msg_packet_timestamp */
	
NFQA_IFINDEX_INDEV,		/* __u32 ifindex */
	
NFQA_IFINDEX_OUTDEV,		/* __u32 ifindex */
	
NFQA_IFINDEX_PHYSINDEV,		/* __u32 ifindex */
	
NFQA_IFINDEX_PHYSOUTDEV,	/* __u32 ifindex */
	
NFQA_HWADDR,			/* nfqnl_msg_packet_hw */
	
NFQA_PAYLOAD,			/* opaque data payload */
	
NFQA_CT,			/* nf_conntrack_netlink.h */
	
NFQA_CT_INFO,			/* enum ip_conntrack_info */
	
NFQA_CAP_LEN,			/* __u32 length of captured packet */
	
NFQA_SKB_INFO,			/* __u32 skb meta information */
	
NFQA_EXP,			/* nf_conntrack_netlink.h */
	
NFQA_UID,			/* __u32 sk uid */
	
NFQA_GID,			/* __u32 sk gid */
	
NFQA_SECCTX,			/* security context string */
	
NFQA_VLAN,			/* nested attribute: packet vlan info */
	
NFQA_L2HDR,			/* full L2 header */
	
__NFQA_MAX
};
#define NFQA_MAX (__NFQA_MAX - 1)
struct nfqnl_msg_verdict_hdr {
	
__be32 verdict;
	
__be32 id;
};
enum nfqnl_msg_config_cmds {
	
NFQNL_CFG_CMD_NONE,
	
NFQNL_CFG_CMD_BIND,
	
NFQNL_CFG_CMD_UNBIND,
	
NFQNL_CFG_CMD_PF_BIND,
	
NFQNL_CFG_CMD_PF_UNBIND,
};
struct nfqnl_msg_config_cmd {
	
__u8	command;	/* nfqnl_msg_config_cmds */
	
__u8	_pad;
	
__be16		pf;		/* AF_xxx for PF_[UN]BIND */
};
enum nfqnl_config_mode {
	
NFQNL_COPY_NONE,
	
NFQNL_COPY_META,
	
NFQNL_COPY_PACKET,
};
struct nfqnl_msg_config_params {
	
__be32		copy_range;
	
__u8	copy_mode;	/* enum nfqnl_config_mode */
} __attribute__ ((packed));
enum nfqnl_attr_config {
	
NFQA_CFG_UNSPEC,
	
NFQA_CFG_CMD,			/* nfqnl_msg_config_cmd */
	
NFQA_CFG_PARAMS,		/* nfqnl_msg_config_params */
	
NFQA_CFG_QUEUE_MAXLEN,		/* __u32 */
	
NFQA_CFG_MASK,			/* identify which flags to change */
	
NFQA_CFG_FLAGS,			/* value of these flags (__u32) */
	
__NFQA_CFG_MAX
};
#define NFQA_CFG_MAX (__NFQA_CFG_MAX-1)
/* Flags for NFQA_CFG_FLAGS */
#define NFQA_CFG_F_FAIL_OPEN			(1 << 0)
#define NFQA_CFG_F_CONNTRACK			(1 << 1)
#define NFQA_CFG_F_GSO				(1 << 2)
#define NFQA_CFG_F_UID_GID			(1 << 3)
#define NFQA_CFG_F_SECCTX			(1 << 4)
#define NFQA_CFG_F_MAX				(1 << 5)
/* flags for NFQA_SKB_INFO */
/* packet appears to have wrong checksums, but they are ok */
#define NFQA_SKB_CSUMNOTREADY (1 << 0)
/* packet is GSO (i.e., exceeds device mtu) */
#define NFQA_SKB_GSO (1 << 1)
/* csum not validated (incoming device doesn't support hw checksum, etc.) */
#define NFQA_SKB_CSUM_NOTVERIFIED (1 << 2)
#endif /* _NFNETLINK_QUEUE_H */
Overall Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Harald Welte | 189 | 60.77% | 4 | 18.18% | 
| Florian Westphal | 26 | 8.36% | 4 | 18.18% | 
| Stephane Bryant | 23 | 7.40% | 1 | 4.55% | 
| Pablo Neira Ayuso | 16 | 5.14% | 3 | 13.64% | 
| Krishna Kumar | 14 | 4.50% | 2 | 9.09% | 
| Arnd Bergmann | 12 | 3.86% | 1 | 4.55% | 
| Valentina Giusti | 10 | 3.22% | 1 | 4.55% | 
| Roman Kubiak | 8 | 2.57% | 1 | 4.55% | 
| Al Viro | 7 | 2.25% | 1 | 4.55% | 
| Eric Leblond | 2 | 0.64% | 1 | 4.55% | 
| Mike Frysinger | 2 | 0.64% | 1 | 4.55% | 
| Ken-ichirou MATSUZAWA | 1 | 0.32% | 1 | 4.55% | 
| Greg Kroah-Hartman | 1 | 0.32% | 1 | 4.55% | 
| Total | 311 | 100.00% | 22 | 100.00% | 
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.