blob: a693bcf017ea2c01366eb91d598cc863d6688c7d [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001// SPDX-License-Identifier: GPL-2.0
Wang Nana0748652016-11-26 07:03:28 +00002#include <signal.h>
3#include <stdlib.h>
4
5#include "tests.h"
6#include "debug.h"
7#include "util.h"
8#include "perf-hooks.h"
9
10static void sigsegv_handler(int sig __maybe_unused)
11{
12 pr_debug("SIGSEGV is observed as expected, try to recover.\n");
13 perf_hooks__recover();
14 signal(SIGSEGV, SIG_DFL);
15 raise(SIGSEGV);
16 exit(-1);
17}
18
Wang Nana0748652016-11-26 07:03:28 +000019
Wang Nan8ad85e92016-11-26 07:03:29 +000020static void the_hook(void *_hook_flags)
Wang Nana0748652016-11-26 07:03:28 +000021{
Wang Nan8ad85e92016-11-26 07:03:29 +000022 int *hook_flags = _hook_flags;
Wang Nana0748652016-11-26 07:03:28 +000023 int *p = NULL;
24
Wang Nan8ad85e92016-11-26 07:03:29 +000025 *hook_flags = 1234;
Wang Nana0748652016-11-26 07:03:28 +000026
27 /* Generate a segfault, test perf_hooks__recover */
28 *p = 0;
29}
30
Arnaldo Carvalho de Melo81f17c92017-08-03 15:16:31 -030031int test__perf_hooks(struct test *test __maybe_unused, int subtest __maybe_unused)
Wang Nana0748652016-11-26 07:03:28 +000032{
Wang Nan8ad85e92016-11-26 07:03:29 +000033 int hook_flags = 0;
34
Wang Nana0748652016-11-26 07:03:28 +000035 signal(SIGSEGV, sigsegv_handler);
Wang Nan8ad85e92016-11-26 07:03:29 +000036 perf_hooks__set_hook("test", the_hook, &hook_flags);
Wang Nana0748652016-11-26 07:03:28 +000037 perf_hooks__invoke_test();
38
39 /* hook is triggered? */
Wang Nan8ad85e92016-11-26 07:03:29 +000040 if (hook_flags != 1234) {
41 pr_debug("Setting failed: %d (%p)\n", hook_flags, &hook_flags);
Wang Nana0748652016-11-26 07:03:28 +000042 return TEST_FAIL;
Wang Nan8ad85e92016-11-26 07:03:29 +000043 }
Wang Nana0748652016-11-26 07:03:28 +000044
45 /* the buggy hook is removed? */
46 if (perf_hooks__get_hook("test"))
47 return TEST_FAIL;
48 return TEST_OK;
49}