Commit c3fc706e authored by Kumar Kartikeya Dwivedi's avatar Kumar Kartikeya Dwivedi Committed by Alexei Starovoitov

selftests/bpf: Fix fd cleanup in sk_lookup test

Similar to the fix in commit:
e31eec77 ("bpf: selftests: Fix fd cleanup in get_branch_snapshot")

We use designated initializer to set fds to -1 without breaking on
future changes to MAX_SERVER constant denoting the array size.

The particular close(0) occurs on non-reuseport tests, so it can be seen
with -n 115/{2,3} but not 115/4. This can cause problems with future
tests if they depend on BTF fd never being acquired as fd 0, breaking
internal libbpf assumptions.

Fixes: 0ab5539f ("selftests/bpf: Tests for BPF_SK_LOOKUP attach point")
Signed-off-by: default avatarKumar Kartikeya Dwivedi <memxor@gmail.com>
Signed-off-by: default avatarAlexei Starovoitov <ast@kernel.org>
Reviewed-by: default avatarJakub Sitnicki <jakub@cloudflare.com>
Acked-by: default avatarSong Liu <songliubraving@fb.com>
Link: https://lore.kernel.org/bpf/20211028063501.2239335-8-memxor@gmail.com
parent 087cba79
...@@ -598,7 +598,7 @@ static void query_lookup_prog(struct test_sk_lookup *skel) ...@@ -598,7 +598,7 @@ static void query_lookup_prog(struct test_sk_lookup *skel)
static void run_lookup_prog(const struct test *t) static void run_lookup_prog(const struct test *t)
{ {
int server_fds[MAX_SERVERS] = { -1 }; int server_fds[] = { [0 ... MAX_SERVERS - 1] = -1 };
int client_fd, reuse_conn_fd = -1; int client_fd, reuse_conn_fd = -1;
struct bpf_link *lookup_link; struct bpf_link *lookup_link;
int i, err; int i, err;
...@@ -1053,7 +1053,7 @@ static void run_sk_assign(struct test_sk_lookup *skel, ...@@ -1053,7 +1053,7 @@ static void run_sk_assign(struct test_sk_lookup *skel,
struct bpf_program *lookup_prog, struct bpf_program *lookup_prog,
const char *remote_ip, const char *local_ip) const char *remote_ip, const char *local_ip)
{ {
int server_fds[MAX_SERVERS] = { -1 }; int server_fds[] = { [0 ... MAX_SERVERS - 1] = -1 };
struct bpf_sk_lookup ctx; struct bpf_sk_lookup ctx;
__u64 server_cookie; __u64 server_cookie;
int i, err; int i, err;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment