From: "Steven Rostedt (Red Hat)" <[email protected]>

When reading from trace_pipe, if tracing is off but nothing was read
it should block. If something is read and tracing is off, then EOF
is returned. If tracing is on and there's nothing to read, it will block.

But because the check of whether tracing is off and something was read
is done after the block on the pipe, it is hit or miss if the EOF is
returned or not leading to inconsistent behavior.

Signed-off-by: Steven Rostedt <[email protected]>
---
 kernel/trace/trace.c | 18 +++++++++---------
 1 file changed, 9 insertions(+), 9 deletions(-)

diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
index cb41e98..e058c60 100644
--- a/kernel/trace/trace.c
+++ b/kernel/trace/trace.c
@@ -4237,15 +4237,6 @@ static int tracing_wait_pipe(struct file *filp)
                        return -EAGAIN;
                }
 
-               mutex_unlock(&iter->mutex);
-
-               iter->trace->wait_pipe(iter);
-
-               mutex_lock(&iter->mutex);
-
-               if (signal_pending(current))
-                       return -EINTR;
-
                /*
                 * We block until we read something and tracing is disabled.
                 * We still block if tracing is disabled, but we have never
@@ -4257,6 +4248,15 @@ static int tracing_wait_pipe(struct file *filp)
                 */
                if (!tracing_is_on() && iter->pos)
                        break;
+
+               mutex_unlock(&iter->mutex);
+
+               iter->trace->wait_pipe(iter);
+
+               mutex_lock(&iter->mutex);
+
+               if (signal_pending(current))
+                       return -EINTR;
        }
 
        return 1;
-- 
1.8.5.3


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to