1 // SPDX-License-Identifier: GPL-2.0
3 #include <test_progs.h>
4 #include <linux/pkt_cls.h>
6 #include "test_tc_change_tail.skel.h"
7 #include "socket_helpers.h"
11 void test_tc_change_tail(void)
13 LIBBPF_OPTS(bpf_tcx_opts, tcx_opts);
14 struct test_tc_change_tail *skel = NULL;
15 struct bpf_link *link;
20 skel = test_tc_change_tail__open_and_load();
21 if (!ASSERT_OK_PTR(skel, "test_tc_change_tail__open_and_load"))
24 link = bpf_program__attach_tcx(skel->progs.change_tail, LO_IFINDEX,
26 if (!ASSERT_OK_PTR(link, "bpf_program__attach_tcx"))
29 skel->links.change_tail = link;
30 ret = create_pair(AF_INET, SOCK_DGRAM, &c1, &p1);
31 if (!ASSERT_OK(ret, "create_pair"))
34 ret = xsend(p1, "Tr", 2, 0);
35 ASSERT_EQ(ret, 2, "xsend(p1)");
36 ret = recv(c1, buf, 2, 0);
37 ASSERT_EQ(ret, 2, "recv(c1)");
38 ASSERT_EQ(skel->data->change_tail_ret, 0, "change_tail_ret");
40 ret = xsend(p1, "G", 1, 0);
41 ASSERT_EQ(ret, 1, "xsend(p1)");
42 ret = recv(c1, buf, 2, 0);
43 ASSERT_EQ(ret, 1, "recv(c1)");
44 ASSERT_EQ(skel->data->change_tail_ret, 0, "change_tail_ret");
46 ret = xsend(p1, "E", 1, 0);
47 ASSERT_EQ(ret, 1, "xsend(p1)");
48 ret = recv(c1, buf, 1, 0);
49 ASSERT_EQ(ret, 1, "recv(c1)");
50 ASSERT_EQ(skel->data->change_tail_ret, -EINVAL, "change_tail_ret");
52 ret = xsend(p1, "Z", 1, 0);
53 ASSERT_EQ(ret, 1, "xsend(p1)");
54 ret = recv(c1, buf, 1, 0);
55 ASSERT_EQ(ret, 1, "recv(c1)");
56 ASSERT_EQ(skel->data->change_tail_ret, -EINVAL, "change_tail_ret");
61 test_tc_change_tail__destroy(skel);