- 18 Jul, 2017 2 commits
-
-
4ast authored
Fix a clang memory leak
-
Yonghong Song authored
In clang frontend actions, several compiler invocations are called for rewriter and transforming source code to IR. During the invocation to transform source code to IR, CodeGenOpts.DisableFree is used to control whether the top target machine structure should be freed or not for a particular clang invocation, and its default value is TRUE. See clang:lib/CodeGen/BackendUtil.cpp: ~EmitAssemblyHelper() { if (CodeGenOpts.DisableFree) BuryPointer(std::move(TM)); } So by default, the memory held by TM will not freed, even if BPF module itself is freed. This is even more problematic when continuous building/loading/unloading happens for long live service. This patch explicitly sets CodeGenOpts.DisableFree to FALSE so memory can be properly freed. I did a simple experiment to compile/load/unload an empty BPF program and the saving is roughly 0.5MB. Signed-off-by: Yonghong Song <yhs@fb.com>
-
- 17 Jul, 2017 2 commits
-
-
Brenden Blanco authored
Update bpf.h and virtual_bpf.h to 4.13-rc1
-
Huapeng Zhou authored
-
- 14 Jul, 2017 2 commits
-
-
Geneviève Bastien authored
Signed-off-by: Geneviève Bastien <gbastien@versatic.net>
-
vkhromov authored
`trace.py` parses a probe using the colon as a separator. As a result, it fails to create a uprobe for binary/library with a filename containing colons. This diff fixes that issue with `trace.py`. It requires a kernel with https://lkml.org/lkml/2017/1/13/585 merged to work properly, otherwise `trace.py` still fails for create uprobes.
-
- 11 Jul, 2017 3 commits
-
-
Romain authored
-
Rinat Ibragimov authored
* memleak: handle libc allocation functions other than malloc * memleak: use tracepoints to track kernel allocations * memleak: add combined-only mode With large number of outstanding allocations, amount of data passed from kernel becomes large, which slows everything down. This patch calculates allocation statistics inside kernel, allowing user- space part to pull combined statistics data only, thus significantly reducing amount of passed data. * memleak: increase hashtable capacities There are a lot of allocations happen in kernel. Default values are not enough to keep up. * test: add a test for the memleak tool
-
bveldhoen authored
This sample contains: - A library with an operation that uses usdt probes. - A console application that calls the operation. - Scripts to trace the latency of the operation. - Corresponding cmake files.
-
- 07 Jul, 2017 1 commit
-
-
Quentin Monnet authored
And fix a typo: direct_action -> direct-action
-
- 06 Jul, 2017 1 commit
-
-
Colin Ian King authored
The macro _GNU_SOURCE should be defined to pick up the function declaration for setns. Fixes build warning: "src/cc/libbpf.c:482:7: warning: implicit declaration of function 'setns' [-Wimplicit-function-declaration] if (setns(target_fd, CLONE_NEWNS)) {" Signed-off-by: Colin Ian King <colin.king@canonical.com>
-
- 01 Jul, 2017 1 commit
-
-
4ast authored
Fix bcc.lua build issue in Ubuntu 17.04
-
- 30 Jun, 2017 4 commits
-
-
Vicent Marti authored
-
Vicent Marti authored
Cleanup the `strncmp` code and add a few more ignored map names
-
Yonghong Song authored
In fc25 box, gcc6.3.1 is configured with pie default off. Here, pie stands for position independent execution. In ubuntu 17.04, gcc6.3.0, however, is configured with pie default on. The gcc driver automatically adds -pie to the linker options. Since bcc.lua build needs pie off, previously, -fno-pie is passed to the compiler. -fno-pie is a gcc option impacting the code generation and it didn't negate the -pie option in the linker. The correct way seems to use gcc linker option -no-pie which can successfully cancel the default -pie in the linker. Signed-off-by: Yonghong Song <yhs@fb.com>
-
Nan Xiao authored
-
- 29 Jun, 2017 2 commits
-
-
Romain authored
-
Taekho Nam authored
-
- 23 Jun, 2017 1 commit
-
-
Brenden Blanco authored
Treat strings as bytes. This is independent of the larger refactor (#1139) from which it is cherry-picked) Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
- 22 Jun, 2017 1 commit
-
-
Brendan Gregg authored
-
- 19 Jun, 2017 1 commit
-
-
Yonghong Song authored
The issue is caused by the following clang change on 5.0: https://reviews.llvm.org/D28404 Basically, at -O0, unless always inlining is specified, a function will be marked as optnone and noinline. This causes two kinds of issues: (1). optnone will generate suboptimal code with heavy stack use and this high likely can cause verifier failure; and (2). even if user mark all his/her defined functions in bpf program as always inlining, some functions in linux header files are not marked as always inline and hence will be marked as noinline instead, ultimately causing llvm complaining about global function reference. This patch bumps the clang optimization level to -O2. This should work with older versions of llvm as well. Signed-off-by: Yonghong Song <yhs@fb.com>
-
- 14 Jun, 2017 3 commits
-
-
Brendan Gregg authored
Update the installation instructions for Fedora
-
Navin Francis authored
-
Yonghong Song authored
Signed-off-by: Yonghong Song <yhs@fb.com>
-
- 12 Jun, 2017 1 commit
-
-
Gary Ching-Pang Lin authored
-
- 10 Jun, 2017 1 commit
-
-
Carlos Neira authored
cnb@ubuntu-14:~/iovisor/bcc/build$ make [ 6%] Built target clang_frontend [ 9%] Built target bpf-static [ 16%] Built target bcc-loader-static [ 30%] Built target b_frontend [ 47%] Built target bcc-static [ 48%] Built target CPUDistribution [ 50%] Built target FollyRequestContextSwitch [ 51%] Built target HelloWorld [ 52%] Built target LLCStat [ 54%] Built target RandomRead [ 55%] Built target RecordMySQLQuery [ 56%] Built target TCPSendStack [ 80%] Built target bcc-shared [ 83%] Built target bpf-shared [ 84%] Built target bcc_py Linking C executable bcc-lua cc: error: unrecognized command line option â-no-pieâ make[2]: *** [src/lua/bcc-lua] Error 1 make[1]: *** [src/lua/CMakeFiles/bcc-lua.dir/all] Error option is called -fno-pie
-
- 08 Jun, 2017 1 commit
-
-
Ryan Tomayko authored
Fixes #782. Solution taken verbatim from @jepio here: https://github.com/iovisor/bcc/issues/782#issuecomment-259075010 I ran into the same issue attempting to compile from source on a fresh Ubuntu 16.10/Yakkety host: Linking C executable bcc-lua /usr/bin/ld: libluajit-5.1.a(ljamalg.o): relocation R_X86_64_32S against `.rodata' can not be used when making a shared object; recompile with -fPIC /usr/bin/ld: final link failed: Nonrepresentable section on output Build succeeded after patch was applied.
-
- 07 Jun, 2017 1 commit
-
-
Yonghong Song authored
o This is caused by my ignorant error in previous usdt change. Obviously, I need to store into pointer address in order to propagate value back to caller. o Thanks Tetsuo Handa pointing this out. Signed-off-by: Yonghong Song <yhs@fb.com>
-
- 06 Jun, 2017 3 commits
-
-
Evan Dandrea authored
-
Evan Dandrea authored
-
Evan Dandrea authored
-
- 05 Jun, 2017 1 commit
-
-
Taekho Nam authored
-
- 03 Jun, 2017 1 commit
-
-
Yonghong Song authored
o The sample application covers different aspects of usdt rewriter code generation: - const - *(ctx + offset) - use bpf_probe_read to get trace data - the switch in ctx->ip if the same probe is triggered in multiple .text locations. o folly (https://github.com/facebook/folly/) tracing header files are pulled into python test directory and used to produce USDT probes. Signed-off-by: Yonghong Song <yhs@fb.com>
-
- 01 Jun, 2017 1 commit
-
-
Teng Qin authored
-
- 31 May, 2017 5 commits
-
-
4ast authored
Force udst ctx->#reg load to be volatile
-
4ast authored
Add linux/sched.h to list of libbpf.c includes
-
Brenden Blanco authored
This should hopefully fix compile errors on some ubuntu systems. Also, reorders the includes according to clang-format Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
Brenden Blanco authored
Break the c++ dependency in libbpf.c, and turn it into a separate lib from cmake point of view. Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
Brenden Blanco authored
This moves ProcMountNS[Guard] classes to a separate header file and implementation. The goal will be to use these more directly in libbpf.c without creating a circular dependency. Removed the friend class statements and exposed a few public getters instead. Slightly changed the implementation in ProcMountNS constructor to avoid a few error cases and the use of snprintf. Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
- 30 May, 2017 1 commit
-
-
Christian Resell authored
-