staticstruct { constchar *prog_name; constchar *err_msg;
} spin_lock_fail_tests[] = {
{ "lock_id_kptr_preserve", "5: (bf) r1 = r0 ; R0_w=ptr_foo(id=2,ref_obj_id=2) " "R1_w=ptr_foo(id=2,ref_obj_id=2) refs=2\n6: (85) call bpf_this_cpu_ptr#154\n" "R1 type=ptr_ expected=percpu_ptr_" },
{ "lock_id_global_zero", "; R1_w=map_value(map=.data.A,ks=4,vs=4)\n2: (85) call bpf_this_cpu_ptr#154\n" "R1 type=map_value expected=percpu_ptr_" },
{ "lock_id_mapval_preserve", "[0-9]\\+: (bf) r1 = r0 ;" " R0_w=map_value(id=1,map=array_map,ks=4,vs=8)" " R1_w=map_value(id=1,map=array_map,ks=4,vs=8)\n" "[0-9]\\+: (85) call bpf_this_cpu_ptr#154\n" "R1 type=map_value expected=percpu_ptr_" },
{ "lock_id_innermapval_preserve", "[0-9]\\+: (bf) r1 = r0 ;" " R0=map_value(id=2,ks=4,vs=8)" " R1_w=map_value(id=2,ks=4,vs=8)\n" "[0-9]\\+: (85) call bpf_this_cpu_ptr#154\n" "R1 type=map_value expected=percpu_ptr_" },
{ "lock_id_mismatch_kptr_kptr", "bpf_spin_unlock of different lock" },
{ "lock_id_mismatch_kptr_global", "bpf_spin_unlock of different lock" },
{ "lock_id_mismatch_kptr_mapval", "bpf_spin_unlock of different lock" },
{ "lock_id_mismatch_kptr_innermapval", "bpf_spin_unlock of different lock" },
{ "lock_id_mismatch_global_global", "bpf_spin_unlock of different lock" },
{ "lock_id_mismatch_global_kptr", "bpf_spin_unlock of different lock" },
{ "lock_id_mismatch_global_mapval", "bpf_spin_unlock of different lock" },
{ "lock_id_mismatch_global_innermapval", "bpf_spin_unlock of different lock" },
{ "lock_id_mismatch_mapval_mapval", "bpf_spin_unlock of different lock" },
{ "lock_id_mismatch_mapval_kptr", "bpf_spin_unlock of different lock" },
{ "lock_id_mismatch_mapval_global", "bpf_spin_unlock of different lock" },
{ "lock_id_mismatch_mapval_innermapval", "bpf_spin_unlock of different lock" },
{ "lock_id_mismatch_innermapval_innermapval1", "bpf_spin_unlock of different lock"},
{ "lock_id_mismatch_innermapval_innermapval2", "bpf_spin_unlock of different lock"},
{ "lock_id_mismatch_innermapval_kptr", "bpf_spin_unlock of different lock" },
{ "lock_id_mismatch_innermapval_global", "bpf_spin_unlock of different lock" },
{ "lock_id_mismatch_innermapval_mapval", "bpf_spin_unlock of different lock" },
{ "lock_global_subprog_call1", "global function calls are not allowed while holding a lock" },
{ "lock_global_subprog_call2", "global function calls are not allowed while holding a lock" },
{ "lock_global_sleepable_helper_subprog", "global function calls are not allowed while holding a lock" },
{ "lock_global_sleepable_kfunc_subprog", "global function calls are not allowed while holding a lock" },
{ "lock_global_sleepable_subprog_indirect", "global function calls are not allowed while holding a lock" },
};
skel = test_spin_lock_fail__open_opts(&opts); if (!ASSERT_OK_PTR(skel, "test_spin_lock_fail__open_opts")) return;
prog = bpf_object__find_program_by_name(skel->obj, prog_name); if (!ASSERT_OK_PTR(prog, "bpf_object__find_program_by_name")) goto end;
bpf_program__set_autoload(prog, true);
ret = test_spin_lock_fail__load(skel); if (!ASSERT_ERR(ret, "test_spin_lock_fail__load must fail")) goto end;
/* Skip check if JIT does not support kfuncs */ if (strstr(log_buf, "JIT does not support calling kernel function")) {
test__skip(); goto end;
}
ret = match_regex(err_msg, log_buf); if (!ASSERT_GE(ret, 0, "match_regex")) goto end;
if (!ASSERT_TRUE(ret, "no match for expected error message")) {
fprintf(stderr, "Expected: %s\n", err_msg);
fprintf(stderr, "Verifier: %s\n", log_buf);
}
skel = test_spin_lock__open_and_load(); if (!ASSERT_OK_PTR(skel, "test_spin_lock__open_and_load")) return;
prog_fd = bpf_program__fd(skel->progs.bpf_spin_lock_test); for (i = 0; i < 4; i++) { int err;
for (i = 0; i < 4; i++) { if (!ASSERT_OK(pthread_join(thread_id[i], &ret), "pthread_join")) goto end; if (!ASSERT_EQ(ret, &prog_fd, "ret == prog_fd")) goto end;
}
end:
test_spin_lock__destroy(skel);
}
void test_spin_lock(void)
{ int i;
test_spin_lock_success();
for (i = 0; i < ARRAY_SIZE(spin_lock_fail_tests); i++) { if (!test__start_subtest(spin_lock_fail_tests[i].prog_name)) continue;
test_spin_lock_fail_prog(spin_lock_fail_tests[i].prog_name,
spin_lock_fail_tests[i].err_msg);
}
}
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.