2020-05-27 13:12:04 +00:00
|
|
|
From 118802c75e04a2f1b94245695076d2506f667ae7 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Gurchetan Singh <gurchetansingh@chromium.org>
|
|
|
|
Date: Mon, 2 Dec 2019 17:36:26 -0800
|
|
|
|
Subject: [PATCH] udmabuf: separate out creating/destroying
|
|
|
|
scatter-table
|
|
|
|
|
|
|
|
Commit 17a7ce203490459cff14fb1c8f9a15d65fd1c544 upstream.
|
|
|
|
|
|
|
|
These are nice functions and can be re-used.
|
|
|
|
|
|
|
|
Signed-off-by: Gurchetan Singh <gurchetansingh@chromium.org>
|
|
|
|
Link: http://patchwork.freedesktop.org/patch/msgid/20191203013627.85991-3-gurchetansingh@chromium.org
|
|
|
|
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
|
|
|
|
---
|
|
|
|
drivers/dma-buf/udmabuf.c | 26 +++++++++++++++++++-------
|
|
|
|
1 file changed, 19 insertions(+), 7 deletions(-)
|
|
|
|
|
|
|
|
--- a/drivers/dma-buf/udmabuf.c
|
|
|
|
+++ b/drivers/dma-buf/udmabuf.c
|
2022-07-03 16:46:35 +00:00
|
|
|
@@ -50,10 +50,10 @@ static int mmap_udmabuf(struct dma_buf *
|
2020-05-27 13:12:04 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
-static struct sg_table *map_udmabuf(struct dma_buf_attachment *at,
|
|
|
|
- enum dma_data_direction direction)
|
|
|
|
+static struct sg_table *get_sg_table(struct device *dev, struct dma_buf *buf,
|
|
|
|
+ enum dma_data_direction direction)
|
|
|
|
{
|
|
|
|
- struct udmabuf *ubuf = at->dmabuf->priv;
|
|
|
|
+ struct udmabuf *ubuf = buf->priv;
|
|
|
|
struct sg_table *sg;
|
|
|
|
int ret;
|
|
|
|
|
2022-07-03 16:46:35 +00:00
|
|
|
@@ -65,7 +65,7 @@ static struct sg_table *map_udmabuf(stru
|
2020-05-27 13:12:04 +00:00
|
|
|
GFP_KERNEL);
|
|
|
|
if (ret < 0)
|
|
|
|
goto err;
|
|
|
|
- if (!dma_map_sg(at->dev, sg->sgl, sg->nents, direction)) {
|
|
|
|
+ if (!dma_map_sg(dev, sg->sgl, sg->nents, direction)) {
|
|
|
|
ret = -EINVAL;
|
|
|
|
goto err;
|
|
|
|
}
|
2022-07-03 16:46:35 +00:00
|
|
|
@@ -77,13 +77,25 @@ err:
|
2020-05-27 13:12:04 +00:00
|
|
|
return ERR_PTR(ret);
|
|
|
|
}
|
|
|
|
|
|
|
|
+static void put_sg_table(struct device *dev, struct sg_table *sg,
|
|
|
|
+ enum dma_data_direction direction)
|
|
|
|
+{
|
|
|
|
+ dma_unmap_sg(dev, sg->sgl, sg->nents, direction);
|
|
|
|
+ sg_free_table(sg);
|
|
|
|
+ kfree(sg);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static struct sg_table *map_udmabuf(struct dma_buf_attachment *at,
|
|
|
|
+ enum dma_data_direction direction)
|
|
|
|
+{
|
|
|
|
+ return get_sg_table(at->dev, at->dmabuf, direction);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
static void unmap_udmabuf(struct dma_buf_attachment *at,
|
|
|
|
struct sg_table *sg,
|
|
|
|
enum dma_data_direction direction)
|
|
|
|
{
|
|
|
|
- dma_unmap_sg(at->dev, sg->sgl, sg->nents, direction);
|
|
|
|
- sg_free_table(sg);
|
|
|
|
- kfree(sg);
|
|
|
|
+ return put_sg_table(at->dev, sg, direction);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void release_udmabuf(struct dma_buf *buf)
|