]> www.pilppa.org Git - linux-2.6-omap-h63xx.git/commitdiff
[DLM] add new lockspace to list ealier
authorDavid Teigland <teigland@redhat.com>
Thu, 24 Aug 2006 19:47:20 +0000 (14:47 -0500)
committerSteven Whitehouse <swhiteho@redhat.com>
Fri, 25 Aug 2006 14:02:53 +0000 (10:02 -0400)
When a new lockspace was being created, the recoverd thread was being
started for it before the lockspace was added to the global list of
lockspaces.  The new thread was looking up the lockspace in the global
list and sometimes not finding it due to the race with the original thread
adding it to the list.  We need to add the lockspace to the global list
before starting the thread instead of after, and if the new thread can't
find the lockspace for some reason, it should return an error.

Signed-off-by: David Teigland <teigland@redhat.com>
Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
fs/dlm/lockspace.c
fs/dlm/recoverd.c

index 7adaad53fc3830c3cc522efcaeab6aa034032b89..ff83f80e43eb4aafbde8559e343dfa2e08f45e18 100644 (file)
@@ -488,16 +488,17 @@ static int new_lockspace(char *name, int namelen, void **lockspace,
 
        down_write(&ls->ls_in_recovery);
 
+       spin_lock(&lslist_lock);
+       list_add(&ls->ls_list, &lslist);
+       spin_unlock(&lslist_lock);
+
+       /* needs to find ls in lslist */
        error = dlm_recoverd_start(ls);
        if (error) {
                log_error(ls, "can't start dlm_recoverd %d", error);
                goto out_rcomfree;
        }
 
-       spin_lock(&lslist_lock);
-       list_add(&ls->ls_list, &lslist);
-       spin_unlock(&lslist_lock);
-
        dlm_create_debug_file(ls);
 
        error = kobject_setup(ls);
@@ -519,11 +520,11 @@ static int new_lockspace(char *name, int namelen, void **lockspace,
        kobject_unregister(&ls->ls_kobj);
  out_del:
        dlm_delete_debug_file(ls);
+       dlm_recoverd_stop(ls);
+ out_rcomfree:
        spin_lock(&lslist_lock);
        list_del(&ls->ls_list);
        spin_unlock(&lslist_lock);
-       dlm_recoverd_stop(ls);
- out_rcomfree:
        kfree(ls->ls_recover_buf);
  out_dirfree:
        kfree(ls->ls_dirtbl);
index eac8e9fa67f13cb03e8953eaacdaba892e889519..362e3eff4dc9afef2e8bd02777ed87591636fcfe 100644 (file)
@@ -234,6 +234,10 @@ static int dlm_recoverd(void *arg)
        struct dlm_ls *ls;
 
        ls = dlm_find_lockspace_local(arg);
+       if (!ls) {
+               log_print("dlm_recoverd: no lockspace %p", arg);
+               return -1;
+       }
 
        while (!kthread_should_stop()) {
                set_current_state(TASK_INTERRUPTIBLE);