Skip to content

Commit

Permalink
selftests/bpf: no need to track next_match_pos in struct test_loader
Browse files Browse the repository at this point in the history
The call stack for validate_case() function looks as follows:
- test_loader__run_subtests()
  - process_subtest()
    - run_subtest()
      - prepare_case(), which does 'tester->next_match_pos = 0';
      - validate_case(), which increments tester->next_match_pos.

Hence, each subtest is run with next_match_pos freshly set to zero.
Meaning that there is no need to persist this variable in the
struct test_loader, use local variable instead.

Acked-by: Andrii Nakryiko <[email protected]>
Signed-off-by: Eduard Zingerman <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Alexei Starovoitov <[email protected]>
Signed-off-by: Andrii Nakryiko <[email protected]>
  • Loading branch information
eddyz87 authored and anakryiko committed Jul 29, 2024
1 parent 203e6ab commit 4ef5d6a
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 12 deletions.
19 changes: 8 additions & 11 deletions tools/testing/selftests/bpf/test_loader.c
Original file line number Diff line number Diff line change
Expand Up @@ -434,7 +434,6 @@ static void prepare_case(struct test_loader *tester,
bpf_program__set_flags(prog, prog_flags | spec->prog_flags);

tester->log_buf[0] = '\0';
tester->next_match_pos = 0;
}

static void emit_verifier_log(const char *log_buf, bool force)
Expand All @@ -450,25 +449,23 @@ static void validate_case(struct test_loader *tester,
struct bpf_program *prog,
int load_err)
{
int i, j, err;
char *match;
regmatch_t reg_match[1];
const char *log = tester->log_buf;
int i, j, err;

for (i = 0; i < subspec->expect_msg_cnt; i++) {
struct expect_msg *msg = &subspec->expect_msgs[i];
const char *match = NULL;

if (msg->substr) {
match = strstr(tester->log_buf + tester->next_match_pos, msg->substr);
match = strstr(log, msg->substr);
if (match)
tester->next_match_pos = match - tester->log_buf + strlen(msg->substr);
log += strlen(msg->substr);
} else {
err = regexec(&msg->regex,
tester->log_buf + tester->next_match_pos, 1, reg_match, 0);
err = regexec(&msg->regex, log, 1, reg_match, 0);
if (err == 0) {
match = tester->log_buf + tester->next_match_pos + reg_match[0].rm_so;
tester->next_match_pos += reg_match[0].rm_eo;
} else {
match = NULL;
match = log + reg_match[0].rm_so;
log += reg_match[0].rm_eo;
}
}

Expand Down
1 change: 0 additions & 1 deletion tools/testing/selftests/bpf/test_progs.h
Original file line number Diff line number Diff line change
Expand Up @@ -447,7 +447,6 @@ typedef int (*pre_execution_cb)(struct bpf_object *obj);
struct test_loader {
char *log_buf;
size_t log_buf_sz;
size_t next_match_pos;
pre_execution_cb pre_execution_cb;

struct bpf_object *obj;
Expand Down

0 comments on commit 4ef5d6a

Please sign in to comment.