Commit 5801e96b authored by Ian Rogers's avatar Ian Rogers Committed by Arnaldo Carvalho de Melo

perf test: Convert bpf tests to test cases.

Use null terminated array of test cases rather than the previous sub
test functions.
Signed-off-by: default avatarIan Rogers <irogers@google.com>
Tested-by: default avatarSohaib Mohamed <sohaib.amhmd@gmail.com>
Acked-by: default avatarJiri Olsa <jolsa@redhat.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Brendan Higgins <brendanhiggins@google.com>
Cc: Daniel Latypov <dlatypov@google.com>
Cc: David Gow <davidgow@google.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Jin Yao <yao.jin@linux.intel.com>
Cc: John Garry <john.garry@huawei.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Paul Clarke <pc@us.ibm.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Link: https://lore.kernel.org/r/20211104064208.3156807-14-irogers@google.comSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 44a8528c
...@@ -62,7 +62,6 @@ static int llseek_loop(void) ...@@ -62,7 +62,6 @@ static int llseek_loop(void)
static struct { static struct {
enum test_llvm__testcase prog_id; enum test_llvm__testcase prog_id;
const char *desc;
const char *name; const char *name;
const char *msg_compile_fail; const char *msg_compile_fail;
const char *msg_load_fail; const char *msg_load_fail;
...@@ -72,7 +71,6 @@ static struct { ...@@ -72,7 +71,6 @@ static struct {
} bpf_testcase_table[] = { } bpf_testcase_table[] = {
{ {
.prog_id = LLVM_TESTCASE_BASE, .prog_id = LLVM_TESTCASE_BASE,
.desc = "Basic BPF filtering",
.name = "[basic_bpf_test]", .name = "[basic_bpf_test]",
.msg_compile_fail = "fix 'perf test LLVM' first", .msg_compile_fail = "fix 'perf test LLVM' first",
.msg_load_fail = "load bpf object failed", .msg_load_fail = "load bpf object failed",
...@@ -81,7 +79,6 @@ static struct { ...@@ -81,7 +79,6 @@ static struct {
}, },
{ {
.prog_id = LLVM_TESTCASE_BASE, .prog_id = LLVM_TESTCASE_BASE,
.desc = "BPF pinning",
.name = "[bpf_pinning]", .name = "[bpf_pinning]",
.msg_compile_fail = "fix kbuild first", .msg_compile_fail = "fix kbuild first",
.msg_load_fail = "check your vmlinux setting?", .msg_load_fail = "check your vmlinux setting?",
...@@ -92,7 +89,6 @@ static struct { ...@@ -92,7 +89,6 @@ static struct {
#ifdef HAVE_BPF_PROLOGUE #ifdef HAVE_BPF_PROLOGUE
{ {
.prog_id = LLVM_TESTCASE_BPF_PROLOGUE, .prog_id = LLVM_TESTCASE_BPF_PROLOGUE,
.desc = "BPF prologue generation",
.name = "[bpf_prologue_test]", .name = "[bpf_prologue_test]",
.msg_compile_fail = "fix kbuild first", .msg_compile_fail = "fix kbuild first",
.msg_load_fail = "check your vmlinux setting?", .msg_load_fail = "check your vmlinux setting?",
...@@ -283,18 +279,6 @@ static int __test__bpf(int idx) ...@@ -283,18 +279,6 @@ static int __test__bpf(int idx)
return ret; return ret;
} }
static int test__bpf_subtest_get_nr(void)
{
return (int)ARRAY_SIZE(bpf_testcase_table);
}
static const char *test__bpf_subtest_get_desc(int i)
{
if (i < 0 || i >= (int)ARRAY_SIZE(bpf_testcase_table))
return NULL;
return bpf_testcase_table[i].desc;
}
static int check_env(void) static int check_env(void)
{ {
int err; int err;
...@@ -325,7 +309,7 @@ static int check_env(void) ...@@ -325,7 +309,7 @@ static int check_env(void)
return 0; return 0;
} }
static int test__bpf(struct test_suite *test __maybe_unused, int i) static int test__bpf(int i)
{ {
int err; int err;
...@@ -343,31 +327,61 @@ static int test__bpf(struct test_suite *test __maybe_unused, int i) ...@@ -343,31 +327,61 @@ static int test__bpf(struct test_suite *test __maybe_unused, int i)
err = __test__bpf(i); err = __test__bpf(i);
return err; return err;
} }
#endif
#else static int test__basic_bpf_test(struct test_suite *test __maybe_unused,
static int test__bpf_subtest_get_nr(void) int subtest __maybe_unused)
{ {
return 0; #ifdef HAVE_LIBBPF_SUPPORT
return test__bpf(0);
#else
pr_debug("Skip BPF test because BPF support is not compiled\n");
return TEST_SKIP;
#endif
} }
static const char *test__bpf_subtest_get_desc(int i __maybe_unused) static int test__bpf_pinning(struct test_suite *test __maybe_unused,
int subtest __maybe_unused)
{ {
return NULL; #ifdef HAVE_LIBBPF_SUPPORT
return test__bpf(1);
#else
pr_debug("Skip BPF test because BPF support is not compiled\n");
return TEST_SKIP;
#endif
} }
static int test__bpf(struct test_suite *test __maybe_unused, int i __maybe_unused) static int test__bpf_prologue_test(struct test_suite *test __maybe_unused,
int subtest __maybe_unused)
{ {
#if defined(HAVE_LIBBPF_SUPPORT) && defined(HAVE_BPF_PROLOGUE)
return test__bpf(2);
#else
pr_debug("Skip BPF test because BPF support is not compiled\n"); pr_debug("Skip BPF test because BPF support is not compiled\n");
return TEST_SKIP; return TEST_SKIP;
#endif
} }
static struct test_case bpf_tests[] = {
#ifdef HAVE_LIBBPF_SUPPORT
TEST_CASE("Basic BPF filtering", basic_bpf_test),
TEST_CASE("BPF pinning", bpf_pinning),
#ifdef HAVE_BPF_PROLOGUE
TEST_CASE("BPF prologue generation", bpf_prologue_test),
#else
TEST_CASE_REASON("BPF prologue generation", bpf_prologue_test, "not compiled in"),
#endif #endif
#else
TEST_CASE_REASON("Basic BPF filtering", basic_bpf_test, "not compiled in"),
TEST_CASE_REASON("BPF pinning", bpf_pinning, "not compiled in"),
TEST_CASE_REASON("BPF prologue generation", bpf_prologue_test, "not compiled in"),
#endif
{ .name = NULL, }
};
struct test_suite suite__bpf = { struct test_suite suite__bpf = {
.desc = "BPF filter", .desc = "BPF filter",
.func = test__bpf, .test_cases = bpf_tests,
.subtest = { .subtest = { .skip_if_fail = true, },
.skip_if_fail = true,
.get_nr = test__bpf_subtest_get_nr,
.get_desc = test__bpf_subtest_get_desc,
},
}; };
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment