mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-15 23:14:31 +08:00
4975223b81
Just like the BPF guys did when faced with failures with map creation, etc, i.e. their solution is: tools/testing/selftests/bpf/bpf_rlimit.h For perf use this function in 'perf test' and in 'perf trace'. Make it bump to 4 times the current value, if it fails twice the current value and if it still fails, warn that things like BPF map creation may fail, to help in diagnosing the problem. Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Alexei Starovoitov <ast@kernel.org> Cc: Daniel Borkmann <daniel@iogearbox.net> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Namhyung Kim <namhyung@kernel.org> Link: https://lkml.kernel.org/n/tip-muvqef2i7n6pzqbmu7tn2d2y@git.kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
30 lines
730 B
C
30 lines
730 B
C
/* SPDX-License-Identifier: LGPL-2.1 */
|
|
|
|
#include "util/debug.h"
|
|
#include "util/rlimit.h"
|
|
#include <sys/time.h>
|
|
#include <sys/resource.h>
|
|
|
|
/*
|
|
* Bump the memlock so that we can get bpf maps of a reasonable size,
|
|
* like the ones used with 'perf trace' and with 'perf test bpf',
|
|
* improve this to some specific request if needed.
|
|
*/
|
|
void rlimit__bump_memlock(void)
|
|
{
|
|
struct rlimit rlim;
|
|
|
|
if (getrlimit(RLIMIT_MEMLOCK, &rlim) == 0) {
|
|
rlim.rlim_cur *= 4;
|
|
rlim.rlim_max *= 4;
|
|
|
|
if (setrlimit(RLIMIT_MEMLOCK, &rlim) < 0) {
|
|
rlim.rlim_cur /= 2;
|
|
rlim.rlim_max /= 2;
|
|
|
|
if (setrlimit(RLIMIT_MEMLOCK, &rlim) < 0)
|
|
pr_debug("Couldn't bump rlimit(MEMLOCK), failures may take place when creating BPF maps, etc\n");
|
|
}
|
|
}
|
|
}
|