disable_writeback_work);
        struct mddev *mddev = log->rdev->mddev;
        struct r5conf *conf = mddev->private;
-       int locked = 0;
 
        if (log->r5c_journal_mode == R5C_JOURNAL_MODE_WRITE_THROUGH)
                return;
        /* wait superblock change before suspend */
        wait_event(mddev->sb_wait,
                   !READ_ONCE(conf->log) ||
-                  (!test_bit(MD_SB_CHANGE_PENDING, &mddev->sb_flags) &&
-                   (locked = mddev_trylock(mddev))));
-       if (locked) {
-               mddev_suspend(mddev);
+                  !test_bit(MD_SB_CHANGE_PENDING, &mddev->sb_flags));
+
+       log = READ_ONCE(conf->log);
+       if (log) {
+               __mddev_suspend(mddev, false);
                log->r5c_journal_mode = R5C_JOURNAL_MODE_WRITE_THROUGH;
-               mddev_resume(mddev);
-               mddev_unlock(mddev);
+               __mddev_resume(mddev);
        }
 }
 
            mode == R5C_JOURNAL_MODE_WRITE_BACK)
                return -EINVAL;
 
-       mddev_suspend(mddev);
        conf->log->r5c_journal_mode = mode;
-       mddev_resume(mddev);
 
        pr_debug("md/raid:%s: setting r5c cache mode to %d: %s\n",
                 mdname(mddev), mode, r5c_journal_mode_str[mode]);
                if (strlen(r5c_journal_mode_str[mode]) == len &&
                    !strncmp(page, r5c_journal_mode_str[mode], len))
                        break;
-       ret = mddev_lock(mddev);
+       ret = mddev_suspend_and_lock(mddev);
        if (ret)
                return ret;
        ret = r5c_journal_mode_set(mddev, mode);
-       mddev_unlock(mddev);
+       mddev_unlock_and_resume(mddev);
        return ret ?: length;
 }