mirror of
https://github.com/torvalds/linux
synced 2024-11-05 18:23:50 +00:00
perf tests sigtrap: Skip if running on a kernel with sleepable spinlocks
There are issues as reported that need some more investigation on the RT kernel front, till that is addressed, skip this test. This test is already skipped for multiple hardware architectures where the tested kernel feature is not supported. Acked-by: Marco Elver <elver@google.com> Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Clark Williams <williams@redhat.com> Cc: Ian Rogers <irogers@google.com> Cc: Ingo Molnar <mingo@kernel.org> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Juri Lelli <juri.lelli@redhat.com> Cc: Kate Carcia <kcarcia@redhat.com> Cc: Marco Elver <elver@google.com> Cc: Mike Galbraith <efault@gmx.de> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Link: https://lore.kernel.org/all/e368f2c848d77fbc8d259f44e2055fe469c219cf.camel@gmx.de/ Link: https://lore.kernel.org/r/20231129154718.326330-3-acme@kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
a472ee42e6
commit
650e0bde43
1 changed files with 44 additions and 2 deletions
|
@ -103,6 +103,34 @@ static bool attr_has_sigtrap(void)
|
||||||
|
|
||||||
return __btf_type__find_member_by_name(id, "sigtrap") != NULL;
|
return __btf_type__find_member_by_name(id, "sigtrap") != NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool kernel_with_sleepable_spinlocks(void)
|
||||||
|
{
|
||||||
|
const struct btf_member *member;
|
||||||
|
const struct btf_type *type;
|
||||||
|
const char *type_name;
|
||||||
|
int id;
|
||||||
|
|
||||||
|
if (!btf__available())
|
||||||
|
return false;
|
||||||
|
|
||||||
|
id = btf__find_by_name_kind(btf, "spinlock", BTF_KIND_STRUCT);
|
||||||
|
if (id < 0)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// Only RT has a "lock" member for "struct spinlock"
|
||||||
|
member = __btf_type__find_member_by_name(id, "lock");
|
||||||
|
if (member == NULL)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// But check its type as well
|
||||||
|
type = btf__type_by_id(btf, member->type);
|
||||||
|
if (!type || !btf_is_struct(type))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
type_name = btf__name_by_offset(btf, type->name_off);
|
||||||
|
return type_name && !strcmp(type_name, "rt_mutex_base");
|
||||||
|
}
|
||||||
#else /* !HAVE_BPF_SKEL */
|
#else /* !HAVE_BPF_SKEL */
|
||||||
static bool attr_has_sigtrap(void)
|
static bool attr_has_sigtrap(void)
|
||||||
{
|
{
|
||||||
|
@ -125,6 +153,11 @@ static bool attr_has_sigtrap(void)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool kernel_with_sleepable_spinlocks(void)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
static void btf__exit(void)
|
static void btf__exit(void)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -166,7 +199,7 @@ static int run_test_threads(pthread_t *threads, pthread_barrier_t *barrier)
|
||||||
|
|
||||||
static int run_stress_test(int fd, pthread_t *threads, pthread_barrier_t *barrier)
|
static int run_stress_test(int fd, pthread_t *threads, pthread_barrier_t *barrier)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret, expected_sigtraps;
|
||||||
|
|
||||||
ctx.iterate_on = 3000;
|
ctx.iterate_on = 3000;
|
||||||
|
|
||||||
|
@ -175,7 +208,16 @@ static int run_stress_test(int fd, pthread_t *threads, pthread_barrier_t *barrie
|
||||||
ret = run_test_threads(threads, barrier);
|
ret = run_test_threads(threads, barrier);
|
||||||
TEST_ASSERT_EQUAL("disable failed", ioctl(fd, PERF_EVENT_IOC_DISABLE, 0), 0);
|
TEST_ASSERT_EQUAL("disable failed", ioctl(fd, PERF_EVENT_IOC_DISABLE, 0), 0);
|
||||||
|
|
||||||
TEST_ASSERT_EQUAL("unexpected sigtraps", ctx.signal_count, NUM_THREADS * ctx.iterate_on);
|
expected_sigtraps = NUM_THREADS * ctx.iterate_on;
|
||||||
|
|
||||||
|
if (ctx.signal_count < expected_sigtraps && kernel_with_sleepable_spinlocks()) {
|
||||||
|
pr_debug("Expected %d sigtraps, got %d, running on a kernel with sleepable spinlocks.\n",
|
||||||
|
expected_sigtraps, ctx.signal_count);
|
||||||
|
pr_debug("See https://lore.kernel.org/all/e368f2c848d77fbc8d259f44e2055fe469c219cf.camel@gmx.de/\n");
|
||||||
|
return TEST_SKIP;
|
||||||
|
} else
|
||||||
|
TEST_ASSERT_EQUAL("unexpected sigtraps", ctx.signal_count, expected_sigtraps);
|
||||||
|
|
||||||
TEST_ASSERT_EQUAL("missing signals or incorrectly delivered", ctx.tids_want_signal, 0);
|
TEST_ASSERT_EQUAL("missing signals or incorrectly delivered", ctx.tids_want_signal, 0);
|
||||||
TEST_ASSERT_VAL("unexpected si_addr", ctx.first_siginfo.si_addr == &ctx.iterate_on);
|
TEST_ASSERT_VAL("unexpected si_addr", ctx.first_siginfo.si_addr == &ctx.iterate_on);
|
||||||
#if 0 /* FIXME: enable when libc's signal.h has si_perf_{type,data} */
|
#if 0 /* FIXME: enable when libc's signal.h has si_perf_{type,data} */
|
||||||
|
|
Loading…
Reference in a new issue