diff options
author | Ingo Molnar <mingo@elte.hu> | 2009-04-20 09:58:01 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-04-20 11:36:49 -0400 |
commit | e33e0a43736307512422e41aee6e24d5a8c39181 (patch) | |
tree | b1ae3e3287d51dfc33a33724eb00712496b13900 | |
parent | 1d8c8b209e9351a7de1307d7b9b6df4222b8d742 (diff) |
perf_counter tools: add 'perf record' command
Move perf-record.c into the perf suite of commands.
Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r-- | Documentation/perf_counter/Documentation/perf-record.txt | 63 | ||||
-rw-r--r-- | Documentation/perf_counter/Makefile | 1 | ||||
-rw-r--r-- | Documentation/perf_counter/builtin-record.c (renamed from Documentation/perf_counter/perf-record.c) | 30 | ||||
-rw-r--r-- | Documentation/perf_counter/builtin.h | 3 | ||||
-rw-r--r-- | Documentation/perf_counter/command-list.txt | 3 | ||||
-rw-r--r-- | Documentation/perf_counter/perf.c | 3 |
6 files changed, 73 insertions, 30 deletions
diff --git a/Documentation/perf_counter/Documentation/perf-record.txt b/Documentation/perf_counter/Documentation/perf-record.txt new file mode 100644 index 000000000000..d07700e35eb2 --- /dev/null +++ b/Documentation/perf_counter/Documentation/perf-record.txt | |||
@@ -0,0 +1,63 @@ | |||
1 | perf-record(1) | ||
2 | ========== | ||
3 | |||
4 | NAME | ||
5 | ---- | ||
6 | perf-record - Run a command and record its profile into output.perf | ||
7 | |||
8 | SYNOPSIS | ||
9 | -------- | ||
10 | [verse] | ||
11 | 'perf record' [-e <EVENT> | --event=EVENT] [-l] [-a] <command> | ||
12 | |||
13 | DESCRIPTION | ||
14 | ----------- | ||
15 | This command runs a command and gathers a performance counter profile | ||
16 | from it, into output.perf - without displaying anything. | ||
17 | |||
18 | This file can then be inspected later on, using 'perf report'. | ||
19 | |||
20 | |||
21 | OPTIONS | ||
22 | ------- | ||
23 | <command>...:: | ||
24 | Any command you can specify in a shell. | ||
25 | |||
26 | -e:: | ||
27 | --event=:: | ||
28 | 0:0: cpu-cycles | ||
29 | 0:0: cycles | ||
30 | 0:1: instructions | ||
31 | 0:2: cache-references | ||
32 | 0:3: cache-misses | ||
33 | 0:4: branch-instructions | ||
34 | 0:4: branches | ||
35 | 0:5: branch-misses | ||
36 | 0:6: bus-cycles | ||
37 | 1:0: cpu-clock | ||
38 | 1:1: task-clock | ||
39 | 1:2: page-faults | ||
40 | 1:2: faults | ||
41 | 1:5: minor-faults | ||
42 | 1:6: major-faults | ||
43 | 1:3: context-switches | ||
44 | 1:3: cs | ||
45 | 1:4: cpu-migrations | ||
46 | 1:4: migrations | ||
47 | rNNN: raw PMU events (eventsel+umask) | ||
48 | |||
49 | -a:: | ||
50 | system-wide collection | ||
51 | |||
52 | -l:: | ||
53 | scale counter values | ||
54 | |||
55 | Configuration | ||
56 | ------------- | ||
57 | |||
58 | EXAMPLES | ||
59 | -------- | ||
60 | |||
61 | SEE ALSO | ||
62 | -------- | ||
63 | linkperf:git-stat[1] | ||
diff --git a/Documentation/perf_counter/Makefile b/Documentation/perf_counter/Makefile index fb8b71744e59..b6c665eb22e4 100644 --- a/Documentation/perf_counter/Makefile +++ b/Documentation/perf_counter/Makefile | |||
@@ -309,6 +309,7 @@ LIB_OBJS += usage.o | |||
309 | LIB_OBJS += wrapper.o | 309 | LIB_OBJS += wrapper.o |
310 | 310 | ||
311 | BUILTIN_OBJS += builtin-help.o | 311 | BUILTIN_OBJS += builtin-help.o |
312 | BUILTIN_OBJS += builtin-record.o | ||
312 | BUILTIN_OBJS += builtin-stat.o | 313 | BUILTIN_OBJS += builtin-stat.o |
313 | BUILTIN_OBJS += builtin-top.o | 314 | BUILTIN_OBJS += builtin-top.o |
314 | 315 | ||
diff --git a/Documentation/perf_counter/perf-record.c b/Documentation/perf_counter/builtin-record.c index 614de7c468b2..4a50abf843ee 100644 --- a/Documentation/perf_counter/perf-record.c +++ b/Documentation/perf_counter/builtin-record.c | |||
@@ -81,16 +81,12 @@ | |||
81 | (void) (&_min1 == &_min2); \ | 81 | (void) (&_min1 == &_min2); \ |
82 | _min1 < _min2 ? _min1 : _min2; }) | 82 | _min1 < _min2 ? _min1 : _min2; }) |
83 | 83 | ||
84 | asmlinkage int sys_perf_counter_open( | 84 | extern asmlinkage int sys_perf_counter_open( |
85 | struct perf_counter_hw_event *hw_event_uptr __user, | 85 | struct perf_counter_hw_event *hw_event_uptr __user, |
86 | pid_t pid, | 86 | pid_t pid, |
87 | int cpu, | 87 | int cpu, |
88 | int group_fd, | 88 | int group_fd, |
89 | unsigned long flags) | 89 | unsigned long flags); |
90 | { | ||
91 | return syscall( | ||
92 | __NR_perf_counter_open, hw_event_uptr, pid, cpu, group_fd, flags); | ||
93 | } | ||
94 | 90 | ||
95 | #define MAX_COUNTERS 64 | 91 | #define MAX_COUNTERS 64 |
96 | #define MAX_NR_CPUS 256 | 92 | #define MAX_NR_CPUS 256 |
@@ -119,26 +115,6 @@ const unsigned int default_count[] = { | |||
119 | 10000, | 115 | 10000, |
120 | }; | 116 | }; |
121 | 117 | ||
122 | static char *hw_event_names[] = { | ||
123 | "CPU cycles", | ||
124 | "instructions", | ||
125 | "cache references", | ||
126 | "cache misses", | ||
127 | "branches", | ||
128 | "branch misses", | ||
129 | "bus cycles", | ||
130 | }; | ||
131 | |||
132 | static char *sw_event_names[] = { | ||
133 | "cpu clock ticks", | ||
134 | "task clock ticks", | ||
135 | "pagefaults", | ||
136 | "context switches", | ||
137 | "CPU migrations", | ||
138 | "minor faults", | ||
139 | "major faults", | ||
140 | }; | ||
141 | |||
142 | struct event_symbol { | 118 | struct event_symbol { |
143 | __u64 event; | 119 | __u64 event; |
144 | char *symbol; | 120 | char *symbol; |
@@ -414,7 +390,7 @@ static void sigchld_handler(int sig) | |||
414 | done = 1; | 390 | done = 1; |
415 | } | 391 | } |
416 | 392 | ||
417 | int main(int argc, char *argv[]) | 393 | int cmd_record(int argc, const char **argv) |
418 | { | 394 | { |
419 | struct pollfd event_array[MAX_NR_CPUS * MAX_COUNTERS]; | 395 | struct pollfd event_array[MAX_NR_CPUS * MAX_COUNTERS]; |
420 | struct mmap_data mmap_array[MAX_NR_CPUS][MAX_COUNTERS]; | 396 | struct mmap_data mmap_array[MAX_NR_CPUS][MAX_COUNTERS]; |
diff --git a/Documentation/perf_counter/builtin.h b/Documentation/perf_counter/builtin.h index 605323c691f1..5854b1715f54 100644 --- a/Documentation/perf_counter/builtin.h +++ b/Documentation/perf_counter/builtin.h | |||
@@ -14,6 +14,7 @@ extern void prune_packed_objects(int); | |||
14 | extern int read_line_with_nul(char *buf, int size, FILE *file); | 14 | extern int read_line_with_nul(char *buf, int size, FILE *file); |
15 | extern int check_pager_config(const char *cmd); | 15 | extern int check_pager_config(const char *cmd); |
16 | 16 | ||
17 | extern int cmd_top(int argc, const char **argv, const char *prefix); | 17 | extern int cmd_record(int argc, const char **argv, const char *prefix); |
18 | extern int cmd_stat(int argc, const char **argv, const char *prefix); | 18 | extern int cmd_stat(int argc, const char **argv, const char *prefix); |
19 | extern int cmd_top(int argc, const char **argv, const char *prefix); | ||
19 | #endif | 20 | #endif |
diff --git a/Documentation/perf_counter/command-list.txt b/Documentation/perf_counter/command-list.txt index 52455d46bfb5..d15210aa0cae 100644 --- a/Documentation/perf_counter/command-list.txt +++ b/Documentation/perf_counter/command-list.txt | |||
@@ -1,5 +1,6 @@ | |||
1 | # List of known perf commands. | 1 | # List of known perf commands. |
2 | # command name category [deprecated] [common] | 2 | # command name category [deprecated] [common] |
3 | perf-top mainporcelain common | 3 | perf-record mainporcelain common |
4 | perf-stat mainporcelain common | 4 | perf-stat mainporcelain common |
5 | perf-top mainporcelain common | ||
5 | 6 | ||
diff --git a/Documentation/perf_counter/perf.c b/Documentation/perf_counter/perf.c index ff8658f2a2f1..e849dd66b5ef 100644 --- a/Documentation/perf_counter/perf.c +++ b/Documentation/perf_counter/perf.c | |||
@@ -248,8 +248,9 @@ static void handle_internal_command(int argc, const char **argv) | |||
248 | { | 248 | { |
249 | const char *cmd = argv[0]; | 249 | const char *cmd = argv[0]; |
250 | static struct cmd_struct commands[] = { | 250 | static struct cmd_struct commands[] = { |
251 | { "top", cmd_top, 0 }, | 251 | { "record", cmd_record, 0 }, |
252 | { "stat", cmd_stat, 0 }, | 252 | { "stat", cmd_stat, 0 }, |
253 | { "top", cmd_top, 0 }, | ||
253 | }; | 254 | }; |
254 | int i; | 255 | int i; |
255 | static const char ext[] = STRIP_EXTENSION; | 256 | static const char ext[] = STRIP_EXTENSION; |