cregit-Linux how code gets into the kernel

Release 4.10 tools/perf/builtin-bench.c

Directory: tools/perf
/*
 * builtin-bench.c
 *
 * General benchmarking collections provided by perf
 *
 * Copyright (C) 2009, Hitoshi Mitake <mitake@dcl.info.waseda.ac.jp>
 */

/*
 * Available benchmark collection list:
 *
 *  sched ... scheduler and IPC performance
 *  mem   ... memory access performance
 *  numa  ... NUMA scheduling and MM performance
 *  futex ... Futex performance
 */
#include "perf.h"
#include "util/util.h"
#include <subcmd/parse-options.h>
#include "builtin.h"
#include "bench/bench.h"

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/prctl.h>


typedef int (*bench_fn_t)(int argc, const char **argv, const char *prefix);


struct bench {
	
const char	*name;
	
const char	*summary;
	
bench_fn_t	fn;
};

#ifdef HAVE_LIBNUMA_SUPPORT

static struct bench numa_benchmarks[] = {
	{ "mem",	"Benchmark for NUMA workloads",			bench_numa		},
	{ "all",	"Run all NUMA benchmarks",			NULL			},
	{ NULL,		NULL,						NULL			}
};
#endif


static struct bench sched_benchmarks[] = {
	{ "messaging",	"Benchmark for scheduling and IPC",		bench_sched_messaging	},
	{ "pipe",	"Benchmark for pipe() between two processes",	bench_sched_pipe	},
	{ "all",	"Run all scheduler benchmarks",		NULL			},
	{ NULL,		NULL,						NULL			}
};


static struct bench mem_benchmarks[] = {
	{ "memcpy",	"Benchmark for memcpy() functions",		bench_mem_memcpy	},
	{ "memset",	"Benchmark for memset() functions",		bench_mem_memset	},
	{ "all",	"Run all memory access benchmarks",		NULL			},
	{ NULL,		NULL,						NULL			}
};


static struct bench futex_benchmarks[] = {
	{ "hash",	"Benchmark for futex hash table",               bench_futex_hash	},
	{ "wake",	"Benchmark for futex wake calls",               bench_futex_wake	},
	{ "wake-parallel", "Benchmark for parallel futex wake calls",   bench_futex_wake_parallel },
	{ "requeue",	"Benchmark for futex requeue calls",            bench_futex_requeue	},
	/* pi-futexes */
	{ "lock-pi",	"Benchmark for futex lock_pi calls",            bench_futex_lock_pi	},
	{ "all",	"Run all futex benchmarks",			NULL			},
	{ NULL,		NULL,						NULL			}
};


struct collection {
	
const char	*name;
	
const char	*summary;
	
struct bench	*benchmarks;
};


static struct collection collections[] = {
	{ "sched",	"Scheduler and IPC benchmarks",			sched_benchmarks	},
	{ "mem",	"Memory access benchmarks",			mem_benchmarks		},
#ifdef HAVE_LIBNUMA_SUPPORT
	{ "numa",	"NUMA scheduling and MM benchmarks",		numa_benchmarks		},
#endif
	{"futex",       "Futex stressing benchmarks",                   futex_benchmarks        },
	{ "all",	"All benchmarks",				NULL			},
	{ NULL,		NULL,						NULL			}
};

/* Iterate over all benchmark collections: */

#define for_each_collection(coll) \
	for (coll = collections; coll->name; coll++)

/* Iterate over all benchmarks within a collection: */

#define for_each_bench(coll, bench) \
	for (bench = coll->benchmarks; bench && bench->name; bench++)


static void dump_benchmarks(struct collection *coll) { struct bench *bench; printf("\n # List of available benchmarks for collection '%s':\n\n", coll->name); for_each_bench(coll, bench) printf("%14s: %s\n", bench->name, bench->summary); printf("\n"); }

Contributors

PersonTokensPropCommitsCommitProp
hitoshi mitakehitoshi mitake2755.10%266.67%
ingo molnaringo molnar2244.90%133.33%
Total49100.00%3100.00%

static const char *bench_format_str; /* Output/formatting style, exported to benchmark modules: */ int bench_format = BENCH_FORMAT_DEFAULT; unsigned int bench_repeat = 10; /* default number of times to repeat the run */ static const struct option bench_options[] = { OPT_STRING('f', "format", &bench_format_str, "default|simple", "Specify the output formatting style"), OPT_UINTEGER('r', "repeat", &bench_repeat, "Specify amount of times to repeat the run"), OPT_END() }; static const char * const bench_usage[] = { "perf bench [<common options>] <collection> <benchmark> [<options>]", NULL };
static void print_usage(void) { struct collection *coll; int i; printf("Usage: \n"); for (i = 0; bench_usage[i]; i++) printf("\t%s\n", bench_usage[i]); printf("\n"); printf(" # List of all available benchmark collections:\n\n"); for_each_collection(coll) printf("%14s: %s\n", coll->name, coll->summary); printf("\n"); }

Contributors

PersonTokensPropCommitsCommitProp
hitoshi mitakehitoshi mitake6381.82%375.00%
ingo molnaringo molnar1418.18%125.00%
Total77100.00%4100.00%


static int bench_str2int(const char *str) { if (!str) return BENCH_FORMAT_DEFAULT; if (!strcmp(str, BENCH_FORMAT_DEFAULT_STR)) return BENCH_FORMAT_DEFAULT; else if (!strcmp(str, BENCH_FORMAT_SIMPLE_STR)) return BENCH_FORMAT_SIMPLE; return BENCH_FORMAT_UNKNOWN; }

Contributors

PersonTokensPropCommitsCommitProp
hitoshi mitakehitoshi mitake4897.96%150.00%
arnaldo carvalho de meloarnaldo carvalho de melo12.04%150.00%
Total49100.00%2100.00%

/* * Run a specific benchmark but first rename the running task's ->comm[] * to something meaningful: */
static int run_bench(const char *coll_name, const char *bench_name, bench_fn_t fn, int argc, const char **argv, const char *prefix) { int size; char *name; int ret; size = strlen(coll_name) + 1 + strlen(bench_name) + 1; name = zalloc(size); BUG_ON(!name); scnprintf(name, size, "%s-%s", coll_name, bench_name); prctl(PR_SET_NAME, name); argv[0] = name; ret = fn(argc, argv, prefix); free(name); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
ingo molnaringo molnar118100.00%1100.00%
Total118100.00%1100.00%


static void run_collection(struct collection *coll) { struct bench *bench; const char *argv[2]; argv[1] = NULL; /* * TODO: * * Preparing preset parameters for * embedded, ordinary PC, HPC, etc... * would be helpful. */ for_each_bench(coll, bench) { if (!bench->fn) break; printf("# Running %s/%s benchmark...\n", coll->name, bench->name); fflush(stdout); argv[1] = bench->name; run_bench(coll->name, bench->name, bench->fn, 1, argv, NULL); printf("\n"); } }

Contributors

PersonTokensPropCommitsCommitProp
hitoshi mitakehitoshi mitake5655.45%133.33%
ingo molnaringo molnar4039.60%133.33%
namhyung kimnamhyung kim54.95%133.33%
Total101100.00%3100.00%


static void run_all_collections(void) { struct collection *coll; for_each_collection(coll) run_collection(coll); }

Contributors

PersonTokensPropCommitsCommitProp
hitoshi mitakehitoshi mitake1150.00%150.00%
ingo molnaringo molnar1150.00%150.00%
Total22100.00%2100.00%


int cmd_bench(int argc, const char **argv, const char *prefix __maybe_unused) { struct collection *coll; int ret = 0; if (argc < 2) { /* No collection specified. */ print_usage(); goto end; } argc = parse_options(argc, argv, bench_options, bench_usage, PARSE_OPT_STOP_AT_NON_OPTION); bench_format = bench_str2int(bench_format_str); if (bench_format == BENCH_FORMAT_UNKNOWN) { printf("Unknown format descriptor: '%s'\n", bench_format_str); goto end; } if (bench_repeat == 0) { printf("Invalid repeat option: Must specify a positive value\n"); goto end; } if (argc < 1) { print_usage(); goto end; } if (!strcmp(argv[0], "all")) { run_all_collections(); goto end; } for_each_collection(coll) { struct bench *bench; if (strcmp(coll->name, argv[0])) continue; if (argc < 2) { /* No bench specified. */ dump_benchmarks(coll); goto end; } if (!strcmp(argv[1], "all")) { run_collection(coll); goto end; } for_each_bench(coll, bench) { if (strcmp(bench->name, argv[1])) continue; if (bench_format == BENCH_FORMAT_DEFAULT) printf("# Running '%s/%s' benchmark:\n", coll->name, bench->name); fflush(stdout); ret = run_bench(coll->name, bench->name, bench->fn, argc-1, argv+1, prefix); goto end; } if (!strcmp(argv[1], "-h") || !strcmp(argv[1], "--help")) { dump_benchmarks(coll); goto end; } printf("Unknown benchmark: '%s' for collection '%s'\n", argv[1], argv[0]); ret = 1; goto end; } printf("Unknown collection: '%s'\n", argv[0]); ret = 1; end: return ret; }

Contributors

PersonTokensPropCommitsCommitProp
hitoshi mitakehitoshi mitake27377.12%450.00%
ingo molnaringo molnar5916.67%112.50%
davidlohr buesodavidlohr bueso164.52%112.50%
namhyung kimnamhyung kim51.41%112.50%
irina tirdeairina tirdea10.28%112.50%
Total354100.00%8100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
hitoshi mitakehitoshi mitake66655.78%520.83%
ingo molnaringo molnar39433.00%625.00%
davidlohr buesodavidlohr bueso1089.05%625.00%
namhyung kimnamhyung kim100.84%14.17%
jan beulichjan beulich70.59%14.17%
peter hurleypeter hurley40.34%14.17%
arnaldo carvalho de meloarnaldo carvalho de melo20.17%14.17%
josh poimboeufjosh poimboeuf10.08%14.17%
irina tirdeairina tirdea10.08%14.17%
patrick palkapatrick palka10.08%14.17%
Total1194100.00%24100.00%
Directory: tools/perf
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.