Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 329107
b: refs/heads/master
c: a10bf26
h: refs/heads/master
i:
  329105: f66f9a6
  329103: 62012a6
v: v3
  • Loading branch information
Dmitry Kasatkin authored and Mimi Zohar committed Sep 7, 2012
1 parent 96536b1 commit 1f0e9e7
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 10 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: bf2276d10ce58ff44ab8857266a6718024496af6
refs/heads/master: a10bf26b2f53242836e9362c6c9c857b627b82a9
16 changes: 7 additions & 9 deletions trunk/security/integrity/iint.c
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
#include "integrity.h"

static struct rb_root integrity_iint_tree = RB_ROOT;
static DEFINE_SPINLOCK(integrity_iint_lock);
static DEFINE_RWLOCK(integrity_iint_lock);
static struct kmem_cache *iint_cache __read_mostly;

int iint_initialized;
Expand All @@ -35,8 +35,6 @@ static struct integrity_iint_cache *__integrity_iint_find(struct inode *inode)
struct integrity_iint_cache *iint;
struct rb_node *n = integrity_iint_tree.rb_node;

assert_spin_locked(&integrity_iint_lock);

while (n) {
iint = rb_entry(n, struct integrity_iint_cache, rb_node);

Expand All @@ -63,9 +61,9 @@ struct integrity_iint_cache *integrity_iint_find(struct inode *inode)
if (!IS_IMA(inode))
return NULL;

spin_lock(&integrity_iint_lock);
read_lock(&integrity_iint_lock);
iint = __integrity_iint_find(inode);
spin_unlock(&integrity_iint_lock);
read_unlock(&integrity_iint_lock);

return iint;
}
Expand Down Expand Up @@ -100,7 +98,7 @@ struct integrity_iint_cache *integrity_inode_get(struct inode *inode)
if (!iint)
return NULL;

spin_lock(&integrity_iint_lock);
write_lock(&integrity_iint_lock);

p = &integrity_iint_tree.rb_node;
while (*p) {
Expand All @@ -119,7 +117,7 @@ struct integrity_iint_cache *integrity_inode_get(struct inode *inode)
rb_link_node(node, parent, p);
rb_insert_color(node, &integrity_iint_tree);

spin_unlock(&integrity_iint_lock);
write_unlock(&integrity_iint_lock);
return iint;
}

Expand All @@ -136,10 +134,10 @@ void integrity_inode_free(struct inode *inode)
if (!IS_IMA(inode))
return;

spin_lock(&integrity_iint_lock);
write_lock(&integrity_iint_lock);
iint = __integrity_iint_find(inode);
rb_erase(&iint->rb_node, &integrity_iint_tree);
spin_unlock(&integrity_iint_lock);
write_unlock(&integrity_iint_lock);

iint_free(iint);
}
Expand Down

0 comments on commit 1f0e9e7

Please sign in to comment.