mirror of
git://git.yoctoproject.org/linux-yocto.git
synced 2025-10-22 23:13:01 +02:00
commit299910dcb4upstream. After detecting file system corruption and degrading to a read-only mount, dirty folios and buffers in the page cache are cleared, and a large number of warnings are output at that time, often filling up the kernel log. In this case, since the degrading to a read-only mount is output to the kernel log, these warnings are not very meaningful, and are rather a nuisance in system management and debugging. The related nilfs2-specific page/folio routines have a silent argument that suppresses the warning output, but since it is not currently used meaningfully, remove both the silent argument and the warning output. [konishi.ryusuke@gmail.com: adjusted for page/folio conversion] Link: https://lkml.kernel.org/r/20240816090128.4561-1-konishi.ryusuke@gmail.com Signed-off-by: Ryusuke Konishi <konishi.ryusuke@gmail.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Stable-dep-of:ca76bb226b("nilfs2: do not force clear folio if buffer is referenced") Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
67 lines
1.9 KiB
C
67 lines
1.9 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
/*
|
|
* Buffer/page management specific to NILFS
|
|
*
|
|
* Copyright (C) 2005-2008 Nippon Telegraph and Telephone Corporation.
|
|
*
|
|
* Written by Ryusuke Konishi and Seiji Kihara.
|
|
*/
|
|
|
|
#ifndef _NILFS_PAGE_H
|
|
#define _NILFS_PAGE_H
|
|
|
|
#include <linux/buffer_head.h>
|
|
#include "nilfs.h"
|
|
|
|
/*
|
|
* Extended buffer state bits
|
|
*/
|
|
enum {
|
|
BH_NILFS_Allocated = BH_PrivateStart,
|
|
BH_NILFS_Node,
|
|
BH_NILFS_Volatile,
|
|
BH_NILFS_Checked,
|
|
BH_NILFS_Redirected,
|
|
};
|
|
|
|
BUFFER_FNS(NILFS_Node, nilfs_node) /* nilfs node buffers */
|
|
BUFFER_FNS(NILFS_Volatile, nilfs_volatile)
|
|
BUFFER_FNS(NILFS_Checked, nilfs_checked) /* buffer is verified */
|
|
BUFFER_FNS(NILFS_Redirected, nilfs_redirected) /* redirected to a copy */
|
|
|
|
|
|
int __nilfs_clear_page_dirty(struct page *);
|
|
|
|
struct buffer_head *nilfs_grab_buffer(struct inode *, struct address_space *,
|
|
unsigned long, unsigned long);
|
|
void nilfs_forget_buffer(struct buffer_head *);
|
|
void nilfs_copy_buffer(struct buffer_head *, struct buffer_head *);
|
|
int nilfs_page_buffers_clean(struct page *);
|
|
void nilfs_page_bug(struct page *);
|
|
|
|
int nilfs_copy_dirty_pages(struct address_space *, struct address_space *);
|
|
void nilfs_copy_back_pages(struct address_space *, struct address_space *);
|
|
void nilfs_clear_dirty_page(struct page *page);
|
|
void nilfs_clear_dirty_pages(struct address_space *mapping);
|
|
unsigned int nilfs_page_count_clean_buffers(struct page *, unsigned int,
|
|
unsigned int);
|
|
unsigned long nilfs_find_uncommitted_extent(struct inode *inode,
|
|
sector_t start_blk,
|
|
sector_t *blkoff);
|
|
|
|
#define NILFS_PAGE_BUG(page, m, a...) \
|
|
do { nilfs_page_bug(page); BUG(); } while (0)
|
|
|
|
static inline struct buffer_head *
|
|
nilfs_page_get_nth_block(struct page *page, unsigned int count)
|
|
{
|
|
struct buffer_head *bh = page_buffers(page);
|
|
|
|
while (count-- > 0)
|
|
bh = bh->b_this_page;
|
|
get_bh(bh);
|
|
return bh;
|
|
}
|
|
|
|
#endif /* _NILFS_PAGE_H */
|