aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/isci/request.c
diff options
context:
space:
mode:
authorDan Williams <dan.j.williams@intel.com>2011-06-17 13:40:43 -0400
committerDan Williams <dan.j.williams@intel.com>2011-07-03 07:04:51 -0400
commitddcc7e347a891937be65358b43f40b7f81185f8f (patch)
tree35492d904678bb36560efa05dd1a474e9ee78b36 /drivers/scsi/isci/request.c
parent5edc33480c1c363ab361a881f2957b9fba5185cf (diff)
isci: fix dma_unmap_sg usage
One bug and a cleanup: 1/ Fix cases where we were unmapping invalid addresses (smp requests were being unmapped) [ 604.662770] ------------[ cut here ]------------ [ 604.668026] WARNING: at lib/dma-debug.c:800 check_unmap+0x418/0x740() [ 604.675315] Hardware name: SandyBridge Platform [ 604.680465] isci 0000:03:00.0: DMA-API: device driver tries to free an invalid DMA memory address 2/ The unmap routine is too large to be an inline function, and isci_request_io_request_get_next_sge is unused. Signed-off-by: Dan Williams <dan.j.williams@intel.com>
Diffstat (limited to 'drivers/scsi/isci/request.c')
-rw-r--r--drivers/scsi/isci/request.c17
1 files changed, 16 insertions, 1 deletions
diff --git a/drivers/scsi/isci/request.c b/drivers/scsi/isci/request.c
index f4fbca7b1fa3..395084955150 100644
--- a/drivers/scsi/isci/request.c
+++ b/drivers/scsi/isci/request.c
@@ -2930,7 +2930,22 @@ static void isci_request_io_request_complete(struct isci_host *isci_host,
2930 break; 2930 break;
2931 } 2931 }
2932 2932
2933 isci_request_unmap_sgl(request, isci_host->pdev); 2933 switch (task->task_proto) {
2934 case SAS_PROTOCOL_SSP:
2935 if (task->data_dir == DMA_NONE)
2936 break;
2937 if (task->num_scatter == 0)
2938 /* 0 indicates a single dma address */
2939 dma_unmap_single(&isci_host->pdev->dev,
2940 request->zero_scatter_daddr,
2941 task->total_xfer_len, task->data_dir);
2942 else /* unmap the sgl dma addresses */
2943 dma_unmap_sg(&isci_host->pdev->dev, task->scatter,
2944 request->num_sg_entries, task->data_dir);
2945 break;
2946 default:
2947 break;
2948 }
2934 2949
2935 /* Put the completed request on the correct list */ 2950 /* Put the completed request on the correct list */
2936 isci_task_save_for_upper_layer_completion(isci_host, request, response, 2951 isci_task_save_for_upper_layer_completion(isci_host, request, response,