Skip to content

Commit 09c4e3b

Browse files
committed
selftests/bpf: Add mprog API tests for BPF tcx opts
Add a big batch of test coverage to assert all aspects of the tcx opts attach, detach and query API: # ./vmtest.sh -- ./test_progs -t tc_opts [...] + /etc/rcS.d/S50-startup ./test_progs -t tc_opts [ 11.645647] bpf_testmod: loading out-of-tree module taints kernel. [ 11.647546] bpf_testmod: module verification failed: signature and/or required key missing - tainting kernel [ 11.710400] tsc: Refined TSC clocksource calibration: 3407.988 MHz [ 11.712352] clocksource: tsc: mask: 0xffffffffffffffff max_cycles: 0x311fc932722, max_idle_ns: 440795381586 ns [ 11.715657] clocksource: Switched to clocksource tsc torvalds#237 tc_opts_after:OK torvalds#238 tc_opts_append:OK torvalds#239 tc_opts_basic:OK torvalds#240 tc_opts_before:OK torvalds#241 tc_opts_both:OK torvalds#242 tc_opts_chain_classic:OK torvalds#243 tc_opts_dev_cleanup:OK torvalds#244 tc_opts_first:OK torvalds#245 tc_opts_invalid:OK torvalds#246 tc_opts_last:OK torvalds#247 tc_opts_mixed:OK torvalds#248 tc_opts_prepend:OK torvalds#249 tc_opts_replace:OK torvalds#250 tc_opts_revision:OK Summary: 14/0 PASSED, 0 SKIPPED, 0 FAILED Signed-off-by: Daniel Borkmann <[email protected]>
1 parent 7f81ef7 commit 09c4e3b

File tree

3 files changed

+2136
-0
lines changed

3 files changed

+2136
-0
lines changed
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,72 @@
1+
// SPDX-License-Identifier: GPL-2.0
2+
/* Copyright (c) 2023 Isovalent */
3+
#ifndef TC_HELPERS
4+
#define TC_HELPERS
5+
#include <test_progs.h>
6+
7+
static inline __u32 id_from_prog_fd(int fd)
8+
{
9+
struct bpf_prog_info prog_info = {};
10+
__u32 prog_info_len = sizeof(prog_info);
11+
int err;
12+
13+
err = bpf_obj_get_info_by_fd(fd, &prog_info, &prog_info_len);
14+
if (!ASSERT_OK(err, "id_from_prog_fd"))
15+
return 0;
16+
17+
ASSERT_NEQ(prog_info.id, 0, "prog_info.id");
18+
return prog_info.id;
19+
}
20+
21+
static inline __u32 id_from_link_fd(int fd)
22+
{
23+
struct bpf_link_info link_info = {};
24+
__u32 link_info_len = sizeof(link_info);
25+
int err;
26+
27+
err = bpf_link_get_info_by_fd(fd, &link_info, &link_info_len);
28+
if (!ASSERT_OK(err, "id_from_link_fd"))
29+
return 0;
30+
31+
ASSERT_NEQ(link_info.id, 0, "link_info.id");
32+
return link_info.id;
33+
}
34+
35+
static inline __u32 ifindex_from_link_fd(int fd)
36+
{
37+
struct bpf_link_info link_info = {};
38+
__u32 link_info_len = sizeof(link_info);
39+
int err;
40+
41+
err = bpf_link_get_info_by_fd(fd, &link_info, &link_info_len);
42+
if (!ASSERT_OK(err, "id_from_link_fd"))
43+
return 0;
44+
45+
return link_info.tcx.ifindex;
46+
}
47+
48+
static inline void __assert_mprog_count(int target, int expected, bool miniq, int ifindex)
49+
{
50+
__u32 count = 0, attach_flags = 0;
51+
int err;
52+
53+
err = bpf_prog_query(ifindex, target, 0, &attach_flags,
54+
NULL, &count);
55+
ASSERT_EQ(count, expected, "count");
56+
if (!expected && !miniq)
57+
ASSERT_EQ(err, -ENOENT, "prog_query");
58+
else
59+
ASSERT_EQ(err, 0, "prog_query");
60+
}
61+
62+
static inline void assert_mprog_count(int target, int expected)
63+
{
64+
__assert_mprog_count(target, expected, false, loopback);
65+
}
66+
67+
static inline void assert_mprog_count_ifindex(int ifindex, int target, int expected)
68+
{
69+
__assert_mprog_count(target, expected, false, ifindex);
70+
}
71+
72+
#endif /* TC_HELPERS */

0 commit comments

Comments
 (0)