]> git.karo-electronics.de Git - mv-sheeva.git/blob - net/netfilter/xt_NFQUEUE.c
[NETFILTER]: Convert x_tables matches/targets to centralized error checking
[mv-sheeva.git] / net / netfilter / xt_NFQUEUE.c
1 /* 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
6  * it under the terms of the GNU General Public License version 2 as 
7  * published by the Free Software Foundation.
8  * 
9  */
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
19 MODULE_AUTHOR("Harald Welte <laforge@netfilter.org>");
20 MODULE_DESCRIPTION("[ip,ip6,arp]_tables NFQUEUE target");
21 MODULE_LICENSE("GPL");
22 MODULE_ALIAS("ipt_NFQUEUE");
23 MODULE_ALIAS("ip6t_NFQUEUE");
24 MODULE_ALIAS("arpt_NFQUEUE");
25
26 static unsigned int
27 target(struct sk_buff **pskb,
28        const struct net_device *in,
29        const struct net_device *out,
30        unsigned int hooknum,
31        const void *targinfo,
32        void *userinfo)
33 {
34         const struct xt_NFQ_info *tinfo = targinfo;
35
36         return NF_QUEUE_NR(tinfo->queuenum);
37 }
38
39 static struct xt_target ipt_NFQ_reg = {
40         .name           = "NFQUEUE",
41         .target         = target,
42         .targetsize     = sizeof(struct xt_NFQ_info),
43         .me             = THIS_MODULE,
44 };
45
46 static struct xt_target ip6t_NFQ_reg = {
47         .name           = "NFQUEUE",
48         .target         = target,
49         .targetsize     = sizeof(struct xt_NFQ_info),
50         .me             = THIS_MODULE,
51 };
52
53 static struct xt_target arpt_NFQ_reg = {
54         .name           = "NFQUEUE",
55         .target         = target,
56         .targetsize     = sizeof(struct xt_NFQ_info),
57         .me             = THIS_MODULE,
58 };
59
60 static int __init init(void)
61 {
62         int ret;
63         ret = xt_register_target(AF_INET, &ipt_NFQ_reg);
64         if (ret)
65                 return ret;
66         ret = xt_register_target(AF_INET6, &ip6t_NFQ_reg);
67         if (ret)
68                 goto out_ip;
69         ret = xt_register_target(NF_ARP, &arpt_NFQ_reg);
70         if (ret)
71                 goto out_ip6;
72
73         return ret;
74 out_ip6:
75         xt_unregister_target(AF_INET6, &ip6t_NFQ_reg);
76 out_ip:
77         xt_unregister_target(AF_INET, &ipt_NFQ_reg);
78
79         return ret;
80 }
81
82 static void __exit fini(void)
83 {
84         xt_unregister_target(NF_ARP, &arpt_NFQ_reg);
85         xt_unregister_target(AF_INET6, &ip6t_NFQ_reg);
86         xt_unregister_target(AF_INET, &ipt_NFQ_reg);
87 }
88
89 module_init(init);
90 module_exit(fini);