Skip to content

Commit

Permalink
dma-direct: fix DMA_ATTR_NO_KERNEL_MAPPING for remapped allocations
Browse files Browse the repository at this point in the history
We need to return a dma_addr_t even if we don't have a kernel mapping.
Do so by consolidating the phys_to_dma call in a single place and jump
to it from all the branches that return successfully.

Fixes: bfd56cd ("dma-mapping: support highmem in the generic remap allocator")
Reported-by: Liviu Dudau <liviu@dudau.co.uk
Signed-off-by: Christoph Hellwig <hch@lst.de>
Tested-by: Liviu Dudau <liviu@dudau.co.uk>
  • Loading branch information
Christoph Hellwig committed Jan 5, 2019
1 parent 06f55fd commit 8270f3a
Showing 1 changed file with 7 additions and 6 deletions.
13 changes: 7 additions & 6 deletions kernel/dma/remap.c
Original file line number Diff line number Diff line change
Expand Up @@ -204,8 +204,7 @@ void *arch_dma_alloc(struct device *dev, size_t size, dma_addr_t *dma_handle,
ret = dma_alloc_from_pool(size, &page, flags);
if (!ret)
return NULL;
*dma_handle = phys_to_dma(dev, page_to_phys(page));
return ret;
goto done;
}

page = __dma_direct_alloc_pages(dev, size, dma_handle, flags, attrs);
Expand All @@ -215,8 +214,10 @@ void *arch_dma_alloc(struct device *dev, size_t size, dma_addr_t *dma_handle,
/* remove any dirty cache lines on the kernel alias */
arch_dma_prep_coherent(page, size);

if (attrs & DMA_ATTR_NO_KERNEL_MAPPING)
return page; /* opaque cookie */
if (attrs & DMA_ATTR_NO_KERNEL_MAPPING) {
ret = page; /* opaque cookie */
goto done;
}

/* create a coherent mapping */
ret = dma_common_contiguous_remap(page, size, VM_USERMAP,
Expand All @@ -227,9 +228,9 @@ void *arch_dma_alloc(struct device *dev, size_t size, dma_addr_t *dma_handle,
return ret;
}

*dma_handle = phys_to_dma(dev, page_to_phys(page));
memset(ret, 0, size);

done:
*dma_handle = phys_to_dma(dev, page_to_phys(page));
return ret;
}

Expand Down

0 comments on commit 8270f3a

Please sign in to comment.