Blame include/libnetfilter_queue/linux_nfnetlink_queue.h

Packit c43939
#ifndef _NFNETLINK_QUEUE_H
Packit c43939
#define _NFNETLINK_QUEUE_H
Packit c43939
Packit c43939
#ifndef aligned_u64
Packit c43939
#define aligned_u64 unsigned long long __attribute__((aligned(8)))
Packit c43939
#endif
Packit c43939
Packit c43939
#include <linux/types.h>
Packit c43939
#include <libnfnetlink/linux_nfnetlink.h>
Packit c43939
Packit c43939
enum nfqnl_msg_types {
Packit c43939
	NFQNL_MSG_PACKET,		/* packet from kernel to userspace */
Packit c43939
	NFQNL_MSG_VERDICT,		/* verdict from userspace to kernel */
Packit c43939
	NFQNL_MSG_CONFIG,		/* connect to a particular queue */
Packit c43939
	NFQNL_MSG_VERDICT_BATCH,	/* batchv from userspace to kernel */
Packit c43939
Packit c43939
	NFQNL_MSG_MAX
Packit c43939
};
Packit c43939
Packit c43939
struct nfqnl_msg_packet_hdr {
Packit c43939
	__be32		packet_id;	/* unique ID of packet in queue */
Packit c43939
	__be16		hw_protocol;	/* hw protocol (network order) */
Packit c43939
	__u8	hook;		/* netfilter hook */
Packit c43939
} __attribute__ ((packed));
Packit c43939
Packit c43939
struct nfqnl_msg_packet_hw {
Packit c43939
	__be16		hw_addrlen;
Packit c43939
	__u16	_pad;
Packit c43939
	__u8	hw_addr[8];
Packit c43939
};
Packit c43939
Packit c43939
struct nfqnl_msg_packet_timestamp {
Packit c43939
	__aligned_be64	sec;
Packit c43939
	__aligned_be64	usec;
Packit c43939
};
Packit c43939
Packit c43939
enum nfqnl_attr_type {
Packit c43939
	NFQA_UNSPEC,
Packit c43939
	NFQA_PACKET_HDR,
Packit c43939
	NFQA_VERDICT_HDR,		/* nfqnl_msg_verdict_hrd */
Packit c43939
	NFQA_MARK,			/* __u32 nfmark */
Packit c43939
	NFQA_TIMESTAMP,			/* nfqnl_msg_packet_timestamp */
Packit c43939
	NFQA_IFINDEX_INDEV,		/* __u32 ifindex */
Packit c43939
	NFQA_IFINDEX_OUTDEV,		/* __u32 ifindex */
Packit c43939
	NFQA_IFINDEX_PHYSINDEV,		/* __u32 ifindex */
Packit c43939
	NFQA_IFINDEX_PHYSOUTDEV,	/* __u32 ifindex */
Packit c43939
	NFQA_HWADDR,			/* nfqnl_msg_packet_hw */
Packit c43939
	NFQA_PAYLOAD,			/* opaque data payload */
Packit c43939
	NFQA_CT,			/* nf_conntrack_netlink.h */
Packit c43939
	NFQA_CT_INFO,			/* enum ip_conntrack_info */
Packit c43939
	NFQA_CAP_LEN,			/* __u32 length of captured packet */
Packit c43939
	NFQA_SKB_INFO,			/* __u32 skb meta information */
Packit c43939
	NFQA_EXP,			/* nf_conntrack_netlink.h */
Packit c43939
	NFQA_UID,			/* __u32 sk uid */
Packit c43939
	NFQA_GID,			/* __u32 sk gid */
Packit c43939
	NFQA_SECCTX,			/* security context string */
Packit c43939
Packit c43939
	__NFQA_MAX
Packit c43939
};
Packit c43939
#define NFQA_MAX (__NFQA_MAX - 1)
Packit c43939
Packit c43939
struct nfqnl_msg_verdict_hdr {
Packit c43939
	__be32 verdict;
Packit c43939
	__be32 id;
Packit c43939
};
Packit c43939
Packit c43939
Packit c43939
enum nfqnl_msg_config_cmds {
Packit c43939
	NFQNL_CFG_CMD_NONE,
Packit c43939
	NFQNL_CFG_CMD_BIND,
Packit c43939
	NFQNL_CFG_CMD_UNBIND,
Packit c43939
	NFQNL_CFG_CMD_PF_BIND,
Packit c43939
	NFQNL_CFG_CMD_PF_UNBIND,
Packit c43939
};
Packit c43939
Packit c43939
struct nfqnl_msg_config_cmd {
Packit c43939
	__u8	command;	/* nfqnl_msg_config_cmds */
Packit c43939
	__u8	_pad;
Packit c43939
	__be16		pf;		/* AF_xxx for PF_[UN]BIND */
Packit c43939
};
Packit c43939
Packit c43939
enum nfqnl_config_mode {
Packit c43939
	NFQNL_COPY_NONE,
Packit c43939
	NFQNL_COPY_META,
Packit c43939
	NFQNL_COPY_PACKET,
Packit c43939
};
Packit c43939
Packit c43939
struct nfqnl_msg_config_params {
Packit c43939
	__be32		copy_range;
Packit c43939
	__u8	copy_mode;	/* enum nfqnl_config_mode */
Packit c43939
} __attribute__ ((packed));
Packit c43939
Packit c43939
Packit c43939
enum nfqnl_attr_config {
Packit c43939
	NFQA_CFG_UNSPEC,
Packit c43939
	NFQA_CFG_CMD,			/* nfqnl_msg_config_cmd */
Packit c43939
	NFQA_CFG_PARAMS,		/* nfqnl_msg_config_params */
Packit c43939
	NFQA_CFG_QUEUE_MAXLEN,		/* __u32 */
Packit c43939
	NFQA_CFG_MASK,			/* identify which flags to change */
Packit c43939
	NFQA_CFG_FLAGS,			/* value of these flags (__u32) */
Packit c43939
	__NFQA_CFG_MAX
Packit c43939
};
Packit c43939
#define NFQA_CFG_MAX (__NFQA_CFG_MAX-1)
Packit c43939
Packit c43939
/* Flags for NFQA_CFG_FLAGS */
Packit c43939
#define NFQA_CFG_F_FAIL_OPEN			(1 << 0)
Packit c43939
#define NFQA_CFG_F_CONNTRACK			(1 << 1)
Packit c43939
#define NFQA_CFG_F_GSO				(1 << 2)
Packit c43939
#define NFQA_CFG_F_UID_GID			(1 << 3)
Packit c43939
#define NFQA_CFG_F_SECCTX			(1 << 4)
Packit c43939
#define NFQA_CFG_F_MAX				(1 << 5)
Packit c43939
Packit c43939
/* flags for NFQA_SKB_INFO */
Packit c43939
/* packet appears to have wrong checksums, but they are ok */
Packit c43939
#define NFQA_SKB_CSUMNOTREADY (1 << 0)
Packit c43939
/* packet is GSO (i.e., exceeds device mtu) */
Packit c43939
#define NFQA_SKB_GSO (1 << 1)
Packit c43939
/* csum not validated (incoming device doesn't support hw checksum, etc.) */
Packit c43939
#define NFQA_SKB_CSUM_NOTVERIFIED (1 << 2)
Packit c43939
Packit c43939
#endif /* _NFNETLINK_QUEUE_H */