Blame extensions/libxt_NFQUEUE.c

Packit Service d1fe03
/* Shared library add-on to iptables for NFQ
Packit Service d1fe03
 *
Packit Service d1fe03
 * (C) 2005 by Harald Welte <laforge@netfilter.org>
Packit Service d1fe03
 *
Packit Service d1fe03
 * This program is distributed under the terms of GNU GPL v2, 1991
Packit Service d1fe03
 *
Packit Service d1fe03
 */
Packit Service d1fe03
#include <stdio.h>
Packit Service d1fe03
#include <xtables.h>
Packit Service d1fe03
#include <linux/netfilter/xt_NFQUEUE.h>
Packit Service d1fe03
Packit Service d1fe03
enum {
Packit Service d1fe03
	O_QUEUE_NUM = 0,
Packit Service d1fe03
	O_QUEUE_BALANCE,
Packit Service d1fe03
	O_QUEUE_BYPASS,
Packit Service d1fe03
	O_QUEUE_CPU_FANOUT,
Packit Service d1fe03
	F_QUEUE_NUM     = 1 << O_QUEUE_NUM,
Packit Service d1fe03
	F_QUEUE_BALANCE = 1 << O_QUEUE_BALANCE,
Packit Service d1fe03
	F_QUEUE_CPU_FANOUT = 1 << O_QUEUE_CPU_FANOUT,
Packit Service d1fe03
};
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_help(void)
Packit Service d1fe03
{
Packit Service d1fe03
	printf(
Packit Service d1fe03
"NFQUEUE target options\n"
Packit Service d1fe03
"  --queue-num value		Send packet to QUEUE number <value>.\n"
Packit Service d1fe03
"  		                Valid queue numbers are 0-65535\n"
Packit Service d1fe03
);
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_help_v1(void)
Packit Service d1fe03
{
Packit Service d1fe03
	printf(
Packit Service d1fe03
"NFQUEUE target options\n"
Packit Service d1fe03
"  --queue-num value            Send packet to QUEUE number <value>.\n"
Packit Service d1fe03
"                               Valid queue numbers are 0-65535\n"
Packit Service d1fe03
"  --queue-balance first:last	Balance flows between queues <value> to <value>.\n");
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_help_v2(void)
Packit Service d1fe03
{
Packit Service d1fe03
	printf(
Packit Service d1fe03
"NFQUEUE target options\n"
Packit Service d1fe03
"  --queue-num value            Send packet to QUEUE number <value>.\n"
Packit Service d1fe03
"                               Valid queue numbers are 0-65535\n"
Packit Service d1fe03
"  --queue-balance first:last   Balance flows between queues <value> to <value>.\n"
Packit Service d1fe03
"  --queue-bypass		Bypass Queueing if no queue instance exists.\n"
Packit Service d1fe03
"  --queue-cpu-fanout	Use current CPU (no hashing)\n");
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_help_v3(void)
Packit Service d1fe03
{
Packit Service d1fe03
	printf(
Packit Service d1fe03
"NFQUEUE target options\n"
Packit Service d1fe03
"  --queue-num value            Send packet to QUEUE number <value>.\n"
Packit Service d1fe03
"                               Valid queue numbers are 0-65535\n"
Packit Service d1fe03
"  --queue-balance first:last   Balance flows between queues <value> to <value>.\n"
Packit Service d1fe03
"  --queue-bypass               Bypass Queueing if no queue instance exists.\n"
Packit Service d1fe03
"  --queue-cpu-fanout	Use current CPU (no hashing)\n");
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
#define s struct xt_NFQ_info
Packit Service d1fe03
static const struct xt_option_entry NFQUEUE_opts[] = {
Packit Service d1fe03
	{.name = "queue-num", .id = O_QUEUE_NUM, .type = XTTYPE_UINT16,
Packit Service d1fe03
	 .flags = XTOPT_PUT, XTOPT_POINTER(s, queuenum),
Packit Service d1fe03
	 .excl = F_QUEUE_BALANCE},
Packit Service d1fe03
	{.name = "queue-balance", .id = O_QUEUE_BALANCE,
Packit Service d1fe03
	 .type = XTTYPE_UINT16RC, .excl = F_QUEUE_NUM},
Packit Service d1fe03
	{.name = "queue-bypass", .id = O_QUEUE_BYPASS, .type = XTTYPE_NONE},
Packit Service d1fe03
	{.name = "queue-cpu-fanout", .id = O_QUEUE_CPU_FANOUT,
Packit Service d1fe03
	 .type = XTTYPE_NONE, .also = F_QUEUE_BALANCE},
Packit Service d1fe03
	XTOPT_TABLEEND,
Packit Service d1fe03
};
Packit Service d1fe03
#undef s
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_parse(struct xt_option_call *cb)
Packit Service d1fe03
{
Packit Service d1fe03
	xtables_option_parse(cb);
Packit Service d1fe03
	if (cb->entry->id == O_QUEUE_BALANCE)
Packit Service d1fe03
		xtables_error(PARAMETER_PROBLEM, "NFQUEUE target: "
Packit Service d1fe03
				   "--queue-balance not supported (kernel too old?)");
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_parse_v1(struct xt_option_call *cb)
Packit Service d1fe03
{
Packit Service d1fe03
	struct xt_NFQ_info_v1 *info = cb->data;
Packit Service d1fe03
	const uint16_t *r = cb->val.u16_range;
Packit Service d1fe03
Packit Service d1fe03
	xtables_option_parse(cb);
Packit Service d1fe03
	switch (cb->entry->id) {
Packit Service d1fe03
	case O_QUEUE_BALANCE:
Packit Service d1fe03
		if (cb->nvals != 2)
Packit Service d1fe03
			xtables_error(PARAMETER_PROBLEM,
Packit Service d1fe03
				"Bad range \"%s\"", cb->arg);
Packit Service d1fe03
		if (r[0] >= r[1])
Packit Service d1fe03
			xtables_error(PARAMETER_PROBLEM, "%u should be less than %u",
Packit Service d1fe03
				r[0], r[1]);
Packit Service d1fe03
		info->queuenum = r[0];
Packit Service d1fe03
		info->queues_total = r[1] - r[0] + 1;
Packit Service d1fe03
		break;
Packit Service d1fe03
	}
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_parse_v2(struct xt_option_call *cb)
Packit Service d1fe03
{
Packit Service d1fe03
	struct xt_NFQ_info_v2 *info = cb->data;
Packit Service d1fe03
	const uint16_t *r = cb->val.u16_range;
Packit Service d1fe03
Packit Service d1fe03
	xtables_option_parse(cb);
Packit Service d1fe03
	switch (cb->entry->id) {
Packit Service d1fe03
	case O_QUEUE_BALANCE:
Packit Service d1fe03
		if (cb->nvals != 2)
Packit Service d1fe03
			xtables_error(PARAMETER_PROBLEM,
Packit Service d1fe03
				"Bad range \"%s\"", cb->arg);
Packit Service d1fe03
		if (r[0] >= r[1])
Packit Service d1fe03
			xtables_error(PARAMETER_PROBLEM,
Packit Service d1fe03
				      "%u should be less than %u",
Packit Service d1fe03
				      r[0], r[1]);
Packit Service d1fe03
		info->queuenum = r[0];
Packit Service d1fe03
		info->queues_total = r[1] - r[0] + 1;
Packit Service d1fe03
		break;
Packit Service d1fe03
	case O_QUEUE_BYPASS:
Packit Service d1fe03
		info->bypass |= NFQ_FLAG_BYPASS;
Packit Service d1fe03
		break;
Packit Service d1fe03
	}
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_parse_v3(struct xt_option_call *cb)
Packit Service d1fe03
{
Packit Service d1fe03
	struct xt_NFQ_info_v3 *info = cb->data;
Packit Service d1fe03
	const uint16_t *r = cb->val.u16_range;
Packit Service d1fe03
Packit Service d1fe03
	xtables_option_parse(cb);
Packit Service d1fe03
	switch (cb->entry->id) {
Packit Service d1fe03
	case O_QUEUE_BALANCE:
Packit Service d1fe03
		if (cb->nvals != 2)
Packit Service d1fe03
			xtables_error(PARAMETER_PROBLEM,
Packit Service d1fe03
				"Bad range \"%s\"", cb->arg);
Packit Service d1fe03
		if (r[0] >= r[1])
Packit Service d1fe03
			xtables_error(PARAMETER_PROBLEM,
Packit Service d1fe03
				      "%u should be less than %u",
Packit Service d1fe03
				      r[0], r[1]);
Packit Service d1fe03
		info->queuenum = r[0];
Packit Service d1fe03
		info->queues_total = r[1] - r[0] + 1;
Packit Service d1fe03
		break;
Packit Service d1fe03
	case O_QUEUE_BYPASS:
Packit Service d1fe03
		info->flags |= NFQ_FLAG_BYPASS;
Packit Service d1fe03
		break;
Packit Service d1fe03
	case O_QUEUE_CPU_FANOUT:
Packit Service d1fe03
		info->flags |= NFQ_FLAG_CPU_FANOUT;
Packit Service d1fe03
		break;
Packit Service d1fe03
	}
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_print(const void *ip,
Packit Service d1fe03
                          const struct xt_entry_target *target, int numeric)
Packit Service d1fe03
{
Packit Service d1fe03
	const struct xt_NFQ_info *tinfo =
Packit Service d1fe03
		(const struct xt_NFQ_info *)target->data;
Packit Service d1fe03
	printf(" NFQUEUE num %u", tinfo->queuenum);
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_print_v1(const void *ip,
Packit Service d1fe03
                             const struct xt_entry_target *target, int numeric)
Packit Service d1fe03
{
Packit Service d1fe03
	const struct xt_NFQ_info_v1 *tinfo = (const void *)target->data;
Packit Service d1fe03
	unsigned int last = tinfo->queues_total;
Packit Service d1fe03
Packit Service d1fe03
	if (last > 1) {
Packit Service d1fe03
		last += tinfo->queuenum - 1;
Packit Service d1fe03
		printf(" NFQUEUE balance %u:%u", tinfo->queuenum, last);
Packit Service d1fe03
	} else {
Packit Service d1fe03
		printf(" NFQUEUE num %u", tinfo->queuenum);
Packit Service d1fe03
	}
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_print_v2(const void *ip,
Packit Service d1fe03
                             const struct xt_entry_target *target, int numeric)
Packit Service d1fe03
{
Packit Service d1fe03
	const struct xt_NFQ_info_v2 *info = (void *) target->data;
Packit Service d1fe03
	unsigned int last = info->queues_total;
Packit Service d1fe03
Packit Service d1fe03
	if (last > 1) {
Packit Service d1fe03
		last += info->queuenum - 1;
Packit Service d1fe03
		printf(" NFQUEUE balance %u:%u", info->queuenum, last);
Packit Service d1fe03
	} else
Packit Service d1fe03
		printf(" NFQUEUE num %u", info->queuenum);
Packit Service d1fe03
Packit Service d1fe03
	if (info->bypass & NFQ_FLAG_BYPASS)
Packit Service d1fe03
		printf(" bypass");
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_print_v3(const void *ip,
Packit Service d1fe03
                             const struct xt_entry_target *target, int numeric)
Packit Service d1fe03
{
Packit Service d1fe03
	const struct xt_NFQ_info_v3 *info = (void *)target->data;
Packit Service d1fe03
	unsigned int last = info->queues_total;
Packit Service d1fe03
Packit Service d1fe03
	if (last > 1) {
Packit Service d1fe03
		last += info->queuenum - 1;
Packit Service d1fe03
		printf(" NFQUEUE balance %u:%u", info->queuenum, last);
Packit Service d1fe03
	} else
Packit Service d1fe03
		printf(" NFQUEUE num %u", info->queuenum);
Packit Service d1fe03
Packit Service d1fe03
	if (info->flags & NFQ_FLAG_BYPASS)
Packit Service d1fe03
		printf(" bypass");
Packit Service d1fe03
Packit Service d1fe03
	if (info->flags & NFQ_FLAG_CPU_FANOUT)
Packit Service d1fe03
		printf(" cpu-fanout");
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_save(const void *ip, const struct xt_entry_target *target)
Packit Service d1fe03
{
Packit Service d1fe03
	const struct xt_NFQ_info *tinfo =
Packit Service d1fe03
		(const struct xt_NFQ_info *)target->data;
Packit Service d1fe03
Packit Service d1fe03
	printf(" --queue-num %u", tinfo->queuenum);
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_save_v1(const void *ip, const struct xt_entry_target *target)
Packit Service d1fe03
{
Packit Service d1fe03
	const struct xt_NFQ_info_v1 *tinfo = (const void *)target->data;
Packit Service d1fe03
	unsigned int last = tinfo->queues_total;
Packit Service d1fe03
Packit Service d1fe03
	if (last > 1) {
Packit Service d1fe03
		last += tinfo->queuenum - 1;
Packit Service d1fe03
		printf(" --queue-balance %u:%u", tinfo->queuenum, last);
Packit Service d1fe03
	} else {
Packit Service d1fe03
		printf(" --queue-num %u", tinfo->queuenum);
Packit Service d1fe03
	}
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_save_v2(const void *ip, const struct xt_entry_target *target)
Packit Service d1fe03
{
Packit Service d1fe03
	const struct xt_NFQ_info_v2 *info = (void *) target->data;
Packit Service d1fe03
	unsigned int last = info->queues_total;
Packit Service d1fe03
Packit Service d1fe03
	if (last > 1) {
Packit Service d1fe03
		last += info->queuenum - 1;
Packit Service d1fe03
		printf(" --queue-balance %u:%u", info->queuenum, last);
Packit Service d1fe03
	} else
Packit Service d1fe03
		printf(" --queue-num %u", info->queuenum);
Packit Service d1fe03
Packit Service d1fe03
	if (info->bypass & NFQ_FLAG_BYPASS)
Packit Service d1fe03
		printf(" --queue-bypass");
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_save_v3(const void *ip,
Packit Service d1fe03
			    const struct xt_entry_target *target)
Packit Service d1fe03
{
Packit Service d1fe03
	const struct xt_NFQ_info_v3 *info = (void *)target->data;
Packit Service d1fe03
	unsigned int last = info->queues_total;
Packit Service d1fe03
Packit Service d1fe03
	if (last > 1) {
Packit Service d1fe03
		last += info->queuenum - 1;
Packit Service d1fe03
		printf(" --queue-balance %u:%u", info->queuenum, last);
Packit Service d1fe03
	} else
Packit Service d1fe03
		printf(" --queue-num %u", info->queuenum);
Packit Service d1fe03
Packit Service d1fe03
	if (info->flags & NFQ_FLAG_BYPASS)
Packit Service d1fe03
		printf(" --queue-bypass");
Packit Service d1fe03
Packit Service d1fe03
	if (info->flags & NFQ_FLAG_CPU_FANOUT)
Packit Service d1fe03
		printf(" --queue-cpu-fanout");
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static void NFQUEUE_init_v1(struct xt_entry_target *t)
Packit Service d1fe03
{
Packit Service d1fe03
	struct xt_NFQ_info_v1 *tinfo = (void *)t->data;
Packit Service d1fe03
	tinfo->queues_total = 1;
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static int NFQUEUE_xlate(struct xt_xlate *xl,
Packit Service d1fe03
			 const struct xt_xlate_tg_params *params)
Packit Service d1fe03
{
Packit Service d1fe03
	const struct xt_NFQ_info *tinfo =
Packit Service d1fe03
		(const struct xt_NFQ_info *)params->target->data;
Packit Service d1fe03
Packit Service d1fe03
	xt_xlate_add(xl, "queue num %u ", tinfo->queuenum);
Packit Service d1fe03
Packit Service d1fe03
	return 1;
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static int NFQUEUE_xlate_v1(struct xt_xlate *xl,
Packit Service d1fe03
			    const struct xt_xlate_tg_params *params)
Packit Service d1fe03
{
Packit Service d1fe03
	const struct xt_NFQ_info_v1 *tinfo = (const void *)params->target->data;
Packit Service d1fe03
	unsigned int last = tinfo->queues_total;
Packit Service d1fe03
Packit Service d1fe03
	if (last > 1) {
Packit Service d1fe03
		last += tinfo->queuenum - 1;
Packit Service d1fe03
		xt_xlate_add(xl, "queue num %u-%u ", tinfo->queuenum, last);
Packit Service d1fe03
	} else {
Packit Service d1fe03
		xt_xlate_add(xl, "queue num %u ", tinfo->queuenum);
Packit Service d1fe03
	}
Packit Service d1fe03
Packit Service d1fe03
	return 1;
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static int NFQUEUE_xlate_v2(struct xt_xlate *xl,
Packit Service d1fe03
			    const struct xt_xlate_tg_params *params)
Packit Service d1fe03
{
Packit Service d1fe03
	const struct xt_NFQ_info_v2 *info = (void *)params->target->data;
Packit Service d1fe03
	unsigned int last = info->queues_total;
Packit Service d1fe03
Packit Service d1fe03
	if (last > 1) {
Packit Service d1fe03
		last += info->queuenum - 1;
Packit Service d1fe03
		xt_xlate_add(xl, "queue num %u-%u ", info->queuenum, last);
Packit Service d1fe03
	} else
Packit Service d1fe03
		xt_xlate_add(xl, "queue num %u ", info->queuenum);
Packit Service d1fe03
Packit Service d1fe03
	if (info->bypass & NFQ_FLAG_BYPASS)
Packit Service d1fe03
		xt_xlate_add(xl, "bypass");
Packit Service d1fe03
Packit Service d1fe03
	return 1;
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static int NFQUEUE_xlate_v3(struct xt_xlate *xl,
Packit Service d1fe03
			    const struct xt_xlate_tg_params *params)
Packit Service d1fe03
{
Packit Service d1fe03
	const struct xt_NFQ_info_v3 *info = (void *)params->target->data;
Packit Service d1fe03
	unsigned int last = info->queues_total;
Packit Service d1fe03
Packit Service d1fe03
	if (last > 1) {
Packit Service d1fe03
		last += info->queuenum - 1;
Packit Service d1fe03
		xt_xlate_add(xl, "queue num %u-%u ", info->queuenum, last);
Packit Service d1fe03
	} else
Packit Service d1fe03
		xt_xlate_add(xl, "queue num %u ", info->queuenum);
Packit Service d1fe03
Packit Service d1fe03
	if (info->flags & NFQ_FLAG_BYPASS)
Packit Service d1fe03
		xt_xlate_add(xl, "bypass");
Packit Service d1fe03
Packit Service d1fe03
	if (info->flags & NFQ_FLAG_CPU_FANOUT)
Packit Service d1fe03
		xt_xlate_add(xl, "%sfanout ",
Packit Service d1fe03
			     info->flags & NFQ_FLAG_BYPASS ? "," : "");
Packit Service d1fe03
Packit Service d1fe03
	return 1;
Packit Service d1fe03
}
Packit Service d1fe03
Packit Service d1fe03
static struct xtables_target nfqueue_targets[] = {
Packit Service d1fe03
{
Packit Service d1fe03
	.family		= NFPROTO_UNSPEC,
Packit Service d1fe03
	.name		= "NFQUEUE",
Packit Service d1fe03
	.version	= XTABLES_VERSION,
Packit Service d1fe03
	.size		= XT_ALIGN(sizeof(struct xt_NFQ_info)),
Packit Service d1fe03
	.userspacesize	= XT_ALIGN(sizeof(struct xt_NFQ_info)),
Packit Service d1fe03
	.help		= NFQUEUE_help,
Packit Service d1fe03
	.print		= NFQUEUE_print,
Packit Service d1fe03
	.save		= NFQUEUE_save,
Packit Service d1fe03
	.x6_parse	= NFQUEUE_parse,
Packit Service d1fe03
	.x6_options	= NFQUEUE_opts,
Packit Service d1fe03
	.xlate		= NFQUEUE_xlate,
Packit Service d1fe03
},{
Packit Service d1fe03
	.family		= NFPROTO_UNSPEC,
Packit Service d1fe03
	.revision	= 1,
Packit Service d1fe03
	.name		= "NFQUEUE",
Packit Service d1fe03
	.version	= XTABLES_VERSION,
Packit Service d1fe03
	.size		= XT_ALIGN(sizeof(struct xt_NFQ_info_v1)),
Packit Service d1fe03
	.userspacesize	= XT_ALIGN(sizeof(struct xt_NFQ_info_v1)),
Packit Service d1fe03
	.help		= NFQUEUE_help_v1,
Packit Service d1fe03
	.init		= NFQUEUE_init_v1,
Packit Service d1fe03
	.print		= NFQUEUE_print_v1,
Packit Service d1fe03
	.save		= NFQUEUE_save_v1,
Packit Service d1fe03
	.x6_parse	= NFQUEUE_parse_v1,
Packit Service d1fe03
	.x6_options	= NFQUEUE_opts,
Packit Service d1fe03
	.xlate		= NFQUEUE_xlate_v1,
Packit Service d1fe03
},{
Packit Service d1fe03
	.family		= NFPROTO_UNSPEC,
Packit Service d1fe03
	.revision	= 2,
Packit Service d1fe03
	.name		= "NFQUEUE",
Packit Service d1fe03
	.version	= XTABLES_VERSION,
Packit Service d1fe03
	.size		= XT_ALIGN(sizeof(struct xt_NFQ_info_v2)),
Packit Service d1fe03
	.userspacesize	= XT_ALIGN(sizeof(struct xt_NFQ_info_v2)),
Packit Service d1fe03
	.help		= NFQUEUE_help_v2,
Packit Service d1fe03
	.init		= NFQUEUE_init_v1,
Packit Service d1fe03
	.print		= NFQUEUE_print_v2,
Packit Service d1fe03
	.save		= NFQUEUE_save_v2,
Packit Service d1fe03
	.x6_parse	= NFQUEUE_parse_v2,
Packit Service d1fe03
	.x6_options	= NFQUEUE_opts,
Packit Service d1fe03
	.xlate		= NFQUEUE_xlate_v2,
Packit Service d1fe03
},{
Packit Service d1fe03
	.family		= NFPROTO_UNSPEC,
Packit Service d1fe03
	.revision	= 3,
Packit Service d1fe03
	.name		= "NFQUEUE",
Packit Service d1fe03
	.version	= XTABLES_VERSION,
Packit Service d1fe03
	.size		= XT_ALIGN(sizeof(struct xt_NFQ_info_v3)),
Packit Service d1fe03
	.userspacesize	= XT_ALIGN(sizeof(struct xt_NFQ_info_v3)),
Packit Service d1fe03
	.help		= NFQUEUE_help_v3,
Packit Service d1fe03
	.init		= NFQUEUE_init_v1,
Packit Service d1fe03
	.print		= NFQUEUE_print_v3,
Packit Service d1fe03
	.save		= NFQUEUE_save_v3,
Packit Service d1fe03
	.x6_parse	= NFQUEUE_parse_v3,
Packit Service d1fe03
	.x6_options	= NFQUEUE_opts,
Packit Service d1fe03
	.xlate		= NFQUEUE_xlate_v3,
Packit Service d1fe03
}
Packit Service d1fe03
};
Packit Service d1fe03
Packit Service d1fe03
void _init(void)
Packit Service d1fe03
{
Packit Service d1fe03
	xtables_register_targets(nfqueue_targets, ARRAY_SIZE(nfqueue_targets));
Packit Service d1fe03
}