blob: cf4da3d748c29fd4d126929a8b41e07c846306ee [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001// SPDX-License-Identifier: GPL-2.0
Jiri Olsa8dd2a132015-09-07 10:38:06 +02002#include <linux/err.h>
Robert Richter4e319022013-06-11 17:29:18 +02003#include <traceevent/event-parse.h>
Jiri Olsa5e24a092012-11-10 01:46:48 +01004#include "evsel.h"
5#include "tests.h"
Jiri Olsa84f5d362014-07-14 23:46:48 +02006#include "debug.h"
Jiri Olsa5e24a092012-11-10 01:46:48 +01007
Arnaldo Carvalho de Melo56933022020-11-30 09:08:24 -03008static int evsel__test_field(struct evsel *evsel, const char *name, int size, bool should_be_signed)
Jiri Olsa5e24a092012-11-10 01:46:48 +01009{
Arnaldo Carvalho de Meloefc0cdc2020-04-29 16:26:57 -030010 struct tep_format_field *field = evsel__field(evsel, name);
Jiri Olsa5e24a092012-11-10 01:46:48 +010011 int is_signed;
12 int ret = 0;
13
14 if (field == NULL) {
15 pr_debug("%s: \"%s\" field not found!\n", evsel->name, name);
16 return -1;
17 }
18
Gustavo A. R. Silva489338a2019-01-22 17:34:39 -060019 is_signed = !!(field->flags & TEP_FIELD_IS_SIGNED);
Jiri Olsa5e24a092012-11-10 01:46:48 +010020 if (should_be_signed && !is_signed) {
21 pr_debug("%s: \"%s\" signedness(%d) is wrong, should be %d\n",
22 evsel->name, name, is_signed, should_be_signed);
23 ret = -1;
24 }
25
26 if (field->size != size) {
27 pr_debug("%s: \"%s\" size (%d) should be %d!\n",
28 evsel->name, name, field->size, size);
29 ret = -1;
30 }
31
32 return ret;
33}
34
Ian Rogers33f44bf2021-11-03 23:41:51 -070035static int test__perf_evsel__tp_sched_test(struct test_suite *test __maybe_unused,
Ian Rogersd68f0362021-11-03 23:41:50 -070036 int subtest __maybe_unused)
Jiri Olsa5e24a092012-11-10 01:46:48 +010037{
Arnaldo Carvalho de Melo8f6725a2020-05-06 13:27:04 -030038 struct evsel *evsel = evsel__newtp("sched", "sched_switch");
Jiri Olsa5e24a092012-11-10 01:46:48 +010039 int ret = 0;
40
Jiri Olsa8dd2a132015-09-07 10:38:06 +020041 if (IS_ERR(evsel)) {
Arnaldo Carvalho de Melo8f6725a2020-05-06 13:27:04 -030042 pr_debug("evsel__newtp failed with %ld\n", PTR_ERR(evsel));
Jiri Olsa5e24a092012-11-10 01:46:48 +010043 return -1;
44 }
45
Arnaldo Carvalho de Melo56933022020-11-30 09:08:24 -030046 if (evsel__test_field(evsel, "prev_comm", 16, false))
Jiri Olsa5e24a092012-11-10 01:46:48 +010047 ret = -1;
48
Arnaldo Carvalho de Melo56933022020-11-30 09:08:24 -030049 if (evsel__test_field(evsel, "prev_pid", 4, true))
Jiri Olsa5e24a092012-11-10 01:46:48 +010050 ret = -1;
51
Arnaldo Carvalho de Melo56933022020-11-30 09:08:24 -030052 if (evsel__test_field(evsel, "prev_prio", 4, true))
Jiri Olsa5e24a092012-11-10 01:46:48 +010053 ret = -1;
54
Arnaldo Carvalho de Melo56933022020-11-30 09:08:24 -030055 if (evsel__test_field(evsel, "prev_state", sizeof(long), true))
Jiri Olsa5e24a092012-11-10 01:46:48 +010056 ret = -1;
57
Arnaldo Carvalho de Melo56933022020-11-30 09:08:24 -030058 if (evsel__test_field(evsel, "next_comm", 16, false))
Jiri Olsa5e24a092012-11-10 01:46:48 +010059 ret = -1;
60
Arnaldo Carvalho de Melo56933022020-11-30 09:08:24 -030061 if (evsel__test_field(evsel, "next_pid", 4, true))
Jiri Olsa5e24a092012-11-10 01:46:48 +010062 ret = -1;
63
Arnaldo Carvalho de Melo56933022020-11-30 09:08:24 -030064 if (evsel__test_field(evsel, "next_prio", 4, true))
Jiri Olsa5e24a092012-11-10 01:46:48 +010065 ret = -1;
66
Jiri Olsa5eb2dd22019-07-21 13:23:57 +020067 evsel__delete(evsel);
Jiri Olsa5e24a092012-11-10 01:46:48 +010068
Arnaldo Carvalho de Melo8f6725a2020-05-06 13:27:04 -030069 evsel = evsel__newtp("sched", "sched_wakeup");
Jiri Olsa5e24a092012-11-10 01:46:48 +010070
Jiri Olsa8dd2a132015-09-07 10:38:06 +020071 if (IS_ERR(evsel)) {
Arnaldo Carvalho de Melo8f6725a2020-05-06 13:27:04 -030072 pr_debug("evsel__newtp failed with %ld\n", PTR_ERR(evsel));
Jiri Olsa8dd2a132015-09-07 10:38:06 +020073 return -1;
74 }
75
Arnaldo Carvalho de Melo56933022020-11-30 09:08:24 -030076 if (evsel__test_field(evsel, "comm", 16, false))
Jiri Olsa5e24a092012-11-10 01:46:48 +010077 ret = -1;
78
Arnaldo Carvalho de Melo56933022020-11-30 09:08:24 -030079 if (evsel__test_field(evsel, "pid", 4, true))
Jiri Olsa5e24a092012-11-10 01:46:48 +010080 ret = -1;
81
Arnaldo Carvalho de Melo56933022020-11-30 09:08:24 -030082 if (evsel__test_field(evsel, "prio", 4, true))
Jiri Olsa5e24a092012-11-10 01:46:48 +010083 ret = -1;
84
Arnaldo Carvalho de Melo56933022020-11-30 09:08:24 -030085 if (evsel__test_field(evsel, "target_cpu", 4, true))
Jiri Olsa5e24a092012-11-10 01:46:48 +010086 ret = -1;
87
Jiri Olsa5eb2dd22019-07-21 13:23:57 +020088 evsel__delete(evsel);
Jiri Olsa5e24a092012-11-10 01:46:48 +010089 return ret;
90}
Ian Rogersd68f0362021-11-03 23:41:50 -070091
92DEFINE_SUITE("Parse sched tracepoints fields", perf_evsel__tp_sched_test);