提交 681066ec 编写于 作者: C Christian König 提交者: Alex Deucher

drm/prime: fix potential race in drm_gem_map_detach

Unpin the GEM object only after freeing the sg table.
Signed-off-by: NChristian König <christian.koenig@amd.com>
Reviewed-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
Acked-by: NRoger He <Hongbo.He@amd.com>
Signed-off-by: NAlex Deucher <alexander.deucher@amd.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20180227115000.4105-1-christian.koenig@amd.com
上级 5ebbb5b4
...@@ -230,18 +230,14 @@ void drm_gem_map_detach(struct dma_buf *dma_buf, ...@@ -230,18 +230,14 @@ void drm_gem_map_detach(struct dma_buf *dma_buf,
struct drm_prime_attachment *prime_attach = attach->priv; struct drm_prime_attachment *prime_attach = attach->priv;
struct drm_gem_object *obj = dma_buf->priv; struct drm_gem_object *obj = dma_buf->priv;
struct drm_device *dev = obj->dev; struct drm_device *dev = obj->dev;
struct sg_table *sgt;
if (dev->driver->gem_prime_unpin) if (prime_attach) {
dev->driver->gem_prime_unpin(obj); struct sg_table *sgt = prime_attach->sgt;
if (!prime_attach)
return;
sgt = prime_attach->sgt;
if (sgt) { if (sgt) {
if (prime_attach->dir != DMA_NONE) if (prime_attach->dir != DMA_NONE)
dma_unmap_sg_attrs(attach->dev, sgt->sgl, sgt->nents, dma_unmap_sg_attrs(attach->dev, sgt->sgl,
sgt->nents,
prime_attach->dir, prime_attach->dir,
DMA_ATTR_SKIP_CPU_SYNC); DMA_ATTR_SKIP_CPU_SYNC);
sg_free_table(sgt); sg_free_table(sgt);
...@@ -250,6 +246,10 @@ void drm_gem_map_detach(struct dma_buf *dma_buf, ...@@ -250,6 +246,10 @@ void drm_gem_map_detach(struct dma_buf *dma_buf,
kfree(sgt); kfree(sgt);
kfree(prime_attach); kfree(prime_attach);
attach->priv = NULL; attach->priv = NULL;
}
if (dev->driver->gem_prime_unpin)
dev->driver->gem_prime_unpin(obj);
} }
EXPORT_SYMBOL(drm_gem_map_detach); EXPORT_SYMBOL(drm_gem_map_detach);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册