xref: /linux/tools/testing/selftests/bpf/xskxceiver.h (revision 40ccd6aa3e2e05be93394e3cd560c718dedfcc77)
1 /* SPDX-License-Identifier: GPL-2.0
2  * Copyright(c) 2020 Intel Corporation.
3  */
4 
5 #ifndef XSKXCEIVER_H_
6 #define XSKXCEIVER_H_
7 
8 #include <limits.h>
9 
10 #include "xsk_xdp_progs.skel.h"
11 #include "xsk_xdp_common.h"
12 
13 #ifndef SOL_XDP
14 #define SOL_XDP 283
15 #endif
16 
17 #ifndef AF_XDP
18 #define AF_XDP 44
19 #endif
20 
21 #ifndef PF_XDP
22 #define PF_XDP AF_XDP
23 #endif
24 
25 #ifndef SO_BUSY_POLL_BUDGET
26 #define SO_BUSY_POLL_BUDGET 70
27 #endif
28 
29 #ifndef SO_PREFER_BUSY_POLL
30 #define SO_PREFER_BUSY_POLL 69
31 #endif
32 
33 #define TEST_PASS 0
34 #define TEST_FAILURE -1
35 #define TEST_CONTINUE 1
36 #define TEST_SKIP 2
37 #define MAX_INTERFACES 2
38 #define MAX_INTERFACE_NAME_CHARS 16
39 #define MAX_TEST_NAME_SIZE 48
40 #define MAX_TEARDOWN_ITER 10
41 #define PKT_HDR_SIZE (sizeof(struct ethhdr) + 2) /* Just to align the data in the packet */
42 #define MIN_PKT_SIZE 64
43 #define MAX_ETH_PKT_SIZE 1518
44 #define MAX_ETH_JUMBO_SIZE 9000
45 #define USLEEP_MAX 10000
46 #define SOCK_RECONF_CTR 10
47 #define DEFAULT_BATCH_SIZE 64
48 #define POLL_TMOUT 1000
49 #define THREAD_TMOUT 3
50 #define DEFAULT_PKT_CNT (4 * 1024)
51 #define DEFAULT_UMEM_BUFFERS (DEFAULT_PKT_CNT / 4)
52 #define RX_FULL_RXQSIZE 32
53 #define UMEM_HEADROOM_TEST_SIZE 128
54 #define XSK_UMEM__INVALID_FRAME_SIZE (MAX_ETH_JUMBO_SIZE + 1)
55 #define XSK_UMEM__LARGE_FRAME_SIZE (3 * 1024)
56 #define XSK_UMEM__MAX_FRAME_SIZE (4 * 1024)
57 #define XSK_DESC__INVALID_OPTION (0xffff)
58 #define XSK_DESC__MAX_SKB_FRAGS 18
59 #define HUGEPAGE_SIZE (2 * 1024 * 1024)
60 #define PKT_DUMP_NB_TO_PRINT 16
61 #define RUN_ALL_TESTS UINT_MAX
62 #define NUM_MAC_ADDRESSES 4
63 
64 #define print_verbose(x...) do { if (opt_verbose) ksft_print_msg(x); } while (0)
65 
66 enum test_mode {
67 	TEST_MODE_SKB,
68 	TEST_MODE_DRV,
69 	TEST_MODE_ZC,
70 	TEST_MODE_ALL
71 };
72 
73 struct xsk_umem_info {
74 	struct xsk_ring_prod fq;
75 	struct xsk_ring_cons cq;
76 	struct xsk_umem *umem;
77 	u64 next_buffer;
78 	u32 num_frames;
79 	u32 frame_headroom;
80 	void *buffer;
81 	u32 frame_size;
82 	u32 base_addr;
83 	bool unaligned_mode;
84 };
85 
86 struct xsk_socket_info {
87 	struct xsk_ring_cons rx;
88 	struct xsk_ring_prod tx;
89 	struct xsk_umem_info *umem;
90 	struct xsk_socket *xsk;
91 	struct pkt_stream *pkt_stream;
92 	u32 outstanding_tx;
93 	u32 rxqsize;
94 	u32 batch_size;
95 	u8 dst_mac[ETH_ALEN];
96 	u8 src_mac[ETH_ALEN];
97 };
98 
99 struct pkt {
100 	int offset;
101 	u32 len;
102 	u32 pkt_nb;
103 	bool valid;
104 	u16 options;
105 };
106 
107 struct pkt_stream {
108 	u32 nb_pkts;
109 	u32 current_pkt_nb;
110 	struct pkt *pkts;
111 	u32 max_pkt_len;
112 	u32 nb_rx_pkts;
113 	u32 nb_valid_entries;
114 	bool verbatim;
115 };
116 
117 struct set_hw_ring {
118 	u32 default_tx;
119 	u32 default_rx;
120 };
121 
122 struct ifobject;
123 struct test_spec;
124 typedef int (*validation_func_t)(struct ifobject *ifobj);
125 typedef void *(*thread_func_t)(void *arg);
126 typedef int (*test_func_t)(struct test_spec *test);
127 
128 struct ifobject {
129 	char ifname[MAX_INTERFACE_NAME_CHARS];
130 	struct xsk_socket_info *xsk;
131 	struct xsk_socket_info *xsk_arr;
132 	struct xsk_umem_info *umem;
133 	thread_func_t func_ptr;
134 	validation_func_t validation_func;
135 	struct xsk_xdp_progs *xdp_progs;
136 	struct bpf_map *xskmap;
137 	struct bpf_program *xdp_prog;
138 	struct ethtool_ringparam ring;
139 	struct set_hw_ring set_ring;
140 	enum test_mode mode;
141 	int ifindex;
142 	int mtu;
143 	u32 bind_flags;
144 	u32 xdp_zc_max_segs;
145 	bool tx_on;
146 	bool rx_on;
147 	bool use_poll;
148 	bool busy_poll;
149 	bool use_fill_ring;
150 	bool release_rx;
151 	bool shared_umem;
152 	bool use_metadata;
153 	bool unaligned_supp;
154 	bool multi_buff_supp;
155 	bool multi_buff_zc_supp;
156 	bool hw_ring_size_supp;
157 };
158 
159 struct test_spec {
160 	struct ifobject *ifobj_tx;
161 	struct ifobject *ifobj_rx;
162 	struct pkt_stream *tx_pkt_stream_default;
163 	struct pkt_stream *rx_pkt_stream_default;
164 	struct bpf_program *xdp_prog_rx;
165 	struct bpf_program *xdp_prog_tx;
166 	struct bpf_map *xskmap_rx;
167 	struct bpf_map *xskmap_tx;
168 	test_func_t test_func;
169 	int mtu;
170 	u16 total_steps;
171 	u16 current_step;
172 	u16 nb_sockets;
173 	bool fail;
174 	bool set_ring;
175 	enum test_mode mode;
176 	char name[MAX_TEST_NAME_SIZE];
177 };
178 
179 pthread_barrier_t barr;
180 pthread_mutex_t pacing_mutex = PTHREAD_MUTEX_INITIALIZER;
181 
182 int pkts_in_flight;
183 
184 static const u8 g_mac[ETH_ALEN] = {0x55, 0x44, 0x33, 0x22, 0x11, 0x00};
185 
186 #endif				/* XSKXCEIVER_H_ */
187