mirror of
https://github.com/torvalds/linux.git
synced 2024-11-08 21:21:47 +00:00
8fb974c937
task_cls_classid() should not be defined in case the configuration is CONFIG_NET_CLS_CGROUP=n. The reason is that in a following patch the net_cls_subsys_id will only be defined if CONFIG_NET_CLS_CGROUP!=n. When net_cls is not built at all a callee should only get an empty task_cls_classid() without any references to net_cls_subsys_id. Signed-off-by: Daniel Wagner <daniel.wagner@bmw-carit.de> Signed-off-by: Tejun Heo <tj@kernel.org> Acked-by: Li Zefan <lizefan@huawei.com> Acked-by: Neil Horman <nhorman@tuxdriver.com> Cc: Gao feng <gaofeng@cn.fujitsu.com> Cc: Jamal Hadi Salim <jhs@mojatatu.com> Cc: John Fastabend <john.r.fastabend@intel.com> Cc: netdev@vger.kernel.org Cc: cgroups@vger.kernel.org
78 lines
1.6 KiB
C
78 lines
1.6 KiB
C
/*
|
|
* 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>
|
|
|
|
#if IS_ENABLED(CONFIG_NET_CLS_CGROUP)
|
|
struct cgroup_cls_state
|
|
{
|
|
struct cgroup_subsys_state css;
|
|
u32 classid;
|
|
};
|
|
|
|
extern void sock_update_classid(struct sock *sk);
|
|
|
|
#if IS_BUILTIN(CONFIG_NET_CLS_CGROUP)
|
|
static inline u32 task_cls_classid(struct task_struct *p)
|
|
{
|
|
int classid;
|
|
|
|
if (in_interrupt())
|
|
return 0;
|
|
|
|
rcu_read_lock();
|
|
classid = container_of(task_subsys_state(p, net_cls_subsys_id),
|
|
struct cgroup_cls_state, css)->classid;
|
|
rcu_read_unlock();
|
|
|
|
return classid;
|
|
}
|
|
#elif IS_MODULE(CONFIG_NET_CLS_CGROUP)
|
|
|
|
extern int net_cls_subsys_id;
|
|
|
|
static inline u32 task_cls_classid(struct task_struct *p)
|
|
{
|
|
int id;
|
|
u32 classid = 0;
|
|
|
|
if (in_interrupt())
|
|
return 0;
|
|
|
|
rcu_read_lock();
|
|
id = rcu_dereference_index_check(net_cls_subsys_id,
|
|
rcu_read_lock_held());
|
|
if (id >= 0)
|
|
classid = container_of(task_subsys_state(p, id),
|
|
struct cgroup_cls_state, css)->classid;
|
|
rcu_read_unlock();
|
|
|
|
return classid;
|
|
}
|
|
#endif
|
|
#else /* !CGROUP_NET_CLS_CGROUP */
|
|
static inline void sock_update_classid(struct sock *sk)
|
|
{
|
|
}
|
|
|
|
static inline u32 task_cls_classid(struct task_struct *p)
|
|
{
|
|
return 0;
|
|
}
|
|
#endif /* CGROUP_NET_CLS_CGROUP */
|
|
#endif /* _NET_CLS_CGROUP_H */
|