#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/module.h>
#include <linux/netlink.h>
#include <linux/netfilter.h>
#include <linux/netfilter/nf_tables.h>
#include <net/netfilter/nf_tables_core.h>
#include <net/netfilter/nf_tables.h>
#include <net/netfilter/nf_tables_offload.h>
void nft_immediate_eval(const struct nft_expr *expr,
struct nft_regs *regs,
const struct nft_pktinfo *pkt)
{ … }
static const struct nla_policy nft_immediate_policy[NFTA_IMMEDIATE_MAX + 1] = …;
static enum nft_data_types nft_reg_to_type(const struct nlattr *nla)
{ … }
static int nft_immediate_init(const struct nft_ctx *ctx,
const struct nft_expr *expr,
const struct nlattr * const tb[])
{ … }
static void nft_immediate_activate(const struct nft_ctx *ctx,
const struct nft_expr *expr)
{ … }
static void nft_immediate_chain_deactivate(const struct nft_ctx *ctx,
struct nft_chain *chain,
enum nft_trans_phase phase)
{ … }
static void nft_immediate_deactivate(const struct nft_ctx *ctx,
const struct nft_expr *expr,
enum nft_trans_phase phase)
{ … }
static void nft_immediate_destroy(const struct nft_ctx *ctx,
const struct nft_expr *expr)
{ … }
static int nft_immediate_dump(struct sk_buff *skb,
const struct nft_expr *expr, bool reset)
{ … }
static int nft_immediate_validate(const struct nft_ctx *ctx,
const struct nft_expr *expr,
const struct nft_data **d)
{ … }
static int nft_immediate_offload_verdict(struct nft_offload_ctx *ctx,
struct nft_flow_rule *flow,
const struct nft_immediate_expr *priv)
{ … }
static int nft_immediate_offload(struct nft_offload_ctx *ctx,
struct nft_flow_rule *flow,
const struct nft_expr *expr)
{ … }
static bool nft_immediate_offload_action(const struct nft_expr *expr)
{ … }
static bool nft_immediate_reduce(struct nft_regs_track *track,
const struct nft_expr *expr)
{ … }
static const struct nft_expr_ops nft_imm_ops = …;
struct nft_expr_type nft_imm_type __read_mostly = …;