#include #include #include "tests.h" #include "debug.h" #include "util.h" #include "perf-hooks.h" static void sigsegv_handler(int sig __maybe_unused) { pr_debug("SIGSEGV is observed as expected, try to recover.\n"); perf_hooks__recover(); signal(SIGSEGV, SIG_DFL); raise(SIGSEGV); exit(-1); } static void the_hook(void *_hook_flags) { int *hook_flags = _hook_flags; int *p = NULL; *hook_flags = 1234; /* Generate a segfault, test perf_hooks__recover */ *p = 0; } int test__perf_hooks(int subtest __maybe_unused) { int hook_flags = 0; signal(SIGSEGV, sigsegv_handler); perf_hooks__set_hook("test", the_hook, &hook_flags); perf_hooks__invoke_test(); /* hook is triggered? */ if (hook_flags != 1234) { pr_debug("Setting failed: %d (%p)\n", hook_flags, &hook_flags); return TEST_FAIL; } /* the buggy hook is removed? */ if (perf_hooks__get_hook("test")) return TEST_FAIL; return TEST_OK; } 5eeacf1820a08305c2b0960febfa190f5a6dd63'/> net-next plumbingsTobias Klauser
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid S. Miller <davem@davemloft.net>2017-02-11 02:31:11 -0500
committerDavid S. Miller <davem@davemloft.net>2017-02-11 02:31:11 -0500
commit35eeacf1820a08305c2b0960febfa190f5a6dd63 (patch)
treef1227c7384ee01d3f029cc5f82223234e6456c5f /net/core/tso.c
parentbed45f79a2afc9d7c279b880dfcac8f27d513b50 (diff)
parent1ee18329fae936089c6c599250ae92482ff2b81f (diff)
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net
Diffstat (limited to 'net/core/tso.c')