- 15 Dec, 2017 1 commit
-
-
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
-
- 14 Dec, 2017 3 commits
- 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 1 commit
-
-
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>
-
- 04 Dec, 2017 2 commits
-
-
4ast authored
sync compat headers with latest net-next
-
Yonghong Song authored
The same header is in torvalds/linux 4.15 rc2. Signed-off-by: Yonghong Song <yhs@fb.com>
-
- 30 Nov, 2017 2 commits
-
-
yonghong-song authored
Update INSTALL instructions for binary packages
-
Brenden Blanco authored
The old link to netperf is dead, but a copy exists in the iovisor repo (for the buildbots to use). Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
- 29 Nov, 2017 3 commits
-
-
Brenden Blanco authored
* Update the instructions to reflect recent package availability * Nightly/stable packages for Ubuntu Xenial+Artful * Nightly/stable packages for Fedora 26+27 * Remove references to Trusty as those are no longer being built * Remove references to Fedora 24 as those are no longer being built Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
Brenden Blanco authored
Signed-off-by: Brenden Blanco <bblanco@gmail.com>
-
Olivier Tilmans authored
Use ctypes.byref() instead of ctypes.pointer() in cases where we do not need the actual pointer object itself as it is much lighter.
-
- 27 Nov, 2017 3 commits
-
-
yonghong-song authored
python: make _decode_table_types aware of __int128
-
yonghong-song authored
Do not keep Loader instances around
-
Brendan Gregg authored
-
- 25 Nov, 2017 1 commit
-
-
yonghong-song authored
Fix 'test_libbcc' from failing in certain scenarios
-
- 24 Nov, 2017 2 commits
-
-
yonghong-song authored
man/bps: Add a man page for introspection/bps.c
-
Olivier Tilmans authored
There are no ctypes types ready for int128. However, recognizing this type and representing it as an array is better than simply erroring out. * Add mapping between (unsigned) __128 C types declaration and ctypes parsing * Add simple test case in test_clang to recognisze and use such types * Fixes deprecation warnings about self.assertEquals in 2 other test cases.
-
- 23 Nov, 2017 1 commit
-
-
Teng Qin authored
-
- 22 Nov, 2017 8 commits
-
-
Martin KaFai Lau authored
This patch adds a man page for bps.c and also introduces bps in README.md Signed-off-by: Martin KaFai Lau <kafai@fb.com>
-
yonghong-song authored
libbpf: Enable the creation of unbound raw socket
-
4ast authored
force linking the whole api-static library into shared library
-
Yonghong Song authored
When a static library is linked to produce a shared library, only referenced symbols in the static library eventually gets linked. api-static library has entry points for C++ API. Many symbols in this library do not have references outside of this library and will get dropped during linking process. This patch forces the linking of the whole api-static library in order to procude bcc shared library. Reported-by: Mauricio Vasquez <mauricio.vasquez@polito.it> Signed-off-by: Yonghong Song <yhs@fb.com>
-
yonghong-song authored
funcslower: add a note about nested calls
-
Olivier Tilmans authored
Passing a NULL (or empty) char string to bpf_open_raw_sock() will skip the bind call on the newly created raw socket. This can create sniffers for all interfaces using a single socket filter. The dns_matching example has been updated to default to 'any' interface if noone is specified in the arguments.
-
yonghong-song authored
funcslower: fix missing tgid when filtering by pid
-
Ivan Babrou authored
-
- 21 Nov, 2017 5 commits
-
-
Ivan Babrou authored
-
Olivier Tilmans authored
* The name encoding function was not checking the constraints on domain names properly (<= 253 chars as one byte is needed for the name of the label and one for the terminating 0-len label; <= 63 chars per label). * The name encoding function was erroring when assigning a struct value in the byte array (Python 3.6.3). Refactored to join successive subarrays, and moved the null padding to make it explicit that it is needed by the bpf map key (and not the dns encoding). * Used builtin from argparse to have a list of domains in the command line arguments. * Reset the non-block flag through fcntl directly instead of reconstructing a socket object. * Exit gracefully when triggering SIGINT as hinted.
-
Lukasz Dorau authored
Update info about installing stable packages for Ubuntu Xenial in INSTALL.md Fixes:#1440
-
4ast authored
Update perf event type and config checks
-
Teng Qin authored
-
- 20 Nov, 2017 1 commit
-
-
yonghong-song authored
solisten.py maintenance
-