|
@@ -1085,13 +1085,13 @@ update_max_tr_single(struct trace_array *tr, struct task_struct *tsk, int cpu)
|
|
|
}
|
|
|
#endif /* CONFIG_TRACER_MAX_TRACE */
|
|
|
|
|
|
-static void wait_on_pipe(struct trace_iterator *iter)
|
|
|
+static int wait_on_pipe(struct trace_iterator *iter)
|
|
|
{
|
|
|
/* Iterators are static, they should be filled or empty */
|
|
|
if (trace_buffer_iter(iter, iter->cpu_file))
|
|
|
- return;
|
|
|
+ return 0;
|
|
|
|
|
|
- ring_buffer_wait(iter->trace_buffer->buffer, iter->cpu_file);
|
|
|
+ return ring_buffer_wait(iter->trace_buffer->buffer, iter->cpu_file);
|
|
|
}
|
|
|
|
|
|
#ifdef CONFIG_FTRACE_STARTUP_TEST
|
|
@@ -4378,6 +4378,7 @@ tracing_poll_pipe(struct file *filp, poll_table *poll_table)
|
|
|
static int tracing_wait_pipe(struct file *filp)
|
|
|
{
|
|
|
struct trace_iterator *iter = filp->private_data;
|
|
|
+ int ret;
|
|
|
|
|
|
while (trace_empty(iter)) {
|
|
|
|
|
@@ -4399,10 +4400,13 @@ static int tracing_wait_pipe(struct file *filp)
|
|
|
|
|
|
mutex_unlock(&iter->mutex);
|
|
|
|
|
|
- wait_on_pipe(iter);
|
|
|
+ ret = wait_on_pipe(iter);
|
|
|
|
|
|
mutex_lock(&iter->mutex);
|
|
|
|
|
|
+ if (ret)
|
|
|
+ return ret;
|
|
|
+
|
|
|
if (signal_pending(current))
|
|
|
return -EINTR;
|
|
|
}
|
|
@@ -5327,8 +5331,12 @@ tracing_buffers_read(struct file *filp, char __user *ubuf,
|
|
|
goto out_unlock;
|
|
|
}
|
|
|
mutex_unlock(&trace_types_lock);
|
|
|
- wait_on_pipe(iter);
|
|
|
+ ret = wait_on_pipe(iter);
|
|
|
mutex_lock(&trace_types_lock);
|
|
|
+ if (ret) {
|
|
|
+ size = ret;
|
|
|
+ goto out_unlock;
|
|
|
+ }
|
|
|
if (signal_pending(current)) {
|
|
|
size = -EINTR;
|
|
|
goto out_unlock;
|
|
@@ -5538,8 +5546,10 @@ tracing_buffers_splice_read(struct file *file, loff_t *ppos,
|
|
|
goto out;
|
|
|
}
|
|
|
mutex_unlock(&trace_types_lock);
|
|
|
- wait_on_pipe(iter);
|
|
|
+ ret = wait_on_pipe(iter);
|
|
|
mutex_lock(&trace_types_lock);
|
|
|
+ if (ret)
|
|
|
+ goto out;
|
|
|
if (signal_pending(current)) {
|
|
|
ret = -EINTR;
|
|
|
goto out;
|