- 30 May, 2017 1 commit
-
-
Yonghong Song authored
This is related to issue #1133. Compiler sometimes generates code patterns likes: r1 = ctx + 96 goto next here: r1 = ctx + 48 next: r3 = load (r1 + 0) Verifier will fail for such cases as r1 is marked as "unknown" at the time of load. The previous workaround is to add volatile attribute to the store like *(volatile u64 *)&dest = ctx->bx The hope is to force ctx related load in-place since its value is needed for store. Unfortunately, this does not always work and compiler still has freedom to merge different ctx loads at the same time honoring the volatile &dest. In USDT generated code, different branches of &dest are the same. This patch directly make ctx->bx itself as a volatile load: *(volatile u64 *)&ctx->bx This seems working as compiler stops playing around the address pointing to a volatile data. Signed-off-by: Yonghong Song <yhs@fb.com>
-
- 31 May, 2017 4 commits
-
-
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 2 commits
-
-
Christian Resell authored
-
Christian Resell authored
-
- 27 May, 2017 1 commit
-
-
Tomaz Solc authored
-
- 25 May, 2017 3 commits
-
-
Brenden Blanco authored
funclatency/sslsniff: fix the TypeError when enabling pid filter on u…
-
4ast authored
Fix usage of CMAKE_BUILD_TYPE setting
-
4ast authored
Use BPF_F_CURRENT_CPU in perf_submit when possible
-
- 24 May, 2017 6 commits
- 23 May, 2017 3 commits
-
-
Brenden Blanco authored
Add support for generic XDP mode
-
Teng Qin authored
-
Andy Gospodarek authored
Reused some of the code and command-line format from kernel XDP samples. $ sudo ./xdp_drop_count.py -S enp1s0 Printing drops per IP protocol-number, hit CTRL+C to stop 17: 36616 pkt/s 17: 19720757 pkt/s 17: 19685768 pkt/s 17: 19643601 pkt/s 17: 19694537 pkt/s [...] $ sudo ./xdp_drop_count.py enp1s0 Printing drops per IP protocol-number, hit CTRL+C to stop 17: 7029 pkt/s 17: 29996706 pkt/s 17: 30048705 pkt/s 17: 30261417 pkt/s 17: 30291967 pkt/s [...] Throughput difference is expected since generic XDP takes more instructions per packet than optimized XDP. v2: switch __u32 to uint32_t in bpf_attach_xdp Signed-off-by: Andy Gospodarek <gospo@broadcom.com>
-
- 22 May, 2017 3 commits
- 21 May, 2017 3 commits
- 20 May, 2017 9 commits
-
-
Teng Qin authored
-
Teng Qin authored
-
Brenden Blanco authored
Add ability for users to control symboling behavior
-
Teng Qin authored
As the symbol type check now controled by the specified `bcc_symbol_option` and handled in lower level, there is not need to pass the type flag to the callback anymore.
-
Teng Qin authored
This commit makes `ProcSyms` constructor takes a `bcc_symbol_option`, and pass it down to underlying calls to control symboling behavior. If `nullptr` is passed, `ProcSyms` will use default setting, which is to use debug file, verify debug file checksum, and only load function symbols. This commit also makes `bcc_symcache_new` take a `bcc_symbol_option` parameter and pass it to the underlying `ProcSyms` constructor.
-
Teng Qin authored
This commit makes `bcc_resolve_symname` to take an `bcc_symbol_option` parameter, and pass it to underlying calls to control symboling behavior. When `NULL` is passed, it will fallback to default which is current behavior that uses debug file, verify debug file CRC, and check all types of symbols. This commit also removes the unneccesary intermediate `bcc_find_symbol_addr`. Added documentation for usage of the API, updated most call sites to use default with `NULL`, and fixed some memory leaks at call sites.
-
Teng Qin authored
`bcc_resolve_symname` should free `sym->module` on error. Also remove unused `sym_search_t`
-
Teng Qin authored
This commit changes `bcc_foreach_symbol` to use the new `bcc_symbol_option` to control it only wants function symbols. Also renamed it to bcc_foreach_function_symbol and added comments for better information. This commit maintained current behavior of the function to prefer use debug file and check debug file CRC. We could add option to configure that behavior in the future if needed.
-
Teng Qin authored
This commit adds a `bcc_symbol_option` to configure various symboling behaviors. Currently added options for reading debug file, and what type of symbols are wanted. This commit also makes bcc_elf_foreach_sym take a `bcc_symbol_option` parameter and repect the specified configurations.
-
- 19 May, 2017 2 commits
-
-
Gabor Buella authored
The build type was set to Release in the top level cmake file. This was a rather confusing behaviour, as one would expect to be able to easily debug the code after using `cmake -DCMAKE_BUILD_TYPE=Debug`.
-
Brenden Blanco authored
Use new Kernel functionality to get first key of map
-
- 18 May, 2017 3 commits
-
-
Teng Qin authored
-
Teng Qin authored
-
Teng Qin authored
This commit adds bpf_get_first_key helper, which gets the first key of the map. It automatically tries to use the new Kernel functionality and falls back to old Kernel behavior. This helps us unify the logic to walk a map across different APIs (Python, C++, etc.)
-