Skip to content
  1. Dec 06, 2018
    • Serge Pavlov's avatar
      Diagnose friend function template redefinitions. · acfcd78a
      Serge Pavlov authored
      Friend function template defined in a class template becomes available if
      the enclosing class template is instantiated. Until the function template
      is used, it does not have a body, but still is considered a definition for
      the purpose of redeclaration checks.
      
      This change modifies redefinition check so that it can find the friend
      function template definitions in instantiated classes.
      
      Differential Revision: http://reviews.llvm.org/D21508
      
      llvm-svn: 348473
      acfcd78a
    • Leonard Chan's avatar
      [Sema] Push and Pop Expression Evaluation Context Records at the start and end... · bf5fe2db
      Leonard Chan authored
      [Sema] Push and Pop Expression Evaluation Context Records at the start and end of function definitions
      
      This patch creates a new context for every function definition we enter.
      Currently we do not push and pop on these, usually working off of the global
      context record added in the Sema constructor, which never gets popped.
      
      Differential Revision: https://reviews.llvm.org/D54014
      
      llvm-svn: 348434
      bf5fe2db
  2. Dec 05, 2018
  3. 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
  4. Dec 01, 2018
  5. Nov 30, 2018
  6. Nov 29, 2018
  7. 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
  8. 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
  9. Nov 21, 2018
  10. Nov 16, 2018
  11. 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
  12. Nov 02, 2018
  13. Oct 31, 2018
  14. Oct 30, 2018
  15. Oct 24, 2018
  16. Oct 22, 2018
  17. Oct 11, 2018
  18. Oct 10, 2018
  19. Oct 01, 2018
  20. 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
  21. Sep 26, 2018
  22. Sep 24, 2018
  23. Sep 15, 2018
  24. 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
  25. Sep 10, 2018
  26. Sep 09, 2018
  27. Sep 08, 2018
  28. 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
  29. 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
  30. Aug 14, 2018
Loading