All of lore.kernel.org
 help / color / mirror / Atom feed
From: Christof Schmitt <christof.schmitt@de.ibm.com>
To: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
Cc: linux-scsi@vger.kernel.org, dgilbert@interlog.com
Subject: Re: sg: Free data buffers after calling blk_rq_unmap_user
Date: Thu, 17 Sep 2009 08:53:00 +0200	[thread overview]
Message-ID: <20090917065259.GA5594@schmichrtp> (raw)
In-Reply-To: <20090917150001F.fujita.tomonori@lab.ntt.co.jp>

On Thu, Sep 17, 2009 at 03:00:44PM +0900, FUJITA Tomonori wrote:
> Sorry for the delay,
> 
> On Tue, 15 Sep 2009 18:53:57 +0200
> Christof Schmitt <christof.schmitt@de.ibm.com> wrote:
> 
> > This patch fixes a problem with the sg driver that is only visible
> > with the CONFIG_DEBUG_PAGEALLOC kernel config option. The patch works
> > for me, but i would appreciate the review of somebody with more
> > knowledge about the interactions between the sg driver and the block
> > layer.
> > 
> > Christof
> > ---
> > sg: Free data buffers after calling blk_rq_unmap_user
> > 
> > From: Christof Schmitt <christof.schmitt@de.ibm.com>
> > 
> > Running sg_luns on s390x with CONFIG_DEBUG_PAGEALLOC enabled fails
> > with EFAULT from the SG_IO ioctl. The EFAULT is the result from
> > copy_to_user failing in this call chain:
> > 
> > sg_ioctl
> > sg_new_read
> > sg_finish_rem_req
> > blk_rq_unmap_user
> > __blk_rq_unmap_user
> > bio_uncopy_user
> > __bio_copy_iov
> > copy_to_user
> > 
> > The sg driver calls sg_remove_scat to free the memory pages before
> > calling blk_rq_unmap_user that tries to copy the data back to
> > userspace. Change the order to first call blk_rq_unmap_user before
> > freeing the pages in sg_remove_scat.
> > 
> > Signed-off-by: Christof Schmitt <christof.schmitt@de.ibm.com>
> > ---
> >  drivers/scsi/sg.c |   10 +++++-----
> >  1 file changed, 5 insertions(+), 5 deletions(-)
> 
> Oops, thanks a lot!
> 
> Acked-by: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
> 
> It would be better to add "Cc: stable@kernel.org" tag since this fix
> needs to be sent to stable trees.

Thanks for the review. I will resend the patch with the added acked-by
and cc.

--
Christof

      reply	other threads:[~2009-09-17  6:52 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-09-15 16:53 sg: Free data buffers after calling blk_rq_unmap_user Christof Schmitt
2009-09-17  6:00 ` FUJITA Tomonori
2009-09-17  6:53   ` Christof Schmitt [this message]

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=20090917065259.GA5594@schmichrtp \
    --to=christof.schmitt@de.ibm.com \
    --cc=dgilbert@interlog.com \
    --cc=fujita.tomonori@lab.ntt.co.jp \
    --cc=linux-scsi@vger.kernel.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 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.