Skip to content
  1. Aug 14, 2019
  2. Jul 31, 2019
  3. Jul 23, 2019
  4. Jun 24, 2019
  5. Jun 04, 2019
  6. Jun 02, 2019
    • Don Hinton's avatar
      [test] Fix plugin tests · ccbda6b0
      Don Hinton authored
      Recommit of r361790 that was temporarily reverted in r361793 due to bot breakage.
      
      Summary:
      The following changes were required to fix these tests:
      
      1) Change LLVM_ENABLE_PLUGINS to an option and move it to
         llvm/CMakeLists.txt with an appropriate default -- which matches
         the original default behavior.
      
      2) Move the plugins directory from clang/test/Analysis
         clang/lib/Analysis.  It's not enough to add an exclude to the
         lit.local.cfg file because add_lit_testsuites recurses the tree and
         automatically adds the appropriate `check-` targets, which don't
         make sense for the plugins because they aren't tests and don't
         have `RUN` statements.
      
         Here's a list of the `clang-check-anlysis*` targets with this
         change:
      
      ```
        $ ninja -t targets all| sed -n "s/.*\/\(check[^:]*\):.*/\1/p" | sort -u | grep clang-analysis
        check-clang-analysis
        check-clang-analysis-checkers
        check-clang-analysis-copypaste
        check-clang-analysis-diagnostics
        check-clang-analysis-engine
        check-clang-analysis-exploration_order
        check-clang-analysis-html_diagnostics
        check-clang-analysis-html_diagnostics-relevant_lines
        check-clang-analysis-inlining
        check-clang-analysis-objc
        check-clang-analysis-unified-sources
        check-clang-analysis-z3
      ```
      
      3) Simplify the logic and only include the subdirectories under
         clang/lib/Analysis/plugins if LLVM_ENABLE_PLUGINS is set.
      
      Reviewed By: NoQ
      
      Tags: #clang, #llvm
      
      Differential Revision: https://reviews.llvm.org/D62445
      
      llvm-svn: 362328
      ccbda6b0
  7. May 31, 2019
    • Petr Hosek's avatar
      [CMake] Provide an option to use relative paths in debug info · 2ab7af29
      Petr Hosek authored
      CMake always uses absolute file paths in the generated compiler
      invocation which results in absolute file paths being embedded in debug
      info. This is undesirable when building a toolchain e.g. on bots as the
      debug info may embed the bot source checkout path which is meaningless
      anywhere else.
      
      This change introduces the LLVM_USE_RELATIVE_PATHS_IN_DEBUG_INFO which uses
      -fdebug-prefix-map (where supported) options to rewrite paths embedded
      into debug info with relative ones. Additionally, LLVM_SOURCE_PREFIX can
      be used to override the path to source directory with a different one.
      
      Differential Revision: https://reviews.llvm.org/D62622
      
      llvm-svn: 362185
      2ab7af29
  8. May 28, 2019
    • Alexandre Ganea's avatar
      Revert r361826, as it still breaks LLDB. · 9bf766c5
      Alexandre Ganea authored
      llvm-svn: 361837
      9bf766c5
    • Alexandre Ganea's avatar
      [CMake] Default options for faster executables on MSVC · c4eee405
      Alexandre Ganea authored
      Differential Revision: https://reviews.llvm.org/D55056
      
      llvm-svn: 361826
      c4eee405
    • Don Hinton's avatar
      Revert [test] Fix plugin tests · 102b4b24
      Don Hinton authored
      This reverts r361790 (git commit fe5eaab2)
      
      It's causing buildbot breakage, so reverting while I investigate.
      
      llvm-svn: 361793
      102b4b24
    • Don Hinton's avatar
      [test] Fix plugin tests · fe5eaab2
      Don Hinton authored
      Summary:
      The following changes were required to fix these tests:
      
      1) Change LLVM_ENABLE_PLUGINS to an option and move it to
         llvm/CMakeLists.txt with an appropriate default -- which matches
         the original default behavior.
      
      2) Move the plugins directory from clang/test/Analysis
         clang/lib/Analysis.  It's not enough to add an exclude to the
         lit.local.cfg file because add_lit_testsuites recurses the tree and
         automatically adds the appropriate `check-` targets, which don't
         make sense for the plugins because they aren't tests and don't
         have `RUN` statements.
      
         Here's a list of the `clang-check-anlysis*` targets with this
         change:
      
      ```
        $ ninja -t targets all| sed -n "s/.*\/\(check[^:]*\):.*/\1/p" | sort -u | grep clang-analysis
        check-clang-analysis
        check-clang-analysis-checkers
        check-clang-analysis-copypaste
        check-clang-analysis-diagnostics
        check-clang-analysis-engine
        check-clang-analysis-exploration_order
        check-clang-analysis-html_diagnostics
        check-clang-analysis-html_diagnostics-relevant_lines
        check-clang-analysis-inlining
        check-clang-analysis-objc
        check-clang-analysis-unified-sources
        check-clang-analysis-z3
      ```
      
      3) Simplify the logic and only include the subdirectories under
         clang/lib/Analysis/plugins if LLVM_ENABLE_PLUGINS is set.
      
      Reviewed By: NoQ
      
      Tags: #clang, #llvm
      
      Differential Revision: https://reviews.llvm.org/D62445
      
      llvm-svn: 361790
      fe5eaab2
  9. May 25, 2019
  10. May 22, 2019
  11. May 21, 2019
    • Nico Weber's avatar
      Tweaks for setting CMAKE_LINKER to lld-link · c6f363f5
      Nico Weber authored
      - Just look for "lld-link", not "lld-link.exe".
        llvm/cmake/platforms/WinMsvc.cmake for example sets CMAKE_LINKER to
        lld-link without .exe
      
      - Stop passing -gwarf to the compiler in sanitizer options when lld is
        enabled -- there's no reason to use different debug information keyed
        off the linker. (If this was for MinGW, we should check for that
        instead.)
      
      Differential Revision: https://reviews.llvm.org/D62111
      
      llvm-svn: 361214
      c6f363f5
  12. May 17, 2019
  13. May 10, 2019
  14. May 08, 2019
  15. May 06, 2019
  16. Apr 27, 2019
  17. Apr 09, 2019
  18. Apr 08, 2019
  19. Mar 13, 2019
  20. Mar 06, 2019
  21. Mar 04, 2019
  22. Feb 19, 2019
    • Daniel Sanders's avatar
      Fix builds with llvm/runtimes/compiler-rt after r354365 · ee95e878
      Daniel Sanders authored
      Compiler-rt doesn't include config-ix which was providing CheckSymbolExists to
      the LLVM build. Add it to HandleLLVMOptions to fix this
      
      llvm-svn: 354389
      ee95e878
    • Daniel Sanders's avatar
      Fix builds for older macOS deployment targets after r354365 · daf777b2
      Daniel Sanders authored
      Surprisingly, check_symbol_exists is not sufficient. The macOS linker checks the
      called functions against a compatibility list for the given deployment target
      and check_symbol_exists doesn't trigger this check as it never calls the
      function.
      
      This fixes the GreenDragon bots where the deployment target is 10.9
      
      llvm-svn: 354374
      daf777b2
    • Daniel Sanders's avatar
      Annotate timeline in Instruments with passes and other timed regions. · e1414d17
      Daniel Sanders authored
      Summary:
      Instruments is a useful tool for finding performance issues in LLVM but it can
      be difficult to identify regions of interest on the timeline that we can use
      to filter the profiler or allocations instrument. Xcode 10 and the latest
      macOS/iOS/etc. added support for the os_signpost() API which allows us to
      annotate the timeline with information that's meaningful to LLVM.
      
      This patch causes timer start and end events to emit signposts. When used with
      -time-passes, this causes the passes to be annotated on the Instruments timeline.
      In addition to visually showing the duration of passes on the timeline, it also
      allows us to filter the profile and allocations instrument down to an individual
      pass allowing us to find the issues within that pass without being drowned out
      by the noise from other parts of the compiler.
      
      Using this in conjunction with the Time Profiler (in high frequency mode) and
      the Allocations instrument is how I found the SparseBitVector that should have
      been a BitVector and the DenseMap that could be replaced by a sorted vector a
      couple months ago. I added NamedRegionTimers to TableGen and used the resulting
      annotations to identify the slow portions of the Register Info Emitter. Some of
      these were placed according to educated guesses while others were placed
      according to hot functions from a previous profile. From there I filtered the
      profile to a slow portion and the aforementioned issues stood out in the
      profile.
      
      To use this feature enable LLVM_SUPPORT_XCODE_SIGNPOSTS in CMake and run the
      compiler under Instruments with -time-passes like so:
        instruments -t 'Time Profiler' bin/llc -time-passes -o - input.ll'
      Then open the resulting trace in Instruments.
      
      There was a talk at WWDC 2018 that explained the feature which can be found at
      https://developer.apple.com/videos/play/wwdc2018/405/ if you'd like to know
      more about it.
      
      Reviewers: bogner
      
      Reviewed By: bogner
      
      Subscribers: jdoerfert, mgorny, kristina, llvm-commits
      
      Tags: #llvm
      
      Differential Revision: https://reviews.llvm.org/D52954
      
      llvm-svn: 354365
      e1414d17
  23. Feb 08, 2019
  24. Dec 19, 2018
  25. Dec 18, 2018
    • Alexandre Ganea's avatar
      [CMake] Default options for faster executables on MSVC · b5053199
      Alexandre Ganea authored
      - Disable incremental linking by default. /INCREMENTAL adds extra thunks in the EXE, which makes execution slower.
      - Set /MT (static CRT lib) by default instead of CMake's default /MD (dll CRT lib). The previous default /MD makes all DLL functions to be thunked, thus making execution slower (memcmp, memset, etc.)
      - Adds LLVM_ENABLE_INCREMENTAL_LINK which is set to OFF by default.
      
      Differential revision: https://reviews.llvm.org/D55056
      
      llvm-svn: 349517
      b5053199
  26. Nov 20, 2018
    • Aaron Ballman's avatar
      Silence C4709 in MSVC because it is buggy. · 02e1f191
      Aaron Ballman authored
      The diagnostic will trigger on code that does not have any comma operator, but instead default-constructs an object with an explicitly defaulted constructor as the array index argument.
      
      llvm-svn: 347345
      02e1f191
  27. Nov 10, 2018
  28. Nov 01, 2018
  29. Oct 24, 2018
Loading