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