Skip to content
  1. Sep 04, 2017
    • Lang Hames's avatar
      [ORC] Refactor OrcRemoteTarget code to expose its RPC API, reduce · 9e68b734
      Lang Hames authored
      code duplication in the client, and improve error propagation.
      
      This patch moves the OrcRemoteTarget rpc::Function declarations from
      OrcRemoteTargetRPCAPI into their own namespaces under llvm::orc::remote so that
      they can be used in new contexts (in particular, a remote-object-file adapter
      layer that I will commit shortly).
      
      Code duplication in OrcRemoteTargetClient (especially in loops processing the
      code, rw-data and ro-data allocations) is removed by moving the loop bodies
      into their own functions.
      
      Error propagation is (slightly) improved by adding an ErrorReporter functor to
      the OrcRemoteTargetClient -- Errors that can't be returned (because they occur
      in destructors, or behind stable APIs that don't provide error returns) can be
      sent to the ErrorReporter instead. Some methods in the Client API are also
      changed to make better use of the Expected class: returning Expected<T>s rather
      than returning Errors and taking T&s to store the results.
      
      llvm-svn: 312500
      9e68b734
  2. Sep 03, 2017
    • Keith Wyss's avatar
      Revert "[XRay][tools] Function call stack based analysis tooling for XRay traces" · 1eb03d42
      Keith Wyss authored
      This reverts commit 204a65e0702847a1880336372ad7abd1df414b44.
      
      Double ref qualifier failed bots.
      
      llvm-svn: 312428
      1eb03d42
    • Keith Wyss's avatar
      [XRay][tools] Function call stack based analysis tooling for XRay traces · 4c12c782
      Keith Wyss authored
      This change introduces a subcommand to the llvm-xray tool called
      "stacks" which allows for analysing XRay traces provided as inputs and
      accounting time to stacks instead of just individual functions. This
      gives us a more precise view of where in a program the latency is
      actually attributed.
      
      The tool uses a trie data structure to keep track of the caller-callee
      relationships as we process the XRay traces. In particular, we keep
      track of the function call stack as we enter functions. While we're
      doing this we're adding nodes in a trie and indicating a "calls"
      relatinship between the caller (current top of the stack) and the callee
      (the new top of the stack). When we push function ids onto the stack, we
      keep track of the timestamp (TSC) for the enter event.
      
      When exiting functions, we are able to account the duration by getting
      the difference between the timestamp of the exit event and the
      corresponding entry event in the stack. This works even if we somehow
      miss the exit events for intermediary functions (i.e. if the exit event
      is not cleanly associated with the enter event at the top of the stack).
      
      The output of the tool currently provides just the top N leaf functions
      that contribute the most latency, and the top N stacks that have the
      most frequency. In the future we can provide more sophisticated query
      mechanisms and potentially an export to database feature to make offline
      analysis of the stack traces possible with existing tools.
      
      llvm-svn: 312426
      4c12c782
    • Justin Bogner's avatar
      Move some CLI utils out of llvm-isel-fuzzer and into the library · 7f28d732
      Justin Bogner authored
      FuzzMutate might not be the best place for these, but it makes more
      sense than an entirely new library for now. This will make setting up
      fuzz targets with consistent CLI handling easier.
      
      llvm-svn: 312425
      7f28d732
  3. Sep 02, 2017
  4. Sep 01, 2017
  5. Aug 31, 2017
    • Eugene Zelenko's avatar
      [Analysis] Fix some Clang-tidy modernize-use-using and Include What You Use... · fa6434be
      Eugene Zelenko authored
      [Analysis] Fix some Clang-tidy modernize-use-using and Include What You Use warnings; other minor fixes. Also affected in files (NFC).
      
      llvm-svn: 312289
      fa6434be
    • Sam Clegg's avatar
      [llvm-nm] Fix output formatting of -f sysv for 64bit targets · 32cfbeb4
      Sam Clegg authored
      Differential Revision: https://reviews.llvm.org/D37347
      
      llvm-svn: 312284
      32cfbeb4
    • Zachary Turner's avatar
      Fix some size_t / uint32_t mismatched comparisons. · 4c806613
      Zachary Turner authored
      llvm-svn: 312278
      4c806613
    • Zachary Turner's avatar
      [llvm-pdbutil] Print detailed S_UDT stats. · 99c6982b
      Zachary Turner authored
      This adds a new command line option, -udt-stats, which breaks
      down the stats of S_UDT records.  These are one of the biggest
      contributors to the size of /DEBUG:FASTLINK PDBs, so they need
      some additional tools to be able to analyze their usage.  This
      option will dig into each S_UDT record and determine what kind
      of record it points to, and then break down the statistics by
      the target type.  The goal here is to identify how our object
      files differ from MSVC object files in S_UDT records, so that
      we can output fewer of them and reach size parity.
      
      llvm-svn: 312276
      99c6982b
    • Jonas Devlieghere's avatar
      [dsymutil] Don't mark forward declarations as canonical. · d9063658
      Jonas Devlieghere authored
      This patch completes the work done by Frederic Riss to addresses
      dsymutil incorrectly considering forward declaration as canonical during
      uniquing. This resulted in references to the forward declaration even
      after the definition was encountered.
      
      In addition to the test provided by Alexander Shaposhnikov in D29609, I
      added another test to cover several scenarios that were mentioned in his
      conversation with Fred. We now also check that uniquing still occurs
      after the definition was encountered.
      
      For more context please refer to D29609
      
      Differential revision: https://reviews.llvm.org/D37127
      
      llvm-svn: 312274
      d9063658
    • Jonas Devlieghere's avatar
      Revert "[dsymutil] Don't mark forward declarations as canonical." · 3aefe872
      Jonas Devlieghere authored
      This reverts commit r312264.
      
      llvm-svn: 312271
      3aefe872
    • Jonas Devlieghere's avatar
      [dsymutil] Don't mark forward declarations as canonical. · e200f9ba
      Jonas Devlieghere authored
      This patch completes the work done by Frederic Riss to addresses
      dsymutil incorrectly considering forward declaration as canonical during
      uniquing. This resulted in references to the forward declaration even
      after the definition was encountered.
      
      In addition to the test provided by Alexander Shaposhnikov in D29609, I
      added another test to cover several scenarios that were mentioned in his
      conversation with Fred. We now also check that uniquing still occurs
      after the definition was encountered.
      
      For more context please refer to D29609
      
      Differential revision: https://reviews.llvm.org/D37127
      
      llvm-svn: 312264
      e200f9ba
    • Jonas Devlieghere's avatar
      [llvm-dwarfdump] Brief mode only dumps debug_info by default · 8ac8df03
      Jonas Devlieghere authored
      This patch changes the default behavior in brief mode to only show the
      debug_info section. This is undoubtedly the most popular and likely the
      one you'd want in brief mode.
      
      Non-brief mode behavior is not affected and still defaults to all.
      
      Differential revision: https://reviews.llvm.org/D37334
      
      llvm-svn: 312252
      8ac8df03
    • Sean Eveson's avatar
      [llvm-cov] Read in function names for filtering from a text file. · e15300ec
      Sean Eveson authored
      Summary: Add a -name-whitelist option, which behaves in the same way as -name, but it reads in multiple function names from the given input file(s).
      
      Reviewers: vsk
      
      Reviewed By: vsk
      
      Subscribers: llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D37111
      
      llvm-svn: 312227
      e15300ec
    • Dean Michael Berris's avatar
      [XRay][tools] Fix an accounting bug in llvm-xray account · 415f15c5
      Dean Michael Berris authored
      Summary:
      Before this patch, llvm-xray account will assume that thread stacks will
      not be empty. Unfortunately there are cases where an instrumented
      function will see a call to `fork()` which will cause the child process
      to not see the start of the function, but only see the end of the
      function. The tooling cannot assume that threads will always have
      perfect stacks, and so we change it to support this reality.
      
      Reviewers: dblaikie
      
      Subscribers: llvm-commits
      
      Differential Revision: https://reviews.llvm.org/D31870
      
      llvm-svn: 312204
      415f15c5
    • Justin Bogner's avatar
      cmake: Invent add_llvm_fuzzer to set up fuzzer targets · 52047172
      Justin Bogner authored
      This moves the cmake configuration for fuzzers in LLVM to a new macro,
      add_llvm_fuzzer. This will make it easier to keep things consistent
      while implementing llvm.org/pr34314.
      
      I've also made a couple of minor functional changes here:
      
      - the fuzzers now use add_llvm_executable rather than add_llvm_tool.
        This means they won't create install targets and stuff like that,
        because those made little sense for these fuzzers.
      - I've grouped these under "Fuzzers" rather than in with "Tools" for
        people who build with IDEs.
      
      llvm-svn: 312200
      52047172
    • Justin Bogner's avatar
      llvm-isel-fuzzer: Stop including FuzzerInterface.h · 53bb83d2
      Justin Bogner authored
      All this does is forward declare the interface functions (and make
      sure that they're `extern "C"`), but since we're using libFuzzer from
      the toolchain it doesn't make sense to include the local copy of the
      interface.
      
      llvm-svn: 312195
      53bb83d2
    • Petr Hosek's avatar
      [yaml2obj][ELF] Make symbols optional for relocations · 5aa80f16
      Petr Hosek authored
      Some kinds of relocations do not have symbols, like R_X86_64_RELATIVE
      for instance. I would like to test this case in D36554 but currently
      can't because symbols are required by yaml2obj. The other option is
      using the empty symbol but that doesn't seem quite right to me.
      
      This change makes the Symbol field of Relocation optional and in the
      case where the user does not specify a symbol name the Symbol index is 0.
      
      Patch by Jake Ehrlich
      
      Differential Revision: https://reviews.llvm.org/D37276
      
      llvm-svn: 312192
      5aa80f16
    • Rui Ueyama's avatar
      Simplify writeArchive return type. · 01d02651
      Rui Ueyama authored
      writeArchive returned a pair, but the first element of the pair is always
      its first argument on failure, so it doesn't make sense to return it from
      the function. This patch change the return type so that it does't return it.
      
      Differential Revision: https://reviews.llvm.org/D37313
      
      llvm-svn: 312177
      01d02651
  6. Aug 29, 2017
  7. Aug 28, 2017
Loading