Commit 96777fe7 authored by Dave Kleikamp's avatar Dave Kleikamp Committed by Linus Torvalds
Browse files

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: default avatarDave Kleikamp <shaggy@linux.vnet.ibm.com>
Cc: Arjan van de Ven <arjan@linux.intel.com>
Reported-by: default avatarGrissiom <chaos.proton@gmail.com>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 9e42d0cf
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -458,7 +458,6 @@ void sync_filesystems(int wait)
		if (sb->s_flags & MS_RDONLY)
			continue;
		sb->s_need_sync_fs = 1;
		async_synchronize_full_special(&sb->s_async_list);
	}

restart:
@@ -471,6 +470,7 @@ restart:
		sb->s_count++;
		spin_unlock(&sb_lock);
		down_read(&sb->s_umount);
		async_synchronize_full_special(&sb->s_async_list);
		if (sb->s_root && (wait || sb->s_dirt))
			sb->s_op->sync_fs(sb, wait);
		up_read(&sb->s_umount);