From: Andrii Nakryiko Date: Thu, 7 Nov 2019 05:40:59 +0000 (-0800) Subject: libbpf: Fix negative FD close() in xsk_setup_xdp_prog() X-Git-Tag: v5.4.7~169 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=fe3a9c40723235f1c649a1c161011e57a785689d;p=platform%2Fkernel%2Flinux-rpi.git libbpf: Fix negative FD close() in xsk_setup_xdp_prog() [ Upstream commit 9656b346b280c3e49c8a116c3a715f966633b161 ] Fix issue reported by static analysis (Coverity). If bpf_prog_get_fd_by_id() fails, xsk_lookup_bpf_maps() will fail as well and clean-up code will attempt close() with fd=-1. Fix by checking bpf_prog_get_fd_by_id() return result and exiting early. Fixes: 10a13bb40e54 ("libbpf: remove qidconf and better support external bpf programs.") Signed-off-by: Andrii Nakryiko Signed-off-by: Daniel Borkmann Link: https://lore.kernel.org/bpf/20191107054059.313884-1-andriin@fb.com Signed-off-by: Sasha Levin --- diff --git a/tools/lib/bpf/xsk.c b/tools/lib/bpf/xsk.c index 9d534808..a73b79d 100644 --- a/tools/lib/bpf/xsk.c +++ b/tools/lib/bpf/xsk.c @@ -466,6 +466,8 @@ static int xsk_setup_xdp_prog(struct xsk_socket *xsk) } } else { xsk->prog_fd = bpf_prog_get_fd_by_id(prog_id); + if (xsk->prog_fd < 0) + return -errno; err = xsk_lookup_bpf_maps(xsk); if (err) { close(xsk->prog_fd);