All of lore.kernel.org
 help / color / mirror / Atom feed
From: Boaz Harrosh <bharrosh@panasas.com>
To: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
Cc: seokmann.ju@qlogic.com, jens.axboe@oracle.com,
	James.Smart@Emulex.Com, James.Bottomley@hansenpartnership.com,
	linux-scsi@vger.kernel.org, andrew.vasquez@qlogic.com,
	michaelc@cs.wisc.edu, robert.w.love@intel.com
Subject: Re: [PATCH 1/2] scsi_transport_fc: FC pass through support via bsg interface - revised
Date: Mon, 27 Oct 2008 10:20:21 +0200	[thread overview]
Message-ID: <490579C5.5080102@panasas.com> (raw)
In-Reply-To: <20081027131110Z.fujita.tomonori@lab.ntt.co.jp>

FUJITA Tomonori wrote:
> On Sun, 26 Oct 2008 11:38:04 +0200
> Boaz Harrosh <bharrosh@panasas.com> wrote:
> 
>> FUJITA Tomonori wrote:
>>> CC'ed Jens,
>>>
>>> On Wed, 22 Oct 2008 19:27:35 -0700
>>> Seokmann Ju <seokmann.ju@qlogic.com> wrote:
>>>
>>>> And it seems like that the panic is happening due to the fact that  
>>>> blk_delete_timer() is not called upon having completion of the service.
>>>> In other words, the block layer calls blk_add_timer() prior to  
>>>> dispatch the service but, it doesn't call blk_delete_timer() when it  
>>>> returned.
>>> Yeah, we need to call blk_delete_timer somewhere.
>>>
>>>
>>>> Just for heck of it, I've tried out by adding blk_delete_timer() in  
>>>> the ~/block/blk-exec.c:blk_end_sync_rq() and it seems fixes the problem.
>>> I think blk_end_sync_rq() is not the good place. From the perspective
>>> of bsg, we need to handle both blk_execute_rq_nowait and
>>> blk_execute_rq.
>>>
>>>
>>>> Seems like that there are APIs in the block layer that are call the  
>>>> blk_delete_timer(), including,
>>>> - blk_end_io()
>>>> - __blk_end_request()
>>>>
>>>> Could you guide me what is right way to fix the problem?
>>> Exporting blk_delete_timer is one option, but it doesn't look very
>>> nice (since the block layer doesn't export any details about its timer
>>> infrastructure), I think. Modifying blk_end_io() to make it usable for
>>> requests via something like bsg might be better.
>>>
>>> Anyway, we need to ask Jens.
>>>
>>> Jens, fc people have working on fc pass through support via bsg, which
>>> hooks bsg's request queue on fc transport objects (We did the similar
>>> thing for sas transport).
>>>
>>> We want the timeout feature for fc pass through and I think that it's
>>> nice to use the block layer timeout feature for it. But the users of
>>> bsg request queue don't need (or call) APIs such as
>>> end_that_request_last to call blk_delete_timer internally. How should
>>> these users call blk_delete_timer?
>> TOMO Hi
>> If a command is queued by bsg to a scsi device, which is posible. Then
>> blk_end_request() is called by scsi-ml. So it does work.
> 
> It doesn't work for bsg's scsi transport pass through stuff such as
> SMP (sas management protocol, we already support) and FC. Virtually,
> they don't use scsi-ml.
> 

Right, I know that, that's why I say.

> 
>> I think that all block-queue consumers should call one of
>> blk_end_request(),
> 
> This is kinda what I suggested in the previous mail but as I wrote,
> some of them don't now.
> 

I think they should, specially if they're going to use the timer.
The way I see it they must. It's kind of a block layer API thing.
Someone calls blk_execute_xx then eventually someone needs to call
blk_end_request. You could call it from bsg but only temporary until
all are fixed. (because you will need an ugly check to see if request
was not already ended)

> 
>> there are lots to choose from. We don't need
>> a new API. It will work with or without data, and it does what
>> you want.

Boaz

  reply	other threads:[~2008-10-27  8:20 UTC|newest]

Thread overview: 23+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-10-13 17:53 [PATCH 1/2] scsi_transport_fc: FC pass through support via bsg interface - revised Seokmann Ju
2008-10-13 18:14 ` Seokmann Ju
2008-10-14  2:22   ` FUJITA Tomonori
2008-10-14 11:44     ` Seokmann Ju
2008-10-14 13:34       ` FUJITA Tomonori
2008-10-14 14:13         ` Seokmann Ju
2008-10-20 10:59           ` Seokmann Ju
2008-10-20 11:45             ` FUJITA Tomonori
2008-10-20 12:46               ` Seokmann Ju
2008-10-20 13:36                 ` FUJITA Tomonori
2008-10-23  2:27                   ` Seokmann Ju
2008-10-24  3:54                     ` FUJITA Tomonori
2008-10-26  9:38                       ` Boaz Harrosh
2008-10-27  4:12                         ` FUJITA Tomonori
2008-10-27  8:20                           ` Boaz Harrosh [this message]
2008-10-27  8:47                             ` FUJITA Tomonori
2008-10-27 16:46                             ` Seokmann Ju
2008-10-28  7:57                               ` Boaz Harrosh
2008-10-28 14:06                                 ` Seokmann Ju
2008-10-28 14:38                                   ` Boaz Harrosh
2008-10-28 14:55                                     ` Boaz Harrosh
2008-10-28 14:59                                       ` Boaz Harrosh
2008-10-28 16:03                                         ` Seokmann Ju

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=490579C5.5080102@panasas.com \
    --to=bharrosh@panasas.com \
    --cc=James.Bottomley@hansenpartnership.com \
    --cc=James.Smart@Emulex.Com \
    --cc=andrew.vasquez@qlogic.com \
    --cc=fujita.tomonori@lab.ntt.co.jp \
    --cc=jens.axboe@oracle.com \
    --cc=linux-scsi@vger.kernel.org \
    --cc=michaelc@cs.wisc.edu \
    --cc=robert.w.love@intel.com \
    --cc=seokmann.ju@qlogic.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.