Received: by 2002:a05:6358:16cc:b0:ea:6187:17c9 with SMTP id r12csp5653810rwl; Thu, 29 Dec 2022 00:16:59 -0800 (PST) X-Google-Smtp-Source: AMrXdXv7aqxgJNBRxn4mmCv06aII38iskLpIscND+rA3i8ww34Rbwjmtq3qCsckaPLBe8iOWDXUS X-Received: by 2002:a17:907:8c81:b0:7c0:7d35:e9db with SMTP id td1-20020a1709078c8100b007c07d35e9dbmr33095326ejc.15.1672301819048; Thu, 29 Dec 2022 00:16:59 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1672301819; cv=none; d=google.com; s=arc-20160816; b=oFIE9jfuCOQv9MdV8hlB+UDCCYBaDuwceC+xEKLzIx7bbuxhVu/tZCuU++G0tG/ZLq mVH9zCbL1pF2fYpAVnlmNIh0EqZWTFQ5hZhMjULA/e0BmeBMa1wFlhA0DoU1ewuj3Xuw RNhXyxOihq9m/qtGpey0Fyy4+/4LDutSYgB6139oA5fRd0DLYbBt8tlWFPtyqdggIUnX LOjDvomAMmiC7NFgFpE1zyWGRNidYkVbwVSI/ZIE8ejQu8pm4iajJiyWe1nyVdmfoCaG 1L7kIqOYXbu42xnhfx1h5fNk5oS5hRGOnvWEMB7bQocmyribiRrE+ervu+q5pEQFVvjF 8hXQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=NARw7AM8RPJfstkTCRPS/K1vPXKbzp2JAGZWB+homt4=; b=P8E/KFFMeQylE/ZOY5XuvWNXdZUn3TnYThw8329unOnNU6zkotk1QSqNgVGm3h2Ack bggRYFCfO/2o2XoQNiRIV/GXuuzLlGWP6XtrgUodO1aP7in8DCzLZwNtiPM55BuxFRmY tkzWrq9agyng+Lnc9/LJx5+XiuEu1ljLYEY/8ubD/vnry7HQeniDATx7KWDr9zpR+64C N7/apyRv0P81p2a5sr2Kt/pHnokybIunJXcDc91KhtE/00sr3STlw10VuaqQ/YsckmjB wA/1JaZMMK0KWBiBnxVYu/XNH2WZfCP8mFJQiyild7w30B/6Z2JgZ4xAmhIUqdQX49aV T8jg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=EFrJra0q; spf=pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-ext4-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id dp19-20020a170906c15300b0082033822e26si15700287ejc.487.2022.12.29.00.16.34; Thu, 29 Dec 2022 00:16:59 -0800 (PST) Received-SPF: pass (google.com: domain of linux-ext4-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=@chromium.org header.s=google header.b=EFrJra0q; spf=pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-ext4-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233256AbiL2IPx (ORCPT + 99 others); Thu, 29 Dec 2022 03:15:53 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38986 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233166AbiL2IPP (ORCPT ); Thu, 29 Dec 2022 03:15:15 -0500 Received: from mail-ej1-x635.google.com (mail-ej1-x635.google.com [IPv6:2a00:1450:4864:20::635]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9CE0A13F25 for ; Thu, 29 Dec 2022 00:13:52 -0800 (PST) Received: by mail-ej1-x635.google.com with SMTP id u9so43561961ejo.0 for ; Thu, 29 Dec 2022 00:13:52 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:from:to:cc:subject:date:message-id:reply-to; bh=NARw7AM8RPJfstkTCRPS/K1vPXKbzp2JAGZWB+homt4=; b=EFrJra0qXIGHW80x3wh0gJZ4clskDBwf3pW2R91EgjdoUgYirzuHUOOvOTgVrH2bWg kUXrEazSaXpXTScJ4I96vG2hb6RYzVpzzs4U2kRJCIkXQT1rc2cVEHxviDwTTQTceto2 accj2X22DQpAqJgLKpaveAV+snt8L8tUgoxxY= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=NARw7AM8RPJfstkTCRPS/K1vPXKbzp2JAGZWB+homt4=; b=IKvt7Sfu2Y+yRKncyINuJTYns4AXF9G+vO3eA3IqjwfqJKM1suZdfBWt+Fys63u8Ct yJuvQ4NCJ4v5VJ/YnIO3QKrdd9a8cuPUUUV9gWeBxU5EIVXInej1QrmA8zfR3GifjC6h GvDalSOOmPkV+pxoCUWt+1/Bjwq0YOKK9VRYXIg22ExJEd/lx9YZRaZiNTpofMEkkhbg xDbHd0AvdimaYKjqXPTcSTgEdIDR5DwKPVijF4llp1uRpG7WsjLNzeSYvEUrFxUns94X 5RTh9VcsqHhI5GEg4fwsaqauHXfDeZyMxw1wr14eEg1sUg3JGjmhPR3667JRvPSCtsb+ cwqg== X-Gm-Message-State: AFqh2kqzyerDZuuCxNsDwEMtNv80Zftq5lbLopwpFtLAphnaZkE7z41+ GeEUs0NnG3gzhdHgSEcwAWdGeUPdyODYP5cVhXFSHA== X-Received: by 2002:a17:906:195a:b0:78d:b371:16e5 with SMTP id b26-20020a170906195a00b0078db37116e5mr1574790eje.456.1672301631125; Thu, 29 Dec 2022 00:13:51 -0800 (PST) MIME-Version: 1.0 References: <20220915164826.1396245-1-sarthakkukreti@google.com> <20220915164826.1396245-5-sarthakkukreti@google.com> In-Reply-To: From: Sarthak Kukreti Date: Thu, 29 Dec 2022 00:13:40 -0800 Message-ID: Subject: Re: [PATCH RFC 4/8] fs: Introduce FALLOC_FL_PROVISION To: Brian Foster Cc: dm-devel@redhat.com, linux-block@vger.kernel.org, linux-ext4@vger.kernel.org, linux-kernel@vger.kernel.org, virtualization@lists.linux-foundation.org, Jens Axboe , "Michael S . Tsirkin" , Jason Wang , Paolo Bonzini , Stefan Hajnoczi , Alasdair Kergon , Mike Snitzer , "Theodore Ts'o" , Andreas Dilger , Bart Van Assche , Daniil Lunev , Evan Green , Gwendal Grignou Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS autolearn=ham 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-ext4@vger.kernel.org On Thu, Sep 22, 2022 at 11:29 AM Brian Foster wrote: > > On Thu, Sep 22, 2022 at 01:04:33AM -0700, Sarthak Kukreti wrote: > > On Wed, Sep 21, 2022 at 8:39 AM Brian Foster wrote: > > > > > > On Fri, Sep 16, 2022 at 02:02:31PM -0700, Sarthak Kukreti wrote: > > > > On Fri, Sep 16, 2022 at 4:56 AM Brian Foster wrote: > > > > > > > > > > On Thu, Sep 15, 2022 at 09:48:22AM -0700, Sarthak Kukreti wrote: > > > > > > From: Sarthak Kukreti > > > > > > > > > > > > FALLOC_FL_PROVISION is a new fallocate() allocation mode that > > > > > > sends a hint to (supported) thinly provisioned block devices to > > > > > > allocate space for the given range of sectors via REQ_OP_PROVISION. > > > > > > > > > > > > Signed-off-by: Sarthak Kukreti > > > > > > --- > > > > > > block/fops.c | 7 ++++++- > > > > > > include/linux/falloc.h | 3 ++- > > > > > > include/uapi/linux/falloc.h | 8 ++++++++ > > > > > > 3 files changed, 16 insertions(+), 2 deletions(-) > > > > > > > > > > > > diff --git a/block/fops.c b/block/fops.c > > > > > > index b90742595317..a436a7596508 100644 > > > > > > --- a/block/fops.c > > > > > > +++ b/block/fops.c > > > > > ... > > > > > > @@ -661,6 +662,10 @@ static long blkdev_fallocate(struct file *file, int mode, loff_t start, > > > > > > error = blkdev_issue_discard(bdev, start >> SECTOR_SHIFT, > > > > > > len >> SECTOR_SHIFT, GFP_KERNEL); > > > > > > break; > > > > > > + case FALLOC_FL_PROVISION: > > > > > > + error = blkdev_issue_provision(bdev, start >> SECTOR_SHIFT, > > > > > > + len >> SECTOR_SHIFT, GFP_KERNEL); > > > > > > + break; > > > > > > default: > > > > > > error = -EOPNOTSUPP; > > > > > > } > > > > > > > > > > Hi Sarthak, > > > > > > > > > > Neat mechanism.. I played with something very similar in the past (that > > > > > was much more crudely hacked up to target dm-thin) to allow filesystems > > > > > to request a thinly provisioned device to allocate blocks and try to do > > > > > a better job of avoiding inactivation when overprovisioned. > > > > > > > > > > One thing I'm a little curious about here.. what's the need for a new > > > > > fallocate mode? On a cursory glance, the provision mode looks fairly > > > > > analogous to normal (mode == 0) allocation mode with the exception of > > > > > sending the request down to the bdev. blkdev_fallocate() already maps > > > > > some of the logical falloc modes (i.e. punch hole, zero range) to > > > > > sending write sames or discards, etc., and it doesn't currently look > > > > > like it supports allocation mode, so could it not map such requests to > > > > > the underlying REQ_OP_PROVISION op? > > > > > > > > > > I guess the difference would be at the filesystem level where we'd > > > > > probably need to rely on a mount option or some such to control whether > > > > > traditional fallocate issues provision ops (like you've implemented for > > > > > ext4) vs. the specific falloc command, but that seems fairly consistent > > > > > with historical punch hole/discard behavior too. Hm? You might want to > > > > > cc linux-fsdevel in future posts in any event to get some more feedback > > > > > on how other filesystems might want to interact with such a thing. > > > > > > > > > Thanks for the feedback! > > > > Argh, I completely forgot that I should add linux-fsdevel. Let me > > > > re-send this with linux-fsdevel cc'd > > > > > > > > There's a slight distinction is that the current filesystem-level > > > > controls are usually for default handling, but userspace can still > > > > call the relevant functions manually if they need to. For example, for > > > > ext4, the 'discard' mount option dictates whether free blocks are > > > > discarded, but it doesn't set the policy to allow/disallow userspace > > > > from manually punching holes into files even if the mount opt is > > > > 'nodiscard'. FALLOC_FL_PROVISION is similar in that regard; it adds a > > > > manual mechanism for users to provision the files' extents, that is > > > > separate from the filesystems' default handling of provisioning files. > > > > > > > > > > What I'm trying to understand is why not let blkdev_fallocate() issue a > > > provision based on the default mode (i.e. mode == 0) of fallocate(), > > > which is already defined to mean "perform allocation?" It currently > > > issues discards or write zeroes based on variants of > > > FALLOC_FL_PUNCH_HOLE without the need for a separate FALLOC_FL_DISCARD > > > mode, for example. > > > > > It's mostly to keep the block device fallocate() semantics in-line and > > consistent with the file-specific modes: I added the separate > > filesystem fallocate() mode under the assumption that we'd want to > > keep the traditional handling for filesystems intact with (mode == 0). > > And for block devices, I didn't map the requests to mode == 0 so that > > it's less confusing to describe (eg. mode == 0 on block devices will > > issue provision; mode == 0 on files will not). It would complicate > > loopback devices, for instance; if the loop device is backed by a > > file, it would need to use (mode == FALLOC_FL_PROVISION) but if the > > loop device is backed by another block device, then the fallocate() > > call would need to switch to (mode == 0). > > > > I would expect the loopback scenario for provision to behave similar to > how discards are handled. I.e., loopback receives a provision request > and translates that to fallocate(mode = 0). If the backing device is > block, blkdev_fallocate(mode = 0) translates that to another provision > request. If the backing device is a file, the associated fallocate > handler allocs/maps, if necessary, and then issues a provision on > allocation, if enabled by the fs. > > AFAICT there's no need for FL_PROVISION at all in that scenario. Is > there a functional purpose to FL_PROVISION? Is the intent to try and > guarantee that a provision request propagates down the I/O stack? If so, > what happens if blocks were already preallocated in the backing file (in > the loopback file example)? > > BTW, an unrelated thing I noticed is that blkdev_fallocate() > unconditionally calls truncate_bdev_range(), which probably doesn't make > sense for any sort of alloc mode. > Thanks for pointing that out, fixed in v2. > > With the separate mode, we can describe the semantics of falllcate() > > modes a bit more cleanly, and it is common for both files and block > > devices: > > > > 1. mode == 0: allocation at the same layer, will not provision on the > > underlying device/filesystem (unsupported for block devices). > > 2. mode == FALLOC_FL_PROVISION, allocation at the layer, will > > provision on the underlying device/filesystem. > > > > I think I see why you make the distinction, since the block layer > doesn't have a "this layer only" mode, but IMO it's also quite confusing > to say that mode == FL_PROVISION can allocate at the current and > underlying layer(s) but mode == 0 to that underlying layer cannot. > > Either way, if you want to propose a new falloc mode/modifier, it > probably warrants a more detailed commit log with more explanation of > the purpose, examples of behavior, perhaps some details on how the mode > might be documented in man pages, etc. > That's fair. Added more details to the patch commit log in v2. Thanks Sarthak > Brian > > > Block devices don't technically need to use a separate mode, but it > > makes it much less confusing if filesystems are already using a > > separate mode for provision. > > > > Best > > Sarthak > > > > > Brian > > > > > > > > BTW another thing that might be useful wrt to dm-thin is to support > > > > > FALLOC_FL_UNSHARE. I.e., it looks like the previous dm-thin patch only > > > > > checks that blocks are allocated, but not whether those blocks are > > > > > shared (re: lookup_result.shared). It might be useful to do the COW in > > > > > such cases if the caller passes down a REQ_UNSHARE or some such flag. > > > > > > > > > That's an interesting idea! There's a few more things on the TODO list > > > > for this patch series but I think we can follow up with a patch to > > > > handle that as well. > > > > > > > > Sarthak > > > > > > > > > Brian > > > > > > > > > > > diff --git a/include/linux/falloc.h b/include/linux/falloc.h > > > > > > index f3f0b97b1675..a0e506255b20 100644 > > > > > > --- a/include/linux/falloc.h > > > > > > +++ b/include/linux/falloc.h > > > > > > @@ -30,7 +30,8 @@ struct space_resv { > > > > > > FALLOC_FL_COLLAPSE_RANGE | \ > > > > > > FALLOC_FL_ZERO_RANGE | \ > > > > > > FALLOC_FL_INSERT_RANGE | \ > > > > > > - FALLOC_FL_UNSHARE_RANGE) > > > > > > + FALLOC_FL_UNSHARE_RANGE | \ > > > > > > + FALLOC_FL_PROVISION) > > > > > > > > > > > > /* on ia32 l_start is on a 32-bit boundary */ > > > > > > #if defined(CONFIG_X86_64) > > > > > > diff --git a/include/uapi/linux/falloc.h b/include/uapi/linux/falloc.h > > > > > > index 51398fa57f6c..2d323d113eed 100644 > > > > > > --- a/include/uapi/linux/falloc.h > > > > > > +++ b/include/uapi/linux/falloc.h > > > > > > @@ -77,4 +77,12 @@ > > > > > > */ > > > > > > #define FALLOC_FL_UNSHARE_RANGE 0x40 > > > > > > > > > > > > +/* > > > > > > + * FALLOC_FL_PROVISION acts as a hint for thinly provisioned devices to allocate > > > > > > + * blocks for the range/EOF. > > > > > > + * > > > > > > + * FALLOC_FL_PROVISION can only be used with allocate-mode fallocate. > > > > > > + */ > > > > > > +#define FALLOC_FL_PROVISION 0x80 > > > > > > + > > > > > > #endif /* _UAPI_FALLOC_H_ */ > > > > > > -- > > > > > > 2.31.0 > > > > > > > > > > > > > > > > > > > > >