Merge branch 'tracing/urgent' into tracing/ftrace
This commit is contained in:
Коммит
86665c75da
|
@ -20,7 +20,6 @@
|
||||||
|
|
||||||
#include <asm/cacheflush.h>
|
#include <asm/cacheflush.h>
|
||||||
#include <asm/ftrace.h>
|
#include <asm/ftrace.h>
|
||||||
#include <linux/ftrace.h>
|
|
||||||
#include <asm/nops.h>
|
#include <asm/nops.h>
|
||||||
#include <asm/nmi.h>
|
#include <asm/nmi.h>
|
||||||
|
|
||||||
|
|
|
@ -132,6 +132,7 @@ void blk_rq_init(struct request_queue *q, struct request *rq)
|
||||||
INIT_HLIST_NODE(&rq->hash);
|
INIT_HLIST_NODE(&rq->hash);
|
||||||
RB_CLEAR_NODE(&rq->rb_node);
|
RB_CLEAR_NODE(&rq->rb_node);
|
||||||
rq->cmd = rq->__cmd;
|
rq->cmd = rq->__cmd;
|
||||||
|
rq->cmd_len = BLK_MAX_CDB;
|
||||||
rq->tag = -1;
|
rq->tag = -1;
|
||||||
rq->ref_count = 1;
|
rq->ref_count = 1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -356,6 +356,9 @@ struct ftrace_graph_ret {
|
||||||
|
|
||||||
#ifdef CONFIG_FUNCTION_GRAPH_TRACER
|
#ifdef CONFIG_FUNCTION_GRAPH_TRACER
|
||||||
|
|
||||||
|
/* for init task */
|
||||||
|
#define INIT_FTRACE_GRAPH .ret_stack = NULL
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Stack of return addresses for functions
|
* Stack of return addresses for functions
|
||||||
* of a thread.
|
* of a thread.
|
||||||
|
@ -429,10 +432,11 @@ static inline void unpause_graph_tracing(void)
|
||||||
{
|
{
|
||||||
atomic_dec(¤t->tracing_graph_pause);
|
atomic_dec(¤t->tracing_graph_pause);
|
||||||
}
|
}
|
||||||
#else
|
#else /* !CONFIG_FUNCTION_GRAPH_TRACER */
|
||||||
|
|
||||||
#define __notrace_funcgraph
|
#define __notrace_funcgraph
|
||||||
#define __irq_entry
|
#define __irq_entry
|
||||||
|
#define INIT_FTRACE_GRAPH
|
||||||
|
|
||||||
static inline void ftrace_graph_init_task(struct task_struct *t) { }
|
static inline void ftrace_graph_init_task(struct task_struct *t) { }
|
||||||
static inline void ftrace_graph_exit_task(struct task_struct *t) { }
|
static inline void ftrace_graph_exit_task(struct task_struct *t) { }
|
||||||
|
@ -444,7 +448,7 @@ static inline int task_curr_ret_stack(struct task_struct *tsk)
|
||||||
|
|
||||||
static inline void pause_graph_tracing(void) { }
|
static inline void pause_graph_tracing(void) { }
|
||||||
static inline void unpause_graph_tracing(void) { }
|
static inline void unpause_graph_tracing(void) { }
|
||||||
#endif
|
#endif /* CONFIG_FUNCTION_GRAPH_TRACER */
|
||||||
|
|
||||||
#ifdef CONFIG_TRACING
|
#ifdef CONFIG_TRACING
|
||||||
#include <linux/sched.h>
|
#include <linux/sched.h>
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
#include <linux/irqflags.h>
|
#include <linux/irqflags.h>
|
||||||
#include <linux/utsname.h>
|
#include <linux/utsname.h>
|
||||||
#include <linux/lockdep.h>
|
#include <linux/lockdep.h>
|
||||||
|
#include <linux/ftrace.h>
|
||||||
#include <linux/ipc.h>
|
#include <linux/ipc.h>
|
||||||
#include <linux/pid_namespace.h>
|
#include <linux/pid_namespace.h>
|
||||||
#include <linux/user_namespace.h>
|
#include <linux/user_namespace.h>
|
||||||
|
@ -185,6 +186,7 @@ extern struct cred init_cred;
|
||||||
INIT_IDS \
|
INIT_IDS \
|
||||||
INIT_TRACE_IRQFLAGS \
|
INIT_TRACE_IRQFLAGS \
|
||||||
INIT_LOCKDEP \
|
INIT_LOCKDEP \
|
||||||
|
INIT_FTRACE_GRAPH \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -327,10 +327,10 @@ static ssize_t blk_msg_write(struct file *filp, const char __user *buffer,
|
||||||
char *msg;
|
char *msg;
|
||||||
struct blk_trace *bt;
|
struct blk_trace *bt;
|
||||||
|
|
||||||
if (count > BLK_TN_MAX_MSG)
|
if (count >= BLK_TN_MAX_MSG)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
msg = kmalloc(count, GFP_KERNEL);
|
msg = kmalloc(count + 1, GFP_KERNEL);
|
||||||
if (msg == NULL)
|
if (msg == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
|
@ -339,6 +339,7 @@ static ssize_t blk_msg_write(struct file *filp, const char __user *buffer,
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
msg[count] = '\0';
|
||||||
bt = filp->private_data;
|
bt = filp->private_data;
|
||||||
__trace_note_message(bt, "%s", msg);
|
__trace_note_message(bt, "%s", msg);
|
||||||
kfree(msg);
|
kfree(msg);
|
||||||
|
@ -642,7 +643,7 @@ static void blk_add_trace_rq(struct request_queue *q, struct request *rq,
|
||||||
if (blk_pc_request(rq)) {
|
if (blk_pc_request(rq)) {
|
||||||
what |= BLK_TC_ACT(BLK_TC_PC);
|
what |= BLK_TC_ACT(BLK_TC_PC);
|
||||||
__blk_add_trace(bt, 0, rq->data_len, rw, what, rq->errors,
|
__blk_add_trace(bt, 0, rq->data_len, rw, what, rq->errors,
|
||||||
sizeof(rq->cmd), rq->cmd);
|
rq->cmd_len, rq->cmd);
|
||||||
} else {
|
} else {
|
||||||
what |= BLK_TC_ACT(BLK_TC_FS);
|
what |= BLK_TC_ACT(BLK_TC_FS);
|
||||||
__blk_add_trace(bt, rq->hard_sector, rq->hard_nr_sectors << 9,
|
__blk_add_trace(bt, rq->hard_sector, rq->hard_nr_sectors << 9,
|
||||||
|
|
|
@ -30,6 +30,7 @@
|
||||||
#include <linux/percpu.h>
|
#include <linux/percpu.h>
|
||||||
#include <linux/splice.h>
|
#include <linux/splice.h>
|
||||||
#include <linux/kdebug.h>
|
#include <linux/kdebug.h>
|
||||||
|
#include <linux/string.h>
|
||||||
#include <linux/ctype.h>
|
#include <linux/ctype.h>
|
||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
#include <linux/poll.h>
|
#include <linux/poll.h>
|
||||||
|
@ -147,8 +148,7 @@ static int __init set_ftrace_dump_on_oops(char *str)
|
||||||
}
|
}
|
||||||
__setup("ftrace_dump_on_oops", set_ftrace_dump_on_oops);
|
__setup("ftrace_dump_on_oops", set_ftrace_dump_on_oops);
|
||||||
|
|
||||||
long
|
unsigned long long ns2usecs(cycle_t nsec)
|
||||||
ns2usecs(cycle_t nsec)
|
|
||||||
{
|
{
|
||||||
nsec += 500;
|
nsec += 500;
|
||||||
do_div(nsec, 1000);
|
do_div(nsec, 1000);
|
||||||
|
@ -1623,7 +1623,11 @@ static void test_cpu_buff_start(struct trace_iterator *iter)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
cpumask_set_cpu(iter->cpu, iter->started);
|
cpumask_set_cpu(iter->cpu, iter->started);
|
||||||
trace_seq_printf(s, "##### CPU %u buffer started ####\n", iter->cpu);
|
|
||||||
|
/* Don't print started cpu buffer for the first entry of the trace */
|
||||||
|
if (iter->idx > 1)
|
||||||
|
trace_seq_printf(s, "##### CPU %u buffer started ####\n",
|
||||||
|
iter->cpu);
|
||||||
}
|
}
|
||||||
|
|
||||||
static enum print_line_t print_trace_fmt(struct trace_iterator *iter)
|
static enum print_line_t print_trace_fmt(struct trace_iterator *iter)
|
||||||
|
@ -1858,6 +1862,11 @@ __tracing_open(struct inode *inode, struct file *file)
|
||||||
if (current_trace)
|
if (current_trace)
|
||||||
*iter->trace = *current_trace;
|
*iter->trace = *current_trace;
|
||||||
|
|
||||||
|
if (!alloc_cpumask_var(&iter->started, GFP_KERNEL))
|
||||||
|
goto fail;
|
||||||
|
|
||||||
|
cpumask_clear(iter->started);
|
||||||
|
|
||||||
if (current_trace && current_trace->print_max)
|
if (current_trace && current_trace->print_max)
|
||||||
iter->tr = &max_tr;
|
iter->tr = &max_tr;
|
||||||
else
|
else
|
||||||
|
@ -1908,6 +1917,7 @@ __tracing_open(struct inode *inode, struct file *file)
|
||||||
if (iter->buffer_iter[cpu])
|
if (iter->buffer_iter[cpu])
|
||||||
ring_buffer_read_finish(iter->buffer_iter[cpu]);
|
ring_buffer_read_finish(iter->buffer_iter[cpu]);
|
||||||
}
|
}
|
||||||
|
free_cpumask_var(iter->started);
|
||||||
fail:
|
fail:
|
||||||
mutex_unlock(&trace_types_lock);
|
mutex_unlock(&trace_types_lock);
|
||||||
kfree(iter->trace);
|
kfree(iter->trace);
|
||||||
|
@ -1951,6 +1961,7 @@ static int tracing_release(struct inode *inode, struct file *file)
|
||||||
|
|
||||||
seq_release(inode, file);
|
seq_release(inode, file);
|
||||||
mutex_destroy(&iter->mutex);
|
mutex_destroy(&iter->mutex);
|
||||||
|
free_cpumask_var(iter->started);
|
||||||
kfree(iter->trace);
|
kfree(iter->trace);
|
||||||
kfree(iter);
|
kfree(iter);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -2349,9 +2360,9 @@ static const char readme_msg[] =
|
||||||
"# mkdir /debug\n"
|
"# mkdir /debug\n"
|
||||||
"# mount -t debugfs nodev /debug\n\n"
|
"# mount -t debugfs nodev /debug\n\n"
|
||||||
"# cat /debug/tracing/available_tracers\n"
|
"# cat /debug/tracing/available_tracers\n"
|
||||||
"wakeup preemptirqsoff preemptoff irqsoff ftrace sched_switch none\n\n"
|
"wakeup preemptirqsoff preemptoff irqsoff function sched_switch nop\n\n"
|
||||||
"# cat /debug/tracing/current_tracer\n"
|
"# cat /debug/tracing/current_tracer\n"
|
||||||
"none\n"
|
"nop\n"
|
||||||
"# echo sched_switch > /debug/tracing/current_tracer\n"
|
"# echo sched_switch > /debug/tracing/current_tracer\n"
|
||||||
"# cat /debug/tracing/current_tracer\n"
|
"# cat /debug/tracing/current_tracer\n"
|
||||||
"sched_switch\n"
|
"sched_switch\n"
|
||||||
|
|
|
@ -602,7 +602,7 @@ extern int trace_selftest_startup_branch(struct tracer *trace,
|
||||||
#endif /* CONFIG_FTRACE_STARTUP_TEST */
|
#endif /* CONFIG_FTRACE_STARTUP_TEST */
|
||||||
|
|
||||||
extern void *head_page(struct trace_array_cpu *data);
|
extern void *head_page(struct trace_array_cpu *data);
|
||||||
extern long ns2usecs(cycle_t nsec);
|
extern unsigned long long ns2usecs(cycle_t nsec);
|
||||||
extern int
|
extern int
|
||||||
trace_vbprintk(unsigned long ip, const char *fmt, va_list args);
|
trace_vbprintk(unsigned long ip, const char *fmt, va_list args);
|
||||||
extern int
|
extern int
|
||||||
|
|
|
@ -40,7 +40,7 @@
|
||||||
|
|
||||||
#undef TRACE_FIELD_ZERO_CHAR
|
#undef TRACE_FIELD_ZERO_CHAR
|
||||||
#define TRACE_FIELD_ZERO_CHAR(item) \
|
#define TRACE_FIELD_ZERO_CHAR(item) \
|
||||||
ret = trace_seq_printf(s, "\tfield: char " #item ";\t" \
|
ret = trace_seq_printf(s, "\tfield:char " #item ";\t" \
|
||||||
"offset:%u;\tsize:0;\n", \
|
"offset:%u;\tsize:0;\n", \
|
||||||
(unsigned int)offsetof(typeof(field), item)); \
|
(unsigned int)offsetof(typeof(field), item)); \
|
||||||
if (!ret) \
|
if (!ret) \
|
||||||
|
|
|
@ -433,7 +433,7 @@ int trace_print_lat_context(struct trace_iterator *iter)
|
||||||
|
|
||||||
trace_find_cmdline(entry->pid, comm);
|
trace_find_cmdline(entry->pid, comm);
|
||||||
|
|
||||||
ret = trace_seq_printf(s, "%16s %5d %3d %d %08x %08lx [%08lx]"
|
ret = trace_seq_printf(s, "%16s %5d %3d %d %08x %08lx [%08llx]"
|
||||||
" %ld.%03ldms (+%ld.%03ldms): ", comm,
|
" %ld.%03ldms (+%ld.%03ldms): ", comm,
|
||||||
entry->pid, iter->cpu, entry->flags,
|
entry->pid, iter->cpu, entry->flags,
|
||||||
entry->preempt_count, iter->idx,
|
entry->preempt_count, iter->idx,
|
||||||
|
|
|
@ -62,6 +62,9 @@ probe_sched_wakeup(struct rq *__rq, struct task_struct *wakee, int success)
|
||||||
pc = preempt_count();
|
pc = preempt_count();
|
||||||
tracing_record_cmdline(current);
|
tracing_record_cmdline(current);
|
||||||
|
|
||||||
|
if (sched_stopped)
|
||||||
|
return;
|
||||||
|
|
||||||
local_irq_save(flags);
|
local_irq_save(flags);
|
||||||
cpu = raw_smp_processor_id();
|
cpu = raw_smp_processor_id();
|
||||||
data = ctx_trace->data[cpu];
|
data = ctx_trace->data[cpu];
|
||||||
|
|
|
@ -154,7 +154,7 @@ probe_wakeup_sched_switch(struct rq *rq, struct task_struct *prev,
|
||||||
if (unlikely(!tracer_enabled || next != wakeup_task))
|
if (unlikely(!tracer_enabled || next != wakeup_task))
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
|
|
||||||
trace_function(wakeup_trace, CALLER_ADDR1, CALLER_ADDR2, flags, pc);
|
trace_function(wakeup_trace, CALLER_ADDR0, CALLER_ADDR1, flags, pc);
|
||||||
tracing_sched_switch_trace(wakeup_trace, prev, next, flags, pc);
|
tracing_sched_switch_trace(wakeup_trace, prev, next, flags, pc);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -257,6 +257,12 @@ probe_wakeup(struct rq *rq, struct task_struct *p, int success)
|
||||||
data = wakeup_trace->data[wakeup_cpu];
|
data = wakeup_trace->data[wakeup_cpu];
|
||||||
data->preempt_timestamp = ftrace_now(cpu);
|
data->preempt_timestamp = ftrace_now(cpu);
|
||||||
tracing_sched_wakeup_trace(wakeup_trace, p, current, flags, pc);
|
tracing_sched_wakeup_trace(wakeup_trace, p, current, flags, pc);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We must be careful in using CALLER_ADDR2. But since wake_up
|
||||||
|
* is not called by an assembly function (where as schedule is)
|
||||||
|
* it should be safe to use it here.
|
||||||
|
*/
|
||||||
trace_function(wakeup_trace, CALLER_ADDR1, CALLER_ADDR2, flags, pc);
|
trace_function(wakeup_trace, CALLER_ADDR1, CALLER_ADDR2, flags, pc);
|
||||||
|
|
||||||
out_locked:
|
out_locked:
|
||||||
|
|
Загрузка…
Ссылка в новой задаче