Merge branch 'tracing-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip

* 'tracing-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip:
  tracing: Remove cpu arg from the rb_time_stamp() function
  tracing: Fix comment typo and documentation example
  tracing: Fix trace_seq_printf() return value
  tracing: Update *ppos instead of filp->f_pos
This commit is contained in:
Linus Torvalds 2009-11-02 09:45:44 -08:00
commit a5e3013d66
6 changed files with 18 additions and 13 deletions

View File

@ -1231,6 +1231,7 @@ something like this simple program:
#include <sys/stat.h> #include <sys/stat.h>
#include <fcntl.h> #include <fcntl.h>
#include <unistd.h> #include <unistd.h>
#include <string.h>
#define _STR(x) #x #define _STR(x) #x
#define STR(x) _STR(x) #define STR(x) _STR(x)
@ -1265,6 +1266,7 @@ const char *find_debugfs(void)
return NULL; return NULL;
} }
strcat(debugfs, "/tracing/");
debugfs_found = 1; debugfs_found = 1;
return debugfs; return debugfs;

View File

@ -7,7 +7,7 @@
/* /*
* Trace sequences are used to allow a function to call several other functions * Trace sequences are used to allow a function to call several other functions
* to create a string of data to use (up to a max of PAGE_SIZE. * to create a string of data to use (up to a max of PAGE_SIZE).
*/ */
struct trace_seq { struct trace_seq {

View File

@ -740,7 +740,7 @@ ftrace_profile_write(struct file *filp, const char __user *ubuf,
out: out:
mutex_unlock(&ftrace_profile_lock); mutex_unlock(&ftrace_profile_lock);
filp->f_pos += cnt; *ppos += cnt;
return cnt; return cnt;
} }

View File

@ -483,7 +483,7 @@ struct ring_buffer_iter {
/* Up this if you want to test the TIME_EXTENTS and normalization */ /* Up this if you want to test the TIME_EXTENTS and normalization */
#define DEBUG_SHIFT 0 #define DEBUG_SHIFT 0
static inline u64 rb_time_stamp(struct ring_buffer *buffer, int cpu) static inline u64 rb_time_stamp(struct ring_buffer *buffer)
{ {
/* shift to debug/test normalization and TIME_EXTENTS */ /* shift to debug/test normalization and TIME_EXTENTS */
return buffer->clock() << DEBUG_SHIFT; return buffer->clock() << DEBUG_SHIFT;
@ -494,7 +494,7 @@ u64 ring_buffer_time_stamp(struct ring_buffer *buffer, int cpu)
u64 time; u64 time;
preempt_disable_notrace(); preempt_disable_notrace();
time = rb_time_stamp(buffer, cpu); time = rb_time_stamp(buffer);
preempt_enable_no_resched_notrace(); preempt_enable_no_resched_notrace();
return time; return time;
@ -599,7 +599,7 @@ static struct list_head *rb_list_head(struct list_head *list)
} }
/* /*
* rb_is_head_page - test if the give page is the head page * rb_is_head_page - test if the given page is the head page
* *
* Because the reader may move the head_page pointer, we can * Because the reader may move the head_page pointer, we can
* not trust what the head page is (it may be pointing to * not trust what the head page is (it may be pointing to
@ -1868,7 +1868,7 @@ rb_move_tail(struct ring_buffer_per_cpu *cpu_buffer,
* Nested commits always have zero deltas, so * Nested commits always have zero deltas, so
* just reread the time stamp * just reread the time stamp
*/ */
*ts = rb_time_stamp(buffer, cpu_buffer->cpu); *ts = rb_time_stamp(buffer);
next_page->page->time_stamp = *ts; next_page->page->time_stamp = *ts;
} }
@ -2111,7 +2111,7 @@ rb_reserve_next_event(struct ring_buffer *buffer,
if (RB_WARN_ON(cpu_buffer, ++nr_loops > 1000)) if (RB_WARN_ON(cpu_buffer, ++nr_loops > 1000))
goto out_fail; goto out_fail;
ts = rb_time_stamp(cpu_buffer->buffer, cpu_buffer->cpu); ts = rb_time_stamp(cpu_buffer->buffer);
/* /*
* Only the first commit can update the timestamp. * Only the first commit can update the timestamp.
@ -2681,7 +2681,7 @@ unsigned long ring_buffer_entries(struct ring_buffer *buffer)
EXPORT_SYMBOL_GPL(ring_buffer_entries); EXPORT_SYMBOL_GPL(ring_buffer_entries);
/** /**
* ring_buffer_overrun_cpu - get the number of overruns in buffer * ring_buffer_overruns - get the number of overruns in buffer
* @buffer: The ring buffer * @buffer: The ring buffer
* *
* Returns the total number of overruns in the ring buffer * Returns the total number of overruns in the ring buffer

View File

@ -2440,7 +2440,7 @@ tracing_trace_options_write(struct file *filp, const char __user *ubuf,
return ret; return ret;
} }
filp->f_pos += cnt; *ppos += cnt;
return cnt; return cnt;
} }
@ -2582,7 +2582,7 @@ tracing_ctrl_write(struct file *filp, const char __user *ubuf,
} }
mutex_unlock(&trace_types_lock); mutex_unlock(&trace_types_lock);
filp->f_pos += cnt; *ppos += cnt;
return cnt; return cnt;
} }
@ -2764,7 +2764,7 @@ tracing_set_trace_write(struct file *filp, const char __user *ubuf,
if (err) if (err)
return err; return err;
filp->f_pos += ret; *ppos += ret;
return ret; return ret;
} }
@ -3299,7 +3299,7 @@ tracing_entries_write(struct file *filp, const char __user *ubuf,
} }
} }
filp->f_pos += cnt; *ppos += cnt;
/* If check pages failed, return ENOMEM */ /* If check pages failed, return ENOMEM */
if (tracing_disabled) if (tracing_disabled)

View File

@ -69,6 +69,9 @@ enum print_line_t trace_print_printk_msg_only(struct trace_iterator *iter)
* @s: trace sequence descriptor * @s: trace sequence descriptor
* @fmt: printf format string * @fmt: printf format string
* *
* It returns 0 if the trace oversizes the buffer's free
* space, 1 otherwise.
*
* The tracer may use either sequence operations or its own * The tracer may use either sequence operations or its own
* copy to user routines. To simplify formating of a trace * copy to user routines. To simplify formating of a trace
* trace_seq_printf is used to store strings into a special * trace_seq_printf is used to store strings into a special
@ -95,7 +98,7 @@ trace_seq_printf(struct trace_seq *s, const char *fmt, ...)
s->len += ret; s->len += ret;
return len; return 1;
} }
EXPORT_SYMBOL_GPL(trace_seq_printf); EXPORT_SYMBOL_GPL(trace_seq_printf);