Commit 3a95ea11 authored by OGAWA Hirofumi's avatar OGAWA Hirofumi Committed by Linus Torvalds

Fix _fat_bmap() locking

On swapon() path, it has already i_mutex. So, this uses i_alloc_sem
instead of it.
Signed-off-by: default avatarOGAWA Hirofumi <hirofumi@mail.parknet.co.jp>
Reported-by: default avatarLaurent GUERBY <laurent@guerby.net>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent ad3bdefe
...@@ -202,9 +202,9 @@ static sector_t _fat_bmap(struct address_space *mapping, sector_t block) ...@@ -202,9 +202,9 @@ static sector_t _fat_bmap(struct address_space *mapping, sector_t block)
sector_t blocknr; sector_t blocknr;
/* fat_get_cluster() assumes the requested blocknr isn't truncated. */ /* fat_get_cluster() assumes the requested blocknr isn't truncated. */
mutex_lock(&mapping->host->i_mutex); down_read(&mapping->host->i_alloc_sem);
blocknr = generic_block_bmap(mapping, block, fat_get_block); blocknr = generic_block_bmap(mapping, block, fat_get_block);
mutex_unlock(&mapping->host->i_mutex); up_read(&mapping->host->i_alloc_sem);
return blocknr; return blocknr;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment