Message ID | 20240813141331.417067-1-chao@kernel.org (mailing list archive) |
---|---|
State | Accepted |
Commit | 2cbbc4f9431716b8a59065f4a3b63a5eb338be0c |
Headers | show |
Series | [f2fs-dev,1/9] f2fs: convert f2fs_compress_ctx_add_page() to use folio | expand |
Could you please test this series? I hit kernel hang along with refcount warning in f2fs_put_dic, when running fsstress. You can reproduce it quickly. On 08/13, Chao Yu wrote: > onvert to use folio, so that we can get rid of 'page->index' to > prepare for removal of 'index' field in structure page [1]. > > [1] https://lore.kernel.org/all/Zp8fgUSIBGQ1TN0D@casper.infradead.org/ > > Cc: Matthew Wilcox <willy@infradead.org> > Signed-off-by: Chao Yu <chao@kernel.org> > --- > fs/f2fs/compress.c | 14 +++++++------- > fs/f2fs/data.c | 4 ++-- > fs/f2fs/f2fs.h | 2 +- > 3 files changed, 10 insertions(+), 10 deletions(-) > > diff --git a/fs/f2fs/compress.c b/fs/f2fs/compress.c > index 990b93689b46..eb5cd1457ffc 100644 > --- a/fs/f2fs/compress.c > +++ b/fs/f2fs/compress.c > @@ -160,17 +160,17 @@ void f2fs_destroy_compress_ctx(struct compress_ctx *cc, bool reuse) > cc->cluster_idx = NULL_CLUSTER; > } > > -void f2fs_compress_ctx_add_page(struct compress_ctx *cc, struct page *page) > +void f2fs_compress_ctx_add_page(struct compress_ctx *cc, struct folio *folio) > { > unsigned int cluster_ofs; > > - if (!f2fs_cluster_can_merge_page(cc, page->index)) > + if (!f2fs_cluster_can_merge_page(cc, folio->index)) > f2fs_bug_on(F2FS_I_SB(cc->inode), 1); > > - cluster_ofs = offset_in_cluster(cc, page->index); > - cc->rpages[cluster_ofs] = page; > + cluster_ofs = offset_in_cluster(cc, folio->index); > + cc->rpages[cluster_ofs] = folio_page(folio, 0); > cc->nr_rpages++; > - cc->cluster_idx = cluster_idx(cc, page->index); > + cc->cluster_idx = cluster_idx(cc, folio->index); > } > > #ifdef CONFIG_F2FS_FS_LZO > @@ -1093,7 +1093,7 @@ static int prepare_compress_overwrite(struct compress_ctx *cc, > if (PageUptodate(page)) > f2fs_put_page(page, 1); > else > - f2fs_compress_ctx_add_page(cc, page); > + f2fs_compress_ctx_add_page(cc, page_folio(page)); > } > > if (!f2fs_cluster_is_empty(cc)) { > @@ -1123,7 +1123,7 @@ static int prepare_compress_overwrite(struct compress_ctx *cc, > } > > f2fs_wait_on_page_writeback(page, DATA, true, true); > - f2fs_compress_ctx_add_page(cc, page); > + f2fs_compress_ctx_add_page(cc, page_folio(page)); > > if (!PageUptodate(page)) { > release_and_retry: > diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c > index e9570f4e0f21..100b6526717f 100644 > --- a/fs/f2fs/data.c > +++ b/fs/f2fs/data.c > @@ -2429,7 +2429,7 @@ static int f2fs_mpage_readpages(struct inode *inode, > if (ret) > goto set_error_page; > > - f2fs_compress_ctx_add_page(&cc, &folio->page); > + f2fs_compress_ctx_add_page(&cc, folio); > > goto next_page; > read_single_page: > @@ -3161,7 +3161,7 @@ static int f2fs_write_cache_pages(struct address_space *mapping, > #ifdef CONFIG_F2FS_FS_COMPRESSION > if (f2fs_compressed_file(inode)) { > folio_get(folio); > - f2fs_compress_ctx_add_page(&cc, &folio->page); > + f2fs_compress_ctx_add_page(&cc, folio); > continue; > } > #endif > diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h > index 51fd5063a69c..df436dd3aac1 100644 > --- a/fs/f2fs/f2fs.h > +++ b/fs/f2fs/f2fs.h > @@ -4322,7 +4322,7 @@ bool f2fs_cluster_can_merge_page(struct compress_ctx *cc, pgoff_t index); > bool f2fs_all_cluster_page_ready(struct compress_ctx *cc, struct page **pages, > int index, int nr_pages, bool uptodate); > bool f2fs_sanity_check_cluster(struct dnode_of_data *dn); > -void f2fs_compress_ctx_add_page(struct compress_ctx *cc, struct page *page); > +void f2fs_compress_ctx_add_page(struct compress_ctx *cc, struct folio *folio); > int f2fs_write_multi_pages(struct compress_ctx *cc, > int *submitted, > struct writeback_control *wbc, > -- > 2.40.1
On 2024/8/14 6:24, Jaegeuk Kim wrote: > Could you please test this series? I hit kernel hang along with refcount warning Oops, I've did fstest before sending this patchset, however I missed to cover w/ compression testcase..., so, too rush to push the patchset, sorry. Will check and fix it soon. Thanks, > in f2fs_put_dic, when running fsstress. You can reproduce it quickly. > > On 08/13, Chao Yu wrote: >> onvert to use folio, so that we can get rid of 'page->index' to >> prepare for removal of 'index' field in structure page [1]. >> >> [1] https://lore.kernel.org/all/Zp8fgUSIBGQ1TN0D@casper.infradead.org/ >> >> Cc: Matthew Wilcox <willy@infradead.org> >> Signed-off-by: Chao Yu <chao@kernel.org> >> --- >> fs/f2fs/compress.c | 14 +++++++------- >> fs/f2fs/data.c | 4 ++-- >> fs/f2fs/f2fs.h | 2 +- >> 3 files changed, 10 insertions(+), 10 deletions(-) >> >> diff --git a/fs/f2fs/compress.c b/fs/f2fs/compress.c >> index 990b93689b46..eb5cd1457ffc 100644 >> --- a/fs/f2fs/compress.c >> +++ b/fs/f2fs/compress.c >> @@ -160,17 +160,17 @@ void f2fs_destroy_compress_ctx(struct compress_ctx *cc, bool reuse) >> cc->cluster_idx = NULL_CLUSTER; >> } >> >> -void f2fs_compress_ctx_add_page(struct compress_ctx *cc, struct page *page) >> +void f2fs_compress_ctx_add_page(struct compress_ctx *cc, struct folio *folio) >> { >> unsigned int cluster_ofs; >> >> - if (!f2fs_cluster_can_merge_page(cc, page->index)) >> + if (!f2fs_cluster_can_merge_page(cc, folio->index)) >> f2fs_bug_on(F2FS_I_SB(cc->inode), 1); >> >> - cluster_ofs = offset_in_cluster(cc, page->index); >> - cc->rpages[cluster_ofs] = page; >> + cluster_ofs = offset_in_cluster(cc, folio->index); >> + cc->rpages[cluster_ofs] = folio_page(folio, 0); >> cc->nr_rpages++; >> - cc->cluster_idx = cluster_idx(cc, page->index); >> + cc->cluster_idx = cluster_idx(cc, folio->index); >> } >> >> #ifdef CONFIG_F2FS_FS_LZO >> @@ -1093,7 +1093,7 @@ static int prepare_compress_overwrite(struct compress_ctx *cc, >> if (PageUptodate(page)) >> f2fs_put_page(page, 1); >> else >> - f2fs_compress_ctx_add_page(cc, page); >> + f2fs_compress_ctx_add_page(cc, page_folio(page)); >> } >> >> if (!f2fs_cluster_is_empty(cc)) { >> @@ -1123,7 +1123,7 @@ static int prepare_compress_overwrite(struct compress_ctx *cc, >> } >> >> f2fs_wait_on_page_writeback(page, DATA, true, true); >> - f2fs_compress_ctx_add_page(cc, page); >> + f2fs_compress_ctx_add_page(cc, page_folio(page)); >> >> if (!PageUptodate(page)) { >> release_and_retry: >> diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c >> index e9570f4e0f21..100b6526717f 100644 >> --- a/fs/f2fs/data.c >> +++ b/fs/f2fs/data.c >> @@ -2429,7 +2429,7 @@ static int f2fs_mpage_readpages(struct inode *inode, >> if (ret) >> goto set_error_page; >> >> - f2fs_compress_ctx_add_page(&cc, &folio->page); >> + f2fs_compress_ctx_add_page(&cc, folio); >> >> goto next_page; >> read_single_page: >> @@ -3161,7 +3161,7 @@ static int f2fs_write_cache_pages(struct address_space *mapping, >> #ifdef CONFIG_F2FS_FS_COMPRESSION >> if (f2fs_compressed_file(inode)) { >> folio_get(folio); >> - f2fs_compress_ctx_add_page(&cc, &folio->page); >> + f2fs_compress_ctx_add_page(&cc, folio); >> continue; >> } >> #endif >> diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h >> index 51fd5063a69c..df436dd3aac1 100644 >> --- a/fs/f2fs/f2fs.h >> +++ b/fs/f2fs/f2fs.h >> @@ -4322,7 +4322,7 @@ bool f2fs_cluster_can_merge_page(struct compress_ctx *cc, pgoff_t index); >> bool f2fs_all_cluster_page_ready(struct compress_ctx *cc, struct page **pages, >> int index, int nr_pages, bool uptodate); >> bool f2fs_sanity_check_cluster(struct dnode_of_data *dn); >> -void f2fs_compress_ctx_add_page(struct compress_ctx *cc, struct page *page); >> +void f2fs_compress_ctx_add_page(struct compress_ctx *cc, struct folio *folio); >> int f2fs_write_multi_pages(struct compress_ctx *cc, >> int *submitted, >> struct writeback_control *wbc, >> -- >> 2.40.1
On 2024/8/14 6:24, Jaegeuk Kim wrote: > Could you please test this series? I hit kernel hang along with refcount warning > in f2fs_put_dic, when running fsstress. You can reproduce it quickly. --- fs/f2fs/data.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c index 9e21cfe11cc7..4f4e76c33611 100644 --- a/fs/f2fs/data.c +++ b/fs/f2fs/data.c @@ -2322,7 +2322,7 @@ int f2fs_read_multi_pages(struct compress_ctx *cc, struct bio **bio_ret, } } - if (bio_add_folio(bio, folio, blocksize, 0) < blocksize) + if (!bio_add_folio(bio, folio, blocksize, 0)) goto submit_and_realloc; ctx = get_post_read_ctx(bio);
Hello: This series was applied to jaegeuk/f2fs.git (dev) by Jaegeuk Kim <jaegeuk@kernel.org>: On Tue, 13 Aug 2024 22:13:23 +0800 you wrote: > onvert to use folio, so that we can get rid of 'page->index' to > prepare for removal of 'index' field in structure page [1]. > > [1] https://lore.kernel.org/all/Zp8fgUSIBGQ1TN0D@casper.infradead.org/ > > Cc: Matthew Wilcox <willy@infradead.org> > Signed-off-by: Chao Yu <chao@kernel.org> > > [...] Here is the summary with links: - [f2fs-dev,1/9] f2fs: convert f2fs_compress_ctx_add_page() to use folio https://git.kernel.org/jaegeuk/f2fs/c/2cbbc4f94317 - [f2fs-dev,2/9] f2fs: convert f2fs_vm_page_mkwrite() to use folio https://git.kernel.org/jaegeuk/f2fs/c/8ed263450530 - [f2fs-dev,3/9] f2fs: convert f2fs_clear_page_cache_dirty_tag() to use folio https://git.kernel.org/jaegeuk/f2fs/c/71aa6bbfc247 - [f2fs-dev,4/9] f2fs: convert f2fs_write_inline_data() to use folio https://git.kernel.org/jaegeuk/f2fs/c/333ad04822f5 - [f2fs-dev,5/9] f2fs: convert f2fs_write_single_data_page() to use folio https://git.kernel.org/jaegeuk/f2fs/c/65826f2732fa - [f2fs-dev,6/9] f2fs: convert f2fs_do_write_meta_page() to use folio https://git.kernel.org/jaegeuk/f2fs/c/9f9bbd634792 - [f2fs-dev,7/9] f2fs: convert __f2fs_write_meta_page() to use folio https://git.kernel.org/jaegeuk/f2fs/c/1b9eb6539810 - [f2fs-dev,8/9] f2fs: convert f2fs_read_multi_pages() to use folio (no matching commit) - [f2fs-dev,9/9] f2fs: convert f2fs_handle_page_eio() to use folio https://git.kernel.org/jaegeuk/f2fs/c/6d899d7e3999 You are awesome, thank you!
diff --git a/fs/f2fs/compress.c b/fs/f2fs/compress.c index 990b93689b46..eb5cd1457ffc 100644 --- a/fs/f2fs/compress.c +++ b/fs/f2fs/compress.c @@ -160,17 +160,17 @@ void f2fs_destroy_compress_ctx(struct compress_ctx *cc, bool reuse) cc->cluster_idx = NULL_CLUSTER; } -void f2fs_compress_ctx_add_page(struct compress_ctx *cc, struct page *page) +void f2fs_compress_ctx_add_page(struct compress_ctx *cc, struct folio *folio) { unsigned int cluster_ofs; - if (!f2fs_cluster_can_merge_page(cc, page->index)) + if (!f2fs_cluster_can_merge_page(cc, folio->index)) f2fs_bug_on(F2FS_I_SB(cc->inode), 1); - cluster_ofs = offset_in_cluster(cc, page->index); - cc->rpages[cluster_ofs] = page; + cluster_ofs = offset_in_cluster(cc, folio->index); + cc->rpages[cluster_ofs] = folio_page(folio, 0); cc->nr_rpages++; - cc->cluster_idx = cluster_idx(cc, page->index); + cc->cluster_idx = cluster_idx(cc, folio->index); } #ifdef CONFIG_F2FS_FS_LZO @@ -1093,7 +1093,7 @@ static int prepare_compress_overwrite(struct compress_ctx *cc, if (PageUptodate(page)) f2fs_put_page(page, 1); else - f2fs_compress_ctx_add_page(cc, page); + f2fs_compress_ctx_add_page(cc, page_folio(page)); } if (!f2fs_cluster_is_empty(cc)) { @@ -1123,7 +1123,7 @@ static int prepare_compress_overwrite(struct compress_ctx *cc, } f2fs_wait_on_page_writeback(page, DATA, true, true); - f2fs_compress_ctx_add_page(cc, page); + f2fs_compress_ctx_add_page(cc, page_folio(page)); if (!PageUptodate(page)) { release_and_retry: diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c index e9570f4e0f21..100b6526717f 100644 --- a/fs/f2fs/data.c +++ b/fs/f2fs/data.c @@ -2429,7 +2429,7 @@ static int f2fs_mpage_readpages(struct inode *inode, if (ret) goto set_error_page; - f2fs_compress_ctx_add_page(&cc, &folio->page); + f2fs_compress_ctx_add_page(&cc, folio); goto next_page; read_single_page: @@ -3161,7 +3161,7 @@ static int f2fs_write_cache_pages(struct address_space *mapping, #ifdef CONFIG_F2FS_FS_COMPRESSION if (f2fs_compressed_file(inode)) { folio_get(folio); - f2fs_compress_ctx_add_page(&cc, &folio->page); + f2fs_compress_ctx_add_page(&cc, folio); continue; } #endif diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h index 51fd5063a69c..df436dd3aac1 100644 --- a/fs/f2fs/f2fs.h +++ b/fs/f2fs/f2fs.h @@ -4322,7 +4322,7 @@ bool f2fs_cluster_can_merge_page(struct compress_ctx *cc, pgoff_t index); bool f2fs_all_cluster_page_ready(struct compress_ctx *cc, struct page **pages, int index, int nr_pages, bool uptodate); bool f2fs_sanity_check_cluster(struct dnode_of_data *dn); -void f2fs_compress_ctx_add_page(struct compress_ctx *cc, struct page *page); +void f2fs_compress_ctx_add_page(struct compress_ctx *cc, struct folio *folio); int f2fs_write_multi_pages(struct compress_ctx *cc, int *submitted, struct writeback_control *wbc,
onvert to use folio, so that we can get rid of 'page->index' to prepare for removal of 'index' field in structure page [1]. [1] https://lore.kernel.org/all/Zp8fgUSIBGQ1TN0D@casper.infradead.org/ Cc: Matthew Wilcox <willy@infradead.org> Signed-off-by: Chao Yu <chao@kernel.org> --- fs/f2fs/compress.c | 14 +++++++------- fs/f2fs/data.c | 4 ++-- fs/f2fs/f2fs.h | 2 +- 3 files changed, 10 insertions(+), 10 deletions(-)