summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/msm/msm_rd.c
diff options
context:
space:
mode:
authorStefan Agner <stefan@agner.ch>2019-03-07 10:22:26 +0100
committerStefan Agner <stefan@agner.ch>2019-03-07 10:22:26 +0100
commit8ccc4bfd08f1f8c5da48084c66ff46022d9db273 (patch)
treed4d37535f4529db914d4da6f9f366d3bbd908a0c /drivers/gpu/drm/msm/msm_rd.c
parentf8cf7c18863f584e45132c5c7732a945bf0e2249 (diff)
parentbc3041f2385d60dd8ee665becd8a51ab872b2a8c (diff)
Merge tag 'v4.20.14' into toradex_4.20.y
This is the 4.20.14 stable release
Diffstat (limited to 'drivers/gpu/drm/msm/msm_rd.c')
-rw-r--r--drivers/gpu/drm/msm/msm_rd.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/drivers/gpu/drm/msm/msm_rd.c b/drivers/gpu/drm/msm/msm_rd.c
index 0c2c8d2c631f..25fc161ab618 100644
--- a/drivers/gpu/drm/msm/msm_rd.c
+++ b/drivers/gpu/drm/msm/msm_rd.c
@@ -115,7 +115,9 @@ static void rd_write(struct msm_rd_state *rd, const void *buf, int sz)
char *fptr = &fifo->buf[fifo->head];
int n;
- wait_event(rd->fifo_event, circ_space(&rd->fifo) > 0);
+ wait_event(rd->fifo_event, circ_space(&rd->fifo) > 0 || !rd->open);
+ if (!rd->open)
+ return;
/* Note that smp_load_acquire() is not strictly required
* as CIRC_SPACE_TO_END() does not access the tail more
@@ -213,7 +215,10 @@ out:
static int rd_release(struct inode *inode, struct file *file)
{
struct msm_rd_state *rd = inode->i_private;
+
rd->open = false;
+ wake_up_all(&rd->fifo_event);
+
return 0;
}