~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/net/netfilter/xt_cpu.c

Version: ~ [ linux-6.4-rc3 ] ~ [ linux-6.3.4 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.30 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.113 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.180 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.243 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.283 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.315 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 // SPDX-License-Identifier: GPL-2.0-only
  2 /* Kernel module to match running CPU */
  3 
  4 /*
  5  * Might be used to distribute connections on several daemons, if
  6  * RPS (Remote Packet Steering) is enabled or NIC is multiqueue capable,
  7  * each RX queue IRQ affined to one CPU (1:1 mapping)
  8  */
  9 
 10 /* (C) 2010 Eric Dumazet
 11  */
 12 
 13 #include <linux/module.h>
 14 #include <linux/skbuff.h>
 15 #include <linux/netfilter/xt_cpu.h>
 16 #include <linux/netfilter/x_tables.h>
 17 
 18 MODULE_LICENSE("GPL");
 19 MODULE_AUTHOR("Eric Dumazet <eric.dumazet@gmail.com>");
 20 MODULE_DESCRIPTION("Xtables: CPU match");
 21 MODULE_ALIAS("ipt_cpu");
 22 MODULE_ALIAS("ip6t_cpu");
 23 
 24 static int cpu_mt_check(const struct xt_mtchk_param *par)
 25 {
 26         const struct xt_cpu_info *info = par->matchinfo;
 27 
 28         if (info->invert & ~1)
 29                 return -EINVAL;
 30         return 0;
 31 }
 32 
 33 static bool cpu_mt(const struct sk_buff *skb, struct xt_action_param *par)
 34 {
 35         const struct xt_cpu_info *info = par->matchinfo;
 36 
 37         return (info->cpu == smp_processor_id()) ^ info->invert;
 38 }
 39 
 40 static struct xt_match cpu_mt_reg __read_mostly = {
 41         .name       = "cpu",
 42         .revision   = 0,
 43         .family     = NFPROTO_UNSPEC,
 44         .checkentry = cpu_mt_check,
 45         .match      = cpu_mt,
 46         .matchsize  = sizeof(struct xt_cpu_info),
 47         .me         = THIS_MODULE,
 48 };
 49 
 50 static int __init cpu_mt_init(void)
 51 {
 52         return xt_register_match(&cpu_mt_reg);
 53 }
 54 
 55 static void __exit cpu_mt_exit(void)
 56 {
 57         xt_unregister_match(&cpu_mt_reg);
 58 }
 59 
 60 module_init(cpu_mt_init);
 61 module_exit(cpu_mt_exit);
 62 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | Wiki (Japanese) | Wiki (English) | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

osdn.jp