The benchmark is similar to the pipe benchmark. It creates two processes, one is calling syscalls, and another process is handling them via seccomp user notifications. It measures the time required to run a specified number of interations. $ ./perf bench sched seccomp-notify --sync-mode --loop 1000000 # Running 'sched/seccomp-notify' benchmark: # Executed 1000000 system calls Total time: 2.769 [sec] 2.769629 usecs/op 361059 ops/sec $ ./perf bench sched seccomp-notify # Running 'sched/seccomp-notify' benchmark: # Executed 1000000 system calls Total time: 8.571 [sec] 8.571119 usecs/op 116670 ops/sec Signed-off-by: Andrei Vagin <avagin@google.com> Acked-by: "Peter Zijlstra (Intel)" <peterz@infradead.org> Link: https://lore.kernel.org/r/20230308073201.3102738-7-avagin@google.com Link: https://lore.kernel.org/r/20230630051953.454638-1-avagin@gmail.com [kees: Added PRIu64 format string] Signed-off-by: Kees Cook <keescook@chromium.org>
70 lines
2.3 KiB
C
70 lines
2.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef BENCH_H
|
|
#define BENCH_H
|
|
|
|
#include <sys/time.h>
|
|
|
|
extern struct timeval bench__start, bench__end, bench__runtime;
|
|
|
|
/*
|
|
* The madvise transparent hugepage constants were added in glibc
|
|
* 2.13. For compatibility with older versions of glibc, define these
|
|
* tokens if they are not already defined.
|
|
*/
|
|
# ifndef MADV_HUGEPAGE
|
|
# define MADV_HUGEPAGE 14
|
|
# endif
|
|
# ifndef MADV_NOHUGEPAGE
|
|
# define MADV_NOHUGEPAGE 15
|
|
# endif
|
|
|
|
int bench_numa(int argc, const char **argv);
|
|
int bench_sched_messaging(int argc, const char **argv);
|
|
int bench_sched_pipe(int argc, const char **argv);
|
|
int bench_sched_seccomp_notify(int argc, const char **argv);
|
|
int bench_syscall_basic(int argc, const char **argv);
|
|
int bench_syscall_getpgid(int argc, const char **argv);
|
|
int bench_syscall_fork(int argc, const char **argv);
|
|
int bench_syscall_execve(int argc, const char **argv);
|
|
int bench_mem_memcpy(int argc, const char **argv);
|
|
int bench_mem_memset(int argc, const char **argv);
|
|
int bench_mem_find_bit(int argc, const char **argv);
|
|
int bench_futex_hash(int argc, const char **argv);
|
|
int bench_futex_wake(int argc, const char **argv);
|
|
int bench_futex_wake_parallel(int argc, const char **argv);
|
|
int bench_futex_requeue(int argc, const char **argv);
|
|
/* pi futexes */
|
|
int bench_futex_lock_pi(int argc, const char **argv);
|
|
int bench_epoll_wait(int argc, const char **argv);
|
|
int bench_epoll_ctl(int argc, const char **argv);
|
|
int bench_synthesize(int argc, const char **argv);
|
|
int bench_kallsyms_parse(int argc, const char **argv);
|
|
int bench_inject_build_id(int argc, const char **argv);
|
|
int bench_evlist_open_close(int argc, const char **argv);
|
|
int bench_breakpoint_thread(int argc, const char **argv);
|
|
int bench_breakpoint_enable(int argc, const char **argv);
|
|
int bench_pmu_scan(int argc, const char **argv);
|
|
|
|
#define BENCH_FORMAT_DEFAULT_STR "default"
|
|
#define BENCH_FORMAT_DEFAULT 0
|
|
#define BENCH_FORMAT_SIMPLE_STR "simple"
|
|
#define BENCH_FORMAT_SIMPLE 1
|
|
|
|
#define BENCH_FORMAT_UNKNOWN -1
|
|
|
|
extern int bench_format;
|
|
extern unsigned int bench_repeat;
|
|
|
|
#ifndef HAVE_PTHREAD_ATTR_SETAFFINITY_NP
|
|
#include <pthread.h>
|
|
#include <linux/compiler.h>
|
|
static inline int pthread_attr_setaffinity_np(pthread_attr_t *attr __maybe_unused,
|
|
size_t cpusetsize __maybe_unused,
|
|
cpu_set_t *cpuset __maybe_unused)
|
|
{
|
|
return 0;
|
|
}
|
|
#endif
|
|
|
|
#endif
|