2012-11-10 08:46:41 +08:00
|
|
|
#ifndef TESTS_H
|
|
|
|
#define TESTS_H
|
|
|
|
|
2013-06-07 21:37:03 +08: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 03:30:20 +08: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 22:33:39 +08:00
|
|
|
enum {
|
|
|
|
TEST_OK = 0,
|
|
|
|
TEST_FAIL = -1,
|
|
|
|
TEST_SKIP = -2,
|
|
|
|
};
|
|
|
|
|
2012-11-10 08:46:42 +08:00
|
|
|
/* Tests */
|
2012-11-10 08:46:41 +08:00
|
|
|
int test__vmlinux_matches_kallsyms(void);
|
2015-04-16 21:52:53 +08:00
|
|
|
int test__openat_syscall_event(void);
|
|
|
|
int test__openat_syscall_event_on_all_cpus(void);
|
2012-11-10 08:46:44 +08:00
|
|
|
int test__basic_mmap(void);
|
2012-11-10 08:46:45 +08:00
|
|
|
int test__PERF_RECORD(void);
|
2012-11-10 08:46:46 +08:00
|
|
|
int test__rdpmc(void);
|
2012-11-10 08:46:47 +08:00
|
|
|
int test__perf_evsel__roundtrip_name_test(void);
|
2012-11-10 08:46:48 +08:00
|
|
|
int test__perf_evsel__tp_sched_test(void);
|
2015-04-16 21:52:53 +08:00
|
|
|
int test__syscall_openat_tp_fields(void);
|
2012-11-10 08:46:50 +08:00
|
|
|
int test__pmu(void);
|
2012-11-10 08:46:51 +08:00
|
|
|
int test__attr(void);
|
|
|
|
int test__dso_data(void);
|
2014-05-12 20:43:53 +08:00
|
|
|
int test__dso_data_cache(void);
|
2014-05-12 20:50:03 +08:00
|
|
|
int test__dso_data_reopen(void);
|
2012-11-10 08:46:51 +08:00
|
|
|
int test__parse_events(void);
|
2012-12-10 16:29:57 +08:00
|
|
|
int test__hists_link(void);
|
2012-12-15 00:06:13 +08:00
|
|
|
int test__python_use(void);
|
2013-03-11 02:41:10 +08:00
|
|
|
int test__bp_signal(void);
|
2013-03-11 02:41:11 +08:00
|
|
|
int test__bp_signal_overflow(void);
|
2013-03-15 13:58:11 +08:00
|
|
|
int test__task_exit(void);
|
2013-03-18 10:41:47 +08:00
|
|
|
int test__sw_clock_freq(void);
|
2013-06-28 21:22:19 +08:00
|
|
|
int test__perf_time_to_tsc(void);
|
2013-08-07 19:38:45 +08:00
|
|
|
int test__code_reading(void);
|
2013-08-27 16:23:13 +08:00
|
|
|
int test__sample_parsing(void);
|
2013-09-01 02:50:53 +08:00
|
|
|
int test__keep_tracking(void);
|
2013-09-05 04:18:16 +08:00
|
|
|
int test__parse_no_sample_id_all(void);
|
2014-01-07 20:47:22 +08:00
|
|
|
int test__dwarf_unwind(void);
|
2014-04-25 11:28:14 +08:00
|
|
|
int test__hists_filter(void);
|
2014-03-06 00:20:31 +08:00
|
|
|
int test__mmap_thread_lookup(void);
|
2014-03-17 21:39:00 +08:00
|
|
|
int test__thread_mg_share(void);
|
2014-05-12 13:43:18 +08:00
|
|
|
int test__hists_output(void);
|
2014-05-23 17:04:42 +08:00
|
|
|
int test__hists_cumulate(void);
|
2014-08-16 03:08:36 +08:00
|
|
|
int test__switch_tracking(void);
|
2014-09-04 05:02:59 +08: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 22:40:25 +08:00
|
|
|
int test__kmod_path__parse(void);
|
2015-06-26 17:29:08 +08:00
|
|
|
int test__thread_map(void);
|
2015-07-08 18:04:02 +08:00
|
|
|
int test__llvm(void);
|
2015-09-02 20:15:26 +08:00
|
|
|
int test__insn_x86(void);
|
2012-11-10 08:46:42 +08:00
|
|
|
|
2015-03-27 21:08:01 +08:00
|
|
|
#if defined(__x86_64__) || defined(__i386__) || defined(__arm__) || defined(__aarch64__)
|
2014-01-07 20:47:28 +08:00
|
|
|
#ifdef HAVE_DWARF_UNWIND_SUPPORT
|
2014-01-07 20:47:22 +08:00
|
|
|
struct thread;
|
|
|
|
struct perf_sample;
|
|
|
|
int test__arch_unwind_sample(struct perf_sample *sample,
|
|
|
|
struct thread *thread);
|
|
|
|
#endif
|
|
|
|
#endif
|
2012-11-10 08:46:41 +08:00
|
|
|
#endif /* TESTS_H */
|