提交 96777fe7 编写于 作者: D Dave Kleikamp 提交者: Linus Torvalds

async: Don't call async_synchronize_full_special() while holding sb_lock

sync_filesystems() shouldn't be calling async_synchronize_full_special
while holding a spinlock.  The second while loop in that function is the
right place for this anyway.
Signed-off-by: NDave Kleikamp <shaggy@linux.vnet.ibm.com>
Cc: Arjan van de Ven <arjan@linux.intel.com>
Reported-by: NGrissiom <chaos.proton@gmail.com>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 9e42d0cf
...@@ -458,7 +458,6 @@ void sync_filesystems(int wait) ...@@ -458,7 +458,6 @@ void sync_filesystems(int wait)
if (sb->s_flags & MS_RDONLY) if (sb->s_flags & MS_RDONLY)
continue; continue;
sb->s_need_sync_fs = 1; sb->s_need_sync_fs = 1;
async_synchronize_full_special(&sb->s_async_list);
} }
restart: restart:
...@@ -471,6 +470,7 @@ void sync_filesystems(int wait) ...@@ -471,6 +470,7 @@ void sync_filesystems(int wait)
sb->s_count++; sb->s_count++;
spin_unlock(&sb_lock); spin_unlock(&sb_lock);
down_read(&sb->s_umount); down_read(&sb->s_umount);
async_synchronize_full_special(&sb->s_async_list);
if (sb->s_root && (wait || sb->s_dirt)) if (sb->s_root && (wait || sb->s_dirt))
sb->s_op->sync_fs(sb, wait); sb->s_op->sync_fs(sb, wait);
up_read(&sb->s_umount); up_read(&sb->s_umount);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册