On 11/07, Yunlei He wrote:
> This patch check new block reserve strictly, in case of
> garbage data of node page.
> 
> Signed-off-by: Yunlei He <[email protected]>
> ---
>  fs/f2fs/data.c    |  9 +++++++--
>  fs/f2fs/file.c    | 13 +++++--------
>  fs/f2fs/segment.c |  1 +
>  3 files changed, 13 insertions(+), 10 deletions(-)
> 
> diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c
> index b0781ed..3017a87 100644
> --- a/fs/f2fs/data.c
> +++ b/fs/f2fs/data.c
> @@ -558,13 +558,18 @@ int reserve_new_blocks(struct dnode_of_data *dn, 
> blkcnt_t count)
>  
>       f2fs_wait_on_page_writeback(dn->node_page, NODE, true);
>  
> -     for (; count > 0; dn->ofs_in_node++) {
> +     for (; count > 0; dn->ofs_in_node++, count--) {
>               block_t blkaddr = datablock_addr(dn->inode,
>                                       dn->node_page, dn->ofs_in_node);
>               if (blkaddr == NULL_ADDR) {
>                       dn->data_blkaddr = NEW_ADDR;
>                       __set_data_blkaddr(dn);
> -                     count--;
> +             } else {
> +                     f2fs_msg(sbi->sb, KERN_ERR, "reserve non NULL block, "
> +                             "blkaddr:%u, ino:%lu, nid:%u, ofs_in_node:%u",
> +                             blkaddr, dn->inode->i_ino, dn->nid,
> +                             dn->ofs_in_node);
> +                     f2fs_bug_on(sbi, 1);

What if there is a hole?

>               }
>       }
>  
> diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c
> index cee0f36..dfc23c2 100644
> --- a/fs/f2fs/file.c
> +++ b/fs/f2fs/file.c
> @@ -1218,19 +1218,16 @@ static int f2fs_do_zero_range(struct dnode_of_data 
> *dn, pgoff_t start,
>       struct f2fs_sb_info *sbi = F2FS_I_SB(dn->inode);
>       pgoff_t index = start;
>       unsigned int ofs_in_node = dn->ofs_in_node;
> -     blkcnt_t count = 0;
> -     int ret;
> +     int ret = 0;
>  
>       for (; index < end; index++, dn->ofs_in_node++) {
>               if (datablock_addr(dn->inode, dn->node_page,
>                                       dn->ofs_in_node) == NULL_ADDR)
> -                     count++;
> -     }
> +                     ret = reserve_new_blocks(dn, 1);
>  
> -     dn->ofs_in_node = ofs_in_node;
> -     ret = reserve_new_blocks(dn, count);
> -     if (ret)
> -             return ret;
> +             if (ret)
> +                     return ret;
> +     }
>  
>       dn->ofs_in_node = ofs_in_node;
>       for (index = start; index < end; index++, dn->ofs_in_node++) {
> diff --git a/fs/f2fs/segment.c b/fs/f2fs/segment.c
> index 20722b2..e670967 100644
> --- a/fs/f2fs/segment.c
> +++ b/fs/f2fs/segment.c
> @@ -1815,6 +1815,7 @@ static void update_sit_entry(struct f2fs_sb_info *sbi, 
> block_t blkaddr, int del)
>       bool mir_exist;
>  #endif
>  
> +     verify_block_addr(sbi, blkaddr);
>       segno = GET_SEGNO(sbi, blkaddr);
>  
>       se = get_seg_entry(sbi, segno);
> -- 
> 1.9.1

------------------------------------------------------------------------------
Check out the vibrant tech community on one of the world's most
engaging tech sites, Slashdot.org! http://sdm.link/slashdot
_______________________________________________
Linux-f2fs-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel

Reply via email to