linux-stable/tools/perf/tests/workloads/brstack.c
Namhyung Kim a104f0ea99 perf test: Add 'brstack' test workload
The brstack is to run different kinds of branches repeatedly.  This is
necessary for brstack test case to verify if it has correct branch info.

  $ perf test -w brstack

I renamed the internal functions to have brstack_ prefix as it's too
generic name.

Add a -U_FORTIFY_SOURCE to the brstack CFLAGS, as the main perf flags
set it and it requires building with optimization, and this new test has
a -O0.

Signed-off-by: Namhyung Kim <namhyung@kernel.org>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Athira Jajeev <atrajeev@linux.vnet.ibm.com>
Cc: German Gomez <german.gomez@arm.com>
Cc: Ian Rogers <irogers@google.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: James Clark <james.clark@arm.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Leo Yan <leo.yan@linaro.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Zhengjun Xing <zhengjun.xing@linux.intel.com>
Link: https://lore.kernel.org/r/20221116233854.1596378-10-namhyung@kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
2022-11-23 10:28:01 -03:00

40 lines
751 B
C

/* SPDX-License-Identifier: GPL-2.0 */
#include <stdlib.h>
#include "../tests.h"
#define BENCH_RUNS 999999
static volatile int cnt;
static void brstack_bar(void) {
} /* return */
static void brstack_foo(void) {
brstack_bar(); /* call */
} /* return */
static void brstack_bench(void) {
void (*brstack_foo_ind)(void) = brstack_foo;
if ((cnt++) % 3) /* branch (cond) */
brstack_foo(); /* call */
brstack_bar(); /* call */
brstack_foo_ind(); /* call (ind) */
}
static int brstack(int argc, const char **argv)
{
int num_loops = BENCH_RUNS;
if (argc > 0)
num_loops = atoi(argv[0]);
while (1) {
if ((cnt++) > num_loops)
break;
brstack_bench();/* call */
} /* branch (uncond) */
return 0;
}
DEFINE_WORKLOAD(brstack);