llvmbot wrote:

<!--LLVM PR SUMMARY COMMENT-->

@llvm/pr-subscribers-clang

Author: Ilya Biryukov (ilya-biryukov)

<details>
<summary>Changes</summary>



At some point the call to static `TypedefType::Profile` inside 
`ASTContext::getTypedefType` got out-of-sync with the non-static 
`TypedefType::Profile`.

This seem to cause some bad performance patterns with `FoldingSet` and are 
seeing 10x increases in compile times in certain scenarios. After this commit, 
the compile times go back to normal.

This commit does not include tests or benchmarks because we want to land this 
ASAP to unbreak our deployment. I will work on adding asserts, tests or 
benchmarks in a follow-up.

---
Full diff: https://github.com/llvm/llvm-project/pull/157662.diff


1 Files Affected:

- (modified) clang/lib/AST/ASTContext.cpp (+2-1) 


``````````diff
diff --git a/clang/lib/AST/ASTContext.cpp b/clang/lib/AST/ASTContext.cpp
index dca05b41aee77..c04de4e132739 100644
--- a/clang/lib/AST/ASTContext.cpp
+++ b/clang/lib/AST/ASTContext.cpp
@@ -5316,7 +5316,8 @@ ASTContext::getTypedefType(ElaboratedTypeKeyword Keyword,
   }
 
   llvm::FoldingSetNodeID ID;
-  TypedefType::Profile(ID, Keyword, Qualifier, Decl, UnderlyingType);
+  TypedefType::Profile(ID, Keyword, Qualifier, Decl,
+                       *TypeMatchesDeclOrNone ? QualType() : UnderlyingType);
 
   void *InsertPos = nullptr;
   if (FoldingSetPlaceholder<TypedefType> *Placeholder =

``````````

</details>


https://github.com/llvm/llvm-project/pull/157662
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to