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);
                }
        }
 
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