From: Mike Snitzer <snitzer@kernel.org>
To: Sarthak Kukreti <sarthakkukreti@chromium.org>
Cc: Jens Axboe <axboe@kernel.dk>,
Christoph Hellwig <hch@infradead.org>,
Theodore Ts'o <tytso@mit.edu>,
"Michael S. Tsirkin" <mst@redhat.com>,
"Darrick J. Wong" <djwong@kernel.org>,
Jason Wang <jasowang@redhat.com>,
Bart Van Assche <bvanassche@google.com>,
linux-kernel@vger.kernel.org, linux-block@vger.kernel.org,
dm-devel@redhat.com, Andreas Dilger <adilger.kernel@dilger.ca>,
Stefan Hajnoczi <stefanha@redhat.com>,
linux-fsdevel@vger.kernel.org, linux-ext4@vger.kernel.org,
Brian Foster <bfoster@redhat.com>,
Alasdair Kergon <agk@redhat.com>
Subject: Re: [dm-devel] [PATCH v7 2/5] block: Introduce provisioning primitives
Date: Fri, 9 Jun 2023 16:00:24 -0400 [thread overview]
Message-ID: <ZIOE2ASeUAXxzpRO@redhat.com> (raw)
In-Reply-To: <20230518223326.18744-3-sarthakkukreti@chromium.org>
On Thu, May 18 2023 at 6:33P -0400,
Sarthak Kukreti <sarthakkukreti@chromium.org> wrote:
> Introduce block request REQ_OP_PROVISION. The intent of this request
> is to request underlying storage to preallocate disk space for the given
> block range. Block devices that support this capability will export
> a provision limit within their request queues.
>
> This patch also adds the capability to call fallocate() in mode 0
> on block devices, which will send REQ_OP_PROVISION to the block
> device for the specified range,
>
> Signed-off-by: Sarthak Kukreti <sarthakkukreti@chromium.org>
> ---
...
> diff --git a/block/blk-settings.c b/block/blk-settings.c
> index 896b4654ab00..d303e6614c36 100644
> --- a/block/blk-settings.c
> +++ b/block/blk-settings.c
> @@ -59,6 +59,7 @@ void blk_set_default_limits(struct queue_limits *lim)
> lim->zoned = BLK_ZONED_NONE;
> lim->zone_write_granularity = 0;
> lim->dma_alignment = 511;
> + lim->max_provision_sectors = 0;
> }
>
> /**
> @@ -82,6 +83,7 @@ void blk_set_stacking_limits(struct queue_limits *lim)
> lim->max_dev_sectors = UINT_MAX;
> lim->max_write_zeroes_sectors = UINT_MAX;
> lim->max_zone_append_sectors = UINT_MAX;
> + lim->max_provision_sectors = UINT_MAX;
> }
> EXPORT_SYMBOL(blk_set_stacking_limits);
>
> @@ -578,6 +594,9 @@ int blk_stack_limits(struct queue_limits *t, struct queue_limits *b,
> t->max_segment_size = min_not_zero(t->max_segment_size,
> b->max_segment_size);
>
> + t->max_provision_sectors = min_not_zero(t->max_provision_sectors,
> + b->max_provision_sectors);
> +
This needs to use min() since max_provision_sectors also serves to
indicate if the device supports REQ_OP_PROVISION. Otherwise, if I set
max_provision_sectors to 0 on a dm thin-pool the blk_stack_limits()
will ignore my having set it to 0 (to disable) and it'll remain as
UINT_MAX (thanks to blk_set_default_limits).
Mike
--
dm-devel mailing list
dm-devel@redhat.com
https://listman.redhat.com/mailman/listinfo/dm-devel
WARNING: multiple messages have this Message-ID (diff)
From: Mike Snitzer <snitzer@kernel.org>
To: Sarthak Kukreti <sarthakkukreti@chromium.org>
Cc: dm-devel@redhat.com, linux-block@vger.kernel.org,
linux-ext4@vger.kernel.org, linux-kernel@vger.kernel.org,
linux-fsdevel@vger.kernel.org, Jens Axboe <axboe@kernel.dk>,
"Michael S. Tsirkin" <mst@redhat.com>,
Jason Wang <jasowang@redhat.com>,
Stefan Hajnoczi <stefanha@redhat.com>,
Alasdair Kergon <agk@redhat.com>,
Christoph Hellwig <hch@infradead.org>,
Brian Foster <bfoster@redhat.com>, Theodore Ts'o <tytso@mit.edu>,
Andreas Dilger <adilger.kernel@dilger.ca>,
Bart Van Assche <bvanassche@google.com>,
"Darrick J. Wong" <djwong@kernel.org>
Subject: Re: [PATCH v7 2/5] block: Introduce provisioning primitives
Date: Fri, 9 Jun 2023 16:00:24 -0400 [thread overview]
Message-ID: <ZIOE2ASeUAXxzpRO@redhat.com> (raw)
In-Reply-To: <20230518223326.18744-3-sarthakkukreti@chromium.org>
On Thu, May 18 2023 at 6:33P -0400,
Sarthak Kukreti <sarthakkukreti@chromium.org> wrote:
> Introduce block request REQ_OP_PROVISION. The intent of this request
> is to request underlying storage to preallocate disk space for the given
> block range. Block devices that support this capability will export
> a provision limit within their request queues.
>
> This patch also adds the capability to call fallocate() in mode 0
> on block devices, which will send REQ_OP_PROVISION to the block
> device for the specified range,
>
> Signed-off-by: Sarthak Kukreti <sarthakkukreti@chromium.org>
> ---
...
> diff --git a/block/blk-settings.c b/block/blk-settings.c
> index 896b4654ab00..d303e6614c36 100644
> --- a/block/blk-settings.c
> +++ b/block/blk-settings.c
> @@ -59,6 +59,7 @@ void blk_set_default_limits(struct queue_limits *lim)
> lim->zoned = BLK_ZONED_NONE;
> lim->zone_write_granularity = 0;
> lim->dma_alignment = 511;
> + lim->max_provision_sectors = 0;
> }
>
> /**
> @@ -82,6 +83,7 @@ void blk_set_stacking_limits(struct queue_limits *lim)
> lim->max_dev_sectors = UINT_MAX;
> lim->max_write_zeroes_sectors = UINT_MAX;
> lim->max_zone_append_sectors = UINT_MAX;
> + lim->max_provision_sectors = UINT_MAX;
> }
> EXPORT_SYMBOL(blk_set_stacking_limits);
>
> @@ -578,6 +594,9 @@ int blk_stack_limits(struct queue_limits *t, struct queue_limits *b,
> t->max_segment_size = min_not_zero(t->max_segment_size,
> b->max_segment_size);
>
> + t->max_provision_sectors = min_not_zero(t->max_provision_sectors,
> + b->max_provision_sectors);
> +
This needs to use min() since max_provision_sectors also serves to
indicate if the device supports REQ_OP_PROVISION. Otherwise, if I set
max_provision_sectors to 0 on a dm thin-pool the blk_stack_limits()
will ignore my having set it to 0 (to disable) and it'll remain as
UINT_MAX (thanks to blk_set_default_limits).
Mike
next prev parent reply other threads:[~2023-06-09 20:00 UTC|newest]
Thread overview: 107+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-05-18 22:33 [dm-devel] [PATCH v7 0/5] Introduce provisioning primitives Sarthak Kukreti
2023-05-18 22:33 ` Sarthak Kukreti
2023-05-18 22:33 ` [dm-devel] [PATCH v7 1/5] block: Don't invalidate pagecache for invalid falloc modes Sarthak Kukreti
2023-05-18 22:33 ` Sarthak Kukreti
2023-05-19 4:09 ` [dm-devel] " Christoph Hellwig
2023-05-19 4:09 ` Christoph Hellwig
2023-05-19 15:17 ` [dm-devel] " Darrick J. Wong
2023-05-19 15:17 ` Darrick J. Wong
2023-05-18 22:33 ` [dm-devel] [PATCH v7 2/5] block: Introduce provisioning primitives Sarthak Kukreti
2023-05-18 22:33 ` Sarthak Kukreti
2023-05-19 4:18 ` [dm-devel] " Christoph Hellwig
2023-05-19 4:18 ` Christoph Hellwig
2023-06-09 20:00 ` Mike Snitzer [this message]
2023-06-09 20:00 ` Mike Snitzer
2023-05-18 22:33 ` [dm-devel] [PATCH v7 3/5] dm: Add block provisioning support Sarthak Kukreti
2023-05-18 22:33 ` Sarthak Kukreti
2023-05-18 22:33 ` [dm-devel] [PATCH v7 4/5] dm-thin: Add REQ_OP_PROVISION support Sarthak Kukreti
2023-05-18 22:33 ` Sarthak Kukreti
2023-05-19 15:23 ` [dm-devel] " Mike Snitzer
2023-05-19 15:23 ` Mike Snitzer
2023-06-08 21:24 ` [dm-devel] " Mike Snitzer
2023-06-08 21:24 ` Mike Snitzer
2023-06-09 0:28 ` [dm-devel] " Mike Snitzer
2023-06-09 0:28 ` Mike Snitzer
2023-05-18 22:33 ` [dm-devel] [PATCH v7 5/5] loop: Add support for provision requests Sarthak Kukreti
2023-05-18 22:33 ` Sarthak Kukreti
2023-05-22 16:37 ` [dm-devel] " Darrick J. Wong
2023-05-22 16:37 ` Darrick J. Wong
2023-05-22 22:09 ` Sarthak Kukreti
2023-05-22 22:09 ` Sarthak Kukreti
2023-05-23 1:22 ` [dm-devel] " Darrick J. Wong
2023-05-23 1:22 ` Darrick J. Wong
2023-10-07 1:29 ` [dm-devel] " Sarthak Kukreti
2023-10-07 1:29 ` Sarthak Kukreti
2023-05-19 4:09 ` [dm-devel] [PATCH v7 0/5] Introduce provisioning primitives Christoph Hellwig
2023-05-19 4:09 ` Christoph Hellwig
2023-05-19 14:41 ` [dm-devel] " Mike Snitzer
2023-05-19 14:41 ` Mike Snitzer
2023-05-19 23:07 ` [dm-devel] " Dave Chinner
2023-05-19 23:07 ` Dave Chinner
2023-05-22 18:27 ` [dm-devel] " Mike Snitzer
2023-05-22 18:27 ` Mike Snitzer
2023-05-23 14:05 ` [dm-devel] " Brian Foster
2023-05-23 14:05 ` Brian Foster
2023-05-23 15:26 ` [dm-devel] " Mike Snitzer
2023-05-23 15:26 ` Mike Snitzer
2023-05-24 0:40 ` [dm-devel] " Dave Chinner
2023-05-24 0:40 ` Dave Chinner
2023-05-24 20:02 ` [dm-devel] " Mike Snitzer
2023-05-24 20:02 ` Mike Snitzer
2023-05-25 11:39 ` [dm-devel] " Dave Chinner
2023-05-25 11:39 ` Dave Chinner
2023-05-25 16:00 ` [dm-devel] " Mike Snitzer
2023-05-25 16:00 ` Mike Snitzer
2023-05-25 22:47 ` [dm-devel] " Sarthak Kukreti
2023-05-25 22:47 ` Sarthak Kukreti
2023-05-26 1:36 ` [dm-devel] " Dave Chinner
2023-05-26 1:36 ` Dave Chinner
2023-05-26 2:35 ` [dm-devel] " Sarthak Kukreti
2023-05-26 2:35 ` Sarthak Kukreti
2023-05-26 15:56 ` [dm-devel] " Brian Foster
2023-05-26 15:56 ` Brian Foster
2023-05-25 16:19 ` [dm-devel] " Brian Foster
2023-05-25 16:19 ` Brian Foster
2023-05-26 9:37 ` [dm-devel] " Dave Chinner
2023-05-26 9:37 ` Dave Chinner
2023-05-26 11:04 ` [dm-devel] " Joe Thornber
2023-05-26 23:45 ` Dave Chinner
2023-05-26 23:45 ` Dave Chinner
2023-05-30 7:27 ` [dm-devel] " Joe Thornber
2023-05-30 14:02 ` Mike Snitzer
2023-05-30 14:02 ` Mike Snitzer
2023-05-30 14:55 ` [dm-devel] " Joe Thornber
2023-05-30 15:28 ` Mike Snitzer
2023-05-30 15:28 ` Mike Snitzer
2023-06-02 18:44 ` [dm-devel] " Sarthak Kukreti
2023-06-02 18:44 ` Sarthak Kukreti
2023-06-02 21:50 ` [dm-devel] " Mike Snitzer
2023-06-02 21:50 ` Mike Snitzer
2023-06-03 0:52 ` [dm-devel] " Dave Chinner
2023-06-03 0:52 ` Dave Chinner
2023-06-03 15:57 ` [dm-devel] " Mike Snitzer
2023-06-03 15:57 ` Mike Snitzer
2023-06-05 21:14 ` [dm-devel] " Sarthak Kukreti
2023-06-05 21:14 ` Sarthak Kukreti
2023-06-07 2:15 ` [dm-devel] " Dave Chinner
2023-06-07 2:15 ` Dave Chinner
2023-06-07 23:27 ` [dm-devel] " Mike Snitzer
2023-06-07 23:27 ` Mike Snitzer
2023-06-09 20:31 ` [dm-devel] " Mike Snitzer
2023-06-09 20:31 ` Mike Snitzer
2023-06-09 21:54 ` [dm-devel] " Dave Chinner
2023-06-09 21:54 ` Dave Chinner
2023-10-07 1:30 ` [dm-devel] " Sarthak Kukreti
2023-10-07 1:30 ` Sarthak Kukreti
2023-06-07 2:01 ` [dm-devel] " Dave Chinner
2023-06-07 2:01 ` Dave Chinner
2023-06-07 23:50 ` [dm-devel] " Mike Snitzer
2023-06-07 23:50 ` Mike Snitzer
2023-06-09 3:32 ` [dm-devel] " Dave Chinner
2023-06-09 3:32 ` Dave Chinner
2023-06-08 2:03 ` [dm-devel] " Martin K. Petersen
2023-06-08 2:03 ` Martin K. Petersen
2023-06-09 0:10 ` [dm-devel] " Dave Chinner
2023-06-09 0:10 ` Dave Chinner
2023-05-26 15:47 ` [dm-devel] " Brian Foster
2023-05-26 15:47 ` Brian Foster
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=ZIOE2ASeUAXxzpRO@redhat.com \
--to=snitzer@kernel.org \
--cc=adilger.kernel@dilger.ca \
--cc=agk@redhat.com \
--cc=axboe@kernel.dk \
--cc=bfoster@redhat.com \
--cc=bvanassche@google.com \
--cc=djwong@kernel.org \
--cc=dm-devel@redhat.com \
--cc=hch@infradead.org \
--cc=jasowang@redhat.com \
--cc=linux-block@vger.kernel.org \
--cc=linux-ext4@vger.kernel.org \
--cc=linux-fsdevel@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mst@redhat.com \
--cc=sarthakkukreti@chromium.org \
--cc=stefanha@redhat.com \
--cc=tytso@mit.edu \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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.