On Thu, 20 Mar 2014, James Bottomley wrote:

> On Thu, 2014-03-20 at 12:34 -0400, Alan Stern wrote:
> > On Thu, 20 Mar 2014, James Bottomley wrote:
> > 
> > > OK, so I think we have three things to do
> > > 
> > >      1. Investigate SCSI and fix it's abort state problem that's causing
> > >         it not to send the abort second time around
> > >      2. Fix usb-storage to fail a reset it can't do (i.e. device reset
> > >         with outstanding commands)
> > >      3. Find out why we're sending a spurious request sense.
> > > 
> > > I can look at 1 and 3 if you want to take 2.
> > 
> > It's a deal!  Thanks for your help.
> 
> OK, I think this is the fix for 1, if you could try it out.
> 
> Thanks,
> 
> James
> 
> ---
> 
> diff --git a/drivers/scsi/scsi_error.c b/drivers/scsi/scsi_error.c
> index 771c16b..c52bfb2 100644
> --- a/drivers/scsi/scsi_error.c
> +++ b/drivers/scsi/scsi_error.c
> @@ -145,14 +145,14 @@ scmd_eh_abort_handler(struct work_struct *work)
>                                                   "scmd %p retry "
>                                                   "aborted command\n", scmd));
>                               scsi_queue_insert(scmd, SCSI_MLQUEUE_EH_RETRY);
> -                             return;
> +                             goto out;
>                       } else {
>                               SCSI_LOG_ERROR_RECOVERY(3,
>                                       scmd_printk(KERN_WARNING, scmd,
>                                                   "scmd %p finish "
>                                                   "aborted command\n", scmd));
>                               scsi_finish_command(scmd);
> -                             return;
> +                             goto out;
>                       }
>               } else {
>                       SCSI_LOG_ERROR_RECOVERY(3,
> @@ -162,6 +162,8 @@ scmd_eh_abort_handler(struct work_struct *work)
>               }
>       }
>  
> +     scmd->eh_eflags &= ~SCSI_EH_ABORT_SCHEDULED;
> +
>       if (!scsi_eh_scmd_add(scmd, 0)) {
>               SCSI_LOG_ERROR_RECOVERY(3,
>                       scmd_printk(KERN_WARNING, scmd,
> @@ -170,6 +172,10 @@ scmd_eh_abort_handler(struct work_struct *work)
>               scmd->result |= DID_TIME_OUT << 16;
>               scsi_finish_command(scmd);
>       }
> +     return;
> + out:
> +     scmd->eh_eflags &= ~SCSI_EH_ABORT_SCHEDULED;
> +     return;
>  }
>  
>  /**

This worked the first time.  :-)

But I wonder, is it safe to access scmd after calling 
scsi_finish_command()?

Alan Stern

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to