Index: clang/lib/CodeGen/CGDebugInfo.cpp =================================================================== --- clang/lib/CodeGen/CGDebugInfo.cpp +++ clang/lib/CodeGen/CGDebugInfo.cpp @@ -1433,6 +1433,10 @@ if (isa(V)) continue; + if (isa(V) && + V->getType()->isUndeducedType()) + continue; + // Reuse the existing static member declaration if one exists auto MI = StaticDataMemberCache.find(V->getCanonicalDecl()); if (MI != StaticDataMemberCache.end()) { Index: clang/test/CodeGenCXX/pr42710.cpp =================================================================== --- /dev/null +++ clang/test/CodeGenCXX/pr42710.cpp @@ -0,0 +1,20 @@ +// RUN: %clang %s -DTYPE=auto -emit-llvm -S -g -o - -std=c++17 +// expected-no-diagnostics +// RUN: %clang %s -DTYPE=int -emit-llvm -S -g -o - -std=c++17 +// expected-no-diagnostics + +struct TypeId +{ + inline static int counter{}; + + template + inline static const TYPE identifier = counter++; + + template + inline static const TYPE value = identifier; +}; + +int main() +{ + return TypeId::value; +}