From 248b8c036749ff75c03deac98db9452cec4abf9d Mon Sep 17 00:00:00 2001 From: David Wrighton Date: Thu, 14 Apr 2022 18:08:57 -0700 Subject: [PATCH] Fix PGO trace data collection in the presence of collectible assemblies (#68001) * Fix PGO data emission in the presence of collectible assemblies --- src/coreclr/vm/pgo.cpp | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/src/coreclr/vm/pgo.cpp b/src/coreclr/vm/pgo.cpp index c3f37a3226b98..1799563595329 100644 --- a/src/coreclr/vm/pgo.cpp +++ b/src/coreclr/vm/pgo.cpp @@ -121,6 +121,8 @@ class SchemaWriterFunctor auto lambda = [&](int64_t thWritten) { + if (ICorJitInfo::IsUnknownTypeHandle(thWritten)) return; + if (thWritten != 0) { TypeHandle th = *(TypeHandle*)&thWritten; @@ -129,6 +131,7 @@ class SchemaWriterFunctor typeHandlesEncountered.Append(th); } } + return; }; if (!writer.AppendDataFromLastSchema(lambda)) @@ -140,6 +143,7 @@ class SchemaWriterFunctor } }; +#ifndef DACCESS_COMPILE void PgoManager::WritePgoData() { if (ETW_EVENT_ENABLED(MICROSOFT_WINDOWS_DOTNETRUNTIME_PROVIDER_DOTNET_Context, JitInstrumentationDataVerbose)) @@ -233,11 +237,16 @@ void PgoManager::WritePgoData() break; case ICorJitInfo::PgoInstrumentationKind::TypeHandle: { - TypeHandle th = *(TypeHandle*)(data + entryOffset); + intptr_t typehandleData = *(intptr_t*)(data + entryOffset); + TypeHandle th = TypeHandle::FromPtr((void*)typehandleData); if (th.IsNull()) { fprintf(pgoDataFile, s_TypeHandle, "NULL"); } + else if (ICorJitInfo::IsUnknownTypeHandle(typehandleData)) + { + fprintf(pgoDataFile, s_TypeHandle, "UNKNOWN"); + } else { StackSString ss; @@ -272,6 +281,7 @@ void PgoManager::WritePgoData() fprintf(pgoDataFile, s_FileTrailerString); fclose(pgoDataFile); } +#endif // DACCESS_COMPILE void ReadLineAndDiscard(FILE* file) { @@ -459,7 +469,7 @@ void PgoManager::ReadPgoData() TypeHandle th; INT_PTR ptrVal = 0; - if (strcmp(typeString, "NULL") != 0) + if ((strcmp(typeString, "NULL") != 0) || (strcmp(typeString, "UNKNOWN") != 0)) { // As early type loading is likely problematic, simply drop the string into the data, and fix it up later void* tempString = malloc(endOfString);