blob: f9977b3311f75692239c2f7c32ca7a417ed3eddb [file] [log] [blame]
Harald Welte2e4e6a12006-01-12 13:30:04 -08001/* iptables module for using new netfilter netlink queue
2 *
3 * (C) 2005 by Harald Welte <laforge@netfilter.org>
4 *
5 * This program is free software; you can redistribute it and/or modify
YOSHIFUJI Hideaki601e68e2007-02-12 11:15:49 -08006 * it under the terms of the GNU General Public License version 2 as
Harald Welte2e4e6a12006-01-12 13:30:04 -08007 * published by the Free Software Foundation.
YOSHIFUJI Hideaki601e68e2007-02-12 11:15:49 -08008 *
Harald Welte2e4e6a12006-01-12 13:30:04 -08009 */
10
11#include <linux/module.h>
12#include <linux/skbuff.h>
13
14#include <linux/netfilter.h>
15#include <linux/netfilter_arp.h>
16#include <linux/netfilter/x_tables.h>
17#include <linux/netfilter/xt_NFQUEUE.h>
18
19MODULE_AUTHOR("Harald Welte <laforge@netfilter.org>");
Jan Engelhardt2ae15b62008-01-14 23:42:28 -080020MODULE_DESCRIPTION("Xtables: packet forwarding to netlink");
Harald Welte2e4e6a12006-01-12 13:30:04 -080021MODULE_LICENSE("GPL");
22MODULE_ALIAS("ipt_NFQUEUE");
23MODULE_ALIAS("ip6t_NFQUEUE");
24MODULE_ALIAS("arpt_NFQUEUE");
25
26static unsigned int
Jan Engelhardt7eb35582008-10-08 11:35:19 +020027nfqueue_tg(struct sk_buff *skb, const struct xt_target_param *par)
Harald Welte2e4e6a12006-01-12 13:30:04 -080028{
Jan Engelhardt7eb35582008-10-08 11:35:19 +020029 const struct xt_NFQ_info *tinfo = par->targinfo;
Harald Welte2e4e6a12006-01-12 13:30:04 -080030
31 return NF_QUEUE_NR(tinfo->queuenum);
32}
33
Jan Engelhardtd3c5ee62007-12-04 23:24:03 -080034static struct xt_target nfqueue_tg_reg[] __read_mostly = {
Patrick McHardy4470bbc2006-08-22 00:34:04 -070035 {
36 .name = "NFQUEUE",
Jan Engelhardtee999d82008-10-08 11:35:01 +020037 .family = NFPROTO_IPV4,
Jan Engelhardtd3c5ee62007-12-04 23:24:03 -080038 .target = nfqueue_tg,
Patrick McHardy4470bbc2006-08-22 00:34:04 -070039 .targetsize = sizeof(struct xt_NFQ_info),
40 .me = THIS_MODULE,
41 },
42 {
43 .name = "NFQUEUE",
Jan Engelhardtee999d82008-10-08 11:35:01 +020044 .family = NFPROTO_IPV6,
Jan Engelhardtd3c5ee62007-12-04 23:24:03 -080045 .target = nfqueue_tg,
Patrick McHardy4470bbc2006-08-22 00:34:04 -070046 .targetsize = sizeof(struct xt_NFQ_info),
47 .me = THIS_MODULE,
48 },
49 {
50 .name = "NFQUEUE",
Jan Engelhardtfdc93142008-10-20 03:34:51 -070051 .family = NFPROTO_ARP,
Jan Engelhardtd3c5ee62007-12-04 23:24:03 -080052 .target = nfqueue_tg,
Patrick McHardy4470bbc2006-08-22 00:34:04 -070053 .targetsize = sizeof(struct xt_NFQ_info),
54 .me = THIS_MODULE,
55 },
Harald Welte2e4e6a12006-01-12 13:30:04 -080056};
57
Jan Engelhardtd3c5ee62007-12-04 23:24:03 -080058static int __init nfqueue_tg_init(void)
Harald Welte2e4e6a12006-01-12 13:30:04 -080059{
Jan Engelhardtd3c5ee62007-12-04 23:24:03 -080060 return xt_register_targets(nfqueue_tg_reg, ARRAY_SIZE(nfqueue_tg_reg));
Harald Welte2e4e6a12006-01-12 13:30:04 -080061}
62
Jan Engelhardtd3c5ee62007-12-04 23:24:03 -080063static void __exit nfqueue_tg_exit(void)
Harald Welte2e4e6a12006-01-12 13:30:04 -080064{
Jan Engelhardtd3c5ee62007-12-04 23:24:03 -080065 xt_unregister_targets(nfqueue_tg_reg, ARRAY_SIZE(nfqueue_tg_reg));
Harald Welte2e4e6a12006-01-12 13:30:04 -080066}
67
Jan Engelhardtd3c5ee62007-12-04 23:24:03 -080068module_init(nfqueue_tg_init);
69module_exit(nfqueue_tg_exit);