* [PATCH] f2fs: check block reserve strictly a little bit
@ 2017-11-07 9:56 Yunlei He
2017-11-09 17:55 ` Jaegeuk Kim
0 siblings, 1 reply; 4+ messages in thread
From: Yunlei He @ 2017-11-07 9:56 UTC (permalink / raw)
To: jaegeuk, yuchao0, linux-f2fs-devel; +Cc: ning.jia, heyunlei
This patch check new block reserve strictly, in case of
garbage data of node page.
Signed-off-by: Yunlei He <heyunlei@huawei.com>
---
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
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH] f2fs: check block reserve strictly a little bit
2017-11-07 9:56 [PATCH] f2fs: check block reserve strictly a little bit Yunlei He
@ 2017-11-09 17:55 ` Jaegeuk Kim
2017-11-10 2:30 ` heyunlei
0 siblings, 1 reply; 4+ messages in thread
From: Jaegeuk Kim @ 2017-11-09 17:55 UTC (permalink / raw)
To: Yunlei He; +Cc: ning.jia, linux-f2fs-devel
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 <heyunlei@huawei.com>
> ---
> 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
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH] f2fs: check block reserve strictly a little bit
2017-11-09 17:55 ` Jaegeuk Kim
@ 2017-11-10 2:30 ` heyunlei
2017-11-10 19:55 ` Jaegeuk Kim
0 siblings, 1 reply; 4+ messages in thread
From: heyunlei @ 2017-11-10 2:30 UTC (permalink / raw)
To: Jaegeuk Kim; +Cc: Jianing (Euler), linux-f2fs-devel
>-----Original Message-----
>From: Jaegeuk Kim [mailto:jaegeuk@kernel.org]
>Sent: Friday, November 10, 2017 1:55 AM
>To: heyunlei
>Cc: Yuchao (T); linux-f2fs-devel@lists.sourceforge.net; Wangbintian; Jianing (Euler)
>Subject: Re: [f2fs-dev][PATCH] f2fs: check block reserve strictly a little bit
>
>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 <heyunlei@huawei.com>
>> ---
>> 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?
Hole can hold a non NULL block index?
NEW_ADDR may be possible, for the case date block is reserved but without wb
after new cp.
How about this?
} else if (blkaddr != NEW_ADDR ){
f2fs_msg();
}
Thanks.
>
>> }
>> }
>>
>> 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
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH] f2fs: check block reserve strictly a little bit
2017-11-10 2:30 ` heyunlei
@ 2017-11-10 19:55 ` Jaegeuk Kim
0 siblings, 0 replies; 4+ messages in thread
From: Jaegeuk Kim @ 2017-11-10 19:55 UTC (permalink / raw)
To: heyunlei; +Cc: Jianing (Euler), linux-f2fs-devel
On 11/10, heyunlei wrote:
>
>
> >-----Original Message-----
> >From: Jaegeuk Kim [mailto:jaegeuk@kernel.org]
> >Sent: Friday, November 10, 2017 1:55 AM
> >To: heyunlei
> >Cc: Yuchao (T); linux-f2fs-devel@lists.sourceforge.net; Wangbintian; Jianing (Euler)
> >Subject: Re: [f2fs-dev][PATCH] f2fs: check block reserve strictly a little bit
> >
> >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 <heyunlei@huawei.com>
> >> ---
> >> 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?
>
> Hole can hold a non NULL block index?
> NEW_ADDR may be possible, for the case date block is reserved but without wb
> after new cp.
> How about this?
> } else if (blkaddr != NEW_ADDR ){
> f2fs_msg();
> }
No, it is allowed to allocate new blocks in holes. We can give the # of
allocated blocks to caller which can check its intention.
> Thanks.
> >
> >> }
> >> }
> >>
> >> 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
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2017-11-10 19:55 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-11-07 9:56 [PATCH] f2fs: check block reserve strictly a little bit Yunlei He
2017-11-09 17:55 ` Jaegeuk Kim
2017-11-10 2:30 ` heyunlei
2017-11-10 19:55 ` Jaegeuk Kim
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.