* [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).