]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
dlm: convert ls_waiters_mutex to spinlock
authorAlexander Aring <aahringo@redhat.com>
Tue, 2 Apr 2024 19:18:04 +0000 (15:18 -0400)
committerDavid Teigland <teigland@redhat.com>
Tue, 9 Apr 2024 16:44:49 +0000 (11:44 -0500)
Convert the waiters mutex to a spinlock in prepration for
processing messages in softirq context.

Signed-off-by: Alexander Aring <aahringo@redhat.com>
Signed-off-by: David Teigland <teigland@redhat.com>
fs/dlm/debug_fs.c
fs/dlm/dlm_internal.h
fs/dlm/lock.c
fs/dlm/lockspace.c

index c238a9308323aa3d2f83df008b2c4d89f215ba18..487dcf05d0760a0a1b73564fe7912d9557c0851c 100644 (file)
@@ -743,7 +743,7 @@ static ssize_t waiters_read(struct file *file, char __user *userbuf,
                goto out;
        }
 
-       mutex_lock(&ls->ls_waiters_mutex);
+       spin_lock(&ls->ls_waiters_lock);
        memset(debug_buf, 0, sizeof(debug_buf));
 
        list_for_each_entry(lkb, &ls->ls_waiters, lkb_wait_reply) {
@@ -754,7 +754,7 @@ static ssize_t waiters_read(struct file *file, char __user *userbuf,
                        break;
                pos += ret;
        }
-       mutex_unlock(&ls->ls_waiters_mutex);
+       spin_unlock(&ls->ls_waiters_lock);
        dlm_unlock_recovery(ls);
 
        rv = simple_read_from_buffer(userbuf, count, ppos, debug_buf, pos);
index e03a379832d59e0ad12f53cdc333ab27799f063e..98029fd5cd2b9564b3082f5f69093faaf56a5722 100644 (file)
@@ -595,7 +595,7 @@ struct dlm_ls {
        struct dlm_rsbtable     *ls_rsbtbl;
        uint32_t                ls_rsbtbl_size;
 
-       struct mutex            ls_waiters_mutex;
+       spinlock_t              ls_waiters_lock;
        struct list_head        ls_waiters;     /* lkbs needing a reply */
 
        struct mutex            ls_orphans_mutex;
index 395b904a82f49ec94b7033c15e08d61faa5b4dc7..af677add4f5fce00eb2a7047eb137bcb70facacb 100644 (file)
@@ -1406,7 +1406,7 @@ static int add_to_waiters(struct dlm_lkb *lkb, int mstype, int to_nodeid)
        struct dlm_ls *ls = lkb->lkb_resource->res_ls;
        int error = 0;
 
-       mutex_lock(&ls->ls_waiters_mutex);
+       spin_lock(&ls->ls_waiters_lock);
 
        if (is_overlap_unlock(lkb) ||
            (is_overlap_cancel(lkb) && (mstype == DLM_MSG_CANCEL))) {
@@ -1449,7 +1449,7 @@ static int add_to_waiters(struct dlm_lkb *lkb, int mstype, int to_nodeid)
                log_error(ls, "addwait error %x %d flags %x %d %d %s",
                          lkb->lkb_id, error, dlm_iflags_val(lkb), mstype,
                          lkb->lkb_wait_type, lkb->lkb_resource->res_name);
-       mutex_unlock(&ls->ls_waiters_mutex);
+       spin_unlock(&ls->ls_waiters_lock);
        return error;
 }
 
@@ -1549,9 +1549,9 @@ static int remove_from_waiters(struct dlm_lkb *lkb, int mstype)
        struct dlm_ls *ls = lkb->lkb_resource->res_ls;
        int error;
 
-       mutex_lock(&ls->ls_waiters_mutex);
+       spin_lock(&ls->ls_waiters_lock);
        error = _remove_from_waiters(lkb, mstype, NULL);
-       mutex_unlock(&ls->ls_waiters_mutex);
+       spin_unlock(&ls->ls_waiters_lock);
        return error;
 }
 
@@ -1569,13 +1569,13 @@ static int remove_from_waiters_ms(struct dlm_lkb *lkb,
        int error;
 
        if (!local)
-               mutex_lock(&ls->ls_waiters_mutex);
+               spin_lock(&ls->ls_waiters_lock);
        else
                WARN_ON_ONCE(!rwsem_is_locked(&ls->ls_in_recovery) ||
                             !dlm_locking_stopped(ls));
        error = _remove_from_waiters(lkb, le32_to_cpu(ms->m_type), ms);
        if (!local)
-               mutex_unlock(&ls->ls_waiters_mutex);
+               spin_unlock(&ls->ls_waiters_lock);
        return error;
 }
 
@@ -4993,7 +4993,7 @@ static struct dlm_lkb *find_resend_waiter(struct dlm_ls *ls)
 {
        struct dlm_lkb *lkb = NULL, *iter;
 
-       mutex_lock(&ls->ls_waiters_mutex);
+       spin_lock(&ls->ls_waiters_lock);
        list_for_each_entry(iter, &ls->ls_waiters, lkb_wait_reply) {
                if (test_bit(DLM_IFL_RESEND_BIT, &iter->lkb_iflags)) {
                        hold_lkb(iter);
@@ -5001,7 +5001,7 @@ static struct dlm_lkb *find_resend_waiter(struct dlm_ls *ls)
                        break;
                }
        }
-       mutex_unlock(&ls->ls_waiters_mutex);
+       spin_unlock(&ls->ls_waiters_lock);
 
        return lkb;
 }
@@ -5101,9 +5101,9 @@ int dlm_recover_waiters_post(struct dlm_ls *ls)
                }
 
                /* Forcibly remove from waiters list */
-               mutex_lock(&ls->ls_waiters_mutex);
+               spin_lock(&ls->ls_waiters_lock);
                list_del_init(&lkb->lkb_wait_reply);
-               mutex_unlock(&ls->ls_waiters_mutex);
+               spin_unlock(&ls->ls_waiters_lock);
 
                /*
                 * The lkb is now clear of all prior waiters state and can be
index af7769f8e38c5b64d9686bef98e8f507daf6e041..94513980560575cabbfe6c58766e49027b03fcd2 100644 (file)
@@ -515,7 +515,7 @@ static int new_lockspace(const char *name, const char *cluster,
        spin_lock_init(&ls->ls_lkbidr_spin);
 
        INIT_LIST_HEAD(&ls->ls_waiters);
-       mutex_init(&ls->ls_waiters_mutex);
+       spin_lock_init(&ls->ls_waiters_lock);
        INIT_LIST_HEAD(&ls->ls_orphans);
        mutex_init(&ls->ls_orphans_mutex);