From: Fam Zheng <famz@redhat.com>
To: Eric Blake <eblake@redhat.com>
Cc: qemu-devel@nongnu.org, qemu-block@nongnu.org, kwolf@redhat.com,
Stefan Hajnoczi <stefanha@redhat.com>,
Max Reitz <mreitz@redhat.com>,
Ronnie Sahlberg <ronniesahlberg@gmail.com>,
Paolo Bonzini <pbonzini@redhat.com>, Peter Lieven <pl@kamp.de>
Subject: Re: [Qemu-devel] [PATCH v2 15/17] block: Switch discard length bounds to byte-based
Date: Thu, 16 Jun 2016 13:46:57 +0800 [thread overview]
Message-ID: <20160616054657.GQ12178@ad.usersys.redhat.com> (raw)
In-Reply-To: <1465939839-30097-16-git-send-email-eblake@redhat.com>
On Tue, 06/14 15:30, Eric Blake wrote:
> Sector-based limits are awkward to think about; in our on-going
> quest to move to byte-based interfaces, convert max_discard and
> discard_alignment. Rename them, using 'pdiscard' as an aid to
> track which remaining discard interfaces need conversion, and so
> that the compiler will help us catch the change in semantics
> across any rebased code. In iscsi.c, sector_limits_lun2qemu()
> is no longer needed; and the BlockLimits type is now completely
> byte-based.
>
> Signed-off-by: Eric Blake <eblake@redhat.com>
>
> ---
> v2: rebase nbd and iscsi limits across earlier improvements
> ---
> include/block/block_int.h | 21 +++++++++++++++------
> block/io.c | 16 +++++++++-------
> block/iscsi.c | 19 ++++++-------------
> block/nbd.c | 2 +-
> qemu-img.c | 3 ++-
> 5 files changed, 33 insertions(+), 28 deletions(-)
>
> diff --git a/include/block/block_int.h b/include/block/block_int.h
> index 2b45d57..0169019 100644
> --- a/include/block/block_int.h
> +++ b/include/block/block_int.h
> @@ -324,18 +324,27 @@ struct BlockDriver {
> };
>
> typedef struct BlockLimits {
> - /* maximum number of sectors that can be discarded at once */
> - int max_discard;
> + /* maximum number of bytes that can be discarded at once (since it
> + * is signed, it must be < 2G, if set), should be multiple of
> + * pdiscard_alignment, but need not be power of 2. May be 0 if no
> + * inherent 32-bit limit */
> + int32_t max_pdiscard;
Why not use uint32_t?
>
> - /* optimal alignment for discard requests in sectors */
> - int64_t discard_alignment;
> + /* optimal alignment for discard requests in bytes, must be power
> + * of 2, less than max_discard if that is set, and multiple of
> + * bs->request_alignment. May be 0 if bs->request_alignment is
> + * good enough */
> + uint32_t pdiscard_alignment;
>
> /* maximum number of bytes that can zeroized at once (since it is
> - * signed, it must be < 2G, if set) */
> + * signed, it must be < 2G, if set), should be multiple of
> + * pwrite_zeroes_alignment. May be 0 if no inherent 32-bit limit */
> int32_t max_pwrite_zeroes;
>
> /* optimal alignment for write zeroes requests in bytes, must be
> - * power of 2, and less than max_pwrite_zeroes if that is set */
> + * power of 2, less than max_pwrite_zeroes if that is set, and
> + * multiple of bs->request_alignment. May be 0 if
> + * bs->request_alignment is good enough */
> uint32_t pwrite_zeroes_alignment;
>
> /* optimal transfer length in bytes (must be power of 2, and
> diff --git a/block/io.c b/block/io.c
> index 5e38ab4..0b5c40d 100644
> --- a/block/io.c
> +++ b/block/io.c
> @@ -2352,19 +2352,21 @@ int coroutine_fn bdrv_co_discard(BlockDriverState *bs, int64_t sector_num,
> BDRV_TRACKED_DISCARD);
> bdrv_set_dirty(bs, sector_num, nb_sectors);
>
> - max_discard = MIN_NON_ZERO(bs->bl.max_discard, BDRV_REQUEST_MAX_SECTORS);
> + max_discard = MIN_NON_ZERO(bs->bl.max_pdiscard >> BDRV_SECTOR_BITS,
> + BDRV_REQUEST_MAX_SECTORS);
> while (nb_sectors > 0) {
> int ret;
> int num = nb_sectors;
> + int discard_alignment = bs->bl.pdiscard_alignment >> BDRV_SECTOR_BITS;
>
> /* align request */
> - if (bs->bl.discard_alignment &&
> - num >= bs->bl.discard_alignment &&
> - sector_num % bs->bl.discard_alignment) {
> - if (num > bs->bl.discard_alignment) {
> - num = bs->bl.discard_alignment;
> + if (discard_alignment &&
> + num >= discard_alignment &&
> + sector_num % discard_alignment) {
> + if (num > discard_alignment) {
> + num = discard_alignment;
> }
> - num -= sector_num % bs->bl.discard_alignment;
> + num -= sector_num % discard_alignment;
> }
>
> /* limit request size */
> diff --git a/block/iscsi.c b/block/iscsi.c
> index 739d5ca..af9babf 100644
> --- a/block/iscsi.c
> +++ b/block/iscsi.c
> @@ -1696,13 +1696,6 @@ static void iscsi_close(BlockDriverState *bs)
> memset(iscsilun, 0, sizeof(IscsiLun));
> }
>
> -static int sector_limits_lun2qemu(int64_t sector, IscsiLun *iscsilun)
> -{
> - int limit = MIN(sector_lun2qemu(sector, iscsilun), INT_MAX / 2 + 1);
> -
> - return limit < BDRV_REQUEST_MAX_SECTORS ? limit : 0;
> -}
> -
> static void iscsi_refresh_limits(BlockDriverState *bs, Error **errp)
> {
> /* We don't actually refresh here, but just return data queried in
> @@ -1722,14 +1715,14 @@ static void iscsi_refresh_limits(BlockDriverState *bs, Error **errp)
> }
>
> if (iscsilun->lbp.lbpu) {
> - if (iscsilun->bl.max_unmap < 0xffffffff) {
> - bs->bl.max_discard =
> - sector_limits_lun2qemu(iscsilun->bl.max_unmap, iscsilun);
> + if (iscsilun->bl.max_unmap < 0xffffffff / iscsilun->block_size) {
> + bs->bl.max_pdiscard =
> + iscsilun->bl.max_unmap * iscsilun->block_size;
> }
> - bs->bl.discard_alignment =
> - sector_limits_lun2qemu(iscsilun->bl.opt_unmap_gran, iscsilun);
> + bs->bl.pdiscard_alignment =
> + iscsilun->bl.opt_unmap_gran * iscsilun->block_size;
> } else {
> - bs->bl.discard_alignment = iscsilun->block_size >> BDRV_SECTOR_BITS;
> + bs->bl.pdiscard_alignment = iscsilun->block_size;
> }
>
> if (iscsilun->bl.max_ws_len < 0xffffffff / iscsilun->block_size) {
> diff --git a/block/nbd.c b/block/nbd.c
> index f5511ea..08e5b67 100644
> --- a/block/nbd.c
> +++ b/block/nbd.c
> @@ -362,7 +362,7 @@ static int nbd_co_flush(BlockDriverState *bs)
>
> static void nbd_refresh_limits(BlockDriverState *bs, Error **errp)
> {
> - bs->bl.max_discard = NBD_MAX_SECTORS;
> + bs->bl.max_pdiscard = NBD_MAX_BUFFER_SIZE;
> bs->bl.max_transfer = NBD_MAX_BUFFER_SIZE;
> }
>
> diff --git a/qemu-img.c b/qemu-img.c
> index cf9876d..1237d61 100644
> --- a/qemu-img.c
> +++ b/qemu-img.c
> @@ -2084,7 +2084,8 @@ static int img_convert(int argc, char **argv)
> bufsectors = MIN(32768,
> MAX(bufsectors,
> MAX(out_bs->bl.opt_transfer >> BDRV_SECTOR_BITS,
> - out_bs->bl.discard_alignment)));
> + out_bs->bl.pdiscard_alignment >>
> + BDRV_SECTOR_BITS)));
>
> if (skip_create) {
> int64_t output_sectors = blk_nb_sectors(out_blk);
> --
> 2.5.5
>
next prev parent reply other threads:[~2016-06-16 5:47 UTC|newest]
Thread overview: 63+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-06-14 21:30 [Qemu-devel] [PATCH v2 00/17] Byte-based block limits Eric Blake
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 01/17] block: Tighter assertions on bdrv_aligned_pwritev() Eric Blake
2016-06-16 5:05 ` Fam Zheng
2016-06-20 12:09 ` [Qemu-devel] [Qemu-block] " Stefan Hajnoczi
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 02/17] block: Document supported flags during bdrv_aligned_preadv() Eric Blake
2016-06-16 5:08 ` Fam Zheng
2016-06-20 12:10 ` [Qemu-devel] [Qemu-block] " Stefan Hajnoczi
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 03/17] block: Fix harmless off-by-one in bdrv_aligned_preadv() Eric Blake
2016-06-16 5:10 ` Fam Zheng
2016-06-20 12:12 ` [Qemu-devel] [Qemu-block] " Stefan Hajnoczi
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 04/17] nbd: Allow larger requests Eric Blake
2016-06-15 13:37 ` Paolo Bonzini
2016-06-16 5:12 ` Fam Zheng
2016-06-20 12:13 ` [Qemu-devel] [Qemu-block] " Stefan Hajnoczi
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 05/17] nbd: Advertise realistic limits to block layer Eric Blake
2016-06-15 13:38 ` Paolo Bonzini
2016-06-22 20:58 ` Eric Blake
2016-06-16 5:13 ` Fam Zheng
2016-06-20 12:14 ` [Qemu-devel] [Qemu-block] " Stefan Hajnoczi
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 06/17] iscsi: " Eric Blake
2016-06-16 5:19 ` Fam Zheng
2016-06-20 12:16 ` [Qemu-devel] [Qemu-block] " Stefan Hajnoczi
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 07/17] block: Give nonzero result to blk_get_max_transfer_length() Eric Blake
2016-06-16 5:25 ` Fam Zheng
2016-06-16 13:22 ` Paolo Bonzini
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 08/17] blkdebug: Set request_alignment during .bdrv_refresh_limits() Eric Blake
2016-06-16 5:27 ` Fam Zheng
2016-06-21 13:27 ` Kevin Wolf
2016-06-21 22:17 ` Eric Blake
2016-06-22 10:05 ` Kevin Wolf
2016-06-22 17:33 ` Eric Blake
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 09/17] iscsi: " Eric Blake
2016-06-16 5:28 ` Fam Zheng
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 10/17] qcow2: " Eric Blake
2016-06-16 5:28 ` Fam Zheng
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 11/17] raw-win32: " Eric Blake
2016-06-16 5:30 ` Fam Zheng
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 12/17] block: " Eric Blake
2016-06-16 5:31 ` Fam Zheng
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 13/17] block: Set default request_alignment during bdrv_refresh_limits() Eric Blake
2016-06-16 5:32 ` Fam Zheng
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 14/17] block: Switch transfer length bounds to byte-based Eric Blake
2016-06-16 5:42 ` Fam Zheng
2016-06-21 13:50 ` Kevin Wolf
2016-06-21 22:20 ` Eric Blake
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 15/17] block: Switch discard " Eric Blake
2016-06-16 5:46 ` Fam Zheng [this message]
2016-06-16 14:21 ` Eric Blake
2016-06-17 2:28 ` Fam Zheng
2016-06-21 14:05 ` Kevin Wolf
2016-06-21 22:21 ` Eric Blake
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 16/17] block: Split bdrv_merge_limits() from bdrv_refresh_limits() Eric Blake
2016-06-16 5:50 ` Fam Zheng
2016-06-16 14:22 ` Eric Blake
2016-06-21 14:12 ` Kevin Wolf
2016-06-21 22:24 ` Eric Blake
2016-06-14 21:30 ` [Qemu-devel] [PATCH v2 17/17] block: Move request_alignment into BlockLimit Eric Blake
2016-06-16 5:52 ` Fam Zheng
2016-06-21 14:16 ` Kevin Wolf
2016-06-21 22:26 ` Eric Blake
2016-06-22 10:14 ` Kevin Wolf
2016-06-21 14:18 ` [Qemu-devel] [PATCH v2 00/17] Byte-based block limits Kevin Wolf
2016-06-21 22:27 ` Eric Blake
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=20160616054657.GQ12178@ad.usersys.redhat.com \
--to=famz@redhat.com \
--cc=eblake@redhat.com \
--cc=kwolf@redhat.com \
--cc=mreitz@redhat.com \
--cc=pbonzini@redhat.com \
--cc=pl@kamp.de \
--cc=qemu-block@nongnu.org \
--cc=qemu-devel@nongnu.org \
--cc=ronniesahlberg@gmail.com \
--cc=stefanha@redhat.com \
/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.