- 23 Feb, 2018 1 commit
-
-
Yonghong Song authored
Currently, for every table of a module, corresponding key/value sscanf/snprintf functions will be generated. These functions are mostly used for python API to facilitate passing keys between python and C++. It is a known issue that these sscanf/snprintf functions can consume a lot of system resources esp. memory for large arrays. Commit 22eae8c6 ("Use late-binding to finalize snprintf/sscanf") avoids unnecessary code generation for snprintf/sscanf until they are called. Even with this commit, however, the overhead can still be significant for large arrays. For example, the following large array, #define TCP6_RXMIT_BUCKET_BITS 18 struct tcp6_rxmit_tbl { __u64 buckets[1 << TCP6_RXMIT_BUCKET_BITS]; }; BPF_ARRAY(rxmit_marking_map, struct tcp6_rxmit_tbl, 1); is used inside Facebook. If it is added to examples/cpp/HelloWorld.cpp, the HelloWorld RSS memory will increase from 7MB to 370MB. This patch add a BPFModule API and a C++ API to disable rw_engine sscanf/snprintf function through additional constructor parameters. rw_engine support for Python is not affected. Signed-off-by: Yonghong Song <yhs@fb.com>
-
- 21 Feb, 2018 1 commit
-
-
Gary Lin authored
This commit fixes the following error with python3: Traceback (most recent call last): File "_ctypes/callbacks.c", line 234, in 'calling callback function' File "/usr/lib/python3.6/site-packages/bcc/table.py", line 508, in raw_cb_ callback(cpu, data, size) File "./opensnoop.py", line 169, in print_event if args.name and args.name not in event.comm: TypeError: a bytes-like object is required, not 'str' Signed-off-by: Gary Lin <glin@suse.com>
-
- 20 Feb, 2018 1 commit
-
-
yonghong-song authored
Explicitly include sys/types.h
-
- 19 Feb, 2018 1 commit
-
-
gmile authored
This will help build bcc on Alpine Linux.
-
- 18 Feb, 2018 1 commit
-
-
yonghong-song authored
scripts: avoid check-helpers.sh's writes to disk
-
- 17 Feb, 2018 1 commit
-
-
Paul Chaignon authored
-
- 16 Feb, 2018 1 commit
-
-
yonghong-song authored
Allow to delete elements from prog tables
-
- 15 Feb, 2018 2 commits
-
-
Mauricio Vasquez B authored
Signed-off-by: Mauricio Vasquez B <mauricio.vasquez@polito.it>
-
4ast authored
sync bpf compat headers with latest net-next
-
- 14 Feb, 2018 5 commits
-
-
Yonghong Song authored
Signed-off-by: Yonghong Song <yhs@fb.com>
-
yonghong-song authored
Script to check that the lists of helpers are in sync
-
Mauricio Vasquez B authored
It is allowed in the kernel from some time ago: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/kernel/bpf/arraymap.c?h=v4.4#n267Signed-off-by: Mauricio Vasquez B <mauricio.vasquez@polito.it>
-
Paul Chaignon authored
Checks src/cc/libbpf.c, docs/kernel-versions.md, src/cc/compat/linux/bpf.h, and src/cc/export/helpers.h.
-
yonghong-song authored
Cosmetic: Make kernel-versions commit hashes monospace
-
- 12 Feb, 2018 2 commits
-
-
Teng Qin authored
-
yonghong-song authored
Discourage use of str() type strings in python API
-
- 11 Feb, 2018 2 commits
-
-
yonghong-song authored
Fix two issues in examples
-
yonghong-song authored
Implement get_text for Python USDT class
-
- 10 Feb, 2018 3 commits
- 09 Feb, 2018 2 commits
-
-
Liu Bo authored
<linux/blkdev.h> is not needed. Signed-off-by: Liu Bo <liub.liubo@gmail.com>
-
Liu Bo authored
A function definition doesn't need a tail semicolon. Signed-off-by: Liu Bo <liub.liubo@gmail.com>
-
- 08 Feb, 2018 5 commits
-
-
Brenden Blanco authored
Conform to bytes encoding for some portion of the tools/tests, such that smoke tests pass on python3. More conversions are surely required. Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
Brenden Blanco authored
Move bcc internals to sanitize all arguments as bytes instead of str type. For now, disable warnings or actual assertion, to be turned on incrementally.
-
Brenden Blanco authored
Introduce some helpers for managing bytes/unicode objects in a way that bridges the gap from python2 to 3. 1. Add printb() helper for writing bytes output directly to stdout. This avoids complaints from print() in python3, which expects a unicode str(). Since python 3.5, `b"" % bytes()` style format strings should work and we can write tools with common code, once we convert format strings to bytes. http://legacy.python.org/dev/peps/pep-0461/ 2. Add a class for wrapping command line arguments that are intended for comparing to debugged memory, for instance running process COMM or kernel pathname data. The approach takes some of the discussion from http://legacy.python.org/dev/peps/pep-0383/ into account, though unfortunately the python2-future implementation of "surrogateescape" is buggy, therefore this iteration is partial. The object instance should only ever be coerced into a bytes object. This silently invokes encode(sys.getfilesystemencoding()), which if it fails implies that the tool was passed junk characters on the command line. Thereafter the tool should implement only bytes-bytes comparisons (for instance re.search(b"", b"")) and bytes stdout printing (see printb). 3. Add an _assert_is_bytes helper to check for improper usage of str objects in python arguments. The behavior of the assertion can be tweaked by changing the bcc.utils._strict_bytes bool. Going forward, one should never invoke decode() on a bpf data stream, e.g. the result of a table lookup or perf ring output. Leave that data in the native bytes() representation. Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
Brenden Blanco authored
Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
yonghong-song authored
BCC cross compilation support
-
- 06 Feb, 2018 7 commits
-
-
Joel Fernandes authored
BCC at the moment builds eBPF only considering the local architecture instead of the one that the user's target kernel is running on. For cross-compiler environments, the ARCH environment variable is used to specify which ARCH to build the kernel for. In this patch we add support to read ARCH and if that's not set, then fallback to detecting based on local architecture. This patch borrows some code from a patch doing a similar thing for eBPF samples in the kenrel that I submitted recently [1] [1] https://patchwork.kernel.org/patch/9961801/Signed-off-by: Joel Fernandes <joelaf@google.com>
-
Joel Fernandes authored
Many developers have kernel sources at an specific location. Allow clang to build from there by allowing to specify a single absolute path to the kernel sources through a new env var BCC_KERNEL_SOURCE. Signed-off-by: Joel Fernandes <joelaf@google.com>
-
yonghong-song authored
Updated the FAQ with the error produced if python[2-3]-bcc isn't inst…
-
yonghong-song authored
Document bpf_tail_call()
-
Gary Lin authored
Signed-off-by: Gary Lin <glin@suse.com>
-
Gary Lin authored
Define a new macro to make it easier to declare a program array. Also replace BPF_TABLE("prog") in examples and tests with BPF_PROG_ARRAY. Signed-off-by: Gary Lin <glin@suse.com>
-
yonghong-song authored
Fix missing include
-
- 05 Feb, 2018 5 commits
-
-
Brendan Gregg authored
tcptracer: Fix argparse is not defined error
-
Dane Springmeyer authored
Fixes compile with libc++ on linux: ``` In file included from ../tests/cc/test_array_table.cc:17: In file included from ../src/cc/api/BPF.h:24: ../src/cc/api/BPFTable.h:118:71: error: use of undeclared identifier 'errno' return StatusTuple(-1, "Error getting value: %s", std::strerror(errno)); ```
-
yonghong-song authored
Add missing includes to fix build against libc++
-
Matty authored
-
Gal Pressman authored
argparse is imported as ap, using argparse explicitly results in a name not defined error. Signed-off-by: Gal Pressman <galp@mellanox.com>
-