summaryrefslogtreecommitdiffstats
path: root/tools/lib/subcmd/Build
diff options
context:
space:
mode:
authorYonghong Song <yhs@fb.com>2018-09-11 23:09:11 +0200
committerAlexei Starovoitov <ast@kernel.org>2018-09-11 23:26:30 +0200
commit9d0b3c1f1451d1b9a33de3c70ae3d50ccd77db1a (patch)
treeb5cca3c959f55bd55798f13f7f55cbbc7e54949c /tools/lib/subcmd/Build
parentMerge branch 'progarray_mapinmap_dump' (diff)
downloadlinux-9d0b3c1f1451d1b9a33de3c70ae3d50ccd77db1a.tar.xz
linux-9d0b3c1f1451d1b9a33de3c70ae3d50ccd77db1a.zip
tools/bpf: fix a netlink recv issue
Commit f7010770fbac ("tools/bpf: move bpf/lib netlink related functions into a new file") introduced a while loop for the netlink recv path. This while loop is needed since the buffer in recv syscall may not be enough to hold all the information and in such cases multiple recv calls are needed. There is a bug introduced by the above commit as the while loop may block on recv syscall if there is no more messages are expected. The netlink message header flag NLM_F_MULTI is used to indicate that more messages are expected and this patch fixed the bug by doing further recv syscall only if multipart message is expected. The patch added another fix regarding to message length of 0. When netlink recv returns message length of 0, there will be no more messages for returning data so the while loop can end. Fixes: f7010770fbac ("tools/bpf: move bpf/lib netlink related functions into a new file") Reported-by: Björn Töpel <bjorn.topel@intel.com> Tested-by: Björn Töpel <bjorn.topel@intel.com> Signed-off-by: Yonghong Song <yhs@fb.com> Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Diffstat (limited to 'tools/lib/subcmd/Build')
0 files changed, 0 insertions, 0 deletions