[clang] [AST] Match the FoldingSetNodeID computed before and after creating TypedefType (PR #157662)
Ilya Biryukov via cfe-commits
cfe-commits at lists.llvm.org
Tue Sep 9 05:47:05 PDT 2025
https://github.com/ilya-biryukov created https://github.com/llvm/llvm-project/pull/157662
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.
>From 4cc4469e78fb5c4578c4e228b0897ba6cb162a07 Mon Sep 17 00:00:00 2001
From: Ilya Biryukov <ibiryukov at google.com>
Date: Tue, 9 Sep 2025 14:46:02 +0200
Subject: [PATCH] [AST] Match the FoldingSetNodeID computed before and after
creating TypedefType
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.
---
clang/lib/AST/ASTContext.cpp | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
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 =
More information about the cfe-commits
mailing list