bpf, selftests: fix handling of sparse CPU allocations
authorMartynas Pumputis <m@lambda.lt>
Thu, 31 Jan 2019 09:19:33 +0000 (10:19 +0100)
committerDaniel Borkmann <daniel@iogearbox.net>
Thu, 31 Jan 2019 22:13:22 +0000 (23:13 +0100)
commit1bb54c4071f585ebef56ce8fdfe6026fa2cbcddd
tree7250dc1999a2829c27b5e721446c49cad6b759f3
parent9d90436ece8f2c5b4da617e679590137e54ce4cb
bpf, selftests: fix handling of sparse CPU allocations

Previously, bpf_num_possible_cpus() had a bug when calculating a
number of possible CPUs in the case of sparse CPU allocations, as
it was considering only the first range or element of
/sys/devices/system/cpu/possible.

E.g. in the case of "0,2-3" (CPU 1 is not available), the function
returned 1 instead of 3.

This patch fixes the function by making it parse all CPU ranges and
elements.

Signed-off-by: Martynas Pumputis <m@lambda.lt>
Acked-by: Yonghong Song <yhs@fb.com>
Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
tools/testing/selftests/bpf/bpf_util.h