Merge branch 'for-5.10-drm-sg-fix' of https://github.com/mszyprow/linux into drm-next
Please pull a set of fixes for various DRM drivers that finally resolve incorrect usage of the scatterlists (struct sg_table nents and orig_nents entries), what causes issues when IOMMU is used. Signed-off-by: Dave Airlie <airlied@redhat.com> From: Marek Szyprowski <m.szyprowski@samsung.com> Link: https://patchwork.freedesktop.org/patch/msgid/20200910080505.24456-1-m.szyprowski@samsung.com
This commit is contained in:
@@ -395,8 +395,8 @@ static void g2d_userptr_put_dma_addr(struct g2d_data *g2d,
|
||||
return;
|
||||
|
||||
out:
|
||||
dma_unmap_sg(to_dma_dev(g2d->drm_dev), g2d_userptr->sgt->sgl,
|
||||
g2d_userptr->sgt->nents, DMA_BIDIRECTIONAL);
|
||||
dma_unmap_sgtable(to_dma_dev(g2d->drm_dev), g2d_userptr->sgt,
|
||||
DMA_BIDIRECTIONAL, 0);
|
||||
|
||||
pages = frame_vector_pages(g2d_userptr->vec);
|
||||
if (!IS_ERR(pages)) {
|
||||
@@ -511,10 +511,10 @@ static dma_addr_t *g2d_userptr_get_dma_addr(struct g2d_data *g2d,
|
||||
|
||||
g2d_userptr->sgt = sgt;
|
||||
|
||||
if (!dma_map_sg(to_dma_dev(g2d->drm_dev), sgt->sgl, sgt->nents,
|
||||
DMA_BIDIRECTIONAL)) {
|
||||
ret = dma_map_sgtable(to_dma_dev(g2d->drm_dev), sgt,
|
||||
DMA_BIDIRECTIONAL, 0);
|
||||
if (ret) {
|
||||
DRM_DEV_ERROR(g2d->dev, "failed to map sgt with dma region.\n");
|
||||
ret = -ENOMEM;
|
||||
goto err_sg_free_table;
|
||||
}
|
||||
|
||||
|
@@ -431,27 +431,10 @@ exynos_drm_gem_prime_import_sg_table(struct drm_device *dev,
|
||||
{
|
||||
struct exynos_drm_gem *exynos_gem;
|
||||
|
||||
if (sgt->nents < 1)
|
||||
/* check if the entries in the sg_table are contiguous */
|
||||
if (drm_prime_get_contiguous_size(sgt) < attach->dmabuf->size) {
|
||||
DRM_ERROR("buffer chunks must be mapped contiguously");
|
||||
return ERR_PTR(-EINVAL);
|
||||
|
||||
/*
|
||||
* Check if the provided buffer has been mapped as contiguous
|
||||
* into DMA address space.
|
||||
*/
|
||||
if (sgt->nents > 1) {
|
||||
dma_addr_t next_addr = sg_dma_address(sgt->sgl);
|
||||
struct scatterlist *s;
|
||||
unsigned int i;
|
||||
|
||||
for_each_sg(sgt->sgl, s, sgt->nents, i) {
|
||||
if (!sg_dma_len(s))
|
||||
break;
|
||||
if (sg_dma_address(s) != next_addr) {
|
||||
DRM_ERROR("buffer chunks must be mapped contiguously");
|
||||
return ERR_PTR(-EINVAL);
|
||||
}
|
||||
next_addr = sg_dma_address(s) + sg_dma_len(s);
|
||||
}
|
||||
}
|
||||
|
||||
exynos_gem = exynos_drm_gem_init(dev, attach->dmabuf->size);
|
||||
|
Reference in New Issue
Block a user