root/include/uapi/linux/netfilter/nfnetlink_queue.h

/* [<][>][^][v][top][bottom][index][help] */
#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_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_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_MAX                          (1 << 4)

/* 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 */

/* [<][>][^][v][top][bottom][index][help] */