- 10 May, 2017 3 commits
-
-
Brenden Blanco authored
Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
Brenden Blanco authored
The api should return 0, not the number of bytes successfully written (which is what snprintf directly returns). Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
Brenden Blanco authored
Not all users require the snprintf/sscanf helpers, and in some types the finalization can take a long time. Defer the finalization until the first use. Wrap the invocation with a bound function such that the BPFTable and other users don't need to keep an explicit BPFModule reference. Use-after-free will be avoided by resetting the function to an error-returning stub when/if the BPFModule is freed. Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
- 09 May, 2017 6 commits
-
-
4ast authored
RFC: Improve mount namespace handling
-
Teng Qin authored
This commit adds helper method in C API using `ProcMountNSGuard` to enter and exit mount namespace, and use it in `libbpf.h`
-
Teng Qin authored
This commit adds `ProcMountNS` and `ProcMountNSGuard`, that automatically opens and closes FDs, and enters and exists mount namespace on construction and destruction.
-
Teng Qin authored
-
Teng Qin authored
-
4ast authored
Improve perf map parsing logic
-
- 05 May, 2017 3 commits
-
-
Teng Qin authored
-
4ast authored
docs: update feature list for 4.12
-
Tobias Klauser authored
All of the features listed to be incluude in 4.12 landed in Linus' tree. Update the table accordingly.
-
- 04 May, 2017 1 commit
-
-
Brenden Blanco authored
Add documentation to guide future scripts to be Python3-ready
-
- 03 May, 2017 7 commits
-
-
4ast authored
docs: update features list (ThunderX support for XDP)
-
Teng Qin authored
-
4ast authored
cc: Work around verifier error when reading USDT probe arguments
-
Teng Qin authored
-
Arthur Gautier authored
explicit the type of the nlattr Signed-off-by: Arthur Gautier <baloo@gandi.net>
-
Sasha Goldshtein authored
The code generated by the USDT helpers for reading probe arguments occasionally caused a verifier error due to a construct similar to the following: ``` switch (ctx->ip) { case 0xaaaa: *dest = ctx->cx; break; case 0xbbbb: *dest = ctx->dx; break; } ``` This would generate an instruction sequence that attempts to access ctx through an offset that is not statically known, which confuses the verifier. This was reported in #751, #829, and #1133, and likely seen by others as well. The workaround, suggested by @yonghong-song, is to force memory writes by using the volatile modifier, which precludes this specific optimization. Resolves #751, #829, #1133.
-
Quentin Monnet authored
-
- 02 May, 2017 3 commits
-
-
4ast authored
docs: update features list
-
Quentin Monnet authored
Update of BPF features list, following the release of kernel 4.11. New items include: - Sparc eBPF JIT - ixgbe support for XDP - eBPF benchmarking facility - new helpers `get_socket_*()`
-
4ast authored
Small improvements to symboling availiability
-
- 01 May, 2017 3 commits
-
-
Teng Qin authored
Currently we check if `ProcSyms` needs refresh for every symboling call. However if the `ProcSyms` was loaded, but the Process terminated later, we will see it as a "need refresh" and effectively clear the symbol table and not able to resovle anything anymore. This commit changes so that we only refresh when the PID still exists (but differnt from what loaded).
-
Teng Qin authored
Currently we think the Module's symbol table is not loaed as long as its empty. But some times we were just not able to read the symbols from the binary / perf map, or didn't get symbol from the read. This commit makes so that we don't end up trying to do a read on each lookup.
-
Brenden Blanco authored
Install sudo inside the debian build container
-
- 30 Apr, 2017 1 commit
-
-
Sam Kottler authored
-
- 28 Apr, 2017 1 commit
-
-
4ast authored
frontend/b: fixes for LLVM 4.0 API change
-
- 27 Apr, 2017 5 commits
-
-
Brenden Blanco authored
Upstream LLVM added a new parameter to the AllocaInst constructor, which breaks compilation. Fix it by using the IRBuilder method. Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
Brenden Blanco authored
Add default -Wno-address-of-packed-membe to Clang loader
-
Teng Qin authored
-
4ast authored
Use uintptr_t for addresses in C++ API
-
Teng Qin authored
-
- 26 Apr, 2017 2 commits
-
-
Brenden Blanco authored
[RFC]: Extend table API with string support
-
Mauricio Vasquez B authored
This commit exposes functions to convert between key and value from/to strings, additionally it implements the BPFTable class that allows accessing tables using strings. Signed-off-by: Mauricio Vasquez B <mauricio.vasquez@polito.it>
-
- 21 Apr, 2017 3 commits
-
-
Brenden Blanco authored
With local LLVM (4.0ish), inline strings in this test case would segfault. Fix the crash by constructing explicitly on the stack. Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
Brenden Blanco authored
Possibly due to local LLVM differences, this change was needed for sslsniff code to pass the verifier. Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
Brenden Blanco authored
On my system, the manually unrolled stack walker fails the verifier, due to what seems to me like an incorrect return statement. Setting bp = 0 has no effect, seems that the intent was to return 0 instead. Not sure why others haven't hit this, but the fix contained here seems reasonable. Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
- 20 Apr, 2017 2 commits
-
-
4ast authored
Disable non-static function calls
-
Brenden Blanco authored
Compiled BPF programs must consist of a single contiguous code block, meaning trying to call other function entry points (besides the kernel-defined helpers) is not possible. The bcc frontend didn't explicitly prohibit this, even though the program would fail to compile/load. Add an explicit check and error message. Fixes: #653 Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-