Skip to content
  1. Dec 04, 2018
    • Richard Smith's avatar
      Fix -Wmismatched-tags to not warn on redeclarations of structs in system · a4ca4ca2
      Richard Smith authored
      headers.
      
      Previously, we would only check whether the new declaration is in a
      system header, but that requires the user to be able to correctly guess
      whether a declaration in a system header is declared as a struct or a
      class when specializing standard library traits templates.
      
      We now entirely ignore declarations for which the warning was disabled
      when determining whether to warn on a tag mismatch.
      
      Also extend the diagnostic message to clarify that
       a) code containing such a tag mismatch is in fact valid and correct,
          and
       b) the (non-coding-style) reason to emit such a warning is that the
          Microsoft C++ ABI is broken and includes the tag kind in decorated
          names,
      as it seems a lot of users are confused by our diagnostic here (either
      not understanding why we produce it, or believing that it represents an
      actual language rule).
      
      llvm-svn: 348233
      a4ca4ca2
  2. Dec 01, 2018
  3. Nov 30, 2018
  4. Nov 29, 2018
  5. Nov 28, 2018
    • Erich Keane's avatar
      Allow cpu-dispatch forward declarations. · a3e7a167
      Erich Keane authored
      As a followup to r347805, allow forward declarations of cpu-dispatch and
      cpu-specific for the same reasons.
      
      Change-Id: Ic1bde9be369b1f8f1d47d58e6fbdc2f9dfcdd785
      llvm-svn: 347812
      a3e7a167
    • Erich Keane's avatar
      Correct 'target' default behavior on redecl, allow forward declaration. · 7304f0a6
      Erich Keane authored
      Declarations without the attribute were disallowed because it would be
      ambiguous which 'target' it was supposed to be on.  For example:
      
      void ___attribute__((target("v1"))) foo();
      void foo(); // Redecl of above, or fwd decl of below?
      void ___attribute__((target("v2"))) foo();
      
      However, a first declaration doesn't have that problem, and erroring
      prevents it from working in cases where the forward declaration is
      useful.
      
      Additionally, a forward declaration of target==default wouldn't properly
      cause multiversioning, so this patch fixes that.
      
      The patch was not split since the 'default' fix would require
      implementing the same check for that case, followed by undoing the same
      change for the fwd-decl implementation.
      
      Change-Id: I66f2c5bc2477bcd3f7544b9c16c83ece257077b0
      llvm-svn: 347805
      7304f0a6
    • Erich Keane's avatar
      [NFC] Move MultIversioning::Type into Decl so that it can be used in · 5c0d1925
      Erich Keane authored
      CodeGen
      
      Change-Id: I32b14edca3501277e0e65672eafe3eea38c6f9ae
      llvm-svn: 347791
      5c0d1925
    • Hans Wennborg's avatar
      Re-commit r347417 "Re-Reinstate 347294 with a fix for the failures." · 48ee4ad3
      Hans Wennborg authored
      This was reverted in r347656 due to me thinking it caused a miscompile of
      Chromium. Turns out it was the Chromium code that was broken.
      
      llvm-svn: 347756
      48ee4ad3
  6. Nov 27, 2018
    • Hans Wennborg's avatar
      Revert r347417 "Re-Reinstate 347294 with a fix for the failures." · 8c79706e
      Hans Wennborg authored
      This caused a miscompile in Chrome (see crbug.com/908372) that's
      illustrated by this small reduction:
      
        static bool f(int *a, int *b) {
          return !__builtin_constant_p(b - a) || (!(b - a));
        }
      
        int arr[] = {1,2,3};
      
        bool g() {
          return f(arr, arr + 3);
        }
      
        $ clang -O2 -S -emit-llvm a.cc -o -
      
      g() should return true, but after r347417 it became false for some reason.
      
      This also reverts the follow-up commits.
      
      r347417:
      > Re-Reinstate 347294 with a fix for the failures.
      >
      > Don't try to emit a scalar expression for a non-scalar argument to
      > __builtin_constant_p().
      >
      > Third time's a charm!
      
      r347446:
      > The result of is.constant() is unsigned.
      
      r347480:
      > A __builtin_constant_p() returns 0 with a function type.
      
      r347512:
      > isEvaluatable() implies a constant context.
      >
      > Assume that we're in a constant context if we're asking if the expression can
      > be compiled into a constant initializer. This fixes the issue where a
      > __builtin_constant_p() in a compound literal was diagnosed as not being
      > constant, even though it's always possible to convert the builtin into a
      > constant.
      
      r347531:
      > A "constexpr" is evaluated in a constant context. Make sure this is reflected
      > if a __builtin_constant_p() is a part of a constexpr.
      
      llvm-svn: 347656
      8c79706e
  7. Nov 21, 2018
  8. Nov 16, 2018
  9. Nov 03, 2018
    • Takuto Ikuta's avatar
      Add /Zc:DllexportInlines option to clang-cl · 302c6435
      Takuto Ikuta authored
      Summary:
      This CL adds /Zc:DllexportInlines flag to clang-cl.
      When Zc:DllexportInlines- is specified, inline class member function is not exported if the function does not have local static variables.
      
      By not exporting inline function, code for those functions are not generated and that reduces both compile time and obj size. Also this flag does not import inline functions from dllimported class if the function does not have local static variables.
      
      On my 24C48T windows10 machine, build performance of chrome target in chromium repository is like below.
      These stats are come with 'target_cpu="x86" enable_nacl = false is_component_build=true dcheck_always_on=true` build config and applied
      * https://chromium-review.googlesource.com/c/chromium/src/+/1212379
      * https://chromium-review.googlesource.com/c/v8/v8/+/1186017
      
      Below stats were taken with this patch applied on https://github.com/llvm-project/llvm-project-20170507/commit/a05115cd4c57ff76b0f529e38118765b58ed7f2e
      
      | config                          | build time | speedup | build dir size |
      | with patch, PCH on, debug       | 1h10m0s    | x1.13   | 35.6GB         |
      | without patch, PCH on, debug    | 1h19m17s   |         | 49.0GB         |
      | with patch, PCH off, debug      | 1h15m45s   | x1.16   | 33.7GB         |
      | without patch, PCH off, debug   | 1h28m10s   |         | 52.3GB         |
      | with patch, PCH on, release     | 1h13m13s   | x1.22   | 26.2GB         |
      | without patch, PCH on, release  | 1h29m57s   |         | 37.5GB         |
      | with patch, PCH off, release    | 1h23m38s   | x1.32   | 23.7GB         |
      | without patch, PCH off, release | 1h50m50s   |         | 38.7GB         |
      
      This patch reduced obj size and the number of exported symbols largely, that improved link time too.
      e.g. link time stats of blink_core.dll become like below
      |                              | cold disk cache | warm disk cache |
      | with patch, PCH on, debug    | 71s             | 30s             |
      | without patch, PCH on, debug | 111s            | 48s             |
      
      This patch's implementation is based on Nico Weber's patch. I modified to support static local variable, added tests and took stats.
      
      Bug: https://bugs.llvm.org/show_bug.cgi?id=33628
      
      Reviewers: hans, thakis, rnk, javed.absar
      
      Reviewed By: hans
      
      Subscribers: kristof.beyls, smeenai, dschuff, probinson, cfe-commits, eraman
      
      Differential Revision: https://reviews.llvm.org/D51340
      
      llvm-svn: 346069
      302c6435
  10. Nov 02, 2018
  11. Oct 31, 2018
  12. Oct 30, 2018
  13. Oct 24, 2018
  14. Oct 22, 2018
  15. Oct 11, 2018
  16. Oct 10, 2018
  17. Oct 01, 2018
  18. Sep 30, 2018
    • Fangrui Song's avatar
      Use the container form llvm::sort(C, ...) · 1d38c13f
      Fangrui Song authored
      There are a few leftovers of rC343147 that are not (\w+)\.begin but in
      the form of ([-[:alnum:]>.]+)\.begin or spanning two lines. Change them
      to use the container form in this commit. The 12 occurrences have been
      inspected manually for safety.
      
      llvm-svn: 343425
      1d38c13f
  19. Sep 26, 2018
  20. Sep 24, 2018
  21. Sep 15, 2018
  22. Sep 12, 2018
    • Richard Smith's avatar
      Consistently create a new declaration when merging a pre-existing but · c457766c
      Richard Smith authored
      hidden definition with a would-be-parsed redefinition.
      
      This permits a bunch of cleanups. In particular, we no longer need to
      take merged definitions into account when checking declaration
      visibility, only when checking definition visibility, which makes
      certain visibility checks take linear instead of quadratic time.
      
      We could also now remove the UPD_DECL_EXPORTED update record and track
      on each declaration whether it was demoted from a definition (as we
      already do for variables), but I'm not doing that in this patch to keep
      the changes here simpler.
      
      llvm-svn: 342018
      c457766c
  23. Sep 10, 2018
  24. Sep 09, 2018
  25. Sep 08, 2018
  26. Sep 06, 2018
    • Richard Smith's avatar
      PR38627: Fix handling of exception specification adjustment for · 5159bbad
      Richard Smith authored
      destructors.
      
      We previously tried to patch up the exception specification after
      completing the class, which went wrong when the exception specification
      was needed within the class body (in particular, by a friend
      redeclaration of the destructor in a nested class). We now mark the
      destructor as having a not-yet-computed exception specification
      immediately after creating it.
      
      This requires delaying various checks against the exception
      specification (where we'd previously have just got the wrong exception
      specification, and now find we have an exception specification that we
      can't compute yet) when those checks fire while the class is being
      defined.
      
      This also exposed an issue that we were missing a CodeSynthesisContext
      for computation of exception specifications (otherwise we'd fail to make
      the module containing the definition of the class visible when computing
      its members' exception specs). Adding that incidentally also gives us a
      diagnostic quality improvement.
      
      This has also exposed an pre-existing problem: making the exception
      specification evaluation context a non-SFINAE context (as it should be)
      results in a bootstrap failure; PR38850 filed for this.
      
      llvm-svn: 341499
      5159bbad
  27. Aug 20, 2018
    • Richard Smith's avatar
      Model type attributes as regular Attrs. · e43e2b36
      Richard Smith authored
      Specifically, AttributedType now tracks a regular attr::Kind rather than
      having its own parallel Kind enumeration, and AttributedTypeLoc now
      holds an Attr* instead of holding an ad-hoc collection of Attr fields.
      
      Differential Revision: https://reviews.llvm.org/D50526
      
      This reinstates r339623, reverted in r339638, with a fix to not fail
      template instantiation if we instantiate a QualType with no associated
      type source information and we encounter an AttributedType.
      
      llvm-svn: 340215
      e43e2b36
  28. Aug 14, 2018
  29. Aug 10, 2018
    • Akira Hatanaka's avatar
      [CodeGen] Merge equivalent block copy/helper functions. · 9978da36
      Akira Hatanaka authored
      Clang generates copy and dispose helper functions for each block literal
      on the stack. Often these functions are equivalent for different blocks.
      This commit makes changes to merge equivalent copy and dispose helper
      functions and reduce code size.
      
      To enable merging equivalent copy/dispose functions, the captured object
      infomation is encoded into the helper function name. This allows IRGen
      to check whether an equivalent helper function has already been emitted
      and reuse the function instead of generating a new helper function
      whenever a block is defined. In addition, the helper functions are
      marked as linkonce_odr to enable merging helper functions that have the
      same name across translation units and marked as unnamed_addr to enable
      the linker's deduplication pass to merge functions that have different
      names but the same content.
      
      rdar://problem/42640608
      
      Differential Revision: https://reviews.llvm.org/D50152
      
      llvm-svn: 339438
      9978da36
    • Stephen Kelly's avatar
      Remove obsolete set call · a93380db
      Stephen Kelly authored
      Summary:
      Case case of the switch statement here makes the same call, but it is
      already done at the start of the function.
      
      Reviewers: rsmith, dblaikie
      
      Subscribers: cfe-commits
      
      Differential Revision: https://reviews.llvm.org/D50409
      
      llvm-svn: 339402
      a93380db
  30. Aug 09, 2018
Loading