From: Boaz Harrosh <bharrosh@panasas.com>
To: James Bottomley <James.Bottomley@suse.de>,
John Chandy <john.chandy@uconn.edu>,
open-osd <osd-dev@open-osd.org>,
linux-scsi <linux-scsi@vger.kernel.org>
Subject: Re: [PATCH 4/4] libosd: write/read_sg_kern API
Date: Tue, 19 Oct 2010 16:13:01 +0200 [thread overview]
Message-ID: <4CBDA76D.2030708@panasas.com> (raw)
In-Reply-To: <1287490962-24013-1-git-send-email-bharrosh@panasas.com>
On 10/19/2010 02:22 PM, Boaz Harrosh wrote:
> From: John A. Chandy <john.chandy@uconn.edu>
>
> This is a trivial addition to the SG API that can receive kernel
> pointers. It is only used by the out-of-tree test module. So
> it's immediate need is questionable. For maintenance ease it might
> just get in, as it's very small.
>
> John.
> do you need this in the Kernel, or is it only for osd_ktest.ko?
>
> Signed-off-by: John A. Chandy <john.chandy@uconn.edu>
> Signed-off-by: Boaz Harrosh <bharrosh@panasas.com>
> ---
> drivers/scsi/osd/osd_initiator.c | 71 ++++++++++++++++++++++++++++++++++++++
I forgot the header declarations, Resending version 2
Boaz
> 1 files changed, 71 insertions(+), 0 deletions(-)
>
> diff --git a/drivers/scsi/osd/osd_initiator.c b/drivers/scsi/osd/osd_initiator.c
> index f5b5735..0433ea6 100644
> --- a/drivers/scsi/osd/osd_initiator.c
> +++ b/drivers/scsi/osd/osd_initiator.c
> @@ -1015,6 +1015,77 @@ int osd_req_read_sg(struct osd_request *or,
> }
> EXPORT_SYMBOL(osd_req_read_sg);
>
> +/* SG-list write/read Kern API
> + *
> + * osd_req_{write,read}_sg_kern takes an array of @buff pointers and an array
> + * of sg_entries. @numentries indicates how many pointers and sg_entries there
> + * are. By requiring an array of buff pointers. This allows a caller to do a
> + * single write/read and scatter into multiple buffers.
> + * NOTE: Each buffer + len should not cross a page boundary.
> + */
> +static struct bio *_create_sg_bios(struct osd_request *or,
> + void **buff, const struct osd_sg_entry *sglist, unsigned numentries)
> +{
> + struct request_queue *q = osd_request_queue(or->osd_dev);
> + struct bio *bio;
> + unsigned i;
> +
> + bio = bio_kmalloc(GFP_KERNEL, numentries);
> + if (unlikely(!bio)) {
> + OSD_DEBUG("Faild to allocate BIO size=%u\n", numentries);
> + return ERR_PTR(-ENOMEM);
> + }
> +
> + for (i = 0; i < numentries; i++) {
> + unsigned offset = offset_in_page(buff[i]);
> + struct page *page = virt_to_page(buff[i]);
> + unsigned len = sglist[i].len;
> + unsigned added_len;
> +
> + BUG_ON(offset + len > PAGE_SIZE);
> + added_len = bio_add_pc_page(q, bio, page, len, offset);
> + if (unlikely(len != added_len)) {
> + OSD_DEBUG("bio_add_pc_page len(%d) != added_len(%d)\n",
> + len, added_len);
> + bio_put(bio);
> + return ERR_PTR(-ENOMEM);
> + }
> + }
> +
> + return bio;
> +}
> +
> +int osd_req_write_sg_kern(struct osd_request *or,
> + const struct osd_obj_id *obj, void **buff,
> + const struct osd_sg_entry *sglist, unsigned numentries)
> +{
> + struct bio *bio = _create_sg_bios(or, buff, sglist, numentries);
> + if (IS_ERR(bio))
> + return PTR_ERR(bio);
> +
> + bio->bi_rw |= REQ_WRITE;
> + osd_req_write_sg(or, obj, bio, sglist, numentries);
> +
> + return 0;
> +}
> +EXPORT_SYMBOL(osd_req_write_sg_kern);
> +
> +int osd_req_read_sg_kern(struct osd_request *or,
> + const struct osd_obj_id *obj, void **buff,
> + const struct osd_sg_entry *sglist, unsigned numentries)
> +{
> + struct bio *bio = _create_sg_bios(or, buff, sglist, numentries);
> + if (IS_ERR(bio))
> + return PTR_ERR(bio);
> +
> + osd_req_read_sg(or, obj, bio, sglist, numentries);
> +
> + return 0;
> +}
> +EXPORT_SYMBOL(osd_req_read_sg_kern);
> +
> +
> +
> void osd_req_get_attributes(struct osd_request *or,
> const struct osd_obj_id *obj)
> {
next prev parent reply other threads:[~2010-10-19 14:13 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-10-19 12:18 [PATCHSET 0/4] libosd: scatter gather commands and stuff for 2.6.37 Boaz Harrosh
2010-10-19 12:20 ` [PATCH 1/4] libosd: Fix bug in attr_page handling Boaz Harrosh
2010-10-19 12:21 ` [PATCH 2/4] libosd: Free resources in reverse order of allocation Boaz Harrosh
2010-10-19 12:22 ` [PATCH 3/4] libosd: Support for scatter gather write/read commands Boaz Harrosh
2010-10-19 12:22 ` [PATCH 4/4] libosd: write/read_sg_kern API Boaz Harrosh
2010-10-19 14:13 ` Boaz Harrosh [this message]
2010-10-19 14:13 ` [PATCH 4/4 ver2] " Boaz Harrosh
2010-10-22 17:32 ` Vladislav Bolkhovitin
2010-10-24 9:55 ` Boaz Harrosh
2010-10-25 18:50 ` Vladislav Bolkhovitin
2010-10-26 10:07 ` Boaz Harrosh
2010-10-20 14:28 ` [PATCH 4/4] " John Chandy
2010-10-21 12:13 ` Boaz Harrosh
2010-11-01 16:13 ` Christoph Hellwig
2010-11-02 8:33 ` Boaz Harrosh
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=4CBDA76D.2030708@panasas.com \
--to=bharrosh@panasas.com \
--cc=James.Bottomley@suse.de \
--cc=john.chandy@uconn.edu \
--cc=linux-scsi@vger.kernel.org \
--cc=osd-dev@open-osd.org \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).