diff options
Diffstat (limited to 'kernel/trace/trace_stack.c')
| -rw-r--r-- | kernel/trace/trace_stack.c | 47 | 
1 files changed, 15 insertions, 32 deletions
diff --git a/kernel/trace/trace_stack.c b/kernel/trace/trace_stack.c index 6a2a9d484cd..8504ac71e4e 100644 --- a/kernel/trace/trace_stack.c +++ b/kernel/trace/trace_stack.c @@ -186,43 +186,33 @@ static const struct file_operations stack_max_size_fops = {  };  static void * -t_next(struct seq_file *m, void *v, loff_t *pos) +__next(struct seq_file *m, loff_t *pos)  { -	long i; +	long n = *pos - 1; -	(*pos)++; - -	if (v == SEQ_START_TOKEN) -		i = 0; -	else { -		i = *(long *)v; -		i++; -	} - -	if (i >= max_stack_trace.nr_entries || -	    stack_dump_trace[i] == ULONG_MAX) +	if (n >= max_stack_trace.nr_entries || stack_dump_trace[n] == ULONG_MAX)  		return NULL; -	m->private = (void *)i; - +	m->private = (void *)n;  	return &m->private;  } -static void *t_start(struct seq_file *m, loff_t *pos) +static void * +t_next(struct seq_file *m, void *v, loff_t *pos)  { -	void *t = SEQ_START_TOKEN; -	loff_t l = 0; +	(*pos)++; +	return __next(m, pos); +} +static void *t_start(struct seq_file *m, loff_t *pos) +{  	local_irq_disable();  	__raw_spin_lock(&max_stack_lock);  	if (*pos == 0)  		return SEQ_START_TOKEN; -	for (; t && l < *pos; t = t_next(m, t, &l)) -		; - -	return t; +	return __next(m, pos);  }  static void t_stop(struct seq_file *m, void *p) @@ -234,15 +224,8 @@ static void t_stop(struct seq_file *m, void *p)  static int trace_lookup_stack(struct seq_file *m, long i)  {  	unsigned long addr = stack_dump_trace[i]; -#ifdef CONFIG_KALLSYMS -	char str[KSYM_SYMBOL_LEN]; - -	sprint_symbol(str, addr); -	return seq_printf(m, "%s\n", str); -#else -	return seq_printf(m, "%p\n", (void*)addr); -#endif +	return seq_printf(m, "%pF\n", (void *)addr);  }  static void print_disabled(struct seq_file *m) @@ -313,14 +296,14 @@ static const struct file_operations stack_trace_fops = {  int  stack_trace_sysctl(struct ctl_table *table, int write, -		   struct file *file, void __user *buffer, size_t *lenp, +		   void __user *buffer, size_t *lenp,  		   loff_t *ppos)  {  	int ret;  	mutex_lock(&stack_sysctl_mutex); -	ret = proc_dointvec(table, write, file, buffer, lenp, ppos); +	ret = proc_dointvec(table, write, buffer, lenp, ppos);  	if (ret || !write ||  	    (last_stack_tracer_enabled == !!stack_tracer_enabled))  | 
