summaryrefslogtreecommitdiffstats
path: root/sys/dev/ata/ata-queue.c
diff options
context:
space:
mode:
authormav <mav@FreeBSD.org>2009-11-08 14:33:19 +0000
committermav <mav@FreeBSD.org>2009-11-08 14:33:19 +0000
commitf4274f9678e4ce496e30c73d5889107ff757b668 (patch)
treebf0681a1405da1f51d118ec021474ba048a45f56 /sys/dev/ata/ata-queue.c
parent7280a5804337eb23b6b23e35071316756d35365d (diff)
downloadFreeBSD-src-f4274f9678e4ce496e30c73d5889107ff757b668.zip
FreeBSD-src-f4274f9678e4ce496e30c73d5889107ff757b668.tar.gz
Introduce define and kernel option ATA_REQUEST_TIMEOUT to control ATA(4)
command timeout. Submitted by: keramida
Diffstat (limited to 'sys/dev/ata/ata-queue.c')
-rw-r--r--sys/dev/ata/ata-queue.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/sys/dev/ata/ata-queue.c b/sys/dev/ata/ata-queue.c
index eeb7a1a..c048778 100644
--- a/sys/dev/ata/ata-queue.c
+++ b/sys/dev/ata/ata-queue.c
@@ -141,9 +141,9 @@ ata_controlcmd(device_t dev, u_int8_t command, u_int16_t feature,
if (atadev->spindown_state) {
device_printf(dev, "request while spun down, starting.\n");
atadev->spindown_state = 0;
- request->timeout = 31;
+ request->timeout = MAX(ATA_REQUEST_TIMEOUT, 31);
} else {
- request->timeout = 10;
+ request->timeout = ATA_REQUEST_TIMEOUT;
}
request->retries = 0;
ata_queue_request(request);
@@ -397,7 +397,7 @@ ata_completed(void *context, int dummy)
request->bytecount = sizeof(struct atapi_sense);
request->donecount = 0;
request->transfersize = sizeof(struct atapi_sense);
- request->timeout = 10;
+ request->timeout = ATA_REQUEST_TIMEOUT;
request->flags &= (ATA_R_ATAPI | ATA_R_QUIET | ATA_R_DEBUG);
request->flags |= (ATA_R_READ | ATA_R_AT_HEAD | ATA_R_REQUEUE);
ATA_DEBUG_RQ(request, "autoissue request sense");
OpenPOWER on IntegriCloud