cregit-Linux how code gets into the kernel

Release 4.15 net/netfilter/xt_SECMARK.c

Directory: net/netfilter
/*
 * Module for modifying the secmark field of the skb, for use by
 * security subsystems.
 *
 * Based on the nfmark match by:
 * (C) 1999-2001 Marc Boucher <marc@mbsi.ca>
 *
 * (C) 2006,2008 Red Hat, Inc., James Morris <jmorris@redhat.com>
 *
 * 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.
 *
 */

#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
#include <linux/module.h>
#include <linux/security.h>
#include <linux/skbuff.h>
#include <linux/netfilter/x_tables.h>
#include <linux/netfilter/xt_SECMARK.h>

MODULE_LICENSE("GPL");
MODULE_AUTHOR("James Morris <jmorris@redhat.com>");
MODULE_DESCRIPTION("Xtables: packet security mark modification");
MODULE_ALIAS("ipt_SECMARK");
MODULE_ALIAS("ip6t_SECMARK");


#define PFX "SECMARK: "


static u8 mode;


static unsigned int secmark_tg(struct sk_buff *skb, const struct xt_action_param *par) { u32 secmark = 0; const struct xt_secmark_target_info *info = par->targinfo; BUG_ON(info->mode != mode); switch (mode) { case SECMARK_MODE_SEL: secmark = info->secid; break; default: BUG(); } skb->secmark = secmark; return XT_CONTINUE; }

Contributors

PersonTokensPropCommitsCommitProp
James Morris6388.73%116.67%
Jan Engelhardt57.04%350.00%
Herbert Xu22.82%116.67%
Eric Paris11.41%116.67%
Total71100.00%6100.00%


static int checkentry_lsm(struct xt_secmark_target_info *info) { int err; info->secctx[SECMARK_SECCTX_MAX - 1] = '\0'; info->secid = 0; err = security_secctx_to_secid(info->secctx, strlen(info->secctx), &info->secid); if (err) { if (err == -EINVAL) pr_info("invalid security context \'%s\'\n", info->secctx); return err; } if (!info->secid) { pr_info("unable to map security context \'%s\'\n", info->secctx); return -ENOENT; } err = security_secmark_relabel_packet(info->secid); if (err) { pr_info("unable to obtain relabeling permission\n"); return err; } security_secmark_refcount_inc(); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
James Morris7961.72%233.33%
Eric Paris3325.78%116.67%
Jan Engelhardt1410.94%233.33%
Paul Moore21.56%116.67%
Total128100.00%6100.00%


static int secmark_tg_check(const struct xt_tgchk_param *par) { struct xt_secmark_target_info *info = par->targinfo; int err; if (strcmp(par->table, "mangle") != 0 && strcmp(par->table, "security") != 0) { pr_info("target only valid in the \'mangle\' " "or \'security\' tables, not \'%s\'.\n", par->table); return -EINVAL; } if (mode && mode != info->mode) { pr_info("mode already set to %hu cannot mix with " "rules for mode %hu\n", mode, info->mode); return -EINVAL; } switch (info->mode) { case SECMARK_MODE_SEL: break; default: pr_info("invalid mode: %hu\n", info->mode); return -EINVAL; } err = checkentry_lsm(info); if (err) return err; if (!mode) mode = info->mode; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
James Morris9061.64%222.22%
Jan Engelhardt4228.77%666.67%
Eric Paris149.59%111.11%
Total146100.00%9100.00%


static void secmark_tg_destroy(const struct xt_tgdtor_param *par) { switch (mode) { case SECMARK_MODE_SEL: security_secmark_refcount_dec(); } }

Contributors

PersonTokensPropCommitsCommitProp
Paul Moore2083.33%125.00%
Jan Engelhardt28.33%125.00%
Eric Paris14.17%125.00%
Adrian Bunk14.17%125.00%
Total24100.00%4100.00%

static struct xt_target secmark_tg_reg __read_mostly = { .name = "SECMARK", .revision = 0, .family = NFPROTO_UNSPEC, .checkentry = secmark_tg_check, .destroy = secmark_tg_destroy, .target = secmark_tg, .targetsize = sizeof(struct xt_secmark_target_info), .me = THIS_MODULE, };
static int __init secmark_tg_init(void) { return xt_register_target(&secmark_tg_reg); }

Contributors

PersonTokensPropCommitsCommitProp
James Morris1168.75%125.00%
Jan Engelhardt425.00%250.00%
Patrick McHardy16.25%125.00%
Total16100.00%4100.00%


static void __exit secmark_tg_exit(void) { xt_unregister_target(&secmark_tg_reg); }

Contributors

PersonTokensPropCommitsCommitProp
James Morris1066.67%125.00%
Jan Engelhardt426.67%250.00%
Patrick McHardy16.67%125.00%
Total15100.00%4100.00%

module_init(secmark_tg_init); module_exit(secmark_tg_exit);

Overall Contributors

PersonTokensPropCommitsCommitProp
James Morris34466.41%315.00%
Jan Engelhardt8716.80%1155.00%
Eric Paris519.85%15.00%
Paul Moore275.21%15.00%
Patrick McHardy61.16%210.00%
Herbert Xu20.39%15.00%
Adrian Bunk10.19%15.00%
Total518100.00%20100.00%
Directory: net/netfilter
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.