summaryrefslogtreecommitdiffstats
path: root/sys/cam
diff options
context:
space:
mode:
authormav <mav@FreeBSD.org>2012-10-11 15:21:07 +0000
committermav <mav@FreeBSD.org>2012-10-11 15:21:07 +0000
commite867826c0224f87edbf44239bd842027cd13de79 (patch)
tree10b7633cfbd3dcbb3ed03a3bbeef8c4909b1f138 /sys/cam
parent61816f86e167fba086e2c2d4a8dd9a2f318d1b26 (diff)
downloadFreeBSD-src-e867826c0224f87edbf44239bd842027cd13de79.zip
FreeBSD-src-e867826c0224f87edbf44239bd842027cd13de79.tar.gz
Increase device CCB queue array size by CAM_RL_VALUES - 1 (4) elements.
It is required to store extra recovery requests in case of bus resets. On ATA/SATA this fixes assertion panics on HEAD with INVARIANTS enabled or possible memory corruptions otherwise if timeout/reset happens when device CCB queue is already full. Reported by: gibbs@ MFC after: 1 week
Diffstat (limited to 'sys/cam')
-rw-r--r--sys/cam/cam_queue.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/sys/cam/cam_queue.c b/sys/cam/cam_queue.c
index 3f4ffec..359e7f4 100644
--- a/sys/cam/cam_queue.c
+++ b/sys/cam/cam_queue.c
@@ -314,7 +314,8 @@ cam_ccbq_resize(struct cam_ccbq *ccbq, int new_size)
* same size once the outstanding entries have been processed.
*/
if (space_left < 0
- || camq_resize(&ccbq->queue, new_size) == CAM_REQ_CMP) {
+ || camq_resize(&ccbq->queue, new_size + (CAM_RL_VALUES - 1)) ==
+ CAM_REQ_CMP) {
ccbq->devq_openings += delta;
ccbq->dev_openings += delta;
return (CAM_REQ_CMP);
@@ -327,7 +328,7 @@ int
cam_ccbq_init(struct cam_ccbq *ccbq, int openings)
{
bzero(ccbq, sizeof(*ccbq));
- if (camq_init(&ccbq->queue, openings) != 0) {
+ if (camq_init(&ccbq->queue, openings + (CAM_RL_VALUES - 1)) != 0) {
return (1);
}
ccbq->devq_openings = openings;
OpenPOWER on IntegriCloud