/* * Putting kprobe on bpf_fentry_test1 that calls bpf_kfunc_common_test * kfunc, which has also kprobe on. The latter won't get triggered due * to kprobe recursion check and kprobe missed counter is incremented.
*/ staticvoid test_missed_perf_kprobe(void)
{
LIBBPF_OPTS(bpf_test_run_opts, topts); struct bpf_link_info info = {}; struct missed_kprobe *skel;
__u32 len = sizeof(info); int err, prog_fd;
skel = missed_kprobe__open_and_load(); if (!ASSERT_OK_PTR(skel, "missed_kprobe__open_and_load")) goto cleanup;
err = missed_kprobe__attach(skel); if (!ASSERT_OK(err, "missed_kprobe__attach")) goto cleanup;
/* * Putting kprobe.multi on bpf_fentry_test1 that calls bpf_kfunc_common_test * kfunc which has 3 perf event kprobes and 1 kprobe.multi attached. * * Because fprobe (kprobe.multi attach layear) does not have strict recursion * check the kprobe's bpf_prog_active check is hit for test2-5.
*/ staticvoid test_missed_kprobe_recursion(void)
{
LIBBPF_OPTS(bpf_test_run_opts, topts); struct missed_kprobe_recursion *skel; int err, prog_fd;
skel = missed_kprobe_recursion__open_and_load(); if (!ASSERT_OK_PTR(skel, "missed_kprobe_recursion__open_and_load")) goto cleanup;
err = missed_kprobe_recursion__attach(skel); if (!ASSERT_OK(err, "missed_kprobe_recursion__attach")) goto cleanup;
/* * Putting kprobe on bpf_fentry_test1 that calls bpf_printk and invokes * bpf_trace_printk tracepoint. The bpf_trace_printk tracepoint has test[234] * programs attached to it. * * Because kprobe execution goes through bpf_prog_active check, programs * attached to the tracepoint will fail the recursion check and increment * the recursion_misses stats.
*/ staticvoid test_missed_tp_recursion(void)
{
LIBBPF_OPTS(bpf_test_run_opts, topts); struct missed_tp_recursion *skel; int err, prog_fd;
skel = missed_tp_recursion__open_and_load(); if (!ASSERT_OK_PTR(skel, "missed_tp_recursion__open_and_load")) goto cleanup;
err = missed_tp_recursion__attach(skel); if (!ASSERT_OK(err, "missed_tp_recursion__attach")) goto cleanup;
void test_missed(void)
{ if (test__start_subtest("perf_kprobe"))
test_missed_perf_kprobe(); if (test__start_subtest("kprobe_recursion"))
test_missed_kprobe_recursion(); if (test__start_subtest("tp_recursion"))
test_missed_tp_recursion();
}
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.