Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
B
bcc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
bcc
Commits
8a04fb39
Commit
8a04fb39
authored
Nov 30, 2015
by
Brenden Blanco
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #298 from iovisor/bblanco_dev
Automatically bump memlock ulimit
parents
ee8e5430
4b4bd271
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
34 additions
and
3 deletions
+34
-3
src/cc/libbpf.c
src/cc/libbpf.c
+32
-1
tests/wrapper.sh.in
tests/wrapper.sh.in
+2
-2
No files found.
src/cc/libbpf.c
View file @
8a04fb39
...
...
@@ -30,6 +30,7 @@
#include <stdlib.h>
#include <string.h>
#include <sys/ioctl.h>
#include <sys/resource.h>
#include <unistd.h>
#include "libbpf.h"
...
...
@@ -67,7 +68,19 @@ int bpf_create_map(enum bpf_map_type map_type, int key_size, int value_size, int
attr
.
value_size
=
value_size
;
attr
.
max_entries
=
max_entries
;
return
syscall
(
__NR_bpf
,
BPF_MAP_CREATE
,
&
attr
,
sizeof
(
attr
));
int
ret
=
syscall
(
__NR_bpf
,
BPF_MAP_CREATE
,
&
attr
,
sizeof
(
attr
));
if
(
ret
<
0
&&
errno
==
EPERM
)
{
// see note below about the rationale for this retry
struct
rlimit
rl
=
{};
if
(
getrlimit
(
RLIMIT_MEMLOCK
,
&
rl
)
==
0
)
{
rl
.
rlim_max
=
RLIM_INFINITY
;
rl
.
rlim_cur
=
rl
.
rlim_max
;
if
(
setrlimit
(
RLIMIT_MEMLOCK
,
&
rl
)
==
0
)
ret
=
syscall
(
__NR_bpf
,
BPF_MAP_CREATE
,
&
attr
,
sizeof
(
attr
));
}
}
return
ret
;
}
int
bpf_update_elem
(
int
fd
,
void
*
key
,
void
*
value
,
unsigned
long
long
flags
)
...
...
@@ -138,6 +151,24 @@ int bpf_prog_load(enum bpf_prog_type prog_type,
log_buf
[
0
]
=
0
;
int
ret
=
syscall
(
__NR_bpf
,
BPF_PROG_LOAD
,
&
attr
,
sizeof
(
attr
));
if
(
ret
<
0
&&
errno
==
EPERM
)
{
// When EPERM is returned, two reasons are possible:
// 1. user has no permissions for bpf()
// 2. user has insufficent rlimit for locked memory
// Unfortunately, there is no api to inspect the current usage of locked
// mem for the user, so an accurate calculation of how much memory to lock
// for this new program is difficult to calculate. As a hack, bump the limit
// to unlimited. If program load fails again, return the error.
struct
rlimit
rl
=
{};
if
(
getrlimit
(
RLIMIT_MEMLOCK
,
&
rl
)
==
0
)
{
rl
.
rlim_max
=
RLIM_INFINITY
;
rl
.
rlim_cur
=
rl
.
rlim_max
;
if
(
setrlimit
(
RLIMIT_MEMLOCK
,
&
rl
)
==
0
)
ret
=
syscall
(
__NR_bpf
,
BPF_PROG_LOAD
,
&
attr
,
sizeof
(
attr
));
}
}
if
(
ret
<
0
&&
!
log_buf
)
{
// caller did not specify log_buf but failure should be printed,
// so call recursively and print the result to stderr
...
...
tests/wrapper.sh.in
View file @
8a04fb39
...
...
@@ -32,11 +32,11 @@ function ns_run() {
sudo
ip netns
exec
$ns
ethtool
-K
eth0 tx off
sudo
ip addr add dev
$ns
.out 172.16.1.1/24
sudo
ip
link set
$ns
.out up
sudo
bash
-c
"
ulimit -l 10240;
PYTHONPATH=
$PYTHONPATH
LD_LIBRARY_PATH=
$LD_LIBRARY_PATH
ip netns exec
$ns
$cmd
$1
$2
"
sudo
bash
-c
"PYTHONPATH=
$PYTHONPATH
LD_LIBRARY_PATH=
$LD_LIBRARY_PATH
ip netns exec
$ns
$cmd
$1
$2
"
return
$?
}
function
sudo_run
()
{
sudo
bash
-c
"
ulimit -l 10240;
PYTHONPATH=
$PYTHONPATH
LD_LIBRARY_PATH=
$LD_LIBRARY_PATH
$cmd
$1
$2
"
sudo
bash
-c
"PYTHONPATH=
$PYTHONPATH
LD_LIBRARY_PATH=
$LD_LIBRARY_PATH
$cmd
$1
$2
"
return
$?
}
function
simple_run
()
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment