f2fs: relax migratepage for atomic written page
In order to avoid lock contention for atomic written pages, we'd better give EBUSY in f2fs_migrate_page when mode is asynchronous. We expect it will be released soon as transaction commits. Reviewed-by: Chao Yu <yuchao0@huawei.com> Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
This commit is contained in:
Родитель
000519f278
Коммит
ff1048e7df
|
@ -2203,8 +2203,12 @@ int f2fs_migrate_page(struct address_space *mapping,
|
|||
BUG_ON(PageWriteback(page));
|
||||
|
||||
/* migrating an atomic written page is safe with the inmem_lock hold */
|
||||
if (atomic_written && !mutex_trylock(&fi->inmem_lock))
|
||||
return -EAGAIN;
|
||||
if (atomic_written) {
|
||||
if (mode != MIGRATE_SYNC)
|
||||
return -EBUSY;
|
||||
if (!mutex_trylock(&fi->inmem_lock))
|
||||
return -EAGAIN;
|
||||
}
|
||||
|
||||
/*
|
||||
* A reference is expected if PagePrivate set when move mapping,
|
||||
|
|
Загрузка…
Ссылка в новой задаче