Skip to content
Snippets Groups Projects
  1. Apr 12, 2017
    • Bruno Cardoso Lopes's avatar
      [Driver] Add compiler option to generate a reproducer · f2ee5f1a
      Bruno Cardoso Lopes authored
      One way to currently test the reproducers is to setup
      "FORCE_CLANG_DIAGNOSTICS_CRASH=1" before invoking clang. This simulates
      a crash and produces the same contents needed by the reproducers.  The
      reproducers are specially useful when triaging Modules issues, not only
      on crashes, but also for reproducing misleading warnings, errors, etc.
      
      Add a '-gen-reproducer' driver option to clang (or any similar name) and
      give users a flag option.
      
      Note that clang already has a -fno-crash-diagnostics, which disables the
      crash reproducers. I've decided not to propose "-fcrash-diagnostics"
      since it doesn't convey the ideia of reproduction despite a crash.
      
      rdar://problem/24114619
      
      Differential Revision: https://reviews.llvm.org/D27604
      
      git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@300109 91177308-0d34-0410-b5e6-96231b3b80d8
      f2ee5f1a
  2. Feb 17, 2017
  3. Feb 16, 2017
  4. Feb 09, 2017
  5. Feb 02, 2017
  6. Jan 17, 2017
  7. Jan 16, 2017
  8. Jan 14, 2017
  9. Jan 12, 2017
  10. Dec 12, 2016
  11. Oct 27, 2016
  12. Sep 13, 2016
    • Adam Nemet's avatar
      Reapply r281276 with passing -emit-llvm in one of the tests · 8a7af2f3
      Adam Nemet authored
      Original commit message:
      
      Add -fdiagnostics-show-hotness
      
      Summary:
      I've recently added the ability for optimization remarks to include the
      hotness of the corresponding code region.  This uses PGO and allows
      filtering of the optimization remarks by relevance.  The idea was first
      discussed here:
      http://thread.gmane.org/gmane.comp.compilers.llvm.devel/98334
      
      The general goal is to produce a YAML file with the remarks.  Then, an
      external tool could dynamically filter these by hotness and perhaps by
      other things.
      
      That said it makes sense to also expose this at the more basic level
      where we just include the hotness info with each optimization remark.
      For example, in D22694, the clang flag was pretty useful to measure the
      overhead of the additional analyses required to include hotness.
      (Without the flag we don't even run the analyses.)
      
      For the record, Hal has already expressed support for the idea of this
      patch on IRC.
      
      Differential Revision: https://reviews.llvm.org/D23284
      
      git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@281293 91177308-0d34-0410-b5e6-96231b3b80d8
      8a7af2f3
    • Adam Nemet's avatar
      Revert "Add -fdiagnostics-show-hotness" · 8503d694
      Adam Nemet authored
      This reverts commit r281276.
      
      Many bots are failing.
      
      git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@281279 91177308-0d34-0410-b5e6-96231b3b80d8
      8503d694
    • Adam Nemet's avatar
      Add -fdiagnostics-show-hotness · fd2a481c
      Adam Nemet authored
      Summary:
      I've recently added the ability for optimization remarks to include the
      hotness of the corresponding code region.  This uses PGO and allows
      filtering of the optimization remarks by relevance.  The idea was first
      discussed here:
      http://thread.gmane.org/gmane.comp.compilers.llvm.devel/98334
      
      The general goal is to produce a YAML file with the remarks.  Then, an
      external tool could dynamically filter these by hotness and perhaps by
      other things.
      
      That said it makes sense to also expose this at the more basic level
      where we just include the hotness info with each optimization remark.
      For example, in D22694, the clang flag was pretty useful to measure the
      overhead of the additional analyses required to include hotness.
      (Without the flag we don't even run the analyses.)
      
      For the record, Hal has already expressed support for the idea of this
      patch on IRC.
      
      Differential Revision: https://reviews.llvm.org/D23284
      
      git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@281276 91177308-0d34-0410-b5e6-96231b3b80d8
      fd2a481c
  13. Sep 12, 2016
  14. Aug 30, 2016
  15. Aug 15, 2016
  16. Jul 27, 2016
  17. Jul 23, 2016
  18. Jul 21, 2016
  19. Jul 16, 2016
  20. Jul 15, 2016
  21. Jul 14, 2016
  22. Jun 21, 2016
    • George Burgess IV's avatar
      [Docs] More warning fixes to unbreak the docs buildbot. · 7d29e488
      George Burgess IV authored
      A number of warnings still remain, but these were the last of the
      "unlexable code"-related ones (AFAICT).
      
      I changed a few examples in docs/UsersManual.rst to showcase
      -Wextra-tokens because it's already documented (-Wmultichar isn't), and
      the sphinx C lexer apparently can't handle char literals like 'ab'. It
      seemed like a better overall approach than just marking the code blocks
      as none or console.
      
      
      git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@273232 91177308-0d34-0410-b5e6-96231b3b80d8
      7d29e488
  23. May 27, 2016
    • Simon Dardis's avatar
      [mips] Compact branch policy setting. · 53682693
      Simon Dardis authored
      This patch adds the commandline option -mcompact-branches={never,optimal,always),
      which controls how LLVM generates compact branches for MIPSR6 targets. By default,
      the compact branch policy is 'optimal' where LLVM will generate the most
      appropriate branch for any situation. The 'never' and 'always' policy will disable
      or always generate compact branches wherever possible respectfully.
      
      Reviewers: dsanders, vkalintiris, atanasyan
      
      Differential Revision: http://reviews.llvm.org/D20729
      
      
      git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@271000 91177308-0d34-0410-b5e6-96231b3b80d8
      53682693
  24. May 20, 2016
  25. May 04, 2016
  26. Apr 28, 2016
  27. Apr 27, 2016
    • Peter Collingbourne's avatar
      Rework interface for bitset-using features to use a notion of LTO visibility. · 47213cf9
      Peter Collingbourne authored
      Bitsets, and the compiler features they rely on (vtable opt, CFI),
      only have visibility within the LTO'd part of the linkage unit. Therefore,
      only enable these features for classes with hidden LTO visibility. This
      notion is based on object file visibility or (on Windows)
      dllimport/dllexport attributes.
      
      We provide the [[clang::lto_visibility_public]] attribute to override the
      compiler's LTO visibility inference in cases where the class is defined
      in the non-LTO'd part of the linkage unit, or where the ABI supports
      calling classes derived from abstract base classes with hidden visibility
      in other linkage units (e.g. COM on Windows).
      
      If the cross-DSO CFI mode is enabled, bitset checks are emitted even for
      classes with public LTO visibility, as that mode uses a separate mechanism
      to cause bitsets to be exported.
      
      This mechanism replaces the whole-program-vtables blacklist, so remove the
      -fwhole-program-vtables-blacklist flag.
      
      Because __declspec(uuid()) now implies [[clang::lto_visibility_public]], the
      support for the special attr:uuid blacklist entry is removed.
      
      Differential Revision: http://reviews.llvm.org/D18635
      
      git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@267784 91177308-0d34-0410-b5e6-96231b3b80d8
      47213cf9
  28. Mar 28, 2016
  29. Feb 24, 2016
  30. Feb 12, 2016
  31. Feb 11, 2016
Loading