a104f0ea99
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>
41 lines
751 B
C
41 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);
|