Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp5173727rwl; Tue, 11 Apr 2023 01:15:28 -0700 (PDT) X-Google-Smtp-Source: AKy350YSqO/kwswAdX13ixG3CCTMdLkEgmSjtgORLaDymtUnTML31l8pyu8i9Krw+XX3OQatwZX5 X-Received: by 2002:a17:90b:3b4c:b0:246:b617:c730 with SMTP id ot12-20020a17090b3b4c00b00246b617c730mr6580939pjb.39.1681200927712; Tue, 11 Apr 2023 01:15:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1681200927; cv=none; d=google.com; s=arc-20160816; b=wftKB4THwofkY6tSZrkpOse909hkNTD3IhOQ7btuBP/RF72LzfDmBxuHlfA0Sb8UhS eH7OGglsJWArKVf00h3NQH5Wm3JjniCQJ+Y6ctJ+iJrGnmjUkvWojbY4jzIw7Dtm19+4 OlcfyY1uIllnqA7nphcW6WKOOYAgG9osBoAYzxAcITU+vTZAK36LcqSWHxABc7qg2ILg 5HN6+CbT2QKEIgsdRgJxI2Uz8HUO9lJuzMsbffTaZBoHR2ClwjiqVAxwkhN4yS9n0B1b H3iBc3xWzJeJzf/LCCQboYPXDUjkHePOovpK/g63IFZo5r7mV+ShnBtWKeZB+UpXsdLY 3HDw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=k7sHpHCCYMUBkLrD6mmEeR6OQIpy9GhlbhOMlisCE7U=; b=xk/KQ7K+ZvJoKxKbRmyqldm1imab1Z8PbGjyecf8tGoXQujW5tSycm/bAxsVUHgNQU O86kF6IlIOOsFHxr7qtTlxvcwIkWMqPhLI3a7nLftGn00a5z+W3sbSjI3pkmvb2S7cQC ku4aUB5bETRAao8zlBC7K0fphf+ss5hE/LUQgYKRxWKbh8SCdJDY8E8IsQkncY3AYjOX NXj4Pf8+FaleFkM/yb9cVKpIXcJgrIyzqwvz6eT0eZHFRJjSdd/HrAgJiz2jxdksOZaO Fxy2RRAWO/lS0JQwoOhxFWFNpJtiEDQY5gwNcqO5c8wpJq+/tQThhPIAEzYunRxnlhBI Nr6Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=KOIQLwmQ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id g14-20020a17090a4b0e00b0023d4a3bec5csi12743669pjh.161.2023.04.11.01.15.14; Tue, 11 Apr 2023 01:15:27 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=KOIQLwmQ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229536AbjDKIOf (ORCPT + 99 others); Tue, 11 Apr 2023 04:14:35 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50612 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230173AbjDKIOX (ORCPT ); Tue, 11 Apr 2023 04:14:23 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 244383AA3 for ; Tue, 11 Apr 2023 01:14:22 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id B3AE5616EA for ; Tue, 11 Apr 2023 08:14:21 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id D9A11C433D2; Tue, 11 Apr 2023 08:14:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1681200861; bh=vJBK6C5ZuJ6A5e6j1DfsjQOW7O+Z+ViMotqjJS2EuUE=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=KOIQLwmQ2ZVlFB1a0dNjUGn36Gu0GkpeFs5U+hJg7nzxoIh1u2btinWig/X3EguwG VOCGh2R4fXkTO4jsL8c6VsaBXl7by1vAidRdmFFPE77ASdGqHkNrFSN5whuCroeVyu v/wrd/24DXc5moygc5x000aEk/4EYg8kXTR0Shfe7kiTbCbZF+3SecI3Kj/WLh3aGx ki63jzc11oeg1UOVPW8DYUwEtE1G+grhSwYWuE5so4kyCcTGpmmPrpHp9KyF+l9Nvp hWMbuzkJkpDl/eHI9dgv6I2z6UhNW/qI4EcNdCH+b9A+uwCCOBcNki51sAUK6IBqRg z23jP5/KJ+boQ== Message-ID: <538fd229-28ae-0ec5-ef07-35d505fbb8a9@kernel.org> Date: Tue, 11 Apr 2023 16:14:17 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.9.1 Subject: Re: [PATCH] f2fs: fix to tag FIEMAP_EXTENT_DELALLOC in fiemap() for delay allocated extent Content-Language: en-US To: Jaegeuk Kim Cc: linux-f2fs-devel@lists.sourceforge.net, linux-kernel@vger.kernel.org References: <20230405144359.930253-1-chao@kernel.org> <224e8756-7c63-fd53-a0f3-f3e2a7b4c13f@kernel.org> From: Chao Yu In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.4 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2023/4/11 1:57, Jaegeuk Kim wrote: > On 04/08, Chao Yu wrote: >> On 2023/4/8 4:59, Jaegeuk Kim wrote: >>> This breaks generic/009? >> >> I guess it is as expected? >> >> Please check description of fiemap ioctl manual from [1]: >> >> FIEMAP_EXTENT_UNKNOWN >> The location of this extent is currently unknown. This may >> indicate the data is stored on an inaccessible volume or that >> no storage has been allocated for the file yet. >> >> FIEMAP_EXTENT_DELALLOC >> This will also set FIEMAP_EXTENT_UNKNOWN. >> >> Delayed allocation - while there is data for this extent, its >> physical location has not been allocated yet. >> >> FIEMAP_EXTENT_UNWRITTEN >> Unwritten extent - the extent is allocated but its data has not >> been initialized. This indicates the extent’s data will be all >> zero if read through the filesystem but the contents are undefined >> if read directly from the device. >> >> [1] https://www.kernel.org/doc/html/latest/filesystems/fiemap.html >> >> According to its description, f2fs only support >> FIEMAP_EXTENT_{UNKNOWN, DELALLOC}, but not support >> FIEMAP_EXTENT_UNWRITTEN. > > No, I don't think so. Jaegeuk, Could you please check the detailed description of FIEMAP_EXTENT_UNWRITTEN? The flag indicates two conditions: 1. on-disk blkaddrs were allocated for extent, and the extent is tagged as unwritten status. 2. data readed on those blocks will be all zero. So, let's check f2fs' status: - fallocate only reserve valid block count and set NEW_ADDR in dnode, so it does not match condition 1) - pin & fallocate preallocates blkaddrs and set blkaddrs in dnode, but content on those blkaddrs may contain zero or random data, so it does not match condition 2) Christoph describes this issue in below patch as well, you can check it. da8c7fecc9c7 ("f2fs: rename F2FS_MAP_UNWRITTEN to F2FS_MAP_DELALLOC") Am I missing something? Thanks, > >> >> So 009, 092, 094 .. which expects unwritten status from extent will >> fail. >> >> How about disabling those testcase? >> >> Thanks, >> >>> >>> On 04/05, Chao Yu wrote: >>>> xfstest generic/614 fails to run due below reason: >>>> >>>> generic/614 1s ... [not run] test requires delayed allocation buffered writes >>>> >>>> The root cause is f2fs tags wrong fiemap flag for delay allocated >>>> extent. >>>> >>>> Quoted from fiemap.h: >>>> FIEMAP_EXTENT_UNKNOWN 0x00000002 /* Data location unknown. */ >>>> FIEMAP_EXTENT_DELALLOC 0x00000004 /* Location still pending. >>>> * Sets EXTENT_UNKNOWN. */ >>>> FIEMAP_EXTENT_UNWRITTEN 0x00000800 /* Space allocated, but >>>> * no data (i.e. zero). */ >>>> >>>> FIEMAP_EXTENT_UNWRITTEN means block address is preallocated, but w/o >>>> been written any data, which status f2fs is not supported now, for all >>>> NEW_ADDR block addresses, it means delay allocated blocks, so let's >>>> tag FIEMAP_EXTENT_DELALLOC instead. >>>> >>>> Testcase: >>>> xfs_io -f -c 'pwrite 0 64k' /mnt/f2fs/file; >>>> filefrag -v /mnt/f2fs/file >>>> >>>> Output: >>>> - Before >>>> Filesystem type is: f2f52010 >>>> Fize of /mnt/f2fs/file is 65536 (16 blocks of 4096 bytes) >>>> ext: logical_offset: physical_offset: length: expected: flags: >>>> 0: 0.. 15: 0.. 15: 16: last,unwritten,merged,eof >>>> /mnt/f2fs/file: 1 extent found >>>> >>>> After: >>>> Filesystem type is: f2f52010 >>>> File size of /mnt/f2fs/file is 65536 (16 blocks of 4096 bytes) >>>> ext: logical_offset: physical_offset: length: expected: flags: >>>> 0: 0.. 15: 0.. 0: 0: last,unknown_loc,delalloc,eof >>>> /mnt/f2fs/file: 1 extent found >>>> >>>> Fixes: 7f63eb77af7b ("f2fs: report unwritten area in f2fs_fiemap") >>>> Signed-off-by: Chao Yu >>>> --- >>>> fs/f2fs/data.c | 7 +++++-- >>>> 1 file changed, 5 insertions(+), 2 deletions(-) >>>> >>>> diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c >>>> index 359de650772e..3afc9764743e 100644 >>>> --- a/fs/f2fs/data.c >>>> +++ b/fs/f2fs/data.c >>>> @@ -1995,7 +1995,10 @@ int f2fs_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo, >>>> } >>>> if (size) { >>>> - flags |= FIEMAP_EXTENT_MERGED; >>>> + if (flags & FIEMAP_EXTENT_DELALLOC) >>>> + phys = 0; >>>> + else >>>> + flags |= FIEMAP_EXTENT_MERGED; >>>> if (IS_ENCRYPTED(inode)) >>>> flags |= FIEMAP_EXTENT_DATA_ENCRYPTED; >>>> @@ -2035,7 +2038,7 @@ int f2fs_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo, >>>> size += blks_to_bytes(inode, 1); >>>> } >>>> } else if (map.m_flags & F2FS_MAP_DELALLOC) { >>>> - flags = FIEMAP_EXTENT_UNWRITTEN; >>>> + flags = FIEMAP_EXTENT_DELALLOC; >>>> } >>>> start_blk += bytes_to_blks(inode, size); >>>> -- >>>> 2.36.1