Lines Matching refs:spec

124 static void free_test_spec(struct test_spec *spec)  in free_test_spec()  argument
127 free_msgs(&spec->priv.expect_msgs); in free_test_spec()
128 free_msgs(&spec->unpriv.expect_msgs); in free_test_spec()
129 free_msgs(&spec->priv.expect_xlated); in free_test_spec()
130 free_msgs(&spec->unpriv.expect_xlated); in free_test_spec()
131 free_msgs(&spec->priv.jited); in free_test_spec()
132 free_msgs(&spec->unpriv.jited); in free_test_spec()
134 free(spec->priv.name); in free_test_spec()
135 free(spec->unpriv.name); in free_test_spec()
136 spec->priv.name = NULL; in free_test_spec()
137 spec->unpriv.name = NULL; in free_test_spec()
364 struct test_spec *spec) in parse_test_spec() argument
379 memset(spec, 0, sizeof(*spec)); in parse_test_spec()
381 spec->prog_name = bpf_program__name(prog); in parse_test_spec()
382 spec->prog_flags = testing_prog_flags(); in parse_test_spec()
390 func_id = btf__find_by_name_kind(btf, spec->prog_name, BTF_KIND_FUNC); in parse_test_spec()
392 ASSERT_FAIL("failed to find FUNC BTF type for '%s'", spec->prog_name); in parse_test_spec()
413 spec->priv.expect_failure = true; in parse_test_spec()
414 spec->mode_mask |= PRIV; in parse_test_spec()
416 spec->priv.expect_failure = false; in parse_test_spec()
417 spec->mode_mask |= PRIV; in parse_test_spec()
419 spec->unpriv.expect_failure = true; in parse_test_spec()
420 spec->mode_mask |= UNPRIV; in parse_test_spec()
423 spec->unpriv.expect_failure = false; in parse_test_spec()
424 spec->mode_mask |= UNPRIV; in parse_test_spec()
427 spec->auxiliary = true; in parse_test_spec()
428 spec->mode_mask |= PRIV; in parse_test_spec()
430 spec->auxiliary = true; in parse_test_spec()
431 spec->mode_mask |= UNPRIV; in parse_test_spec()
433 err = push_msg(msg, &spec->priv.expect_msgs); in parse_test_spec()
436 spec->mode_mask |= PRIV; in parse_test_spec()
438 err = push_msg(msg, &spec->unpriv.expect_msgs); in parse_test_spec()
441 spec->mode_mask |= UNPRIV; in parse_test_spec()
449 &spec->priv.jited); in parse_test_spec()
452 spec->mode_mask |= PRIV; in parse_test_spec()
461 &spec->unpriv.jited); in parse_test_spec()
464 spec->mode_mask |= UNPRIV; in parse_test_spec()
468 &spec->priv.expect_xlated); in parse_test_spec()
471 spec->mode_mask |= PRIV; in parse_test_spec()
474 &spec->unpriv.expect_xlated); in parse_test_spec()
477 spec->mode_mask |= UNPRIV; in parse_test_spec()
480 err = parse_retval(val, &spec->priv.retval, "__retval"); in parse_test_spec()
483 spec->priv.execute = true; in parse_test_spec()
484 spec->mode_mask |= PRIV; in parse_test_spec()
487 err = parse_retval(val, &spec->unpriv.retval, "__retval_unpriv"); in parse_test_spec()
490 spec->mode_mask |= UNPRIV; in parse_test_spec()
491 spec->unpriv.execute = true; in parse_test_spec()
495 err = parse_int(val, &spec->log_level, "test log level"); in parse_test_spec()
506 update_flags(&spec->prog_flags, BPF_F_STRICT_ALIGNMENT, clear); in parse_test_spec()
508 update_flags(&spec->prog_flags, BPF_F_ANY_ALIGNMENT, clear); in parse_test_spec()
510 update_flags(&spec->prog_flags, BPF_F_TEST_RND_HI32, clear); in parse_test_spec()
512 update_flags(&spec->prog_flags, BPF_F_TEST_STATE_FREQ, clear); in parse_test_spec()
514 update_flags(&spec->prog_flags, BPF_F_SLEEPABLE, clear); in parse_test_spec()
516 update_flags(&spec->prog_flags, BPF_F_XDP_HAS_FRAGS, clear); in parse_test_spec()
518 update_flags(&spec->prog_flags, BPF_F_TEST_REG_INVARIANTS, clear); in parse_test_spec()
523 update_flags(&spec->prog_flags, flags, clear); in parse_test_spec()
543 spec->btf_custom_path = s + sizeof(TEST_BTF_PATH) - 1; in parse_test_spec()
547 spec->arch_mask = arch_mask ?: -1; in parse_test_spec()
549 if (spec->mode_mask == 0) in parse_test_spec()
550 spec->mode_mask = PRIV; in parse_test_spec()
553 description = spec->prog_name; in parse_test_spec()
555 if (spec->mode_mask & PRIV) { in parse_test_spec()
556 spec->priv.name = strdup(description); in parse_test_spec()
557 if (!spec->priv.name) { in parse_test_spec()
564 if (spec->mode_mask & UNPRIV) { in parse_test_spec()
578 spec->unpriv.name = name; in parse_test_spec()
581 if (spec->mode_mask & (PRIV | UNPRIV)) { in parse_test_spec()
583 spec->unpriv.expect_failure = spec->priv.expect_failure; in parse_test_spec()
586 spec->unpriv.retval = spec->priv.retval; in parse_test_spec()
587 spec->unpriv.execute = spec->priv.execute; in parse_test_spec()
590 if (spec->unpriv.expect_msgs.cnt == 0) in parse_test_spec()
591 clone_msgs(&spec->priv.expect_msgs, &spec->unpriv.expect_msgs); in parse_test_spec()
592 if (spec->unpriv.expect_xlated.cnt == 0) in parse_test_spec()
593 clone_msgs(&spec->priv.expect_xlated, &spec->unpriv.expect_xlated); in parse_test_spec()
594 if (spec->unpriv.jited.cnt == 0) in parse_test_spec()
595 clone_msgs(&spec->priv.jited, &spec->unpriv.jited); in parse_test_spec()
598 spec->valid = true; in parse_test_spec()
603 free_test_spec(spec); in parse_test_spec()
608 struct test_spec *spec, in prepare_case() argument
625 if ((spec->log_level & 3) < min_log_level) in prepare_case()
626 bpf_program__set_log_level(prog, (spec->log_level & 4) | min_log_level); in prepare_case()
628 bpf_program__set_log_level(prog, spec->log_level); in prepare_case()
631 bpf_program__set_flags(prog, prog_flags | spec->prog_flags); in prepare_case()
759 static bool can_execute_unpriv(struct test_loader *tester, struct test_spec *spec) in can_execute_unpriv() argument
765 if ((spec->prog_flags & BPF_F_ANY_ALIGNMENT) && !EFFICIENT_UNALIGNED_ACCESS) in can_execute_unpriv()
831 static bool should_do_test_run(struct test_spec *spec, struct test_subspec *subspec) in should_do_test_run() argument
839 if ((spec->prog_flags & BPF_F_ANY_ALIGNMENT) && !EFFICIENT_UNALIGNED_ACCESS) { in should_do_test_run()
888 struct test_spec *spec, in run_subtest() argument
891 struct test_subspec *subspec = unpriv ? &spec->unpriv : &spec->priv; in run_subtest()
905 if ((get_current_arch() & spec->arch_mask) == 0) { in run_subtest()
911 if (!can_execute_unpriv(tester, spec)) { in run_subtest()
923 open_opts->btf_custom_path = spec->btf_custom_path; in run_subtest()
935 if (strcmp(bpf_program__name(tprog_iter), spec->prog_name) == 0) { in run_subtest()
948 prepare_case(tester, spec, tobj, tprog); in run_subtest()
997 if (should_do_test_run(spec, subspec)) { in run_subtest()
1091 struct test_spec *spec = &specs[i++]; in process_subtest() local
1093 if (!spec->valid || spec->auxiliary) in process_subtest()
1096 if (spec->mode_mask & PRIV) in process_subtest()
1098 specs, spec, false); in process_subtest()
1099 if (spec->mode_mask & UNPRIV) in process_subtest()
1101 specs, spec, true); in process_subtest()