net_sched: convert tcf_proto_ops to use struct list_head
We don't need to maintain our own singly linked list code. Cc: Jamal Hadi Salim <jhs@mojatatu.com> Cc: David S. Miller <davem@davemloft.net> Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com> Signed-off-by: Jamal Hadi Salim <jhs@mojatatu.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
					parent
					
						
							
								1f747c26c4
							
						
					
				
			
			
				commit
				
					
						3627287463
					
				
			
		
					 2 changed files with 9 additions and 11 deletions
				
			
		| 
						 | 
					@ -185,7 +185,7 @@ struct tcf_result {
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
struct tcf_proto_ops {
 | 
					struct tcf_proto_ops {
 | 
				
			||||||
	struct tcf_proto_ops	*next;
 | 
						struct list_head	head;
 | 
				
			||||||
	char			kind[IFNAMSIZ];
 | 
						char			kind[IFNAMSIZ];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	int			(*classify)(struct sk_buff *,
 | 
						int			(*classify)(struct sk_buff *,
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -31,8 +31,7 @@
 | 
				
			||||||
#include <net/pkt_cls.h>
 | 
					#include <net/pkt_cls.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* The list of all installed classifier types */
 | 
					/* The list of all installed classifier types */
 | 
				
			||||||
 | 
					static LIST_HEAD(tcf_proto_base);
 | 
				
			||||||
static struct tcf_proto_ops *tcf_proto_base __read_mostly;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Protects list of registered TC modules. It is pure SMP lock. */
 | 
					/* Protects list of registered TC modules. It is pure SMP lock. */
 | 
				
			||||||
static DEFINE_RWLOCK(cls_mod_lock);
 | 
					static DEFINE_RWLOCK(cls_mod_lock);
 | 
				
			||||||
| 
						 | 
					@ -45,7 +44,7 @@ static const struct tcf_proto_ops *tcf_proto_lookup_ops(struct nlattr *kind)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (kind) {
 | 
						if (kind) {
 | 
				
			||||||
		read_lock(&cls_mod_lock);
 | 
							read_lock(&cls_mod_lock);
 | 
				
			||||||
		for (t = tcf_proto_base; t; t = t->next) {
 | 
							list_for_each_entry(t, &tcf_proto_base, head) {
 | 
				
			||||||
			if (nla_strcmp(kind, t->kind) == 0) {
 | 
								if (nla_strcmp(kind, t->kind) == 0) {
 | 
				
			||||||
				if (!try_module_get(t->owner))
 | 
									if (!try_module_get(t->owner))
 | 
				
			||||||
					t = NULL;
 | 
										t = NULL;
 | 
				
			||||||
| 
						 | 
					@ -61,16 +60,15 @@ static const struct tcf_proto_ops *tcf_proto_lookup_ops(struct nlattr *kind)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int register_tcf_proto_ops(struct tcf_proto_ops *ops)
 | 
					int register_tcf_proto_ops(struct tcf_proto_ops *ops)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct tcf_proto_ops *t, **tp;
 | 
						struct tcf_proto_ops *t;
 | 
				
			||||||
	int rc = -EEXIST;
 | 
						int rc = -EEXIST;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	write_lock(&cls_mod_lock);
 | 
						write_lock(&cls_mod_lock);
 | 
				
			||||||
	for (tp = &tcf_proto_base; (t = *tp) != NULL; tp = &t->next)
 | 
						list_for_each_entry(t, &tcf_proto_base, head)
 | 
				
			||||||
		if (!strcmp(ops->kind, t->kind))
 | 
							if (!strcmp(ops->kind, t->kind))
 | 
				
			||||||
			goto out;
 | 
								goto out;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ops->next = NULL;
 | 
						list_add_tail(&ops->head, &tcf_proto_base);
 | 
				
			||||||
	*tp = ops;
 | 
					 | 
				
			||||||
	rc = 0;
 | 
						rc = 0;
 | 
				
			||||||
out:
 | 
					out:
 | 
				
			||||||
	write_unlock(&cls_mod_lock);
 | 
						write_unlock(&cls_mod_lock);
 | 
				
			||||||
| 
						 | 
					@ -80,17 +78,17 @@ EXPORT_SYMBOL(register_tcf_proto_ops);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int unregister_tcf_proto_ops(struct tcf_proto_ops *ops)
 | 
					int unregister_tcf_proto_ops(struct tcf_proto_ops *ops)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct tcf_proto_ops *t, **tp;
 | 
						struct tcf_proto_ops *t;
 | 
				
			||||||
	int rc = -ENOENT;
 | 
						int rc = -ENOENT;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	write_lock(&cls_mod_lock);
 | 
						write_lock(&cls_mod_lock);
 | 
				
			||||||
	for (tp = &tcf_proto_base; (t = *tp) != NULL; tp = &t->next)
 | 
						list_for_each_entry(t, &tcf_proto_base, head)
 | 
				
			||||||
		if (t == ops)
 | 
							if (t == ops)
 | 
				
			||||||
			break;
 | 
								break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!t)
 | 
						if (!t)
 | 
				
			||||||
		goto out;
 | 
							goto out;
 | 
				
			||||||
	*tp = t->next;
 | 
						list_del(&t->head);
 | 
				
			||||||
	rc = 0;
 | 
						rc = 0;
 | 
				
			||||||
out:
 | 
					out:
 | 
				
			||||||
	write_unlock(&cls_mod_lock);
 | 
						write_unlock(&cls_mod_lock);
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue