summaryrefslogtreecommitdiff
path: root/drivers
diff options
context:
space:
mode:
authorAndrzej Hajda <a.hajda@samsung.com>2014-08-28 11:07:27 +0200
committerChanho Park <chanho61.park@samsung.com>2014-11-18 12:00:45 +0900
commit75a9825a211d179812d43e17be09b5b9e4ddacbf (patch)
tree8c6d735dc295d5d52a893192e968bbafb2032a51 /drivers
parentc4ddd512d116c53ac7fe2138a2bf0322a2eaa555 (diff)
downloadlinux-3.10-75a9825a211d179812d43e17be09b5b9e4ddacbf.tar.gz
linux-3.10-75a9825a211d179812d43e17be09b5b9e4ddacbf.tar.bz2
linux-3.10-75a9825a211d179812d43e17be09b5b9e4ddacbf.zip
drm/exynos/ipp: move file reference from memory to command node
Command node should contain file reference to distinguish commands created by different processes. Change-Id: I98938d16d323a5f83614ae87c84485f8fa4efc69 Signed-off-by: Andrzej Hajda <a.hajda@samsung.com> Reviewed-by: Joonyoung Shim <jy0922.shim@samsung.com> Signed-off-by: Inki Dae <inki.dae@samsung.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/gpu/drm/exynos/exynos_drm_ipp.c5
-rw-r--r--drivers/gpu/drm/exynos/exynos_drm_ipp.h2
2 files changed, 4 insertions, 3 deletions
diff --git a/drivers/gpu/drm/exynos/exynos_drm_ipp.c b/drivers/gpu/drm/exynos/exynos_drm_ipp.c
index 6eec2c9f8da..0915d80277e 100644
--- a/drivers/gpu/drm/exynos/exynos_drm_ipp.c
+++ b/drivers/gpu/drm/exynos/exynos_drm_ipp.c
@@ -76,7 +76,6 @@ struct drm_exynos_ipp_mem_node {
u32 prop_id;
u32 buf_id;
struct drm_exynos_ipp_buf_info buf_info;
- struct drm_file *filp;
};
/*
@@ -498,6 +497,7 @@ int exynos_drm_ipp_set_property(struct drm_device *drm_dev, void *data,
c_node->priv = priv;
c_node->property = *property;
c_node->state = IPP_STATE_IDLE;
+ c_node->filp = file;
c_node->start_work = ipp_create_cmd_work();
if (IS_ERR(c_node->start_work)) {
@@ -744,7 +744,6 @@ static struct drm_exynos_ipp_mem_node
}
}
- m_node->filp = file;
m_node->buf_info = buf_info;
list_add_tail(&m_node->list, &c_node->mem_list[qbuf->ops_id]);
@@ -785,7 +784,7 @@ static int ipp_put_mem_node(struct drm_device *drm_dev,
unsigned long handle = m_node->buf_info.handles[i];
if (handle)
exynos_drm_gem_put_dma_addr(drm_dev, handle,
- m_node->filp);
+ c_node->filp);
}
/* delete list in queue */
diff --git a/drivers/gpu/drm/exynos/exynos_drm_ipp.h b/drivers/gpu/drm/exynos/exynos_drm_ipp.h
index 84e2b3aa634..ad15f287c31 100644
--- a/drivers/gpu/drm/exynos/exynos_drm_ipp.h
+++ b/drivers/gpu/drm/exynos/exynos_drm_ipp.h
@@ -58,6 +58,7 @@ struct drm_exynos_ipp_cmd_work {
* @stop_work: stop command work structure.
* @event_work: event work structure.
* @state: state of command node.
+ * @filp: associated file pointer.
*/
struct drm_exynos_ipp_cmd_node {
struct exynos_drm_ipp_private *priv;
@@ -74,6 +75,7 @@ struct drm_exynos_ipp_cmd_node {
struct drm_exynos_ipp_cmd_work *stop_work;
struct drm_exynos_ipp_event_work *event_work;
enum drm_exynos_ipp_state state;
+ struct drm_file *filp;
};
/*