goto out;
        }
 
+       /* If trace pipe files are being read, we can't change the tracer */
+       if (tr->current_trace->ref) {
+               ret = -EBUSY;
+               goto out;
+       }
+
        trace_branch_disable();
 
        tr->current_trace->enabled--;
                iter->trace->pipe_open(iter);
 
        nonseekable_open(inode, filp);
+
+       tr->current_trace->ref++;
 out:
        mutex_unlock(&trace_types_lock);
        return ret;
 
        mutex_lock(&trace_types_lock);
 
+       tr->current_trace->ref--;
+
        if (iter->trace->pipe_close)
                iter->trace->pipe_close(iter);
 
 
        filp->private_data = info;
 
+       tr->current_trace->ref++;
+
        mutex_unlock(&trace_types_lock);
 
        ret = nonseekable_open(inode, filp);
 
        mutex_lock(&trace_types_lock);
 
+       iter->tr->current_trace->ref--;
+
        __trace_array_put(iter->tr);
 
        if (info->spare)
                goto out_unlock;
 
        ret = -EBUSY;
-       if (tr->ref)
+       if (tr->ref || (tr->current_trace && tr->current_trace->ref))
                goto out_unlock;
 
        list_del(&tr->list);