提交 66cf402b 编写于 作者: O Ohad Ben-Cohen

omap: iovmm: s/sg_dma_len(sg)/sg->length/

iovmm is erroneously using sg_dma_len with unmapped (DMA API-wise)
SG entries, and will break if CONFIG_NEED_SG_DMA_LENGTH is enabled.

Fix that by using sg->length instead.
Reported-by: NRussell King <linux@arm.linux.org.uk>
Tested-by: NLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: NOhad Ben-Cohen <ohad@wizery.com>
上级 7e20b6f3
...@@ -72,7 +72,7 @@ static size_t sgtable_len(const struct sg_table *sgt) ...@@ -72,7 +72,7 @@ static size_t sgtable_len(const struct sg_table *sgt)
for_each_sg(sgt->sgl, sg, sgt->nents, i) { for_each_sg(sgt->sgl, sg, sgt->nents, i) {
size_t bytes; size_t bytes;
bytes = sg_dma_len(sg); bytes = sg->length;
if (!iopgsz_ok(bytes)) { if (!iopgsz_ok(bytes)) {
pr_err("%s: sg[%d] not iommu pagesize(%x)\n", pr_err("%s: sg[%d] not iommu pagesize(%x)\n",
...@@ -198,7 +198,7 @@ static void *vmap_sg(const struct sg_table *sgt) ...@@ -198,7 +198,7 @@ static void *vmap_sg(const struct sg_table *sgt)
int err; int err;
pa = sg_phys(sg); pa = sg_phys(sg);
bytes = sg_dma_len(sg); bytes = sg->length;
BUG_ON(bytes != PAGE_SIZE); BUG_ON(bytes != PAGE_SIZE);
...@@ -476,7 +476,7 @@ static int map_iovm_area(struct iommu *obj, struct iovm_struct *new, ...@@ -476,7 +476,7 @@ static int map_iovm_area(struct iommu *obj, struct iovm_struct *new,
struct iotlb_entry e; struct iotlb_entry e;
pa = sg_phys(sg); pa = sg_phys(sg);
bytes = sg_dma_len(sg); bytes = sg->length;
flags &= ~IOVMF_PGSZ_MASK; flags &= ~IOVMF_PGSZ_MASK;
pgsz = bytes_to_iopgsz(bytes); pgsz = bytes_to_iopgsz(bytes);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册