diff options
author | James Bottomley <JBottomley@Parallels.com> | 2011-09-18 16:56:20 +0200 |
---|---|---|
committer | James Bottomley <JBottomley@Parallels.com> | 2011-09-26 16:28:58 +0200 |
commit | 96067723e46b0dd24ae7b934085ab4eff4d26a1b (patch) | |
tree | 5c0e448201766cc3459c4958064275e2564a43e9 /drivers/scsi | |
parent | [SCSI] cxgb3i: convert cdev->l2opt to use rcu to prevent NULL dereference (diff) | |
download | linux-96067723e46b0dd24ae7b934085ab4eff4d26a1b.tar.xz linux-96067723e46b0dd24ae7b934085ab4eff4d26a1b.zip |
[SCSI] 3w-9xxx: fix iommu_iova leak
Following reports on the list, it looks like the 3e-9xxx driver will leak dma
mappings every time we get a transient queueing error back from the card.
This is because it maps the sg list in the routine that sends the command, but
doesn't unmap again in the transient failure path (even though the command is
sent back to the block layer). Fix by unmapping before returning the status.
Reported-by: Chris Boot <bootc@bootc.net>
Tested-by: Chris Boot <bootc@bootc.net>
Acked-by: Adam Radford <aradford@gmail.com>
Cc: stable@kernel.org
Signed-off-by: James Bottomley <JBottomley@Parallels.com>
Diffstat (limited to 'drivers/scsi')
-rw-r--r-- | drivers/scsi/3w-9xxx.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/scsi/3w-9xxx.c b/drivers/scsi/3w-9xxx.c index b7bd5b0cc7aa..3868ab2397c6 100644 --- a/drivers/scsi/3w-9xxx.c +++ b/drivers/scsi/3w-9xxx.c @@ -1800,10 +1800,12 @@ static int twa_scsi_queue_lck(struct scsi_cmnd *SCpnt, void (*done)(struct scsi_ switch (retval) { case SCSI_MLQUEUE_HOST_BUSY: twa_free_request_id(tw_dev, request_id); + twa_unmap_scsi_data(tw_dev, request_id); break; case 1: tw_dev->state[request_id] = TW_S_COMPLETED; twa_free_request_id(tw_dev, request_id); + twa_unmap_scsi_data(tw_dev, request_id); SCpnt->result = (DID_ERROR << 16); done(SCpnt); retval = 0; |