On Fri, Jun 02 2000, Stephen J. Gowdy wrote:
> My problem is that when I boot with the new kernel it gets as far
> as loading the aic7xxx module and then just times out on the INQUIRE
> command, it says it is doing bus reset and then trying harder (but to no
> avail). My drive is an IBM UltraStore 9ES (only scsi device) and the SCSI
> adapter is an Adaptec AIC7895 (use first channel). The motherboard is a
> Gigabyte GA-6BXDS if that is relevant.
This is because the initial TEST_UNIT_READY command we used to send
prior to INQUIRY is gone in later -ac kernels, as it was in violation.
This broke the aic7xxx driver for some reason, I hope that Doug will
fix this soon. For now you can just reinstane the TUR command, if
you wish to use 2.4.0-test1-ac7. Note - this is not a fix, just
a temporary work-around.
--
* Jens Axboe <[EMAIL PROTECTED]>
* Linux CD/DVD-ROM, SuSE Labs
* http://kernel.dk
--- /opt/kernel/linux-2.4.0-test1-ac6/drivers/scsi/scsi_scan.c Wed May 31 00:14:25
2000
+++ drivers/scsi/scsi_scan.c Wed May 31 00:14:18 2000
@@ -483,7 +483,38 @@
SDpnt->expecting_cc_ua = 0;
SDpnt->starved = 0;
+ scsi_cmd[0] = TEST_UNIT_READY;
+ scsi_cmd[1] = lun << 5;
+ scsi_cmd[2] = scsi_cmd[3] = scsi_cmd[4] = scsi_cmd[5] = 0;
+
SRpnt = scsi_allocate_request(SDpnt);
+
+ SRpnt->sr_data_direction = SCSI_DATA_NONE;
+ scsi_wait_req (SRpnt, (void *) scsi_cmd,
+ (void *) NULL,
+ 0, SCSI_TIMEOUT + 4 * HZ, 5);
+
+ SCSI_LOG_SCAN_BUS(3, printk("scsi: scan_scsis_single id %d lun %d. Return code
+0x%08x\n",
+ dev, lun, SRpnt->sr_result));
+ SCSI_LOG_SCAN_BUS(3, print_driverbyte(SRpnt->sr_result));
+ SCSI_LOG_SCAN_BUS(3, print_hostbyte(SRpnt->sr_result));
+ SCSI_LOG_SCAN_BUS(3, printk("\n"));
+
+ if (SRpnt->sr_result) {
+ if (((driver_byte(SRpnt->sr_result) & DRIVER_SENSE) ||
+ (status_byte(SRpnt->sr_result) & CHECK_CONDITION)) &&
+ ((SRpnt->sr_sense_buffer[0] & 0x70) >> 4) == 7) {
+ if (((SRpnt->sr_sense_buffer[2] & 0xf) != NOT_READY) &&
+ ((SRpnt->sr_sense_buffer[2] & 0xf) != UNIT_ATTENTION) &&
+ ((SRpnt->sr_sense_buffer[2] & 0xf) != ILLEGAL_REQUEST ||
+lun > 0)) {
+ scsi_release_request(SRpnt);
+ return 1;
+ }
+ } else {
+ scsi_release_request(SRpnt);
+ return 0;
+ }
+ }
/*
* We used to do a TEST_UNIT_READY before the INQUIRY but that was