diff options
Diffstat (limited to 'net/802')
| -rw-r--r-- | net/802/garp.c | 22 | 
1 files changed, 10 insertions, 12 deletions
diff --git a/net/802/garp.c b/net/802/garp.c index 8e21b6db398..a5c22483043 100644 --- a/net/802/garp.c +++ b/net/802/garp.c @@ -167,7 +167,8 @@ static struct garp_attr *garp_attr_lookup(const struct garp_applicant *app,  	return NULL;  } -static void garp_attr_insert(struct garp_applicant *app, struct garp_attr *new) +static struct garp_attr *garp_attr_create(struct garp_applicant *app, +					  const void *data, u8 len, u8 type)  {  	struct rb_node *parent = NULL, **p = &app->gid.rb_node;  	struct garp_attr *attr; @@ -176,21 +177,16 @@ static void garp_attr_insert(struct garp_applicant *app, struct garp_attr *new)  	while (*p) {  		parent = *p;  		attr = rb_entry(parent, struct garp_attr, node); -		d = garp_attr_cmp(attr, new->data, new->dlen, new->type); +		d = garp_attr_cmp(attr, data, len, type);  		if (d < 0)  			p = &parent->rb_left;  		else if (d > 0)  			p = &parent->rb_right; +		else { +			/* The attribute already exists; re-use it. */ +			return attr; +		}  	} -	rb_link_node(&new->node, parent, p); -	rb_insert_color(&new->node, &app->gid); -} - -static struct garp_attr *garp_attr_create(struct garp_applicant *app, -					  const void *data, u8 len, u8 type) -{ -	struct garp_attr *attr; -  	attr = kmalloc(sizeof(*attr) + len, GFP_ATOMIC);  	if (!attr)  		return attr; @@ -198,7 +194,9 @@ static struct garp_attr *garp_attr_create(struct garp_applicant *app,  	attr->type  = type;  	attr->dlen  = len;  	memcpy(attr->data, data, len); -	garp_attr_insert(app, attr); + +	rb_link_node(&attr->node, parent, p); +	rb_insert_color(&attr->node, &app->gid);  	return attr;  }  |