From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-3.6 required=3.0 tests=CHARSET_FARAWAY_HEADER, DKIMWL_WL_HIGH,DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI,SIGNED_OFF_BY, SPF_HELO_NONE,SPF_PASS,UNPARSEABLE_RELAY,URIBL_BLOCKED autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id E011AC433E0 for ; Fri, 19 Jun 2020 08:49:38 +0000 (UTC) Received: from lists.sourceforge.net (lists.sourceforge.net [216.105.38.7]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id A40412080C; Fri, 19 Jun 2020 08:49:38 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=lists.sourceforge.net header.i=@lists.sourceforge.net header.b="evJn1jKt"; dkim=fail reason="signature verification failed" (1024-bit key) header.d=sourceforge.net header.i=@sourceforge.net header.b="Mu1wYfDV"; dkim=fail reason="signature verification failed" (1024-bit key) header.d=sf.net header.i=@sf.net header.b="fRyfOXCS" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org A40412080C Authentication-Results: mail.kernel.org; dmarc=pass (p=none dis=none) header.from=lists.sourceforge.net Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=linux-f2fs-devel-bounces@lists.sourceforge.net DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.sourceforge.net; s=beta; h=Content-Transfer-Encoding:Content-Type:Cc: Reply-To:From:List-Subscribe:List-Help:List-Post:List-Archive: List-Unsubscribe:List-Id:Subject:MIME-Version:Message-ID:Date:In-Reply-To: References:To:Sender:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=wD5RCDezo+Q0uO/NmE7srrXenC7RZ3PeuGuGOoGGUM8=; b=evJn1jKtzusGBf2I3Ikkjm3G4y YXA/BzHrVYadnjQqlbllrukV/d2/nt6Q3DI4YjUm/dX9T1tSIhDkESvrW3yWrhE0j2VYFstFnFz5O uAC6deDFUKkxf7vTC39I2PS+HIFbvuWp3LswRgN+PSFECB/EgQh8eLHfhx44BCuA9Jb4=; Received: from [127.0.0.1] (helo=sfs-ml-2.v29.lw.sourceforge.com) by sfs-ml-2.v29.lw.sourceforge.com with esmtp (Exim 4.90_1) (envelope-from ) id 1jmCiQ-0003h4-9I; Fri, 19 Jun 2020 08:49:38 +0000 Received: from [172.30.20.202] (helo=mx.sourceforge.net) by sfs-ml-2.v29.lw.sourceforge.com with esmtps (TLSv1.2:ECDHE-RSA-AES256-GCM-SHA384:256) (Exim 4.90_1) (envelope-from ) id 1jmCiO-0003gw-Rj for linux-f2fs-devel@lists.sourceforge.net; Fri, 19 Jun 2020 08:49:36 +0000 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=sourceforge.net; s=x; h=Content-Transfer-Encoding:Content-Type:MIME-Version :Message-ID:Date:Subject:In-Reply-To:References:Cc:To:From:Sender:Reply-To: Content-ID:Content-Description:Resent-Date:Resent-From:Resent-Sender: Resent-To:Resent-Cc:Resent-Message-ID:List-Id:List-Help:List-Unsubscribe: List-Subscribe:List-Post:List-Owner:List-Archive; bh=l5igM02Om8+o+nNjT+7TeGzTvDzxzw/jxyzVacQcPb4=; b=Mu1wYfDVU1MxdLz28h7cAauSlC EiW2yUrpiCEeiXqvLL0HiHCfl6XiYWFpjXZMo2mkI5gQoZf4fu4goT0j/WKmDz4At3UISDvk+vSZ+ 7NvNmmnhFcb5xPc4D+CgnhvpHxOgIcK6VfpDIyytAetKKEUrS6cX1x4QozaXflcs7mIg=; DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=sf.net; s=x ; h=Content-Transfer-Encoding:Content-Type:MIME-Version:Message-ID:Date: Subject:In-Reply-To:References:Cc:To:From:Sender:Reply-To:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc :Resent-Message-ID:List-Id:List-Help:List-Unsubscribe:List-Subscribe: List-Post:List-Owner:List-Archive; bh=l5igM02Om8+o+nNjT+7TeGzTvDzxzw/jxyzVacQcPb4=; b=fRyfOXCSwDssGM8WIGcPkD4SJt 9CiKu4yanCiRnbJTpTSDrUcM3qGP0Y1otWSH1Yok0BjmVFMPQUILcWqxHBRStxZdBASb0wgiGcRtc qsBlLkqmU+zQWT4Ip+FmPxaQgf+oRpay4woxktCYGAYzervndt5CM/RD/wRg89AO8W1s=; Received: from mx.wingtech.com ([180.166.216.14] helo=mail.wingtech.com) by sfi-mx-4.v28.lw.sourceforge.com with esmtps (TLSv1.2:ECDHE-RSA-AES256-SHA:256) (Exim 4.92.2) id 1jmCiM-00BlbP-Nv for linux-f2fs-devel@lists.sourceforge.net; Fri, 19 Jun 2020 08:49:36 +0000 Received: from mx.wingtech.com ([192.168.2.43]) by mail.wingtech.com with SMTP id 05J8nNJM001462-05J8nNJN001462 for ; Fri, 19 Jun 2020 16:49:23 +0800 Received: from 192.168.51.143 (HELO ZHAOWUYUN); Fri, 19 Jun 2020 16:49:20 +0800 To: "'Chao Yu'" , References: <1592548634-1065-1-git-send-email-zhaowuyun@wingtech.com> <2b44ed71-deba-2c48-bd8a-6b6099fe5a8f@huawei.com> In-Reply-To: <2b44ed71-deba-2c48-bd8a-6b6099fe5a8f@huawei.com> Date: Fri, 19 Jun 2020 16:49:22 +0800 Message-ID: <008901d64616$874db550$95e91ff0$@wingtech.com> MIME-Version: 1.0 X-Mailer: Microsoft Outlook 16.0 Thread-Index: AQNxN4T3+exOUcEf2ChiBNKnJXFQ9wJkgBdrpZaZEmA= Content-Language: zh-cn X-Headers-End: 1jmCiM-00BlbP-Nv Subject: [f2fs-dev] =?gb2312?b?u9i4tDogW1BBVENIIHYyXSBmMmZzLXRvb2xzOiBp?= =?gb2312?b?bnRyb2R1Y2Ugc2V0X25vZGVfZm9vdGVyIHRvIGluaXRpYWxpemUg?= =?gb2312?b?bm9kZSBmb290ZXI=?= X-BeenThere: linux-f2fs-devel@lists.sourceforge.net X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , From: Zac via Linux-f2fs-devel Reply-To: Zac Cc: linux-kernel@vger.kernel.org, linux-f2fs-devel@lists.sourceforge.net Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Errors-To: linux-f2fs-devel-bounces@lists.sourceforge.net > On 2020/6/19 14:37, zhaowuyun@wingtech.com wrote: > > From: Wuyun Zhao > > > > the filesystem will use the cold flag, so deal with it to avoid > > potential issue of inconsistency > > > > Signed-off-by: Wuyun Zhao > > --- > > fsck/dir.c | 6 +----- > > fsck/node.c | 9 +++++---- > > include/f2fs_fs.h | 20 ++++++++++++++++++++ > > mkfs/f2fs_format.c | 14 +++++--------- > > 4 files changed, 31 insertions(+), 18 deletions(-) > > > > diff --git a/fsck/dir.c b/fsck/dir.c > > index 5f4f75e..64aa539 100644 > > --- a/fsck/dir.c > > +++ b/fsck/dir.c > > @@ -517,11 +517,7 @@ static void init_inode_block(struct f2fs_sb_info > *sbi, > > } > > > > set_file_temperature(sbi, node_blk, de->name); > > - > > - node_blk->footer.ino = cpu_to_le32(de->ino); > > - node_blk->footer.nid = cpu_to_le32(de->ino); > > - node_blk->footer.flag = 0; > > - node_blk->footer.cp_ver = ckpt->checkpoint_ver; > > + set_node_footer(node_blk, de->ino, de->ino, 0, > le64_to_cpu(ckpt->checkpoint_ver), S_ISDIR(mode)); > > > > if (S_ISDIR(mode)) { > > make_empty_dir(sbi, node_blk); > > diff --git a/fsck/node.c b/fsck/node.c > > index 229a99c..66e8a81 100644 > > --- a/fsck/node.c > > +++ b/fsck/node.c > > @@ -69,16 +69,17 @@ block_t new_node_block(struct f2fs_sb_info *sbi, > > block_t blkaddr = NULL_ADDR; > > int type; > > int ret; > > + u32 ino; > > nid_t ino; > > > + u64 cp_ver; > > > > f2fs_inode = dn->inode_blk; > > > > node_blk = calloc(BLOCK_SZ, 1); > > ASSERT(node_blk); > > > > - node_blk->footer.nid = cpu_to_le32(dn->nid); > > - node_blk->footer.ino = f2fs_inode->footer.ino; > > - node_blk->footer.flag = cpu_to_le32(ofs << OFFSET_BIT_SHIFT); > > - node_blk->footer.cp_ver = ckpt->checkpoint_ver; > > + ino = le32_to_cpu(f2fs_inode->footer.ino); > > + cp_ver = le64_to_cpu(ckpt->checkpoint_ver); > > + set_node_footer(node_blk, dn->nid, ino, ofs, cp_ver, > S_ISDIR(le16_to_cpu(f2fs_inode->i.i_mode))); > > > > type = CURSEG_COLD_NODE; > > if (IS_DNODE(node_blk)) { > > diff --git a/include/f2fs_fs.h b/include/f2fs_fs.h > > index 709bfd8..3583df4 100644 > > --- a/include/f2fs_fs.h > > +++ b/include/f2fs_fs.h > > @@ -923,6 +923,26 @@ struct f2fs_node { > > struct node_footer footer; > > } __attribute__((packed)); > > > > +static inline void set_cold_node(struct f2fs_node *rn, bool is_dir) > > +{ > > + unsigned int flag = le32_to_cpu(rn->footer.flag); > > + > > + if (is_dir) > > + flag &= ~(0x1 << COLD_BIT_SHIFT); > > + else > > + flag |= (0x1 << COLD_BIT_SHIFT); > > + rn->footer.flag = cpu_to_le32(flag); > > +} > > + > > +static inline void set_node_footer(struct f2fs_node *rn, u32 nid, u32 ino, > u32 ofs, u64 ver, bool is_dir) > > Sorry, I forgot to add parameter for next_blkaddr... > > Could you check this? Sent v3 patch, please help to review, thanks. > From: Wuyun Zhao > Subject: [PATCH] f2fs-tools: introduce set_node_footer to initialize node > footer > > the filesystem will use the cold flag, so deal with it to avoid > potential issue of inconsistency > > Signed-off-by: Wuyun Zhao > --- > fsck/dir.c | 7 ++----- > fsck/node.c | 8 ++++---- > include/f2fs_fs.h | 23 +++++++++++++++++++++++ > mkfs/f2fs_format.c | 34 +++++++++++++--------------------- > 4 files changed, 42 insertions(+), 30 deletions(-) > > diff --git a/fsck/dir.c b/fsck/dir.c > index 5f4f75ebed77..b067aec9cffd 100644 > --- a/fsck/dir.c > +++ b/fsck/dir.c > @@ -517,11 +517,8 @@ static void init_inode_block(struct f2fs_sb_info > *sbi, > } > > set_file_temperature(sbi, node_blk, de->name); > - > - node_blk->footer.ino = cpu_to_le32(de->ino); > - node_blk->footer.nid = cpu_to_le32(de->ino); > - node_blk->footer.flag = 0; > - node_blk->footer.cp_ver = ckpt->checkpoint_ver; > + set_node_footer(node_blk, de->ino, de->ino, 0, > + le64_to_cpu(ckpt->checkpoint_ver), 0, S_ISDIR(mode)); > > if (S_ISDIR(mode)) { > make_empty_dir(sbi, node_blk); > diff --git a/fsck/node.c b/fsck/node.c > index 229a99cab481..da010ff669cc 100644 > --- a/fsck/node.c > +++ b/fsck/node.c > @@ -69,16 +69,16 @@ block_t new_node_block(struct f2fs_sb_info *sbi, > block_t blkaddr = NULL_ADDR; > int type; > int ret; > + nid_t ino = le32_to_cpu(f2fs_inode->footer.ino); > + u64 cp_ver = le64_to_cpu(ckpt->checkpoint_ver); > > f2fs_inode = dn->inode_blk; > > node_blk = calloc(BLOCK_SZ, 1); > ASSERT(node_blk); > > - node_blk->footer.nid = cpu_to_le32(dn->nid); > - node_blk->footer.ino = f2fs_inode->footer.ino; > - node_blk->footer.flag = cpu_to_le32(ofs << OFFSET_BIT_SHIFT); > - node_blk->footer.cp_ver = ckpt->checkpoint_ver; > + set_node_footer(node_blk, dn->nid, ino, ofs, cp_ver, 0, > + S_ISDIR(le16_to_cpu(f2fs_inode->i.i_mode))); > > type = CURSEG_COLD_NODE; > if (IS_DNODE(node_blk)) { > diff --git a/include/f2fs_fs.h b/include/f2fs_fs.h > index 265f50c69fd1..0fe478ed820c 100644 > --- a/include/f2fs_fs.h > +++ b/include/f2fs_fs.h > @@ -923,6 +923,29 @@ struct f2fs_node { > struct node_footer footer; > } __attribute__((packed)); > > +static inline void set_cold_node(struct f2fs_node *rn, bool is_dir) > +{ > + unsigned int flag = le32_to_cpu(rn->footer.flag); > + > + if (is_dir) > + flag &= ~(0x1 << COLD_BIT_SHIFT); > + else > + flag |= (0x1 << COLD_BIT_SHIFT); > + rn->footer.flag = cpu_to_le32(flag); > +} > + > +static inline void set_node_footer(struct f2fs_node *rn, u32 nid, u32 ino, > + u32 ofs, u64 ver, block_t blkaddr, > + bool is_dir) > +{ > + rn->footer.nid = cpu_to_le32(nid); > + rn->footer.ino = cpu_to_le32(ino); > + rn->footer.flag = cpu_to_le32(ofs << OFFSET_BIT_SHIFT); > + rn->footer.cp_ver = cpu_to_le64(ver); > + rn->footer.next_blkaddr = cpu_to_le32(blkaddr); > + set_cold_node(rn, is_dir); > +} > + > /* > * For NAT entries > */ > diff --git a/mkfs/f2fs_format.c b/mkfs/f2fs_format.c > index 44575e0049fa..cb40e5a76332 100644 > --- a/mkfs/f2fs_format.c > +++ b/mkfs/f2fs_format.c > @@ -1094,6 +1094,9 @@ static int f2fs_write_root_inode(void) > struct f2fs_node *raw_node = NULL; > u_int64_t blk_size_bytes, data_blk_nor; > u_int64_t main_area_node_seg_blk_offset = 0; > + nid_t nid = le32_to_cpu(sb->root_ino); > + block_t blkaddr = cpu_to_le32(get_sb(main_blkaddr) + > + c.cur_seg[CURSEG_HOT_NODE] * c.blks_per_seg + 1); > > raw_node = calloc(F2FS_BLKSIZE, 1); > if (raw_node == NULL) { > @@ -1101,13 +1104,7 @@ static int f2fs_write_root_inode(void) > return -1; > } > > - raw_node->footer.nid = sb->root_ino; > - raw_node->footer.ino = sb->root_ino; > - raw_node->footer.cp_ver = cpu_to_le64(1); > - raw_node->footer.next_blkaddr = cpu_to_le32( > - get_sb(main_blkaddr) + > - c.cur_seg[CURSEG_HOT_NODE] * > - c.blks_per_seg + 1); > + set_node_footer(raw_node, nid, nid, 0, 1, blkaddr, 1); > > raw_node->i.i_mode = cpu_to_le16(0x41ed); > if (c.lpf_ino) > @@ -1256,6 +1253,10 @@ static int f2fs_write_qf_inode(int qtype) > u_int64_t main_area_node_seg_blk_offset = 0; > __le32 raw_id; > int i; > + nid_t qf_ino = le32_to_cpu(sb->qf_ino[qtype]); > + block_t blkaddr = cpu_to_le32(get_sb(main_blkaddr) + > + c.cur_seg[CURSEG_HOT_NODE] * > + c.blks_per_seg + 1 + qtype + 1); > > raw_node = calloc(F2FS_BLKSIZE, 1); > if (raw_node == NULL) { > @@ -1263,13 +1264,7 @@ static int f2fs_write_qf_inode(int qtype) > return -1; > } > > - raw_node->footer.nid = sb->qf_ino[qtype]; > - raw_node->footer.ino = sb->qf_ino[qtype]; > - raw_node->footer.cp_ver = cpu_to_le64(1); > - raw_node->footer.next_blkaddr = cpu_to_le32( > - get_sb(main_blkaddr) + > - c.cur_seg[CURSEG_HOT_NODE] * > - c.blks_per_seg + 1 + qtype + 1); > + set_node_footer(raw_node, qf_ino, qf_ino, 0, 1, blkaddr, 0); > > raw_node->i.i_mode = cpu_to_le16(0x8180); > raw_node->i.i_links = cpu_to_le32(1); > @@ -1447,6 +1442,9 @@ static int f2fs_write_lpf_inode(void) > struct f2fs_node *raw_node; > u_int64_t blk_size_bytes, main_area_node_seg_blk_offset; > block_t data_blk_nor; > + block_t blkaddr = cpu_to_le32(get_sb(main_blkaddr) + > + c.cur_seg[CURSEG_HOT_NODE] * c.blks_per_seg + > + 1 + c.quota_inum + 1); > int err = 0; > > ASSERT(c.lpf_ino); > @@ -1457,13 +1455,7 @@ static int f2fs_write_lpf_inode(void) > return -1; > } > > - raw_node->footer.nid = cpu_to_le32(c.lpf_ino); > - raw_node->footer.ino = raw_node->footer.nid; > - raw_node->footer.cp_ver = cpu_to_le64(1); > - raw_node->footer.next_blkaddr = cpu_to_le32( > - get_sb(main_blkaddr) + > - c.cur_seg[CURSEG_HOT_NODE] * c.blks_per_seg + > - 1 + c.quota_inum + 1); > + set_node_footer(raw_node, c.lpf_ino, c.lpf_ino, 0, 1, blkaddr, 1); > > raw_node->i.i_mode = cpu_to_le16(0x41c0); /* 0700 */ > raw_node->i.i_links = cpu_to_le32(2); > -- > 2.26.2 > > > > > > +{ > > + rn->footer.nid = cpu_to_le32(nid); > > + rn->footer.ino = cpu_to_le32(ino); > > + rn->footer.flag = cpu_to_le32(ofs << OFFSET_BIT_SHIFT); > > + rn->footer.cp_ver = cpu_to_le64(ver); > > + set_cold_node(rn, is_dir); > > +} > > + > > /* > > * For NAT entries > > */ > > diff --git a/mkfs/f2fs_format.c b/mkfs/f2fs_format.c > > index 44575e0..b371adf 100644 > > --- a/mkfs/f2fs_format.c > > +++ b/mkfs/f2fs_format.c > > @@ -1101,9 +1101,7 @@ static int f2fs_write_root_inode(void) > > return -1; > > } > > > > - raw_node->footer.nid = sb->root_ino; > > - raw_node->footer.ino = sb->root_ino; > > - raw_node->footer.cp_ver = cpu_to_le64(1); > > + set_node_footer(raw_node, le32_to_cpu(sb->root_ino), > le32_to_cpu(sb->root_ino), 0, 1, 1); > > raw_node->footer.next_blkaddr = cpu_to_le32( > > get_sb(main_blkaddr) + > > c.cur_seg[CURSEG_HOT_NODE] * > > @@ -1256,6 +1254,7 @@ static int f2fs_write_qf_inode(int qtype) > > u_int64_t main_area_node_seg_blk_offset = 0; > > __le32 raw_id; > > int i; > > + u32 qf_ino; > > > > raw_node = calloc(F2FS_BLKSIZE, 1); > > if (raw_node == NULL) { > > @@ -1263,9 +1262,8 @@ static int f2fs_write_qf_inode(int qtype) > > return -1; > > } > > > > - raw_node->footer.nid = sb->qf_ino[qtype]; > > - raw_node->footer.ino = sb->qf_ino[qtype]; > > - raw_node->footer.cp_ver = cpu_to_le64(1); > > + qf_ino = le32_to_cpu(sb->qf_ino[qtype]); > > + set_node_footer(raw_node, qf_ino, qf_ino, 0, 1, 0); > > raw_node->footer.next_blkaddr = cpu_to_le32( > > get_sb(main_blkaddr) + > > c.cur_seg[CURSEG_HOT_NODE] * > > @@ -1457,9 +1455,7 @@ static int f2fs_write_lpf_inode(void) > > return -1; > > } > > > > - raw_node->footer.nid = cpu_to_le32(c.lpf_ino); > > - raw_node->footer.ino = raw_node->footer.nid; > > - raw_node->footer.cp_ver = cpu_to_le64(1); > > + set_node_footer(raw_node, c.lpf_ino, c.lpf_ino, 0, 1, 1); > > raw_node->footer.next_blkaddr = cpu_to_le32( > > get_sb(main_blkaddr) + > > c.cur_seg[CURSEG_HOT_NODE] * c.blks_per_seg + > > _______________________________________________ Linux-f2fs-devel mailing list Linux-f2fs-devel@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel