Commit 50c382e8 authored by Jerry Snitselaar's avatar Jerry Snitselaar Committed by Greg Kroah-Hartman

iommu/amd: Unmap all mapped pages in error path of map_sg

[ Upstream commit f1724c08 ]

In the error path of map_sg there is an incorrect if condition
for breaking out of the loop that searches the scatterlist
for mapped pages to unmap. Instead of breaking out of the
loop once all the pages that were mapped have been unmapped,
it will break out of the loop after it has unmapped 1 page.
Fix the condition, so it breaks out of the loop only after
all the mapped pages have been unmapped.

Fixes: 80187fd3 ("iommu/amd: Optimize map_sg and unmap_sg")
Cc: Joerg Roedel <joro@8bytes.org>
Signed-off-by: default avatarJerry Snitselaar <jsnitsel@redhat.com>
Signed-off-by: default avatarJoerg Roedel <jroedel@suse.de>
Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
parent 8a6c9f65
...@@ -2611,7 +2611,7 @@ static int map_sg(struct device *dev, struct scatterlist *sglist, ...@@ -2611,7 +2611,7 @@ static int map_sg(struct device *dev, struct scatterlist *sglist,
bus_addr = address + s->dma_address + (j << PAGE_SHIFT); bus_addr = address + s->dma_address + (j << PAGE_SHIFT);
iommu_unmap_page(domain, bus_addr, PAGE_SIZE); iommu_unmap_page(domain, bus_addr, PAGE_SIZE);
if (--mapped_pages) if (--mapped_pages == 0)
goto out_free_iova; goto out_free_iova;
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment