Blame view

kernel/trace/trace_kdb.c 3.47 KB
b24413180   Greg Kroah-Hartman   License cleanup: ...
1
  // SPDX-License-Identifier: GPL-2.0
955b61e59   Jason Wessel   ftrace,kdb: Exten...
2
3
4
5
6
7
8
9
10
11
12
13
14
15
  /*
   * kdb helper for dumping the ftrace buffer
   *
   * Copyright (C) 2010 Jason Wessel <jason.wessel@windriver.com>
   *
   * ftrace_dump_buf based on ftrace_dump:
   * Copyright (C) 2007-2008 Steven Rostedt <srostedt@redhat.com>
   * Copyright (C) 2008 Ingo Molnar <mingo@redhat.com>
   *
   */
  #include <linux/init.h>
  #include <linux/kgdb.h>
  #include <linux/kdb.h>
  #include <linux/ftrace.h>
955b61e59   Jason Wessel   ftrace,kdb: Exten...
16
17
  #include "trace.h"
  #include "trace_output.h"
03197fc02   Douglas Anderson   tracing: kdb: All...
18
19
  static struct trace_iterator iter;
  static struct ring_buffer_iter *buffer_iter[CONFIG_NR_CPUS];
dbfe67334   Douglas Anderson   tracing: kdb: The...
20
  static void ftrace_dump_buf(int skip_entries, long cpu_file)
955b61e59   Jason Wessel   ftrace,kdb: Exten...
21
  {
983f938ae   Steven Rostedt (Red Hat)   tracing: Move tra...
22
  	struct trace_array *tr;
955b61e59   Jason Wessel   ftrace,kdb: Exten...
23
24
  	unsigned int old_userobj;
  	int cnt = 0, cpu;
983f938ae   Steven Rostedt (Red Hat)   tracing: Move tra...
25
  	tr = iter.tr;
955b61e59   Jason Wessel   ftrace,kdb: Exten...
26

983f938ae   Steven Rostedt (Red Hat)   tracing: Move tra...
27
  	old_userobj = tr->trace_flags;
955b61e59   Jason Wessel   ftrace,kdb: Exten...
28
29
  
  	/* don't look at user memory in panic mode */
983f938ae   Steven Rostedt (Red Hat)   tracing: Move tra...
30
  	tr->trace_flags &= ~TRACE_ITER_SYM_USEROBJ;
955b61e59   Jason Wessel   ftrace,kdb: Exten...
31
32
33
  
  	kdb_printf("Dumping ftrace buffer:
  ");
03197fc02   Douglas Anderson   tracing: kdb: All...
34
35
36
  	if (skip_entries)
  		kdb_printf("(skipping %d entries)
  ", skip_entries);
955b61e59   Jason Wessel   ftrace,kdb: Exten...
37

0c97bf863   Miguel Ojeda   tracing: Silence ...
38
  	trace_iterator_reset(&iter);
955b61e59   Jason Wessel   ftrace,kdb: Exten...
39
  	iter.iter_flags |= TRACE_FILE_LAT_FMT;
955b61e59   Jason Wessel   ftrace,kdb: Exten...
40

ae3b5093a   Steven Rostedt   tracing: Use RING...
41
  	if (cpu_file == RING_BUFFER_ALL_CPUS) {
19063c776   Jason Wessel   ftrace,kdb: Allow...
42
43
  		for_each_tracing_cpu(cpu) {
  			iter.buffer_iter[cpu] =
31b265b3b   Douglas Anderson   tracing: kdb: Fix...
44
45
  			ring_buffer_read_prepare(iter.trace_buffer->buffer,
  						 cpu, GFP_ATOMIC);
19063c776   Jason Wessel   ftrace,kdb: Allow...
46
47
48
49
50
51
  			ring_buffer_read_start(iter.buffer_iter[cpu]);
  			tracing_iter_reset(&iter, cpu);
  		}
  	} else {
  		iter.cpu_file = cpu_file;
  		iter.buffer_iter[cpu_file] =
31b265b3b   Douglas Anderson   tracing: kdb: Fix...
52
53
  			ring_buffer_read_prepare(iter.trace_buffer->buffer,
  						 cpu_file, GFP_ATOMIC);
19063c776   Jason Wessel   ftrace,kdb: Allow...
54
55
  		ring_buffer_read_start(iter.buffer_iter[cpu_file]);
  		tracing_iter_reset(&iter, cpu_file);
955b61e59   Jason Wessel   ftrace,kdb: Exten...
56
  	}
8520dedbb   Daniel Thompson   tracing: kdb: Fix...
57
58
  
  	while (trace_find_next_entry_inc(&iter)) {
955b61e59   Jason Wessel   ftrace,kdb: Exten...
59
60
61
62
  		if (!cnt)
  			kdb_printf("---------------------------------
  ");
  		cnt++;
dbfe67334   Douglas Anderson   tracing: kdb: The...
63
  		if (!skip_entries) {
955b61e59   Jason Wessel   ftrace,kdb: Exten...
64
  			print_trace_line(&iter);
955b61e59   Jason Wessel   ftrace,kdb: Exten...
65
  			trace_printk_seq(&iter.seq);
8520dedbb   Daniel Thompson   tracing: kdb: Fix...
66
  		} else {
dbfe67334   Douglas Anderson   tracing: kdb: The...
67
  			skip_entries--;
8520dedbb   Daniel Thompson   tracing: kdb: Fix...
68
  		}
955b61e59   Jason Wessel   ftrace,kdb: Exten...
69
70
71
72
73
74
75
76
77
78
79
80
  		if (KDB_FLAG(CMD_INTERRUPT))
  			goto out;
  	}
  
  	if (!cnt)
  		kdb_printf("   (ftrace buffer empty)
  ");
  	else
  		kdb_printf("---------------------------------
  ");
  
  out:
983f938ae   Steven Rostedt (Red Hat)   tracing: Move tra...
81
  	tr->trace_flags = old_userobj;
955b61e59   Jason Wessel   ftrace,kdb: Exten...
82
83
  
  	for_each_tracing_cpu(cpu) {
c270cc75c   Daniel Thompson   tracing: kdb: Fix...
84
  		if (iter.buffer_iter[cpu]) {
955b61e59   Jason Wessel   ftrace,kdb: Exten...
85
  			ring_buffer_read_finish(iter.buffer_iter[cpu]);
c270cc75c   Daniel Thompson   tracing: kdb: Fix...
86
87
88
  			iter.buffer_iter[cpu] = NULL;
  		}
  	}
955b61e59   Jason Wessel   ftrace,kdb: Exten...
89
90
91
92
93
94
95
  }
  
  /*
   * kdb_ftdump - Dump the ftrace log buffer
   */
  static int kdb_ftdump(int argc, const char **argv)
  {
dbfe67334   Douglas Anderson   tracing: kdb: The...
96
  	int skip_entries = 0;
19063c776   Jason Wessel   ftrace,kdb: Allow...
97
  	long cpu_file;
955b61e59   Jason Wessel   ftrace,kdb: Exten...
98
  	char *cp;
03197fc02   Douglas Anderson   tracing: kdb: All...
99
100
  	int cnt;
  	int cpu;
955b61e59   Jason Wessel   ftrace,kdb: Exten...
101

19063c776   Jason Wessel   ftrace,kdb: Allow...
102
  	if (argc > 2)
955b61e59   Jason Wessel   ftrace,kdb: Exten...
103
104
105
  		return KDB_ARGCOUNT;
  
  	if (argc) {
dbfe67334   Douglas Anderson   tracing: kdb: The...
106
  		skip_entries = simple_strtol(argv[1], &cp, 0);
955b61e59   Jason Wessel   ftrace,kdb: Exten...
107
  		if (*cp)
dbfe67334   Douglas Anderson   tracing: kdb: The...
108
  			skip_entries = 0;
955b61e59   Jason Wessel   ftrace,kdb: Exten...
109
  	}
19063c776   Jason Wessel   ftrace,kdb: Allow...
110
111
112
113
114
115
  	if (argc == 2) {
  		cpu_file = simple_strtol(argv[2], &cp, 0);
  		if (*cp || cpu_file >= NR_CPUS || cpu_file < 0 ||
  		    !cpu_online(cpu_file))
  			return KDB_BADINT;
  	} else {
ae3b5093a   Steven Rostedt   tracing: Use RING...
116
  		cpu_file = RING_BUFFER_ALL_CPUS;
19063c776   Jason Wessel   ftrace,kdb: Allow...
117
  	}
955b61e59   Jason Wessel   ftrace,kdb: Exten...
118
  	kdb_trap_printk++;
03197fc02   Douglas Anderson   tracing: kdb: All...
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
  
  	trace_init_global_iter(&iter);
  	iter.buffer_iter = buffer_iter;
  
  	for_each_tracing_cpu(cpu) {
  		atomic_inc(&per_cpu_ptr(iter.trace_buffer->data, cpu)->disabled);
  	}
  
  	/* A negative skip_entries means skip all but the last entries */
  	if (skip_entries < 0) {
  		if (cpu_file == RING_BUFFER_ALL_CPUS)
  			cnt = trace_total_entries(NULL);
  		else
  			cnt = trace_total_entries_cpu(NULL, cpu_file);
  		skip_entries = max(cnt + skip_entries, 0);
  	}
dbfe67334   Douglas Anderson   tracing: kdb: The...
135
  	ftrace_dump_buf(skip_entries, cpu_file);
03197fc02   Douglas Anderson   tracing: kdb: All...
136
137
138
139
  
  	for_each_tracing_cpu(cpu) {
  		atomic_dec(&per_cpu_ptr(iter.trace_buffer->data, cpu)->disabled);
  	}
955b61e59   Jason Wessel   ftrace,kdb: Exten...
140
141
142
143
144
145
146
  	kdb_trap_printk--;
  
  	return 0;
  }
  
  static __init int kdb_ftrace_register(void)
  {
dbfe67334   Douglas Anderson   tracing: kdb: The...
147
  	kdb_register_flags("ftdump", kdb_ftdump, "[skip_#entries] [cpu]",
03197fc02   Douglas Anderson   tracing: kdb: All...
148
149
  			    "Dump ftrace log; -skip dumps last #entries", 0,
  			    KDB_ENABLE_ALWAYS_SAFE);
955b61e59   Jason Wessel   ftrace,kdb: Exten...
150
151
152
153
  	return 0;
  }
  
  late_initcall(kdb_ftrace_register);