Commit 85c6c957 authored by Magnus Karlsson's avatar Magnus Karlsson Committed by Daniel Borkmann

selftests: xsk: Specify number of sockets to create

Add the ability in the test specification to specify numbers of
sockets to create. The default is one socket. This is then used to
remove test specific if-statements around the bpf_res tests.
Signed-off-by: default avatarMagnus Karlsson <magnus.karlsson@intel.com>
Signed-off-by: default avatarDaniel Borkmann <daniel@iogearbox.net>
Acked-by: default avatarMaciej Fijalkowski <maciej.fijalkowski@intel.com>
Link: https://lore.kernel.org/bpf/20210907071928.9750-12-magnus.karlsson@gmail.com
parent 55be575d
...@@ -231,7 +231,7 @@ static void gen_udp_csum(struct udphdr *udp_hdr, struct iphdr *ip_hdr) ...@@ -231,7 +231,7 @@ static void gen_udp_csum(struct udphdr *udp_hdr, struct iphdr *ip_hdr)
udp_csum(ip_hdr->saddr, ip_hdr->daddr, UDP_PKT_SIZE, IPPROTO_UDP, (u16 *)udp_hdr); udp_csum(ip_hdr->saddr, ip_hdr->daddr, UDP_PKT_SIZE, IPPROTO_UDP, (u16 *)udp_hdr);
} }
static int xsk_configure_umem(struct xsk_umem_info *umem, void *buffer, u64 size, int idx) static int xsk_configure_umem(struct xsk_umem_info *umem, void *buffer, u64 size)
{ {
struct xsk_umem_config cfg = { struct xsk_umem_config cfg = {
.fill_size = XSK_RING_PROD__DEFAULT_NUM_DESCS, .fill_size = XSK_RING_PROD__DEFAULT_NUM_DESCS,
...@@ -410,6 +410,7 @@ static void __test_spec_init(struct test_spec *test, struct ifobject *ifobj_tx, ...@@ -410,6 +410,7 @@ static void __test_spec_init(struct test_spec *test, struct ifobject *ifobj_tx,
test->ifobj_rx = ifobj_rx; test->ifobj_rx = ifobj_rx;
test->current_step = 0; test->current_step = 0;
test->total_steps = 1; test->total_steps = 1;
test->nb_sockets = 1;
} }
static void test_spec_init(struct test_spec *test, struct ifobject *ifobj_tx, static void test_spec_init(struct test_spec *test, struct ifobject *ifobj_tx,
...@@ -770,46 +771,37 @@ static void tx_stats_validate(struct ifobject *ifobject) ...@@ -770,46 +771,37 @@ static void tx_stats_validate(struct ifobject *ifobject)
static void thread_common_ops(struct test_spec *test, struct ifobject *ifobject) static void thread_common_ops(struct test_spec *test, struct ifobject *ifobject)
{ {
u64 umem_sz = ifobject->umem->num_frames * ifobject->umem->frame_size; u32 i;
int mmap_flags = MAP_PRIVATE | MAP_ANONYMOUS | MAP_NORESERVE;
size_t mmap_sz = umem_sz;
int ctr = 0, ret;
void *bufs;
ifobject->ns_fd = switch_namespace(ifobject->nsname); ifobject->ns_fd = switch_namespace(ifobject->nsname);
if (test_type == TEST_TYPE_BPF_RES) for (i = 0; i < test->nb_sockets; i++) {
mmap_sz *= 2; u64 umem_sz = ifobject->umem->num_frames * ifobject->umem->frame_size;
int mmap_flags = MAP_PRIVATE | MAP_ANONYMOUS | MAP_NORESERVE;
bufs = mmap(NULL, mmap_sz, PROT_READ | PROT_WRITE, mmap_flags, -1, 0); u32 ctr = 0;
if (bufs == MAP_FAILED) void *bufs;
exit_with_error(errno);
while (ctr++ < SOCK_RECONF_CTR) { bufs = mmap(NULL, umem_sz, PROT_READ | PROT_WRITE, mmap_flags, -1, 0);
ret = xsk_configure_umem(&ifobject->umem_arr[0], bufs, umem_sz, 0); if (bufs == MAP_FAILED)
if (ret) exit_with_error(errno);
exit_with_error(-ret);
ret = xsk_configure_socket(&ifobject->xsk_arr[0], &ifobject->umem_arr[0], while (ctr++ < SOCK_RECONF_CTR) {
ifobject, 0); int ret;
if (!ret)
break;
/* Retry Create Socket if it fails as xsk_socket__create() is asynchronous */ ret = xsk_configure_umem(&ifobject->umem_arr[i], bufs, umem_sz);
if (ctr >= SOCK_RECONF_CTR) if (ret)
exit_with_error(-ret); exit_with_error(-ret);
usleep(USLEEP_MAX);
}
if (test_type == TEST_TYPE_BPF_RES) { ret = xsk_configure_socket(&ifobject->xsk_arr[i], &ifobject->umem_arr[i],
ret = xsk_configure_umem(&ifobject->umem_arr[1], (u8 *)bufs + umem_sz, umem_sz, 1); ifobject, i);
if (ret) if (!ret)
exit_with_error(-ret); break;
ret = xsk_configure_socket(&ifobject->xsk_arr[1], &ifobject->umem_arr[1], /* Retry if it fails as xsk_socket__create() is asynchronous */
ifobject, 1); if (ctr >= SOCK_RECONF_CTR)
if (ret) exit_with_error(-ret);
exit_with_error(-ret); usleep(USLEEP_MAX);
}
} }
ifobject->umem = &ifobject->umem_arr[0]; ifobject->umem = &ifobject->umem_arr[0];
...@@ -959,6 +951,7 @@ static void testapp_bpf_res(struct test_spec *test) ...@@ -959,6 +951,7 @@ static void testapp_bpf_res(struct test_spec *test)
{ {
test_spec_set_name(test, "BPF_RES"); test_spec_set_name(test, "BPF_RES");
test->total_steps = 2; test->total_steps = 2;
test->nb_sockets = 2;
testapp_validate_traffic(test); testapp_validate_traffic(test);
swap_xsk_resources(test->ifobj_tx, test->ifobj_rx); swap_xsk_resources(test->ifobj_tx, test->ifobj_rx);
......
...@@ -24,7 +24,6 @@ ...@@ -24,7 +24,6 @@
#define MAX_SOCKETS 2 #define MAX_SOCKETS 2
#define MAX_TEST_NAME_SIZE 32 #define MAX_TEST_NAME_SIZE 32
#define MAX_TEARDOWN_ITER 10 #define MAX_TEARDOWN_ITER 10
#define MAX_BPF_ITER 2
#define PKT_HDR_SIZE (sizeof(struct ethhdr) + sizeof(struct iphdr) + \ #define PKT_HDR_SIZE (sizeof(struct ethhdr) + sizeof(struct iphdr) + \
sizeof(struct udphdr)) sizeof(struct udphdr))
#define MIN_PKT_SIZE 64 #define MIN_PKT_SIZE 64
...@@ -137,6 +136,7 @@ struct test_spec { ...@@ -137,6 +136,7 @@ struct test_spec {
struct ifobject *ifobj_rx; struct ifobject *ifobj_rx;
u16 total_steps; u16 total_steps;
u16 current_step; u16 current_step;
u16 nb_sockets;
char name[MAX_TEST_NAME_SIZE]; char name[MAX_TEST_NAME_SIZE];
}; };
......
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