- 22 Dec, 2017 1 commit
-
-
yonghong-song authored
ucalls: convert bytes to str
-
- 21 Dec, 2017 1 commit
-
-
yonghong-song authored
Fix incorrect lost_cb type in Python
-
- 20 Dec, 2017 4 commits
-
-
Teng Qin authored
-
yonghong-song authored
Fix and improvement for perf_reader's lost_cb
-
Teng Qin authored
-
Teng Qin authored
-
- 19 Dec, 2017 1 commit
-
-
Brendan Gregg authored
-
- 18 Dec, 2017 3 commits
-
-
Brendan Gregg authored
Handle unknown user in cachetop
-
Brendan Gregg authored
tcpretrans: extend for sum up
-
yonghong-song authored
histogram: support sorting bucket before dumping table
-
- 17 Dec, 2017 2 commits
-
-
yonghong-song authored
Improve trace.py formatting and printing options
-
htbegin authored
add a test case for bucket_sort_fn and show its use scenario as well
-
- 16 Dec, 2017 9 commits
-
-
Teng Qin authored
-
Teng Qin authored
-
4ast authored
add examples for including additional header files
-
4ast authored
Update for new bpf_perf_{event|prog}_read_value helpers
-
4ast authored
Clean-up unused parameter in tracing APIs
-
4ast authored
cmake3 on Ubuntu Trusty
-
Teng Qin authored
-
Teng Qin authored
-
Teng Qin authored
-
- 15 Dec, 2017 4 commits
-
-
Teng Qin authored
-
Teng Qin authored
-
Teng Qin authored
- Set `inherit = 1` only for per-task perf event. Inspired from change https://github.com/torvalds/linux/commit/81b9cf8028a17bdbdaa0da80b735b32150d4e89e - Kernel now support more events (see #1448). Also it's checked in `bpf_attach_perf_event` already. Remove the check from C++ API
-
Rafael Fonseca authored
This fixes the following error with python3 Tracing calls in process 2577 (language: python)... Ctrl-C to quit. ^C Traceback (most recent call last): File "/usr/share/bcc/tools/lib/ucalls", line 303, in <module> data = get_data() # [(function, (num calls, latency in ns))] File "/usr/share/bcc/tools/lib/ucalls", line 264, in get_data bpf["counts"].items())) File "/usr/share/bcc/tools/lib/ucalls", line 262, in <lambda> data = list(map(lambda kv: (kv[0].clazz + "." + kv[0].method, TypeError: can't concat str to bytes Signed-off-by: Rafael Fonseca <r4f4rfs@gmail.com>
-
- 14 Dec, 2017 6 commits
-
-
4ast authored
Add C++ helper to clear BPF tables
-
Teng Qin authored
-
Matthias Tafelmeier authored
Feature to quickly discern heavily retransmitting flows and therefore spotting culprit network paths. Signed-off-by: Matthias Tafelmeier <matthias.tafelmeier@gmx.net>
-
Alexander Dudko authored
-
Yonghong Song authored
Fix issue #1478 Two tools, trace.py and argdist.py, and their corresponding example files were changed. Fixed a minor typo in one of trace.py error messages. Signed-off-by: Yonghong Song <yhs@fb.com>
-
Teng Qin authored
-
- 12 Dec, 2017 4 commits
-
-
4ast authored
add padding to the end of structure
-
Brendan Gregg authored
execsnoop: fix the prototype for kprobe__sys_execve
-
4ast authored
provide padded structure for table_{key|leaf}_desc API
-
Yonghong Song authored
Commit 538a84e1 ("provide padded structure for table_{key|leaf}_desc API") added explicit padding, if needed, before every structure member. This is not enough as if an array of elements are returned from C++ to python side, the size of structure must be correct. This patch also adds padding after the last structure field to make structure size in python side consistent with C++ side. With this patch, I experimented with the pull request for tcpretrans.py by Matthias Tafelmeier, the type struct ipv6_flow_key_t { unsigned __int128 saddr; unsigned __int128 daddr; u64 lport; u64 dport; } can be replaced with struct ipv6_flow_key_t { unsigned __int128 saddr; unsigned __int128 daddr; u16 lport; u16 dport; } where the original type of lport/dport is u16. Some other ipv6 related data structures can also be simplified. Signed-off-by: Yonghong Song <yhs@fb.com>
-
- 09 Dec, 2017 2 commits
-
-
htbegin authored
When there are multiple fields in the secondary key of a histogram (e.g. output the bio latency for each combination of disk and blk cgroup), if the buckets are not sorted before the iteration, the output order of tables often does not meet our expectations. So provide a way to sort them.
-
htbegin authored
For sys_execve() the type of filename parameter should be "const char __user *" instead of "struct filename *". The fix doesn't imply any functional change.
-
- 07 Dec, 2017 2 commits
-
-
yonghong-song authored
Do not print to stderr if user specified log buffer
-
Teng Qin authored
-
- 05 Dec, 2017 1 commit
-
-
Yonghong Song authored
This patch intends to fix issue #606. Currently, the key/value type information is passed from C++ to Python through a JSON interface. The JSON is constructed by traversing the struct/field's through clang AST interface. Once Python gets the JSON, it will reconstruct the C structure through ctype module. There are two known issues where Python reconstructed C structure may not be the same as the original C structure: . if user explicitly use "__attribute__ ((align))" to alter field alignment and such information is not passed to Python. . the "__int128" type is a u64[2] array in python. So in C, __int128 needs to align on 16 bytes boundary, and in Python, it aligns with 8 bytes boundary. To solve this issue, this patch provided the structure with added padding fields to Python. For example, struct { char a; __int128 b; }; Python will receive struct { char a; char __pad_1[15]; __int128 b; }; Signed-off-by: Yonghong Song <yhs@fb.com>
-