dect
/
linux-2.6
Archived
13
0
Fork 0

dlm: Change rwlock which is only used in write mode to a spinlock

The ls_dirtbl[].lock was an rwlock, but since it was only used in write
mode a spinlock will suffice.

Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
Signed-off-by: David Teigland <teigland@redhat.com>
This commit is contained in:
Steven Whitehouse 2009-01-16 16:21:12 +00:00 committed by David Teigland
parent 152a649b64
commit 305a47b17c
3 changed files with 11 additions and 11 deletions

View File

@ -156,7 +156,7 @@ void dlm_dir_remove_entry(struct dlm_ls *ls, int nodeid, char *name, int namelen
bucket = dir_hash(ls, name, namelen); bucket = dir_hash(ls, name, namelen);
write_lock(&ls->ls_dirtbl[bucket].lock); spin_lock(&ls->ls_dirtbl[bucket].lock);
de = search_bucket(ls, name, namelen, bucket); de = search_bucket(ls, name, namelen, bucket);
@ -173,7 +173,7 @@ void dlm_dir_remove_entry(struct dlm_ls *ls, int nodeid, char *name, int namelen
list_del(&de->list); list_del(&de->list);
kfree(de); kfree(de);
out: out:
write_unlock(&ls->ls_dirtbl[bucket].lock); spin_unlock(&ls->ls_dirtbl[bucket].lock);
} }
void dlm_dir_clear(struct dlm_ls *ls) void dlm_dir_clear(struct dlm_ls *ls)
@ -185,14 +185,14 @@ void dlm_dir_clear(struct dlm_ls *ls)
DLM_ASSERT(list_empty(&ls->ls_recover_list), ); DLM_ASSERT(list_empty(&ls->ls_recover_list), );
for (i = 0; i < ls->ls_dirtbl_size; i++) { for (i = 0; i < ls->ls_dirtbl_size; i++) {
write_lock(&ls->ls_dirtbl[i].lock); spin_lock(&ls->ls_dirtbl[i].lock);
head = &ls->ls_dirtbl[i].list; head = &ls->ls_dirtbl[i].list;
while (!list_empty(head)) { while (!list_empty(head)) {
de = list_entry(head->next, struct dlm_direntry, list); de = list_entry(head->next, struct dlm_direntry, list);
list_del(&de->list); list_del(&de->list);
put_free_de(ls, de); put_free_de(ls, de);
} }
write_unlock(&ls->ls_dirtbl[i].lock); spin_unlock(&ls->ls_dirtbl[i].lock);
} }
} }
@ -307,17 +307,17 @@ static int get_entry(struct dlm_ls *ls, int nodeid, char *name,
bucket = dir_hash(ls, name, namelen); bucket = dir_hash(ls, name, namelen);
write_lock(&ls->ls_dirtbl[bucket].lock); spin_lock(&ls->ls_dirtbl[bucket].lock);
de = search_bucket(ls, name, namelen, bucket); de = search_bucket(ls, name, namelen, bucket);
if (de) { if (de) {
*r_nodeid = de->master_nodeid; *r_nodeid = de->master_nodeid;
write_unlock(&ls->ls_dirtbl[bucket].lock); spin_unlock(&ls->ls_dirtbl[bucket].lock);
if (*r_nodeid == nodeid) if (*r_nodeid == nodeid)
return -EEXIST; return -EEXIST;
return 0; return 0;
} }
write_unlock(&ls->ls_dirtbl[bucket].lock); spin_unlock(&ls->ls_dirtbl[bucket].lock);
if (namelen > DLM_RESNAME_MAXLEN) if (namelen > DLM_RESNAME_MAXLEN)
return -EINVAL; return -EINVAL;
@ -330,7 +330,7 @@ static int get_entry(struct dlm_ls *ls, int nodeid, char *name,
de->length = namelen; de->length = namelen;
memcpy(de->name, name, namelen); memcpy(de->name, name, namelen);
write_lock(&ls->ls_dirtbl[bucket].lock); spin_lock(&ls->ls_dirtbl[bucket].lock);
tmp = search_bucket(ls, name, namelen, bucket); tmp = search_bucket(ls, name, namelen, bucket);
if (tmp) { if (tmp) {
kfree(de); kfree(de);
@ -339,7 +339,7 @@ static int get_entry(struct dlm_ls *ls, int nodeid, char *name,
list_add_tail(&de->list, &ls->ls_dirtbl[bucket].list); list_add_tail(&de->list, &ls->ls_dirtbl[bucket].list);
} }
*r_nodeid = de->master_nodeid; *r_nodeid = de->master_nodeid;
write_unlock(&ls->ls_dirtbl[bucket].lock); spin_unlock(&ls->ls_dirtbl[bucket].lock);
return 0; return 0;
} }

View File

@ -99,7 +99,7 @@ struct dlm_direntry {
struct dlm_dirtable { struct dlm_dirtable {
struct list_head list; struct list_head list;
rwlock_t lock; spinlock_t lock;
}; };
struct dlm_rsbtable { struct dlm_rsbtable {

View File

@ -487,7 +487,7 @@ static int new_lockspace(char *name, int namelen, void **lockspace,
goto out_lkbfree; goto out_lkbfree;
for (i = 0; i < size; i++) { for (i = 0; i < size; i++) {
INIT_LIST_HEAD(&ls->ls_dirtbl[i].list); INIT_LIST_HEAD(&ls->ls_dirtbl[i].list);
rwlock_init(&ls->ls_dirtbl[i].lock); spin_lock_init(&ls->ls_dirtbl[i].lock);
} }
INIT_LIST_HEAD(&ls->ls_waiters); INIT_LIST_HEAD(&ls->ls_waiters);