1. 27 Nov, 2017 2 commits
  2. 25 Nov, 2017 1 commit
  3. 24 Nov, 2017 1 commit
  4. 23 Nov, 2017 1 commit
  5. 22 Nov, 2017 8 commits
  6. 21 Nov, 2017 5 commits
    • Ivan Babrou's avatar
      95c20b01
    • Olivier Tilmans's avatar
      Fix dns_matching example · 1af99d4e
      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.
      1af99d4e
    • Lukasz Dorau's avatar
      Update info about Ubuntu Xenial in INSTALL.md · 61bc92ad
      Lukasz Dorau authored
      Update info about installing stable packages
      for Ubuntu Xenial in INSTALL.md
      
      Fixes:#1440
      61bc92ad
    • 4ast's avatar
      Merge pull request #1448 from palmtenor/hw_cache_events · dee8f8f0
      4ast authored
      Update perf event type and config checks
      dee8f8f0
    • Teng Qin's avatar
      Update perf event type and config checks · 01b07bae
      Teng Qin authored
      01b07bae
  7. 20 Nov, 2017 4 commits
    • yonghong-song's avatar
      Merge pull request #1447 from yadutaf/fix-solisten · 10f3f22c
      yonghong-song authored
      solisten.py maintenance
      10f3f22c
    • Sandipan Das's avatar
      Fix 'test_libbcc' from failing because of ruby · c15b5c87
      Sandipan Das authored
      This fixes 'test_usdt_probes', called from 'test_libbcc', from
      failing if the static markers are in libruby rather than a ruby
      executable. So, when the path of the binary having the markers
      is tested, we must check if either "/ruby" or "/libruby" is a
      substring rather than only checking for the former.
      
      Also, rather than relying on hardcoded values for the number of
      locations and arguments for a given probe, we capture this info
      using the readelf tool and then compare these with the values
      reported by bcc. This is because these numbers may vary across
      different versions of ruby and will cause the tests to fail.
      For example, 'test_libbcc' fails on Fedora 26 with ruby-2.4 as
      the number of locations where it expects 'array__create' is 7
      even when it is actually 2 as reported by bcc and verified with
      readelf output.
      Signed-off-by: default avatarSandipan Das <sandipan@linux.vnet.ibm.com>
      c15b5c87
    • Sandipan Das's avatar
      Fix 'test_libbcc' from failing due to symbol name mismatch · 5ac03dda
      Sandipan Das authored
      This fixes 'test_c_api', called from 'test_libbcc', from failing
      if the name of the first symbol with the address of "strtok" in
      libc as returned by bcc_symcache_resolve() is not "strtok" but
      some other alias pointing to the same address. For glibc-2.25 on
      powerpc, a mismatch occurs as the name of the first symbol with
      the same address as that of "strtok" is "__GI_strtok". This can
      be verified from the output of the nm tool on Fedora 26 ppc64le
      as shown below.
      
        00000000000b59c0 t __GI_strtok
        00000000000b59c0 T strtok
      Signed-off-by: default avatarSandipan Das <sandipan@linux.vnet.ibm.com>
      5ac03dda
    • Sandipan Das's avatar
      Add utility for cc tests to read command outputs · 2c4da18a
      Sandipan Das authored
      This introduces a separate source file for adding common
      utilities which can be used by any of the cc tests. For
      now, we add a function to read values from the output of
      a command with a format string like scanf().
      Signed-off-by: default avatarSandipan Das <sandipan@linux.vnet.ibm.com>
      2c4da18a
  8. 18 Nov, 2017 2 commits
  9. 17 Nov, 2017 6 commits
  10. 16 Nov, 2017 3 commits
  11. 14 Nov, 2017 1 commit
  12. 10 Nov, 2017 1 commit
  13. 09 Nov, 2017 3 commits
    • Teng Qin's avatar
      73e2f2d7
    • Yonghong Song's avatar
      change frontend rewriter to better handle anonymous struct/union · 94d15bc8
      Yonghong Song authored
      Kernel Commit 29e48ce87f1e ("task_struct: Allow randomized layout")
      (https://patchwork.kernel.org/patch/9797817/)
      permits to randomize a section of kernel task_struct data
      structure. This only takes effect when CONFIG_GCC_PLUGINS and
      CONFIG_GCC_PLUGIN_RANDSTRUCT are set.
      
      When randomization does not happen, an anonymous struct
      is introduced in task_struct data structure by gcc when compiling
      the kernel. To make field offset compatible, task_struct will
      have the same anonymous struct. The patch is at
      http://www.spinics.net/lists/kernel/msg2644958.html.
      Otherwise, bpf program may get wrong data from the kernel.
      
      Currently, bcc bpf_probe_read rewriter does not support
      anonymous struct/union. For example, with the above
      compiler-clang.h patch, examples/tracing/task_switch.py
      will have the following error:
        /virtual/main.c:16:18: error: internal error: opLoc is invalid while preparing probe rewrite
          key.prev_pid = prev->pid;
                         ^
      
      For anonymous structure, opcode source location ("->") is not available
      and hence the above failure. We could use memberLoc ("pid") which is
      available for anonymous struct/union. For example, for
        struct sock *skp; ...; u32 saddr = skp->__sk_common.skc_rcv_saddr;
      The old way for bpf_probe_read rewrite:
        bpf_probe_read(&_val, sizeof(_val), (u64)skp + offsetof(struct sock, __sk_common.skc_rcv_saddr));
      The new way:
        bpf_probe_read(&_val, sizeof(_val), (u64)&skp->__sk_common.skc_rcv_saddr);
      
      The new way is similar to what typical bpf programs may do manually.
      Signed-off-by: default avatarYonghong Song <yhs@fb.com>
      94d15bc8
    • Gary Lin's avatar
      bpf: use MCJIT explicitly for ExecutionEngine · 1d0f2925
      Gary Lin authored
      When BPFModule finalized the module, it set UseOrcMCJITReplacement to
      true to use OrcJIT for ExecutionEngine. However, this never worked.
      First, in clang_libs.cmake, mcjit is in the library list instead of
      orcjit, so ExecutionEngine always fell back to MCJIT.
      Second, even if OrcJIT was linked correctly, it actually broke bcc.
      For OrcJIT, finalizeObject() is just an empty function. The code
      generation is delayed till getPointerToFunction() or runFunction(), so
      the current implementation of BPFModule won't work for OrcJIT.
      
      This bug was covered when using the separate LLVM share libraries. If
      the system builds LLVM into an unified share library, then OrcJIT will
      be used and bcc would fail to generate BPF bytecodes without any
      warning.
      Signed-off-by: default avatarGary Lin <glin@suse.com>
      1d0f2925
  14. 08 Nov, 2017 2 commits