All of lore.kernel.org
 help / color / mirror / Atom feed
From: Jeff Layton <jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
To: Suresh Jayaraman <sjayaraman-l3A5Bk7waGM@public.gmane.org>
Cc: smfrench-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org,
	linux-cifs-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
Subject: Re: [PATCH 09/18] cifs: clean up sync_mid_result
Date: Mon, 20 Dec 2010 08:04:09 -0500	[thread overview]
Message-ID: <20101220080409.35112ed8@corrin.poochiereds.net> (raw)
In-Reply-To: <4D0F3DAD.7080801-l3A5Bk7waGM@public.gmane.org>

On Mon, 20 Dec 2010 16:57:41 +0530
Suresh Jayaraman <sjayaraman-l3A5Bk7waGM@public.gmane.org> wrote:

> On 12/17/2010 08:38 PM, Jeff Layton wrote:
> > Make it use a switch statement based on the value of the midStatus. If
> > the resp_buf is set, then MID_RESPONSE_RECEIVED is too.
> > 
> > Signed-off-by: Jeff Layton <jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
> > ---
> >  fs/cifs/transport.c |   35 ++++++++++++++++++-----------------
> >  1 files changed, 18 insertions(+), 17 deletions(-)
> > 
> > diff --git a/fs/cifs/transport.c b/fs/cifs/transport.c
> > index f65cdec..6abd144 100644
> > --- a/fs/cifs/transport.c
> > +++ b/fs/cifs/transport.c
> > @@ -363,28 +363,29 @@ sync_mid_result(struct mid_q_entry *mid, struct TCP_Server_Info *server)
> >  {
> >  	int rc = 0;
> >  
> > -	spin_lock(&GlobalMid_Lock);
> > +	cFYI(1, "%s: cmd=%d mid=%d state=%d", __func__, mid->command,
> > +		mid->mid, mid->midState);
> >  
> > -	if (mid->resp_buf) {
> > +	spin_lock(&GlobalMid_Lock);
> > +	switch (mid->midState) {
> > +	case MID_RESPONSE_RECEIVED:
> >  		spin_unlock(&GlobalMid_Lock);
> >  		return rc;
> > -	}
> > -
> > -	cERROR(1, "No response to cmd %d mid %d", mid->command, mid->mid);
> > -	if (mid->midState == MID_REQUEST_SUBMITTED) {
> > -		if (server->tcpStatus == CifsExiting)
> > +	case MID_REQUEST_SUBMITTED:
> > +		/* socket is going down, reject all calls */
> > +		if (server->tcpStatus == CifsExiting) {
> > +			cERROR(1, "%s: canceling mid=%d cmd=0x%x state=%d",
> > +			       __func__, mid->mid, mid->command, mid->midState);
> >  			rc = -EHOSTDOWN;
> > -		else
> > -			mid->midState = MID_RETRY_NEEDED;
> > -	}
> 
> When midState is MID_REQUEST_SUBMITTED and tcpStatus is not CifsExiting,
> the old code used to set midState to MID_RETRY_NEEDED. This is not set
> now - is this intentional?
> 

I don't think it matters much. wait_for_response does this:

        error = wait_event_killable(server->response_q,
                                    midQ->midState != MID_REQUEST_SUBMITTED);

...so you can only get out of that wait with MID_REQUEST_SUBMITTED by
fatal signal. At that point, the caller is going to do send the cancel
and return without calling handle_mid_result.

So TBH, I think that this MID_REQUEST_SUBMITTED clause is going to be
unused, but we could reset the value to MID_RETRY_NEEDED if we think
it'll be better for future-proofness.


> > -	if (rc != -EHOSTDOWN) {
> > -		if (mid->midState == MID_RETRY_NEEDED) {
> > -			rc = -EAGAIN;
> > -			cFYI(1, "marking request for retry");
> > -		} else {
> > -			rc = -EIO;
> > +			break;
> >  		}
> > +	case MID_RETRY_NEEDED:
> > +		rc = -EAGAIN;
> > +		break;
> > +	default:
> > +		cERROR(1, "%s: invalid mid state mid=%d state=%d", __func__,
> > +			mid->mid, mid->midState);
> > +		rc = -EIO;
> >  	}
> >  	spin_unlock(&GlobalMid_Lock);
> >  
> 
> 


-- 
Jeff Layton <jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>

  parent reply	other threads:[~2010-12-20 13:04 UTC|newest]

Thread overview: 47+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-12-17 15:07 [PATCH 00/18] cifs: overhaul request timeout behavior in CIFS (try #3) Jeff Layton
     [not found] ` <1292598497-29796-1-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-17 15:08   ` [PATCH 01/18] cifs: don't fail writepages on -EAGAIN errors Jeff Layton
     [not found]     ` <1292598497-29796-2-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-20 10:53       ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 02/18] cifs: no need to mark smb_ses_list as cifs_demultiplex_thread is exiting Jeff Layton
     [not found]     ` <1292598497-29796-3-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-20 10:52       ` Suresh Jayaraman
2010-12-20 16:38       ` Suresh Jayaraman
     [not found]         ` <4D0F868E.8020407-l3A5Bk7waGM@public.gmane.org>
2010-12-21  1:38           ` Jeff Layton
2010-12-17 15:08   ` [PATCH 03/18] cifs: make wait_for_free_request take a TCP_Server_Info pointer Jeff Layton
     [not found]     ` <1292598497-29796-4-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-20 10:52       ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 04/18] cifs: clean up accesses to midCount Jeff Layton
     [not found]     ` <1292598497-29796-5-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-20 10:52       ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 05/18] cifs: move locked sections out of DeleteMidQEntry and AllocMidQEntry Jeff Layton
     [not found]     ` <1292598497-29796-6-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-20 11:00       ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 06/18] cifs: move mid result processing into common function Jeff Layton
     [not found]     ` <1292598497-29796-7-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-20 11:06       ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 07/18] cifs: wait indefinitely for responses Jeff Layton
     [not found]     ` <1292598497-29796-8-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-21 15:50       ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 08/18] cifs: don't reconnect server when we don't get a response Jeff Layton
     [not found]     ` <1292598497-29796-9-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-20 11:27       ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 09/18] cifs: clean up sync_mid_result Jeff Layton
     [not found]     ` <1292598497-29796-10-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-20 11:27       ` Suresh Jayaraman
     [not found]         ` <4D0F3DAD.7080801-l3A5Bk7waGM@public.gmane.org>
2010-12-20 13:04           ` Jeff Layton [this message]
     [not found]             ` <20101220080409.35112ed8-4QP7MXygkU+dMjc06nkz3ljfA9RmPOcC@public.gmane.org>
2010-12-20 16:35               ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 10/18] cifs: allow for different handling of received response Jeff Layton
     [not found]     ` <1292598497-29796-11-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-21 15:50       ` Suresh Jayaraman
     [not found]         ` <4D10CCD3.1040502-l3A5Bk7waGM@public.gmane.org>
2010-12-21 16:48           ` Jeff Layton
2010-12-21 15:51       ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 11/18] cifs: handle cancelled requests better Jeff Layton
2010-12-17 15:08   ` [PATCH 12/18] cifs: add cifs_call_async Jeff Layton
     [not found]     ` <1292598497-29796-13-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-21 16:05       ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 13/18] cifs: add ability to send an echo request Jeff Layton
     [not found]     ` <1292598497-29796-14-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-21 16:05       ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 14/18] cifs: set up recurring workqueue job to do SMB echo requests Jeff Layton
     [not found]     ` <1292598497-29796-15-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-21 16:06       ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 15/18] cifs: reconnect unresponsive servers Jeff Layton
     [not found]     ` <1292598497-29796-16-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-23 10:31       ` Suresh Jayaraman
     [not found]         ` <4D1324EC.8010305-l3A5Bk7waGM@public.gmane.org>
2010-12-23 13:20           ` Jeff Layton
     [not found]             ` <20101223082005.347b8ca8-xSBYVWDuneFaJnirhKH9O4GKTjYczspe@public.gmane.org>
2010-12-23 15:36               ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 16/18] cifs: remove code for setting timeouts on requests Jeff Layton
     [not found]     ` <1292598497-29796-17-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-23 10:32       ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 17/18] cifs: mangle existing header for SMB_COM_NT_CANCEL Jeff Layton
     [not found]     ` <1292598497-29796-18-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-23 11:05       ` Suresh Jayaraman
2010-12-17 15:08   ` [PATCH 18/18] cifs: send an NT_CANCEL request when a process is signalled Jeff Layton
     [not found]     ` <1292598497-29796-19-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-23 11:06       ` Suresh Jayaraman
  -- strict thread matches above, loose matches on Subject: below --
2010-12-27  2:29 [PATCH 00/18] cifs: overhaul request timeout behavior in CIFS (try #4) Jeff Layton
     [not found] ` <1293417006-6417-1-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-27  2:29   ` [PATCH 09/18] cifs: clean up sync_mid_result Jeff Layton
     [not found]     ` <1293417006-6417-10-git-send-email-jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-12-27 15:53       ` Pavel Shilovsky
2011-01-06  6:57       ` Suresh Jayaraman

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=20101220080409.35112ed8@corrin.poochiereds.net \
    --to=jlayton-h+wxahxf7alqt0dzr+alfa@public.gmane.org \
    --cc=linux-cifs-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=sjayaraman-l3A5Bk7waGM@public.gmane.org \
    --cc=smfrench-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.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.