Skip to content

Commit

Permalink
tracing: Make trace_marker{,_raw} stream-like
Browse files Browse the repository at this point in the history
The tracing marker files are write-only streams with no meaningful
concept of file position.  Using stream_open() to mark them as
stream-link indicates this and has the added advantage that a single
file descriptor can now be used from multiple threads without contention
thanks to clearing FMODE_ATOMIC_POS.

Note that this has the potential to break existing userspace by since
both lseek(2) and pwrite(2) will now return ESPIPE when previously lseek
would have updated the stored offset and pwrite would have appended to
the trace.  A survey of libtracefs and several other projects found to
use trace_marker(_raw) [1][2][3] suggests that everyone limits
themselves to calling write(2) and close(2) on these file descriptors so
there is a good chance this will go unnoticed and the benefits of
reduced overhead and lock contention seem worth the risk.

[1] https://github.com/google/perfetto
[2] https://github.com/intel/media-driver/
[3] https://w1.fi/cgit/hostap/

Link: https://lkml.kernel.org/r/[email protected]

Signed-off-by: John Keeping <[email protected]>
Signed-off-by: Steven Rostedt (VMware) <[email protected]>
  • Loading branch information
johnkeeping authored and rostedt committed Dec 8, 2021
1 parent a6ed2ae commit 2972e30
Showing 1 changed file with 8 additions and 10 deletions.
18 changes: 8 additions & 10 deletions kernel/trace/trace.c
Original file line number Diff line number Diff line change
Expand Up @@ -4841,6 +4841,12 @@ int tracing_open_generic_tr(struct inode *inode, struct file *filp)
return 0;
}

static int tracing_mark_open(struct inode *inode, struct file *filp)
{
stream_open(inode, filp);
return tracing_open_generic_tr(inode, filp);
}

static int tracing_release(struct inode *inode, struct file *file)
{
struct trace_array *tr = inode->i_private;
Expand Down Expand Up @@ -7117,9 +7123,6 @@ tracing_mark_write(struct file *filp, const char __user *ubuf,
if (tt)
event_triggers_post_call(tr->trace_marker_file, tt);

if (written > 0)
*fpos += written;

return written;
}

Expand Down Expand Up @@ -7178,9 +7181,6 @@ tracing_mark_raw_write(struct file *filp, const char __user *ubuf,

__buffer_unlock_commit(buffer, event);

if (written > 0)
*fpos += written;

return written;
}

Expand Down Expand Up @@ -7580,16 +7580,14 @@ static const struct file_operations tracing_free_buffer_fops = {
};

static const struct file_operations tracing_mark_fops = {
.open = tracing_open_generic_tr,
.open = tracing_mark_open,
.write = tracing_mark_write,
.llseek = generic_file_llseek,
.release = tracing_release_generic_tr,
};

static const struct file_operations tracing_mark_raw_fops = {
.open = tracing_open_generic_tr,
.open = tracing_mark_open,
.write = tracing_mark_raw_write,
.llseek = generic_file_llseek,
.release = tracing_release_generic_tr,
};

Expand Down

0 comments on commit 2972e30

Please sign in to comment.