diff options
| author | Pavel Emelyanov <xemul@openvz.org> | 2008-01-22 06:02:14 -0800 | 
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2008-01-28 15:10:34 -0800 | 
| commit | ac18e7509e7df327e30d6e073a787d922eaf211d (patch) | |
| tree | 26be1582b59956c389a667d5426fdc538072795b /net/ipv4/inet_fragment.c | |
| parent | 8d8354d2fb9277f165715a6e1cb92bcc89259975 (diff) | |
| download | olio-linux-3.10-ac18e7509e7df327e30d6e073a787d922eaf211d.tar.xz olio-linux-3.10-ac18e7509e7df327e30d6e073a787d922eaf211d.zip  | |
[NETNS][FRAGS]: Make the inet_frag_queue lookup work in namespaces.
Since fragment management code is consolidated, we cannot have the
pointer from inet_frag_queue to struct net, since we must know what
king of fragment this is.
So, I introduce the netns_frags structure. This one is currently
empty, but will be eventually filled with per-namespace
attributes. Each inet_frag_queue is tagged with this one.
The conntrack_reasm is not "netns-izated", so it has one static
netns_frags instance to keep working in init namespace.
Signed-off-by: Pavel Emelyanov <xemul@openvz.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4/inet_fragment.c')
| -rw-r--r-- | net/ipv4/inet_fragment.c | 27 | 
1 files changed, 15 insertions, 12 deletions
diff --git a/net/ipv4/inet_fragment.c b/net/ipv4/inet_fragment.c index 737910767ff..158c5f60d02 100644 --- a/net/ipv4/inet_fragment.c +++ b/net/ipv4/inet_fragment.c @@ -174,8 +174,9 @@ int inet_frag_evictor(struct inet_frags *f)  }  EXPORT_SYMBOL(inet_frag_evictor); -static struct inet_frag_queue *inet_frag_intern(struct inet_frag_queue *qp_in, -		struct inet_frags *f, unsigned int hash, void *arg) +static struct inet_frag_queue *inet_frag_intern(struct netns_frags *nf, +		struct inet_frag_queue *qp_in, struct inet_frags *f, +		unsigned int hash, void *arg)  {  	struct inet_frag_queue *qp;  #ifdef CONFIG_SMP @@ -189,7 +190,7 @@ static struct inet_frag_queue *inet_frag_intern(struct inet_frag_queue *qp_in,  	 * promoted read lock to write lock.  	 */  	hlist_for_each_entry(qp, n, &f->hash[hash], list) { -		if (f->match(qp, arg)) { +		if (qp->net == nf && f->match(qp, arg)) {  			atomic_inc(&qp->refcnt);  			write_unlock(&f->lock);  			qp_in->last_in |= COMPLETE; @@ -210,7 +211,8 @@ static struct inet_frag_queue *inet_frag_intern(struct inet_frag_queue *qp_in,  	return qp;  } -static struct inet_frag_queue *inet_frag_alloc(struct inet_frags *f, void *arg) +static struct inet_frag_queue *inet_frag_alloc(struct netns_frags *nf, +		struct inet_frags *f, void *arg)  {  	struct inet_frag_queue *q; @@ -223,31 +225,32 @@ static struct inet_frag_queue *inet_frag_alloc(struct inet_frags *f, void *arg)  	setup_timer(&q->timer, f->frag_expire, (unsigned long)q);  	spin_lock_init(&q->lock);  	atomic_set(&q->refcnt, 1); +	q->net = nf;  	return q;  } -static struct inet_frag_queue *inet_frag_create(struct inet_frags *f, -		void *arg, unsigned int hash) +static struct inet_frag_queue *inet_frag_create(struct netns_frags *nf, +		struct inet_frags *f, void *arg, unsigned int hash)  {  	struct inet_frag_queue *q; -	q = inet_frag_alloc(f, arg); +	q = inet_frag_alloc(nf, f, arg);  	if (q == NULL)  		return NULL; -	return inet_frag_intern(q, f, hash, arg); +	return inet_frag_intern(nf, q, f, hash, arg);  } -struct inet_frag_queue *inet_frag_find(struct inet_frags *f, void *key, -		unsigned int hash) +struct inet_frag_queue *inet_frag_find(struct netns_frags *nf, +		struct inet_frags *f, void *key, unsigned int hash)  {  	struct inet_frag_queue *q;  	struct hlist_node *n;  	read_lock(&f->lock);  	hlist_for_each_entry(q, n, &f->hash[hash], list) { -		if (f->match(q, key)) { +		if (q->net == nf && f->match(q, key)) {  			atomic_inc(&q->refcnt);  			read_unlock(&f->lock);  			return q; @@ -255,6 +258,6 @@ struct inet_frag_queue *inet_frag_find(struct inet_frags *f, void *key,  	}  	read_unlock(&f->lock); -	return inet_frag_create(f, key, hash); +	return inet_frag_create(nf, f, key, hash);  }  EXPORT_SYMBOL(inet_frag_find);  |