aboutsummaryrefslogtreecommitdiff
path: root/sys/dev/pms
diff options
context:
space:
mode:
authorAlexander Motin <mav@FreeBSD.org>2021-04-16 19:16:09 +0000
committerMark Johnston <markj@FreeBSD.org>2021-05-26 19:37:18 +0000
commitbf30c74e5a2a3be431f16961c5ac1c9340e8e045 (patch)
tree1114ccf5c6abf6a87b31d833a7af6d366b258b7e /sys/dev/pms
parent71c7f71de5789daff5bc6dedba82544fa97eec84 (diff)
Diffstat (limited to 'sys/dev/pms')
-rw-r--r--sys/dev/pms/freebsd/driver/ini/src/agtiapi.c20
1 files changed, 11 insertions, 9 deletions
diff --git a/sys/dev/pms/freebsd/driver/ini/src/agtiapi.c b/sys/dev/pms/freebsd/driver/ini/src/agtiapi.c
index ef7dc19c05ce..535e60cb5bce 100644
--- a/sys/dev/pms/freebsd/driver/ini/src/agtiapi.c
+++ b/sys/dev/pms/freebsd/driver/ini/src/agtiapi.c
@@ -2628,9 +2628,11 @@ static void agtiapi_PrepareSGListCB( void *arg,
{
AGTIAPI_PRINTK("agtiapi_PrepareSGListCB: error status 0x%x\n", error);
bus_dmamap_unload(pmcsc->buffer_dmat, pccb->CCB_dmamap);
- bus_dmamap_destroy(pmcsc->buffer_dmat, pccb->CCB_dmamap);
agtiapi_FreeCCB(pmcsc, pccb);
- ccb->ccb_h.status = CAM_REQ_CMP;
+ if (error == EFBIG)
+ ccb->ccb_h.status = CAM_REQ_TOO_BIG;
+ else
+ ccb->ccb_h.status = CAM_REQ_CMP_ERR;
xpt_done(ccb);
return;
}
@@ -2642,9 +2644,8 @@ static void agtiapi_PrepareSGListCB( void *arg,
" AGTIAPI_MAX_DMA_SEGS %d\n",
nsegs, AGTIAPI_MAX_DMA_SEGS );
bus_dmamap_unload(pmcsc->buffer_dmat, pccb->CCB_dmamap);
- bus_dmamap_destroy(pmcsc->buffer_dmat, pccb->CCB_dmamap);
agtiapi_FreeCCB(pmcsc, pccb);
- ccb->ccb_h.status = CAM_REQ_CMP;
+ ccb->ccb_h.status = CAM_REQ_TOO_BIG;
xpt_done(ccb);
return;
}
@@ -3688,9 +3689,11 @@ static void agtiapi_PrepareSMPSGListCB( void *arg,
AGTIAPI_PRINTK( "agtiapi_PrepareSMPSGListCB: error status 0x%x\n",
error );
bus_dmamap_unload( pmcsc->buffer_dmat, pccb->CCB_dmamap );
- bus_dmamap_destroy( pmcsc->buffer_dmat, pccb->CCB_dmamap );
agtiapi_FreeCCB( pmcsc, pccb );
- ccb->ccb_h.status = CAM_REQ_CMP;
+ if (error == EFBIG)
+ ccb->ccb_h.status = CAM_REQ_TOO_BIG;
+ else
+ ccb->ccb_h.status = CAM_REQ_CMP_ERR;
xpt_done( ccb );
return;
}
@@ -3702,9 +3705,8 @@ static void agtiapi_PrepareSMPSGListCB( void *arg,
"AGTIAPI_MAX_DMA_SEGS %d\n",
nsegs, AGTIAPI_MAX_DMA_SEGS );
bus_dmamap_unload( pmcsc->buffer_dmat, pccb->CCB_dmamap );
- bus_dmamap_destroy( pmcsc->buffer_dmat, pccb->CCB_dmamap );
agtiapi_FreeCCB( pmcsc, pccb );
- ccb->ccb_h.status = CAM_REQ_CMP;
+ ccb->ccb_h.status = CAM_REQ_TOO_BIG;
xpt_done( ccb );
return;
}
@@ -4409,7 +4411,7 @@ static int agtiapi_QueueSMP(struct agtiapi_softc *pmcsc, union ccb * ccb)
if ((pccb = agtiapi_GetCCB(pmcsc)) == NULL)
{
AGTIAPI_PRINTK("agtiapi_QueueSMP: GetCCB ERROR\n");
- ccb->ccb_h.status = CAM_REQ_CMP;
+ ccb->ccb_h.status = CAM_REQ_CMP_ERR;
xpt_done(ccb);
return tiBusy;
}