cregit-Linux how code gets into the kernel

Release 4.12 include/net/cls_cgroup.h

Directory: include/net
/*
 * cls_cgroup.h                 Control Group Classifier
 *
 * Authors:     Thomas Graf <tgraf@suug.ch>
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License as published by the Free
 * Software Foundation; either version 2 of the License, or (at your option)
 * any later version.
 *
 */

#ifndef _NET_CLS_CGROUP_H

#define _NET_CLS_CGROUP_H

#include <linux/cgroup.h>
#include <linux/hardirq.h>
#include <linux/rcupdate.h>
#include <net/sock.h>
#include <net/inet_sock.h>

#ifdef CONFIG_CGROUP_NET_CLASSID

struct cgroup_cls_state {
	
struct cgroup_subsys_state css;
	
u32 classid;
};

struct cgroup_cls_state *task_cls_state(struct task_struct *p);


static inline u32 task_cls_classid(struct task_struct *p) { u32 classid; if (in_interrupt()) return 0; rcu_read_lock(); classid = container_of(task_css(p, net_cls_cgrp_id), struct cgroup_cls_state, css)->classid; rcu_read_unlock(); return classid; }

Contributors

PersonTokensPropCommitsCommitProp
Herbert Xu3568.63%233.33%
Li Zefan1325.49%116.67%
Tejun Heo23.92%233.33%
Daniel Wagner11.96%116.67%
Total51100.00%6100.00%


static inline void sock_update_classid(struct sock_cgroup_data *skcd) { u32 classid; classid = task_cls_classid(current); sock_cgroup_set_classid(skcd, classid); }

Contributors

PersonTokensPropCommitsCommitProp
Herbert Xu1758.62%133.33%
Tejun Heo724.14%133.33%
Daniel Borkmann517.24%133.33%
Total29100.00%3100.00%


static inline u32 task_get_classid(const struct sk_buff *skb) { u32 classid = task_cls_state(current)->classid; /* Due to the nature of the classifier it is required to ignore all * packets originating from softirq context as accessing `current' * would lead to false results. * * This test assumes that all callers of dev_queue_xmit() explicitly * disable bh. Knowing this, it is possible to detect softirq based * calls by looking at the number of nested bh disable calls because * softirqs always disables bh. */ if (in_serving_softirq()) { struct sock *sk = skb_to_full_sk(skb); /* If there is an sock_cgroup_classid we'll use that. */ if (!sk || !sk_fullsock(sk)) return 0; classid = sock_cgroup_classid(&sk->sk_cgrp_data); } return classid; }

Contributors

PersonTokensPropCommitsCommitProp
Daniel Borkmann4768.12%133.33%
Konstantin Khlebnikov1623.19%133.33%
Tejun Heo68.70%133.33%
Total69100.00%3100.00%

#else /* !CONFIG_CGROUP_NET_CLASSID */
static inline void sock_update_classid(struct sock_cgroup_data *skcd) { }

Contributors

PersonTokensPropCommitsCommitProp
Daniel Wagner981.82%150.00%
Tejun Heo218.18%150.00%
Total11100.00%2100.00%


static inline u32 task_get_classid(const struct sk_buff *skb) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Daniel Borkmann16100.00%1100.00%
Total16100.00%1100.00%

#endif /* CONFIG_CGROUP_NET_CLASSID */ #endif /* _NET_CLS_CGROUP_H */

Overall Contributors

PersonTokensPropCommitsCommitProp
Herbert Xu8737.34%218.18%
Daniel Borkmann8235.19%218.18%
Konstantin Khlebnikov198.15%19.09%
Tejun Heo177.30%327.27%
Daniel Wagner156.44%218.18%
Li Zefan135.58%19.09%
Total233100.00%11100.00%
Directory: include/net
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.