Skip to content
  1. Jan 09, 2019
  2. Jan 07, 2019
    • Richard Smith's avatar
      DR674, PR38883, PR40238: Qualified friend lookup should look for a · 8ce732b4
      Richard Smith authored
      template specialization if there is no matching non-template function.
      
      This exposed a couple of related bugs:
       - we would sometimes substitute into a friend template instead of a
         suitable non-friend declaration; this would now crash because we'd
         decide the specialization of the friend is a redeclaration of itself
       - ADL failed to properly handle the case where an invisible local
         extern declaration redeclares an invisible friend
      
      Both are fixed herein: in particular, we now never make invisible
      friends or local extern declarations visible to name lookup unless
      they are the only declaration of the entity. (We already mostly did
      this for local extern declarations.)
      
      llvm-svn: 350505
      8ce732b4
  3. Jan 04, 2019
    • Aaron Ballman's avatar
      Refactor the way we handle diagnosing unused expression results. · fb6deeb9
      Aaron Ballman authored
      Rather than sprinkle calls to DiagnoseUnusedExprResult() around in places where we want diagnostics, we now diagnose unused expression statements and full expressions in a more generic way when acting on the final expression statement. This results in more appropriate diagnostics for [[nodiscard]] where we were previously lacking them, such as when the body of a for loop is not a compound statement.
      
      This patch fixes PR39837.
      
      llvm-svn: 350404
      fb6deeb9
  4. Dec 21, 2018
  5. Dec 13, 2018
  6. Dec 12, 2018
  7. Dec 10, 2018
    • Raphael Isemann's avatar
      Misc typos fixes in ./lib folder · b23ccecb
      Raphael Isemann authored
      Summary: Found via `codespell -q 3 -I ../clang-whitelist.txt -L uint,importd,crasher,gonna,cant,ue,ons,orign,ned`
      
      Reviewers: teemperor
      
      Reviewed By: teemperor
      
      Subscribers: teemperor, jholewinski, jvesely, nhaehnle, whisperity, jfb, cfe-commits
      
      Differential Revision: https://reviews.llvm.org/D55475
      
      llvm-svn: 348755
      b23ccecb
  8. 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
  9. Dec 05, 2018
  10. 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
  11. Dec 01, 2018
  12. Nov 30, 2018
  13. Nov 29, 2018
  14. 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
  15. 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
  16. Nov 21, 2018
  17. Nov 16, 2018
  18. 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
  19. Nov 02, 2018
  20. Oct 31, 2018
  21. Oct 30, 2018
  22. Oct 24, 2018
  23. Oct 22, 2018
  24. Oct 11, 2018
  25. Oct 10, 2018
  26. Oct 01, 2018
  27. 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
  28. Sep 26, 2018
  29. Sep 24, 2018
  30. Sep 15, 2018
  31. 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
Loading