Commit a68977d2 authored by Magnus Karlsson's avatar Magnus Karlsson Committed by Alexei Starovoitov

libbpf: Allow for creating Rx or Tx only AF_XDP sockets

The libbpf AF_XDP code is extended to allow for the creation of Rx
only or Tx only sockets. Previously it returned an error if the socket
was not initialized for both Rx and Tx.
Signed-off-by: default avatarMagnus Karlsson <magnus.karlsson@intel.com>
Signed-off-by: default avatarAlexei Starovoitov <ast@kernel.org>
Tested-by: default avatarWilliam Tu <u9012063@gmail.com>
Acked-by: default avatarJonathan Lemon <jonathan.lemon@gmail.com>
Link: https://lore.kernel.org/bpf/1573148860-30254-4-git-send-email-magnus.karlsson@intel.com
parent 2e5d72c1
...@@ -562,7 +562,8 @@ static int xsk_setup_xdp_prog(struct xsk_socket *xsk) ...@@ -562,7 +562,8 @@ static int xsk_setup_xdp_prog(struct xsk_socket *xsk)
} }
} }
err = xsk_set_bpf_maps(xsk); if (xsk->rx)
err = xsk_set_bpf_maps(xsk);
if (err) { if (err) {
xsk_delete_bpf_maps(xsk); xsk_delete_bpf_maps(xsk);
close(xsk->prog_fd); close(xsk->prog_fd);
...@@ -583,7 +584,7 @@ int xsk_socket__create(struct xsk_socket **xsk_ptr, const char *ifname, ...@@ -583,7 +584,7 @@ int xsk_socket__create(struct xsk_socket **xsk_ptr, const char *ifname,
struct xsk_socket *xsk; struct xsk_socket *xsk;
int err; int err;
if (!umem || !xsk_ptr || !rx || !tx) if (!umem || !xsk_ptr || !(rx || tx))
return -EFAULT; return -EFAULT;
xsk = calloc(1, sizeof(*xsk)); xsk = calloc(1, sizeof(*xsk));
......
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