cregit-Linux how code gets into the kernel

Release 4.8 net/netfilter/xt_NFQUEUE.c

Directory: net/netfilter
/* iptables module for using new netfilter netlink queue
 *
 * (C) 2005 by Harald Welte <laforge@netfilter.org>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 *
 */

#include <linux/module.h>
#include <linux/skbuff.h>

#include <linux/netfilter.h>
#include <linux/netfilter_arp.h>
#include <linux/netfilter/x_tables.h>
#include <linux/netfilter/xt_NFQUEUE.h>

#include <net/netfilter/nf_queue.h>

MODULE_AUTHOR("Harald Welte <laforge@netfilter.org>");
MODULE_DESCRIPTION("Xtables: packet forwarding to netlink");
MODULE_LICENSE("GPL");
MODULE_ALIAS("ipt_NFQUEUE");
MODULE_ALIAS("ip6t_NFQUEUE");
MODULE_ALIAS("arpt_NFQUEUE");


static u32 jhash_initval __read_mostly;


static unsigned int nfqueue_tg(struct sk_buff *skb, const struct xt_action_param *par) { const struct xt_NFQ_info *tinfo = par->targinfo; return NF_QUEUE_NR(tinfo->queuenum); }

Contributors

PersonTokensPropCommitsCommitProp
harald welteharald welte3083.33%233.33%
jan engelhardtjan engelhardt513.89%350.00%
herbert xuherbert xu12.78%116.67%
Total36100.00%6100.00%


static unsigned int nfqueue_tg_v1(struct sk_buff *skb, const struct xt_action_param *par) { const struct xt_NFQ_info_v1 *info = par->targinfo; u32 queue = info->queuenum; if (info->queues_total > 1) { queue = nfqueue_hash(skb, queue, info->queues_total, par->family, jhash_initval); } return NF_QUEUE_NR(queue); }

Contributors

PersonTokensPropCommitsCommitProp
holger eitzenbergerholger eitzenberger5172.86%133.33%
eric leblonderic leblond1217.14%133.33%
florian westphalflorian westphal710.00%133.33%
Total70100.00%3100.00%


static unsigned int nfqueue_tg_v2(struct sk_buff *skb, const struct xt_action_param *par) { const struct xt_NFQ_info_v2 *info = par->targinfo; unsigned int ret = nfqueue_tg_v1(skb, par); if (info->bypass) ret |= NF_VERDICT_FLAG_QUEUE_BYPASS; return ret; }

Contributors

PersonTokensPropCommitsCommitProp
florian westphalflorian westphal52100.00%1100.00%
Total52100.00%1100.00%


static int nfqueue_tg_check(const struct xt_tgchk_param *par) { const struct xt_NFQ_info_v3 *info = par->targinfo; u32 maxid; init_hashrandom(&jhash_initval); if (info->queues_total == 0) { pr_err("NFQUEUE: number of total queues is 0\n"); return -EINVAL; } maxid = info->queues_total - 1 + info->queuenum; if (maxid > 0xffff) { pr_err("NFQUEUE: number of queues (%u) out of range (got %u)\n", info->queues_total, maxid); return -ERANGE; } if (par->target->revision == 2 && info->flags > 1) return -EINVAL; if (par->target->revision == 3 && info->flags & ~NFQ_FLAG_MASK) return -EINVAL; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
florian westphalflorian westphal9271.32%225.00%
holger eitzenbergerholger eitzenberger2317.83%112.50%
jan engelhardtjan engelhardt1310.08%450.00%
eric leblonderic leblond10.78%112.50%
Total129100.00%8100.00%


static unsigned int nfqueue_tg_v3(struct sk_buff *skb, const struct xt_action_param *par) { const struct xt_NFQ_info_v3 *info = par->targinfo; u32 queue = info->queuenum; int ret; if (info->queues_total > 1) { if (info->flags & NFQ_FLAG_CPU_FANOUT) { int cpu = smp_processor_id(); queue = info->queuenum + cpu % info->queues_total; } else { queue = nfqueue_hash(skb, queue, info->queues_total, par->family, jhash_initval); } } ret = NF_QUEUE_NR(queue); if (info->flags & NFQ_FLAG_BYPASS) ret |= NF_VERDICT_FLAG_QUEUE_BYPASS; return ret; }

Contributors

PersonTokensPropCommitsCommitProp
holger eitzenbergerholger eitzenberger10890.00%375.00%
eric leblonderic leblond1210.00%125.00%
Total120100.00%4100.00%

static struct xt_target nfqueue_tg_reg[] __read_mostly = { { .name = "NFQUEUE", .family = NFPROTO_UNSPEC, .target = nfqueue_tg, .targetsize = sizeof(struct xt_NFQ_info), .me = THIS_MODULE, }, { .name = "NFQUEUE", .revision = 1, .family = NFPROTO_UNSPEC, .checkentry = nfqueue_tg_check, .target = nfqueue_tg_v1, .targetsize = sizeof(struct xt_NFQ_info_v1), .me = THIS_MODULE, }, { .name = "NFQUEUE", .revision = 2, .family = NFPROTO_UNSPEC, .checkentry = nfqueue_tg_check, .target = nfqueue_tg_v2, .targetsize = sizeof(struct xt_NFQ_info_v2), .me = THIS_MODULE, }, { .name = "NFQUEUE", .revision = 3, .family = NFPROTO_UNSPEC, .checkentry = nfqueue_tg_check, .target = nfqueue_tg_v3, .targetsize = sizeof(struct xt_NFQ_info_v3), .me = THIS_MODULE, }, };
static int __init nfqueue_tg_init(void) { return xt_register_targets(nfqueue_tg_reg, ARRAY_SIZE(nfqueue_tg_reg)); }

Contributors

PersonTokensPropCommitsCommitProp
harald welteharald welte1470.00%250.00%
patrick mchardypatrick mchardy315.00%125.00%
jan engelhardtjan engelhardt315.00%125.00%
Total20100.00%4100.00%


static void __exit nfqueue_tg_exit(void) { xt_unregister_targets(nfqueue_tg_reg, ARRAY_SIZE(nfqueue_tg_reg)); }

Contributors

PersonTokensPropCommitsCommitProp
harald welteharald welte1368.42%240.00%
patrick mchardypatrick mchardy315.79%240.00%
jan engelhardtjan engelhardt315.79%120.00%
Total19100.00%5100.00%

module_init(nfqueue_tg_init); module_exit(nfqueue_tg_exit);

Overall Contributors

PersonTokensPropCommitsCommitProp
florian westphalflorian westphal23735.06%312.50%
holger eitzenbergerholger eitzenberger22332.99%312.50%
harald welteharald welte13419.82%28.33%
jan engelhardtjan engelhardt324.73%937.50%
eric leblonderic leblond284.14%14.17%
patrick mchardypatrick mchardy202.96%416.67%
herbert xuherbert xu10.15%14.17%
hideaki yoshifujihideaki yoshifuji10.15%14.17%
Total676100.00%24100.00%
Directory: net/netfilter
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.