From mboxrd@z Thu Jan 1 00:00:00 1970 From: Hannes Reinecke Subject: Re: [PATCH 5/7] Drivers: scsi: storvsc: Implement a timedout handler Date: Mon, 14 Jul 2014 08:16:55 +0200 Message-ID: <53C375D7.5080608@suse.de> References: <1405183684-23928-1-git-send-email-kys@microsoft.com> <1405183712-23967-1-git-send-email-kys@microsoft.com> <1405183712-23967-5-git-send-email-kys@microsoft.com> Mime-Version: 1.0 Content-Type: text/plain; charset="iso-8859-1"; Format="flowed" Content-Transfer-Encoding: quoted-printable Return-path: In-Reply-To: <1405183712-23967-5-git-send-email-kys@microsoft.com> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: driverdev-devel-bounces@linuxdriverproject.org Sender: driverdev-devel-bounces@linuxdriverproject.org To: "K. Y. Srinivasan" , jasowang@redhat.com, apw@canonical.com, linux-kernel@vger.kernel.org, devel@linuxdriverproject.org, ohering@suse.com, jbottomley@parallels.com, hch@infradead.org, linux-scsi@vger.kernel.org Cc: stable@vger.kernel.org List-Id: linux-scsi@vger.kernel.org On 07/12/2014 06:48 PM, K. Y. Srinivasan wrote: > On Azure, we have seen instances of unbounded I/O latencies. To deal with > this issue, implement handler that can reset the timeout. Note that the > host gaurantees that it will respond to each command that has been issued. > > > Signed-off-by: K. Y. Srinivasan > Cc: > --- > drivers/scsi/storvsc_drv.c | 10 ++++++++++ > 1 files changed, 10 insertions(+), 0 deletions(-) > > diff --git a/drivers/scsi/storvsc_drv.c b/drivers/scsi/storvsc_drv.c > index 7e8a642..3516761 100644 > --- a/drivers/scsi/storvsc_drv.c > +++ b/drivers/scsi/storvsc_drv.c > @@ -33,6 +33,7 @@ > #include > #include > #include > +#include > #include > #include > #include > @@ -1518,6 +1519,14 @@ static int storvsc_host_reset_handler(struct scsi_= cmnd *scmnd) > return SUCCESS; > } > > +static enum blk_eh_timer_return storvsc_timeout_handler(struct scsi_cmnd= *scmnd) > +{ > + /* > + * The host will respond; ask for more time. > + */ > + return BLK_EH_RESET_TIMER; > +} > + > static bool storvsc_scsi_cmd_ok(struct scsi_cmnd *scmnd) > { > bool allowed =3D true; > @@ -1697,6 +1706,7 @@ static struct scsi_host_template scsi_driver =3D { > .bios_param =3D storvsc_get_chs, > .queuecommand =3D storvsc_queuecommand, > .eh_host_reset_handler =3D storvsc_host_reset_handler, > + .eh_timed_out =3D storvsc_timeout_handler, > .slave_alloc =3D storvsc_device_alloc, > .slave_destroy =3D storvsc_device_destroy, > .slave_configure =3D storvsc_device_configure, > Reviewed-by: Hannes Reinecke Cheers, Hannes -- = Dr. Hannes Reinecke zSeries & Storage hare@suse.de +49 911 74053 688 SUSE LINUX Products GmbH, Maxfeldstr. 5, 90409 N=FCrnberg GF: J. Hawn, J. Guild, F. Imend=F6rffer, HRB 16746 (AG N=FCrnberg)