Revert part of 1.102:
Don't decrease/check xs_retries when the device report "Power On, Reset, or Bus Device Reset" sense condition, just retry the command. The initial bus reset would cause the first TEST_UNIT_READY to report this condition, and as xs_retries is set to 0 when XS_CTL_DISCOVERY is set, it would report an error instead of being retried, causing the disk probe to report "drive offline" instead of the geometry and capacity. Checking/decreasing xs_retries on the bus reset reported by the adapter is enouth to avoid the problem reported by rev 1.102. Problem analysed by Paul Kranenburg, fix confirmed by Anders Hjalmars, and explaination as to why the INQUIRY wasn't affected by this provided by Bill Studenmund.
This commit is contained in:
parent
032279758d
commit
8cdd8d251c
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: scsipi_base.c,v 1.104 2004/03/16 19:10:43 bouyer Exp $ */
|
/* $NetBSD: scsipi_base.c,v 1.105 2004/04/27 18:15:37 bouyer Exp $ */
|
||||||
|
|
||||||
/*-
|
/*-
|
||||||
* Copyright (c) 1998, 1999, 2000, 2002, 2003 The NetBSD Foundation, Inc.
|
* Copyright (c) 1998, 1999, 2000, 2002, 2003 The NetBSD Foundation, Inc.
|
||||||
@ -38,7 +38,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
__KERNEL_RCSID(0, "$NetBSD: scsipi_base.c,v 1.104 2004/03/16 19:10:43 bouyer Exp $");
|
__KERNEL_RCSID(0, "$NetBSD: scsipi_base.c,v 1.105 2004/04/27 18:15:37 bouyer Exp $");
|
||||||
|
|
||||||
#include "opt_scsi.h"
|
#include "opt_scsi.h"
|
||||||
|
|
||||||
@ -938,12 +938,7 @@ scsipi_interpret_sense(xs)
|
|||||||
if (sense->add_sense_code == 0x29 &&
|
if (sense->add_sense_code == 0x29 &&
|
||||||
sense->add_sense_code_qual == 0x00) {
|
sense->add_sense_code_qual == 0x00) {
|
||||||
/* device or bus reset */
|
/* device or bus reset */
|
||||||
if (xs->xs_retries != 0) {
|
return (ERESTART);
|
||||||
xs->xs_retries--;
|
|
||||||
error = ERESTART;
|
|
||||||
} else
|
|
||||||
error = EIO;
|
|
||||||
return (error);
|
|
||||||
}
|
}
|
||||||
if ((periph->periph_flags & PERIPH_REMOVABLE) != 0)
|
if ((periph->periph_flags & PERIPH_REMOVABLE) != 0)
|
||||||
periph->periph_flags &= ~PERIPH_MEDIA_LOADED;
|
periph->periph_flags &= ~PERIPH_MEDIA_LOADED;
|
||||||
|
Loading…
Reference in New Issue
Block a user