linux-stable/tools/perf/tests/workloads/thloop.c
Ian Rogers 1962ab6f6e perf test workload thloop: Make count increments atomic
The count variable is incremented by multiple threads, doing so
without an atomic operation causes thread sanitizer warnings. Switch
to using relaxed atomics.

Signed-off-by: Ian Rogers <irogers@google.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: https://lore.kernel.org/r/20230114215251.271678-1-irogers@google.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
2023-01-19 13:42:06 -03:00

53 lines
895 B
C

/* SPDX-License-Identifier: GPL-2.0 */
#include <pthread.h>
#include <stdlib.h>
#include <signal.h>
#include <unistd.h>
#include <linux/compiler.h>
#include "../tests.h"
static volatile sig_atomic_t done;
static volatile unsigned count;
/* We want to check this symbol in perf report */
noinline void test_loop(void);
static void sighandler(int sig __maybe_unused)
{
done = 1;
}
noinline void test_loop(void)
{
while (!done)
__atomic_fetch_add(&count, 1, __ATOMIC_RELAXED);
}
static void *thfunc(void *arg)
{
void (*loop_fn)(void) = arg;
loop_fn();
return NULL;
}
static int thloop(int argc, const char **argv)
{
int sec = 1;
pthread_t th;
if (argc > 0)
sec = atoi(argv[0]);
signal(SIGINT, sighandler);
signal(SIGALRM, sighandler);
alarm(sec);
pthread_create(&th, NULL, thfunc, test_loop);
test_loop();
pthread_join(th, NULL);
return 0;
}
DEFINE_WORKLOAD(thloop);