2012-11-10 07:46:41 +07:00
|
|
|
#ifndef TESTS_H
|
|
|
|
#define TESTS_H
|
|
|
|
|
2013-06-07 20:37:03 +07:00
|
|
|
#define TEST_ASSERT_VAL(text, cond) \
|
|
|
|
do { \
|
|
|
|
if (!(cond)) { \
|
|
|
|
pr_debug("FAILED %s:%d %s\n", __FILE__, __LINE__, text); \
|
|
|
|
return -1; \
|
|
|
|
} \
|
|
|
|
} while (0)
|
|
|
|
|
2015-05-12 02:30:20 +07:00
|
|
|
#define TEST_ASSERT_EQUAL(text, val, expected) \
|
|
|
|
do { \
|
|
|
|
if (val != expected) { \
|
|
|
|
pr_debug("FAILED %s:%d %s (%d != %d)\n", \
|
|
|
|
__FILE__, __LINE__, text, val, expected); \
|
|
|
|
return -1; \
|
|
|
|
} \
|
|
|
|
} while (0)
|
|
|
|
|
2012-12-19 21:33:39 +07:00
|
|
|
enum {
|
|
|
|
TEST_OK = 0,
|
|
|
|
TEST_FAIL = -1,
|
|
|
|
TEST_SKIP = -2,
|
|
|
|
};
|
|
|
|
|
2015-10-05 21:40:19 +07:00
|
|
|
struct test {
|
|
|
|
const char *desc;
|
|
|
|
int (*func)(void);
|
|
|
|
};
|
|
|
|
|
2012-11-10 07:46:42 +07:00
|
|
|
/* Tests */
|
2012-11-10 07:46:41 +07:00
|
|
|
int test__vmlinux_matches_kallsyms(void);
|
2015-04-16 20:52:53 +07:00
|
|
|
int test__openat_syscall_event(void);
|
|
|
|
int test__openat_syscall_event_on_all_cpus(void);
|
2012-11-10 07:46:44 +07:00
|
|
|
int test__basic_mmap(void);
|
2012-11-10 07:46:45 +07:00
|
|
|
int test__PERF_RECORD(void);
|
2012-11-10 07:46:46 +07:00
|
|
|
int test__rdpmc(void);
|
2012-11-10 07:46:47 +07:00
|
|
|
int test__perf_evsel__roundtrip_name_test(void);
|
2012-11-10 07:46:48 +07:00
|
|
|
int test__perf_evsel__tp_sched_test(void);
|
2015-04-16 20:52:53 +07:00
|
|
|
int test__syscall_openat_tp_fields(void);
|
2012-11-10 07:46:50 +07:00
|
|
|
int test__pmu(void);
|
2012-11-10 07:46:51 +07:00
|
|
|
int test__attr(void);
|
|
|
|
int test__dso_data(void);
|
2014-05-12 19:43:53 +07:00
|
|
|
int test__dso_data_cache(void);
|
2014-05-12 19:50:03 +07:00
|
|
|
int test__dso_data_reopen(void);
|
2012-11-10 07:46:51 +07:00
|
|
|
int test__parse_events(void);
|
2012-12-10 15:29:57 +07:00
|
|
|
int test__hists_link(void);
|
2012-12-14 23:06:13 +07:00
|
|
|
int test__python_use(void);
|
2013-03-11 01:41:10 +07:00
|
|
|
int test__bp_signal(void);
|
2013-03-11 01:41:11 +07:00
|
|
|
int test__bp_signal_overflow(void);
|
2013-03-15 12:58:11 +07:00
|
|
|
int test__task_exit(void);
|
2013-03-18 09:41:47 +07:00
|
|
|
int test__sw_clock_freq(void);
|
2013-06-28 20:22:19 +07:00
|
|
|
int test__perf_time_to_tsc(void);
|
2013-08-07 18:38:45 +07:00
|
|
|
int test__code_reading(void);
|
2013-08-27 15:23:13 +07:00
|
|
|
int test__sample_parsing(void);
|
2013-09-01 01:50:53 +07:00
|
|
|
int test__keep_tracking(void);
|
2013-09-05 03:18:16 +07:00
|
|
|
int test__parse_no_sample_id_all(void);
|
2014-01-07 19:47:22 +07:00
|
|
|
int test__dwarf_unwind(void);
|
2014-04-25 10:28:14 +07:00
|
|
|
int test__hists_filter(void);
|
2014-03-05 23:20:31 +07:00
|
|
|
int test__mmap_thread_lookup(void);
|
2014-03-17 20:39:00 +07:00
|
|
|
int test__thread_mg_share(void);
|
2014-05-12 12:43:18 +07:00
|
|
|
int test__hists_output(void);
|
2014-05-23 16:04:42 +07:00
|
|
|
int test__hists_cumulate(void);
|
2014-08-16 02:08:36 +07:00
|
|
|
int test__switch_tracking(void);
|
2014-09-04 04:02:59 +07:00
|
|
|
int test__fdarray__filter(void);
|
|
|
|
int test__fdarray__add(void);
|
perf tools: Add kmod_path__parse function
Provides united way of parsing kernel module path
into several components.
The new kmod_path__parse function and few defines:
int __kmod_path__parse(struct kmod_path *m, const char *path,
bool alloc_name, bool alloc_ext);
#define kmod_path__parse(__m, __p) __kmod_path__parse(__m, __p, false, false)
#define kmod_path__parse_name(__m, __p) __kmod_path__parse(__m, __p, true , false)
#define kmod_path__parse_ext(__m, __p) __kmod_path__parse(__m, __p, false, true)
parse kernel module @path and updates @m argument like:
@comp - true if @path contains supported compression suffix,
false otherwise
@kmod - true if @path contains '.ko' suffix in right position,
false otherwise
@name - if (@alloc_name && @kmod) is true, it contains strdup-ed base name
of the kernel module without suffixes, otherwise strudup-ed
base name of @path
@ext - if (@alloc_ext && @comp) is true, it contains strdup-ed string
the compression suffix
It returns 0 if there's no strdup error, -ENOMEM otherwise.
Signed-off-by: Jiri Olsa <jolsa@kernel.org>
Acked-by: Namhyung Kim <namhyung@kernel.org>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com>
Cc: David Ahern <dsahern@gmail.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/n/tip-9t6eqg8j610r94l743hkntiv@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
2015-02-05 21:40:25 +07:00
|
|
|
int test__kmod_path__parse(void);
|
2015-06-26 16:29:08 +07:00
|
|
|
int test__thread_map(void);
|
2015-07-08 17:04:02 +07:00
|
|
|
int test__llvm(void);
|
2015-09-02 19:15:26 +07:00
|
|
|
int test__insn_x86(void);
|
2015-09-04 15:58:31 +07:00
|
|
|
int test_session_topology(void);
|
2012-11-10 07:46:42 +07:00
|
|
|
|
2015-03-27 20:08:01 +07:00
|
|
|
#if defined(__x86_64__) || defined(__i386__) || defined(__arm__) || defined(__aarch64__)
|
2014-01-07 19:47:28 +07:00
|
|
|
#ifdef HAVE_DWARF_UNWIND_SUPPORT
|
2014-01-07 19:47:22 +07:00
|
|
|
struct thread;
|
|
|
|
struct perf_sample;
|
|
|
|
int test__arch_unwind_sample(struct perf_sample *sample,
|
|
|
|
struct thread *thread);
|
|
|
|
#endif
|
|
|
|
#endif
|
2012-11-10 07:46:41 +07:00
|
|
|
#endif /* TESTS_H */
|