blob: bf2517d6de7079dacffb9d78e006952dd593823d [file] [log] [blame]
Wang Nana0748652016-11-26 07:03:28 +00001#include <signal.h>
2#include <stdlib.h>
3
4#include "tests.h"
5#include "debug.h"
6#include "util.h"
7#include "perf-hooks.h"
8
9static void sigsegv_handler(int sig __maybe_unused)
10{
11 pr_debug("SIGSEGV is observed as expected, try to recover.\n");
12 perf_hooks__recover();
13 signal(SIGSEGV, SIG_DFL);
14 raise(SIGSEGV);
15 exit(-1);
16}
17
Wang Nana0748652016-11-26 07:03:28 +000018
Wang Nan8ad85e92016-11-26 07:03:29 +000019static void the_hook(void *_hook_flags)
Wang Nana0748652016-11-26 07:03:28 +000020{
Wang Nan8ad85e92016-11-26 07:03:29 +000021 int *hook_flags = _hook_flags;
Wang Nana0748652016-11-26 07:03:28 +000022 int *p = NULL;
23
Wang Nan8ad85e92016-11-26 07:03:29 +000024 *hook_flags = 1234;
Wang Nana0748652016-11-26 07:03:28 +000025
26 /* Generate a segfault, test perf_hooks__recover */
27 *p = 0;
28}
29
Arnaldo Carvalho de Melo81f17c92017-08-03 15:16:31 -030030int test__perf_hooks(struct test *test __maybe_unused, int subtest __maybe_unused)
Wang Nana0748652016-11-26 07:03:28 +000031{
Wang Nan8ad85e92016-11-26 07:03:29 +000032 int hook_flags = 0;
33
Wang Nana0748652016-11-26 07:03:28 +000034 signal(SIGSEGV, sigsegv_handler);
Wang Nan8ad85e92016-11-26 07:03:29 +000035 perf_hooks__set_hook("test", the_hook, &hook_flags);
Wang Nana0748652016-11-26 07:03:28 +000036 perf_hooks__invoke_test();
37
38 /* hook is triggered? */
Wang Nan8ad85e92016-11-26 07:03:29 +000039 if (hook_flags != 1234) {
40 pr_debug("Setting failed: %d (%p)\n", hook_flags, &hook_flags);
Wang Nana0748652016-11-26 07:03:28 +000041 return TEST_FAIL;
Wang Nan8ad85e92016-11-26 07:03:29 +000042 }
Wang Nana0748652016-11-26 07:03:28 +000043
44 /* the buggy hook is removed? */
45 if (perf_hooks__get_hook("test"))
46 return TEST_FAIL;
47 return TEST_OK;
48}