From: Christoph Hellwig <hch@lst.de>
To: Damien Le Moal <damien.lemoal@wdc.com>
Cc: linux-scsi@vger.kernel.org,
"Martin K . Petersen" <martin.petersen@oracle.com>,
linux-block@vger.kernel.org, Jens Axboe <axboe@kernel.dk>,
Christoph Hellwig <hch@lst.de>,
Bart Van Assche <bvanassche@acm.org>
Subject: Re: [PATCH V5 1/3] block: Allow mapping of vmalloc-ed buffers
Date: Thu, 27 Jun 2019 16:06:32 +0200 [thread overview]
Message-ID: <20190627140632.GA6209@lst.de> (raw)
In-Reply-To: <20190627092944.20957-2-damien.lemoal@wdc.com>
On Thu, Jun 27, 2019 at 06:29:42PM +0900, Damien Le Moal wrote:
> To allow the SCSI subsystem scsi_execute_req() function to issue
> requests using large buffers that are better allocated with vmalloc()
> rather than kmalloc(), modify bio_map_kern() to allow passing a buffer
> allocated with vmalloc().
>
> To do so, detect vmalloc-ed buffers using is_vmalloc_addr(). For
> vmalloc-ed buffers, flush the buffer using flush_kernel_vmap_range(),
> use vmalloc_to_page() instead of virt_to_page() to obtain the pages of
> the buffer, and invalidate the buffer addresses with
> invalidate_kernel_vmap_range() on completion of read BIOs. This last
> point is executed using the function bio_invalidate_vmalloc_pages()
> which is defined only if the architecture defines
> ARCH_HAS_FLUSH_KERNEL_DCACHE_PAGE, that is, if the architecture
> actually needs the invalidation done.
>
> Fixes: 515ce6061312 ("scsi: sd_zbc: Fix sd_zbc_report_zones() buffer allocation")
> Fixes: e76239a3748c ("block: add a report_zones method")
> Cc: stable@vger.kernel.org
> Signed-off-by: Damien Le Moal <damien.lemoal@wdc.com>
> ---
> block/bio.c | 29 ++++++++++++++++++++++++++++-
> 1 file changed, 28 insertions(+), 1 deletion(-)
>
> diff --git a/block/bio.c b/block/bio.c
> index ce797d73bb43..bbba5f08b2ef 100644
> --- a/block/bio.c
> +++ b/block/bio.c
> @@ -16,6 +16,7 @@
> #include <linux/workqueue.h>
> #include <linux/cgroup.h>
> #include <linux/blk-cgroup.h>
> +#include <linux/highmem.h>
>
> #include <trace/events/block.h>
> #include "blk.h"
> @@ -1479,8 +1480,22 @@ void bio_unmap_user(struct bio *bio)
> bio_put(bio);
> }
>
> +static void bio_invalidate_vmalloc_pages(struct bio *bio)
> +{
> +#ifdef ARCH_HAS_FLUSH_KERNEL_DCACHE_PAGE
> + if (bio->bi_private && !op_is_write(bio_op(bio))) {
> + unsigned long i, len = 0;
> +
> + for (i = 0; i < bio->bi_vcnt; i++)
> + len += bio->bi_io_vec[i].bv_len;
> + invalidate_kernel_vmap_range(bio->bi_private, len);
> + }
> +#endif
> +}
Normal Linux style is to keep the ifdefs outside the functions,
or use IS_ENABLED, although the latter would require
ARCH_HAS_FLUSH_KERNEL_DCACHE_PAGE to be a config option. Not that
I personally care much.
> @@ -1531,6 +1557,7 @@ struct bio *bio_map_kern(struct request_queue *q, void *data, unsigned int len,
> }
>
> bio->bi_end_io = bio_map_kern_endio;
> +
> return bio;
> }
Superflous whitespace change.
Otherwise look good:
Reviewed-by: Christoph Hellwig <hch@lst.de>
next prev parent reply other threads:[~2019-06-27 14:11 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-06-27 9:29 [PATCH V5 0/3] Fix zone revalidation memory allocation failures Damien Le Moal
2019-06-27 9:29 ` [PATCH V5 1/3] block: Allow mapping of vmalloc-ed buffers Damien Le Moal
2019-06-27 14:06 ` Christoph Hellwig [this message]
2019-06-27 17:09 ` Chaitanya Kulkarni
2019-06-28 0:12 ` Ming Lei
2019-06-27 9:29 ` [PATCH V5 2/3] sd_zbc: Fix report zones buffer allocation Damien Le Moal
2019-06-27 14:09 ` Christoph Hellwig
2019-06-28 7:30 ` Damien Le Moal
2019-06-28 7:44 ` Christoph Hellwig
2019-06-28 7:57 ` Damien Le Moal
2019-06-28 8:03 ` Christoph Hellwig
2019-06-27 9:29 ` [PATCH V5 3/3] block: Limit zone array allocation size Damien Le Moal
2019-06-27 17:08 ` Chaitanya Kulkarni
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=20190627140632.GA6209@lst.de \
--to=hch@lst.de \
--cc=axboe@kernel.dk \
--cc=bvanassche@acm.org \
--cc=damien.lemoal@wdc.com \
--cc=linux-block@vger.kernel.org \
--cc=linux-scsi@vger.kernel.org \
--cc=martin.petersen@oracle.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.