netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [patch 1/1] NetLabel: add missing rcu_dereference() calls in the LSM domain mapping hash table
@ 2007-08-07 20:54 Paul Moore
  2007-08-08  0:53 ` David Miller
  0 siblings, 1 reply; 2+ messages in thread
From: Paul Moore @ 2007-08-07 20:54 UTC (permalink / raw)
  To: netdev; +Cc: Paul Moore

h
Content-Disposition: inline; filename=netlabel-rcu_deref_fix

The LSM domain mapping head table pointer was not being referenced via the RCU
safe dereferencing function, rcu_dereference().  This patch adds those missing
calls to the NetLabel code.

This has been tested using recent linux-2.6 git kernels with no visible
regressions.

Signed-off-by: Paul Moore <paul.moore@hp.com>
---
 net/netlabel/netlabel_domainhash.c |   10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)

Index: linux-2.6_nlbl-rcu-fixup/net/netlabel/netlabel_domainhash.c
===================================================================
--- linux-2.6_nlbl-rcu-fixup.orig/net/netlabel/netlabel_domainhash.c
+++ linux-2.6_nlbl-rcu-fixup/net/netlabel/netlabel_domainhash.c
@@ -126,7 +126,9 @@ static struct netlbl_dom_map *netlbl_dom
 
 	if (domain != NULL) {
 		bkt = netlbl_domhsh_hash(domain);
-		list_for_each_entry_rcu(iter, &netlbl_domhsh->tbl[bkt], list)
+		list_for_each_entry_rcu(iter,
+				     &rcu_dereference(netlbl_domhsh)->tbl[bkt],
+				     list)
 			if (iter->valid && strcmp(iter->domain, domain) == 0)
 				return iter;
 	}
@@ -227,7 +229,7 @@ int netlbl_domhsh_add(struct netlbl_dom_
 		spin_lock(&netlbl_domhsh_lock);
 		if (netlbl_domhsh_search(entry->domain, 0) == NULL)
 			list_add_tail_rcu(&entry->list,
-					  &netlbl_domhsh->tbl[bkt]);
+				    &rcu_dereference(netlbl_domhsh)->tbl[bkt]);
 		else
 			ret_val = -EEXIST;
 		spin_unlock(&netlbl_domhsh_lock);
@@ -423,8 +425,8 @@ int netlbl_domhsh_walk(u32 *skip_bkt,
 	     iter_bkt < rcu_dereference(netlbl_domhsh)->size;
 	     iter_bkt++, chain_cnt = 0) {
 		list_for_each_entry_rcu(iter_entry,
-					&netlbl_domhsh->tbl[iter_bkt],
-					list)
+				&rcu_dereference(netlbl_domhsh)->tbl[iter_bkt],
+				list)
 			if (iter_entry->valid) {
 				if (chain_cnt++ < *skip_chain)
 					continue;

-- 
paul moore
linux security @ hp


^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: [patch 1/1] NetLabel: add missing rcu_dereference() calls in the LSM domain mapping hash table
  2007-08-07 20:54 [patch 1/1] NetLabel: add missing rcu_dereference() calls in the LSM domain mapping hash table Paul Moore
@ 2007-08-08  0:53 ` David Miller
  0 siblings, 0 replies; 2+ messages in thread
From: David Miller @ 2007-08-08  0:53 UTC (permalink / raw)
  To: paul.moore; +Cc: netdev

From: "Paul Moore" <paul.moore@hp.com>
Date: Tue, 07 Aug 2007 16:54:50 -0400

> The LSM domain mapping head table pointer was not being referenced via the RCU
> safe dereferencing function, rcu_dereference().  This patch adds those missing
> calls to the NetLabel code.
> 
> This has been tested using recent linux-2.6 git kernels with no visible
> regressions.
> 
> Signed-off-by: Paul Moore <paul.moore@hp.com>

Patch applied, thanks Paul.

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2007-08-08  0:53 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-08-07 20:54 [patch 1/1] NetLabel: add missing rcu_dereference() calls in the LSM domain mapping hash table Paul Moore
2007-08-08  0:53 ` David Miller

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).