cls_cgroup.h (f01387d2693813eb5271a3448e6a082322c7d75d) | cls_cgroup.h (b87a173e25d6bf5c26f13d329cdddf57dbd4061a) |
---|---|
1/* 2 * cls_cgroup.h Control Group Classifier 3 * 4 * Authors: Thomas Graf <tgraf@suug.ch> 5 * 6 * This program is free software; you can redistribute it and/or modify it 7 * under the terms of the GNU General Public License as published by the Free 8 * Software Foundation; either version 2 of the License, or (at your option) --- 35 unchanged lines hidden (view full) --- 44static inline void sock_update_classid(struct sock *sk) 45{ 46 u32 classid; 47 48 classid = task_cls_classid(current); 49 if (classid != sk->sk_classid) 50 sk->sk_classid = classid; 51} | 1/* 2 * cls_cgroup.h Control Group Classifier 3 * 4 * Authors: Thomas Graf <tgraf@suug.ch> 5 * 6 * This program is free software; you can redistribute it and/or modify it 7 * under the terms of the GNU General Public License as published by the Free 8 * Software Foundation; either version 2 of the License, or (at your option) --- 35 unchanged lines hidden (view full) --- 44static inline void sock_update_classid(struct sock *sk) 45{ 46 u32 classid; 47 48 classid = task_cls_classid(current); 49 if (classid != sk->sk_classid) 50 sk->sk_classid = classid; 51} |
52 53static inline u32 task_get_classid(const struct sk_buff *skb) 54{ 55 u32 classid = task_cls_state(current)->classid; 56 57 /* Due to the nature of the classifier it is required to ignore all 58 * packets originating from softirq context as accessing `current' 59 * would lead to false results. 60 * 61 * This test assumes that all callers of dev_queue_xmit() explicitly 62 * disable bh. Knowing this, it is possible to detect softirq based 63 * calls by looking at the number of nested bh disable calls because 64 * softirqs always disables bh. 65 */ 66 if (in_serving_softirq()) { 67 /* If there is an sk_classid we'll use that. */ 68 if (!skb->sk) 69 return 0; 70 71 classid = skb->sk->sk_classid; 72 } 73 74 return classid; 75} |
|
52#else /* !CONFIG_CGROUP_NET_CLASSID */ 53static inline void sock_update_classid(struct sock *sk) 54{ 55} | 76#else /* !CONFIG_CGROUP_NET_CLASSID */ 77static inline void sock_update_classid(struct sock *sk) 78{ 79} |
80 81static inline u32 task_get_classid(const struct sk_buff *skb) 82{ 83 return 0; 84} |
|
56#endif /* CONFIG_CGROUP_NET_CLASSID */ 57#endif /* _NET_CLS_CGROUP_H */ | 85#endif /* CONFIG_CGROUP_NET_CLASSID */ 86#endif /* _NET_CLS_CGROUP_H */ |