mirror of
https://github.com/nxp-imx/linux-imx.git
synced 2025-07-07 09:55:19 +02:00
UPSTREAM: f2fs: convert f2fs_clear_page_cache_dirty_tag() to use folio
Convert 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>
Change-Id: I84494d96735dd91384b6828c7f1d397e407e38b5
Signed-off-by: Chao Yu <chao@kernel.org>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
(cherry picked from commit fd3a11aff4
)
This commit is contained in:
parent
7c6ac5c0b4
commit
f2b8a6eca7
|
@ -4139,9 +4139,8 @@ const struct address_space_operations f2fs_dblock_aops = {
|
||||||
.swap_deactivate = f2fs_swap_deactivate,
|
.swap_deactivate = f2fs_swap_deactivate,
|
||||||
};
|
};
|
||||||
|
|
||||||
void f2fs_clear_page_cache_dirty_tag(struct page *page)
|
void f2fs_clear_page_cache_dirty_tag(struct folio *folio)
|
||||||
{
|
{
|
||||||
struct folio *folio = page_folio(page);
|
|
||||||
struct address_space *mapping = folio->mapping;
|
struct address_space *mapping = folio->mapping;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
|
||||||
|
|
|
@ -911,7 +911,7 @@ void f2fs_delete_entry(struct f2fs_dir_entry *dentry, struct page *page,
|
||||||
|
|
||||||
if (bit_pos == NR_DENTRY_IN_BLOCK &&
|
if (bit_pos == NR_DENTRY_IN_BLOCK &&
|
||||||
!f2fs_truncate_hole(dir, page->index, page->index + 1)) {
|
!f2fs_truncate_hole(dir, page->index, page->index + 1)) {
|
||||||
f2fs_clear_page_cache_dirty_tag(page);
|
f2fs_clear_page_cache_dirty_tag(page_folio(page));
|
||||||
clear_page_dirty_for_io(page);
|
clear_page_dirty_for_io(page);
|
||||||
ClearPageUptodate(page);
|
ClearPageUptodate(page);
|
||||||
clear_page_private_all(page);
|
clear_page_private_all(page);
|
||||||
|
|
|
@ -3884,7 +3884,7 @@ void f2fs_write_failed(struct inode *inode, loff_t to);
|
||||||
void f2fs_invalidate_folio(struct folio *folio, size_t offset, size_t length);
|
void f2fs_invalidate_folio(struct folio *folio, size_t offset, size_t length);
|
||||||
bool f2fs_release_folio(struct folio *folio, gfp_t wait);
|
bool f2fs_release_folio(struct folio *folio, gfp_t wait);
|
||||||
bool f2fs_overwrite_io(struct inode *inode, loff_t pos, size_t len);
|
bool f2fs_overwrite_io(struct inode *inode, loff_t pos, size_t len);
|
||||||
void f2fs_clear_page_cache_dirty_tag(struct page *page);
|
void f2fs_clear_page_cache_dirty_tag(struct folio *folio);
|
||||||
int f2fs_init_post_read_processing(void);
|
int f2fs_init_post_read_processing(void);
|
||||||
void f2fs_destroy_post_read_processing(void);
|
void f2fs_destroy_post_read_processing(void);
|
||||||
int f2fs_init_post_read_wq(struct f2fs_sb_info *sbi);
|
int f2fs_init_post_read_wq(struct f2fs_sb_info *sbi);
|
||||||
|
|
|
@ -281,7 +281,7 @@ int f2fs_write_inline_data(struct inode *inode, struct page *page)
|
||||||
page, 0, MAX_INLINE_DATA(inode));
|
page, 0, MAX_INLINE_DATA(inode));
|
||||||
set_page_dirty(ipage);
|
set_page_dirty(ipage);
|
||||||
|
|
||||||
f2fs_clear_page_cache_dirty_tag(page);
|
f2fs_clear_page_cache_dirty_tag(page_folio(page));
|
||||||
|
|
||||||
set_inode_flag(inode, FI_APPEND_WRITE);
|
set_inode_flag(inode, FI_APPEND_WRITE);
|
||||||
set_inode_flag(inode, FI_DATA_EXIST);
|
set_inode_flag(inode, FI_DATA_EXIST);
|
||||||
|
|
|
@ -123,7 +123,7 @@ bool f2fs_available_free_memory(struct f2fs_sb_info *sbi, int type)
|
||||||
static void clear_node_page_dirty(struct page *page)
|
static void clear_node_page_dirty(struct page *page)
|
||||||
{
|
{
|
||||||
if (PageDirty(page)) {
|
if (PageDirty(page)) {
|
||||||
f2fs_clear_page_cache_dirty_tag(page);
|
f2fs_clear_page_cache_dirty_tag(page_folio(page));
|
||||||
clear_page_dirty_for_io(page);
|
clear_page_dirty_for_io(page);
|
||||||
dec_page_count(F2FS_P_SB(page), F2FS_DIRTY_NODES);
|
dec_page_count(F2FS_P_SB(page), F2FS_DIRTY_NODES);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user