Commit f4874261 authored by Steven Rostedt (Red Hat)'s avatar Steven Rostedt (Red Hat) Committed by Steven Rostedt

tracing: Break out of tracing_wait_pipe() before wait_pipe() is called

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: default avatarSteven Rostedt <rostedt@goodmis.org>
parent 8d1b065d
...@@ -4237,15 +4237,6 @@ static int tracing_wait_pipe(struct file *filp) ...@@ -4237,15 +4237,6 @@ static int tracing_wait_pipe(struct file *filp)
return -EAGAIN; 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 block until we read something and tracing is disabled.
* We still block if tracing is disabled, but we have never * We still block if tracing is disabled, but we have never
...@@ -4257,6 +4248,15 @@ static int tracing_wait_pipe(struct file *filp) ...@@ -4257,6 +4248,15 @@ static int tracing_wait_pipe(struct file *filp)
*/ */
if (!tracing_is_on() && iter->pos) if (!tracing_is_on() && iter->pos)
break; break;
mutex_unlock(&iter->mutex);
iter->trace->wait_pipe(iter);
mutex_lock(&iter->mutex);
if (signal_pending(current))
return -EINTR;
} }
return 1; return 1;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment