Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0 |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 2 | /* |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 3 | * builtin-bench.c |
| 4 | * |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 5 | * General benchmarking collections provided by perf |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 6 | * |
| 7 | * Copyright (C) 2009, Hitoshi Mitake <mitake@dcl.info.waseda.ac.jp> |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 8 | */ |
| 9 | |
| 10 | /* |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 11 | * Available benchmark collection list: |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 12 | * |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 13 | * sched ... scheduler and IPC performance |
Davidlohr Bueso | c2a0820 | 2019-03-08 10:17:47 -0800 | [diff] [blame] | 14 | * syscall ... System call performance |
Hitoshi Mitake | 827f3b4 | 2009-11-18 00:20:09 +0900 | [diff] [blame] | 15 | * mem ... memory access performance |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 16 | * numa ... NUMA scheduling and MM performance |
Davidlohr Bueso | a043971 | 2013-12-14 20:31:55 -0800 | [diff] [blame] | 17 | * futex ... Futex performance |
Davidlohr Bueso | 121dd9e | 2018-11-06 07:22:25 -0800 | [diff] [blame] | 18 | * epoll ... Event poll performance |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 19 | */ |
Josh Poimboeuf | 4b6ab94 | 2015-12-15 09:39:39 -0600 | [diff] [blame] | 20 | #include <subcmd/parse-options.h> |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 21 | #include "builtin.h" |
| 22 | #include "bench/bench.h" |
| 23 | |
| 24 | #include <stdio.h> |
| 25 | #include <stdlib.h> |
| 26 | #include <string.h> |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 27 | #include <sys/prctl.h> |
Arnaldo Carvalho de Melo | 7f7c536 | 2019-07-04 11:32:27 -0300 | [diff] [blame] | 28 | #include <linux/zalloc.h> |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 29 | |
Arnaldo Carvalho de Melo | b0ad8ea | 2017-03-27 11:47:20 -0300 | [diff] [blame] | 30 | typedef int (*bench_fn_t)(int argc, const char **argv); |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 31 | |
| 32 | struct bench { |
| 33 | const char *name; |
| 34 | const char *summary; |
| 35 | bench_fn_t fn; |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 36 | }; |
| 37 | |
Ingo Molnar | 89fe808 | 2013-09-30 12:07:11 +0200 | [diff] [blame] | 38 | #ifdef HAVE_LIBNUMA_SUPPORT |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 39 | static struct bench numa_benchmarks[] = { |
| 40 | { "mem", "Benchmark for NUMA workloads", bench_numa }, |
Ingo Molnar | aa254af | 2015-10-19 10:04:30 +0200 | [diff] [blame] | 41 | { "all", "Run all NUMA benchmarks", NULL }, |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 42 | { NULL, NULL, NULL } |
Ingo Molnar | 1c13f3c | 2012-12-06 13:51:59 +0100 | [diff] [blame] | 43 | }; |
Peter Hurley | 79d824e | 2013-01-27 20:51:22 -0500 | [diff] [blame] | 44 | #endif |
Ingo Molnar | 1c13f3c | 2012-12-06 13:51:59 +0100 | [diff] [blame] | 45 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 46 | static struct bench sched_benchmarks[] = { |
| 47 | { "messaging", "Benchmark for scheduling and IPC", bench_sched_messaging }, |
| 48 | { "pipe", "Benchmark for pipe() between two processes", bench_sched_pipe }, |
Ingo Molnar | aa254af | 2015-10-19 10:04:30 +0200 | [diff] [blame] | 49 | { "all", "Run all scheduler benchmarks", NULL }, |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 50 | { NULL, NULL, NULL } |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 51 | }; |
| 52 | |
Davidlohr Bueso | c2a0820 | 2019-03-08 10:17:47 -0800 | [diff] [blame] | 53 | static struct bench syscall_benchmarks[] = { |
| 54 | { "basic", "Benchmark for basic getppid(2) calls", bench_syscall_basic }, |
| 55 | { "all", "Run all syscall benchmarks", NULL }, |
| 56 | { NULL, NULL, NULL }, |
| 57 | }; |
| 58 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 59 | static struct bench mem_benchmarks[] = { |
Ingo Molnar | 13b1fdc | 2015-10-19 10:04:26 +0200 | [diff] [blame] | 60 | { "memcpy", "Benchmark for memcpy() functions", bench_mem_memcpy }, |
| 61 | { "memset", "Benchmark for memset() functions", bench_mem_memset }, |
Ian Rogers | 7c43b0c | 2020-07-29 15:00:34 -0700 | [diff] [blame] | 62 | { "find_bit", "Benchmark for find_bit() functions", bench_mem_find_bit }, |
Ingo Molnar | aa254af | 2015-10-19 10:04:30 +0200 | [diff] [blame] | 63 | { "all", "Run all memory access benchmarks", NULL }, |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 64 | { NULL, NULL, NULL } |
Hitoshi Mitake | 827f3b4 | 2009-11-18 00:20:09 +0900 | [diff] [blame] | 65 | }; |
| 66 | |
Davidlohr Bueso | a043971 | 2013-12-14 20:31:55 -0800 | [diff] [blame] | 67 | static struct bench futex_benchmarks[] = { |
| 68 | { "hash", "Benchmark for futex hash table", bench_futex_hash }, |
Davidlohr Bueso | 27db783 | 2013-12-14 20:31:56 -0800 | [diff] [blame] | 69 | { "wake", "Benchmark for futex wake calls", bench_futex_wake }, |
Davidlohr Bueso | d65817b | 2015-05-08 11:37:59 -0700 | [diff] [blame] | 70 | { "wake-parallel", "Benchmark for parallel futex wake calls", bench_futex_wake_parallel }, |
Davidlohr Bueso | 0fb298c | 2013-12-14 20:31:57 -0800 | [diff] [blame] | 71 | { "requeue", "Benchmark for futex requeue calls", bench_futex_requeue }, |
Davidlohr Bueso | d2f3f5d | 2015-07-07 01:55:53 -0700 | [diff] [blame] | 72 | /* pi-futexes */ |
| 73 | { "lock-pi", "Benchmark for futex lock_pi calls", bench_futex_lock_pi }, |
Ingo Molnar | aa254af | 2015-10-19 10:04:30 +0200 | [diff] [blame] | 74 | { "all", "Run all futex benchmarks", NULL }, |
Davidlohr Bueso | a043971 | 2013-12-14 20:31:55 -0800 | [diff] [blame] | 75 | { NULL, NULL, NULL } |
| 76 | }; |
| 77 | |
Arnaldo Carvalho de Melo | ba35fe9 | 2020-05-20 12:21:07 -0300 | [diff] [blame] | 78 | #ifdef HAVE_EVENTFD_SUPPORT |
Davidlohr Bueso | 121dd9e | 2018-11-06 07:22:25 -0800 | [diff] [blame] | 79 | static struct bench epoll_benchmarks[] = { |
| 80 | { "wait", "Benchmark epoll concurrent epoll_waits", bench_epoll_wait }, |
Davidlohr Bueso | 231457e | 2018-11-06 07:22:26 -0800 | [diff] [blame] | 81 | { "ctl", "Benchmark epoll concurrent epoll_ctls", bench_epoll_ctl }, |
Davidlohr Bueso | 121dd9e | 2018-11-06 07:22:25 -0800 | [diff] [blame] | 82 | { "all", "Run all futex benchmarks", NULL }, |
| 83 | { NULL, NULL, NULL } |
| 84 | }; |
Arnaldo Carvalho de Melo | ba35fe9 | 2020-05-20 12:21:07 -0300 | [diff] [blame] | 85 | #endif // HAVE_EVENTFD_SUPPORT |
Davidlohr Bueso | 121dd9e | 2018-11-06 07:22:25 -0800 | [diff] [blame] | 86 | |
Ian Rogers | 2a4b516 | 2020-04-02 08:43:53 -0700 | [diff] [blame] | 87 | static struct bench internals_benchmarks[] = { |
| 88 | { "synthesize", "Benchmark perf event synthesis", bench_synthesize }, |
Ian Rogers | 51876bd | 2020-05-01 15:13:13 -0700 | [diff] [blame] | 89 | { "kallsyms-parse", "Benchmark kallsyms parsing", bench_kallsyms_parse }, |
Namhyung Kim | 0bf02a0 | 2020-10-12 16:02:09 +0900 | [diff] [blame] | 90 | { "inject-build-id", "Benchmark build-id injection", bench_inject_build_id }, |
Riccardo Mancini | 4241eab | 2021-08-09 22:11:02 +0200 | [diff] [blame] | 91 | { "evlist-open-close", "Benchmark evlist open and close", bench_evlist_open_close }, |
Ian Rogers | 2a4b516 | 2020-04-02 08:43:53 -0700 | [diff] [blame] | 92 | { NULL, NULL, NULL } |
| 93 | }; |
| 94 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 95 | struct collection { |
| 96 | const char *name; |
| 97 | const char *summary; |
| 98 | struct bench *benchmarks; |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 99 | }; |
| 100 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 101 | static struct collection collections[] = { |
Davidlohr Bueso | a043971 | 2013-12-14 20:31:55 -0800 | [diff] [blame] | 102 | { "sched", "Scheduler and IPC benchmarks", sched_benchmarks }, |
Davidlohr Bueso | c2a0820 | 2019-03-08 10:17:47 -0800 | [diff] [blame] | 103 | { "syscall", "System call benchmarks", syscall_benchmarks }, |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 104 | { "mem", "Memory access benchmarks", mem_benchmarks }, |
Ingo Molnar | 89fe808 | 2013-09-30 12:07:11 +0200 | [diff] [blame] | 105 | #ifdef HAVE_LIBNUMA_SUPPORT |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 106 | { "numa", "NUMA scheduling and MM benchmarks", numa_benchmarks }, |
Peter Hurley | 79d824e | 2013-01-27 20:51:22 -0500 | [diff] [blame] | 107 | #endif |
Davidlohr Bueso | a043971 | 2013-12-14 20:31:55 -0800 | [diff] [blame] | 108 | {"futex", "Futex stressing benchmarks", futex_benchmarks }, |
Arnaldo Carvalho de Melo | ba35fe9 | 2020-05-20 12:21:07 -0300 | [diff] [blame] | 109 | #ifdef HAVE_EVENTFD_SUPPORT |
Davidlohr Bueso | 121dd9e | 2018-11-06 07:22:25 -0800 | [diff] [blame] | 110 | {"epoll", "Epoll stressing benchmarks", epoll_benchmarks }, |
| 111 | #endif |
Ian Rogers | 2a4b516 | 2020-04-02 08:43:53 -0700 | [diff] [blame] | 112 | { "internals", "Perf-internals benchmarks", internals_benchmarks }, |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 113 | { "all", "All benchmarks", NULL }, |
| 114 | { NULL, NULL, NULL } |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 115 | }; |
| 116 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 117 | /* Iterate over all benchmark collections: */ |
| 118 | #define for_each_collection(coll) \ |
| 119 | for (coll = collections; coll->name; coll++) |
| 120 | |
| 121 | /* Iterate over all benchmarks within a collection: */ |
| 122 | #define for_each_bench(coll, bench) \ |
Patrick Palka | 6eeefcc | 2014-03-12 18:40:51 -0400 | [diff] [blame] | 123 | for (bench = coll->benchmarks; bench && bench->name; bench++) |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 124 | |
| 125 | static void dump_benchmarks(struct collection *coll) |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 126 | { |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 127 | struct bench *bench; |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 128 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 129 | printf("\n # List of available benchmarks for collection '%s':\n\n", coll->name); |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 130 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 131 | for_each_bench(coll, bench) |
| 132 | printf("%14s: %s\n", bench->name, bench->summary); |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 133 | |
| 134 | printf("\n"); |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 135 | } |
| 136 | |
Arnaldo Carvalho de Melo | edb7c60 | 2010-05-17 16:22:41 -0300 | [diff] [blame] | 137 | static const char *bench_format_str; |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 138 | |
| 139 | /* Output/formatting style, exported to benchmark modules: */ |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 140 | int bench_format = BENCH_FORMAT_DEFAULT; |
Davidlohr Bueso | b6f0629 | 2014-06-16 11:14:19 -0700 | [diff] [blame] | 141 | unsigned int bench_repeat = 10; /* default number of times to repeat the run */ |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 142 | |
| 143 | static const struct option bench_options[] = { |
Ingo Molnar | 7a46a8f | 2015-10-19 10:04:22 +0200 | [diff] [blame] | 144 | OPT_STRING('f', "format", &bench_format_str, "default|simple", "Specify the output formatting style"), |
Davidlohr Bueso | b6f0629 | 2014-06-16 11:14:19 -0700 | [diff] [blame] | 145 | OPT_UINTEGER('r', "repeat", &bench_repeat, "Specify amount of times to repeat the run"), |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 146 | OPT_END() |
| 147 | }; |
| 148 | |
| 149 | static const char * const bench_usage[] = { |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 150 | "perf bench [<common options>] <collection> <benchmark> [<options>]", |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 151 | NULL |
| 152 | }; |
| 153 | |
| 154 | static void print_usage(void) |
| 155 | { |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 156 | struct collection *coll; |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 157 | int i; |
| 158 | |
| 159 | printf("Usage: \n"); |
| 160 | for (i = 0; bench_usage[i]; i++) |
| 161 | printf("\t%s\n", bench_usage[i]); |
| 162 | printf("\n"); |
| 163 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 164 | printf(" # List of all available benchmark collections:\n\n"); |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 165 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 166 | for_each_collection(coll) |
| 167 | printf("%14s: %s\n", coll->name, coll->summary); |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 168 | printf("\n"); |
| 169 | } |
| 170 | |
Arnaldo Carvalho de Melo | edb7c60 | 2010-05-17 16:22:41 -0300 | [diff] [blame] | 171 | static int bench_str2int(const char *str) |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 172 | { |
| 173 | if (!str) |
| 174 | return BENCH_FORMAT_DEFAULT; |
| 175 | |
| 176 | if (!strcmp(str, BENCH_FORMAT_DEFAULT_STR)) |
| 177 | return BENCH_FORMAT_DEFAULT; |
| 178 | else if (!strcmp(str, BENCH_FORMAT_SIMPLE_STR)) |
| 179 | return BENCH_FORMAT_SIMPLE; |
| 180 | |
| 181 | return BENCH_FORMAT_UNKNOWN; |
| 182 | } |
| 183 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 184 | /* |
| 185 | * Run a specific benchmark but first rename the running task's ->comm[] |
| 186 | * to something meaningful: |
| 187 | */ |
| 188 | static int run_bench(const char *coll_name, const char *bench_name, bench_fn_t fn, |
Arnaldo Carvalho de Melo | b0ad8ea | 2017-03-27 11:47:20 -0300 | [diff] [blame] | 189 | int argc, const char **argv) |
Hitoshi Mitake | 2044279 | 2009-12-13 17:01:59 +0900 | [diff] [blame] | 190 | { |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 191 | int size; |
| 192 | char *name; |
| 193 | int ret; |
| 194 | |
| 195 | size = strlen(coll_name) + 1 + strlen(bench_name) + 1; |
| 196 | |
| 197 | name = zalloc(size); |
| 198 | BUG_ON(!name); |
| 199 | |
| 200 | scnprintf(name, size, "%s-%s", coll_name, bench_name); |
| 201 | |
| 202 | prctl(PR_SET_NAME, name); |
| 203 | argv[0] = name; |
| 204 | |
Arnaldo Carvalho de Melo | b0ad8ea | 2017-03-27 11:47:20 -0300 | [diff] [blame] | 205 | ret = fn(argc, argv); |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 206 | |
| 207 | free(name); |
| 208 | |
| 209 | return ret; |
| 210 | } |
| 211 | |
| 212 | static void run_collection(struct collection *coll) |
| 213 | { |
| 214 | struct bench *bench; |
Hitoshi Mitake | 2044279 | 2009-12-13 17:01:59 +0900 | [diff] [blame] | 215 | const char *argv[2]; |
Hitoshi Mitake | 2044279 | 2009-12-13 17:01:59 +0900 | [diff] [blame] | 216 | |
| 217 | argv[1] = NULL; |
| 218 | /* |
| 219 | * TODO: |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 220 | * |
| 221 | * Preparing preset parameters for |
Hitoshi Mitake | 2044279 | 2009-12-13 17:01:59 +0900 | [diff] [blame] | 222 | * embedded, ordinary PC, HPC, etc... |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 223 | * would be helpful. |
Hitoshi Mitake | 2044279 | 2009-12-13 17:01:59 +0900 | [diff] [blame] | 224 | */ |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 225 | for_each_bench(coll, bench) { |
| 226 | if (!bench->fn) |
| 227 | break; |
| 228 | printf("# Running %s/%s benchmark...\n", coll->name, bench->name); |
Hitoshi Mitake | 2044279 | 2009-12-13 17:01:59 +0900 | [diff] [blame] | 229 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 230 | argv[1] = bench->name; |
Arnaldo Carvalho de Melo | b0ad8ea | 2017-03-27 11:47:20 -0300 | [diff] [blame] | 231 | run_bench(coll->name, bench->name, bench->fn, 1, argv); |
Hitoshi Mitake | 2044279 | 2009-12-13 17:01:59 +0900 | [diff] [blame] | 232 | printf("\n"); |
| 233 | } |
| 234 | } |
| 235 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 236 | static void run_all_collections(void) |
Hitoshi Mitake | 2044279 | 2009-12-13 17:01:59 +0900 | [diff] [blame] | 237 | { |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 238 | struct collection *coll; |
| 239 | |
| 240 | for_each_collection(coll) |
| 241 | run_collection(coll); |
Hitoshi Mitake | 2044279 | 2009-12-13 17:01:59 +0900 | [diff] [blame] | 242 | } |
| 243 | |
Arnaldo Carvalho de Melo | b0ad8ea | 2017-03-27 11:47:20 -0300 | [diff] [blame] | 244 | int cmd_bench(int argc, const char **argv) |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 245 | { |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 246 | struct collection *coll; |
| 247 | int ret = 0; |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 248 | |
Sohaib Mohamed | f0a29c9 | 2021-11-19 08:14:08 +0200 | [diff] [blame] | 249 | /* Unbuffered output */ |
| 250 | setvbuf(stdout, NULL, _IONBF, 0); |
| 251 | |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 252 | if (argc < 2) { |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 253 | /* No collection specified. */ |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 254 | print_usage(); |
| 255 | goto end; |
| 256 | } |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 257 | |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 258 | argc = parse_options(argc, argv, bench_options, bench_usage, |
| 259 | PARSE_OPT_STOP_AT_NON_OPTION); |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 260 | |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 261 | bench_format = bench_str2int(bench_format_str); |
| 262 | if (bench_format == BENCH_FORMAT_UNKNOWN) { |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 263 | printf("Unknown format descriptor: '%s'\n", bench_format_str); |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 264 | goto end; |
| 265 | } |
| 266 | |
Davidlohr Bueso | b6f0629 | 2014-06-16 11:14:19 -0700 | [diff] [blame] | 267 | if (bench_repeat == 0) { |
| 268 | printf("Invalid repeat option: Must specify a positive value\n"); |
| 269 | goto end; |
| 270 | } |
| 271 | |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 272 | if (argc < 1) { |
| 273 | print_usage(); |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 274 | goto end; |
| 275 | } |
| 276 | |
Hitoshi Mitake | 2044279 | 2009-12-13 17:01:59 +0900 | [diff] [blame] | 277 | if (!strcmp(argv[0], "all")) { |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 278 | run_all_collections(); |
Hitoshi Mitake | 2044279 | 2009-12-13 17:01:59 +0900 | [diff] [blame] | 279 | goto end; |
| 280 | } |
| 281 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 282 | for_each_collection(coll) { |
| 283 | struct bench *bench; |
| 284 | |
| 285 | if (strcmp(coll->name, argv[0])) |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 286 | continue; |
| 287 | |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 288 | if (argc < 2) { |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 289 | /* No bench specified. */ |
| 290 | dump_benchmarks(coll); |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 291 | goto end; |
| 292 | } |
| 293 | |
Hitoshi Mitake | 2044279 | 2009-12-13 17:01:59 +0900 | [diff] [blame] | 294 | if (!strcmp(argv[1], "all")) { |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 295 | run_collection(coll); |
Hitoshi Mitake | 2044279 | 2009-12-13 17:01:59 +0900 | [diff] [blame] | 296 | goto end; |
| 297 | } |
| 298 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 299 | for_each_bench(coll, bench) { |
| 300 | if (strcmp(bench->name, argv[1])) |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 301 | continue; |
| 302 | |
Hitoshi Mitake | 79e295d | 2009-11-11 00:04:00 +0900 | [diff] [blame] | 303 | if (bench_format == BENCH_FORMAT_DEFAULT) |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 304 | printf("# Running '%s/%s' benchmark:\n", coll->name, bench->name); |
Arnaldo Carvalho de Melo | b0ad8ea | 2017-03-27 11:47:20 -0300 | [diff] [blame] | 305 | ret = run_bench(coll->name, bench->name, bench->fn, argc-1, argv+1); |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 306 | goto end; |
| 307 | } |
| 308 | |
Hitoshi Mitake | 386d7e9 | 2009-11-10 08:20:00 +0900 | [diff] [blame] | 309 | if (!strcmp(argv[1], "-h") || !strcmp(argv[1], "--help")) { |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 310 | dump_benchmarks(coll); |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 311 | goto end; |
| 312 | } |
| 313 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 314 | printf("Unknown benchmark: '%s' for collection '%s'\n", argv[1], argv[0]); |
| 315 | ret = 1; |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 316 | goto end; |
| 317 | } |
| 318 | |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 319 | printf("Unknown collection: '%s'\n", argv[0]); |
| 320 | ret = 1; |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 321 | |
| 322 | end: |
Ingo Molnar | 4157922 | 2013-10-23 14:37:56 +0200 | [diff] [blame] | 323 | return ret; |
Hitoshi Mitake | 629cc35 | 2009-11-05 09:31:34 +0900 | [diff] [blame] | 324 | } |