Microsoft MVP성태의 닷넷 이야기
오류 유형: 356. Unknown custom metadata item kind: 6 [링크 복사], [링크+제목 복사],
조회: 19814
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Unknown custom metadata item kind: 6

닷넷의 PDB 파일 관련 오픈 소스를 빌드하거나 해당 클래스를 사용해 PDB 파일을 분석하다 보면 다음과 같은 예외가 발생할 수 있습니다.

Unhandled Exception: Microsoft.Diagnostics.Runtime.Utilities.Pdb.PdbDebugException: Unknown custom metadata item kind: 6
   at Microsoft.Diagnostics.Runtime.Utilities.Pdb.PdbFunction.ReadCustomMetadata(BitAccess bits)
   at Microsoft.Diagnostics.Runtime.Utilities.Pdb.PdbFunction..ctor(ManProcSym proc, BitAccess bits)
   at Microsoft.Diagnostics.Runtime.Utilities.Pdb.PdbFunction.LoadManagedFunctions(BitAccess bits, UInt32 limit, Boolean readStrings)
   at Microsoft.Diagnostics.Runtime.Utilities.Pdb.PdbFile.LoadFuncsFromDbiModule(BitAccess bits, DbiModuleInfo info, Dictionary`2 names, List`1 funcList, Boolean readStrings, MsfDirectory dir, Dictionary`2 nameIndex, PdbStreamHelper reader, Dictionary`2 sources)
   at Microsoft.Diagnostics.Runtime.Utilities.Pdb.PdbFile.LoadFunctions(Stream read, BitAccess bits, Boolean readAllStrings, Int32& ver, Int32& sig, Int32& age, Guid& guid, IEnumerable`1& sources)
   at Microsoft.Diagnostics.Runtime.Utilities.Pdb.PdbReader.Init(Stream pdbStream)
   at Microsoft.Diagnostics.Runtime.Utilities.Pdb.PdbReader..ctor(String fileName)
   at Extensions.GetReaderForFrame(ClrStackFrame frame) in C:\ConsoleApplication2\ConsoleApplication2\Program.cs:line 260
   at Extensions.GetSourceLocation(ClrStackFrame frame) in C:\ConsoleApplication2\ConsoleApplication2\Program.cs:line 147
   at ConsoleApplication2.Program.threadStart() in C:\ConsoleApplication2\ConsoleApplication2\Program.cs:line 105
   at System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
   at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
   at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
   at System.Threading.ThreadHelper.ThreadStart()

문제가 되는 소스 코드를 따라가 보면,

private void ReadCustomMetadata(BitAccess bits)
{
    int savedPosition = bits.Position;
    byte version;
    bits.ReadUInt8(out version);
    if (version != 4)
    {
        throw new PdbDebugException("Unknown custom metadata item version: {0}", version);
    }
    byte kind;
    bits.ReadUInt8(out kind);
    bits.Align(4);
    uint numberOfBytesInItem;
    bits.ReadUInt32(out numberOfBytesInItem);
    switch (kind)
    {
        case 0: this.ReadUsingInfo(bits); break;
        case 1: break; // this.ReadForwardInfo(bits); break;
        case 2: break; // this.ReadForwardedToModuleInfo(bits); break;
        case 3: this.ReadIteratorLocals(bits); break;
        case 4: this.ReadForwardIterator(bits); break;
        default: throw new PdbDebugException("Unknown custom metadata item kind: {0}", kind);
    }
    bits.Position = savedPosition + (int)numberOfBytesInItem;
}

PDB 분석 항목의 종류가 0 ~ 4까지만 지원하고 그 외의 숫자는 PdbDebugException이 발생하도록 만들어졌기 때문에 당연한 결과입니다.

다음의 이슈에 따르면,

Fody is not working with Visual Studio 2015
; https://github.com/Fody/Fody/issues/141

Visual Studio 2015로 빌드한 PDB 결과물을 분석하는 경우 나오는 이슈라고 합니다. (실제로 좀 더 검색해 보면 2015부터 적용된 Roslyn 컴파일러에서 새롭게 제공되는 PDB 산출물 결과 때문입니다.)

어쨌든, 저 141번 이슈에서 Fody는 문제를 해결했다고 하면서 베타 버전을 내놓습니다. 그런데... ^^ 어떻게 고쳤을까요? 이는 1.26.2-beta1과 1.26.1 버전의 ReadCustomMetadata 메서드를 .NET Reflector로 보면 됩니다.

그래서 2개의 버전을 각각 다음과 같이 개별 프로젝트에 적용해 내려받고,

Install-Package Fody -Version 1.26.2-beta1 -Pre 
Install-Package Fody -Version 1.26.1

Mono.Cecil.Pdb.dll 어셈블리의 Microsoft.Cci.Pdb.PdbFunction 클래스에 있는 ReadCustomMetadata를 1.26.2-beta1에서 변경된 부분을 찾아봤습니다.

private void ReadCustomMetadata(BitAccess bits)
{
    byte num2;
    byte num3;
    uint num4;
    int position = bits.Position;
    bits.ReadUInt8(out num2);
    if (num2 != 4)
    {
        throw new PdbDebugException("Unknown custom metadata item version: {0}", new object[] { num2 });
    }
    bits.ReadUInt8(out num3);
    bits.Align(4);
    bits.ReadUInt32(out num4);
    switch (num3)
    {
        case 0:
            this.ReadUsingInfo(bits);
            break;

        case 1:
            this.ReadForwardInfo(bits);
            break;

        case 3:
            this.ReadIteratorLocals(bits);
            break;

        case 4:
            this.ReadForwardIterator(bits);
            break;
    }
    bits.Position = position + ((int) num4);
}

간단하군요. ^^ 그냥 "default" 조건을 지워버렸습니다. 사실 그래도 되는 것이 switch 문 지나서 Position을 강제로 해당 PDB 항목을 건너 뛴 상태로 이동하기 때문입니다. (물론, 완벽한 것은 6번 종류의 PDB 항목도 읽어서 정보로 가지고 있으면 좋겠지요.)





[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 9/14/2016]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  [9]  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13718정성태8/27/20247432오류 유형: 921. Visual C++ - error C1083: Cannot open include file: 'float.h': No such file or directory [2]
13717정성태8/26/20247023VS.NET IDE: 192. Visual Studio 2022 - Windows XP / 2003용 C/C++ 프로젝트 빌드
13716정성태8/21/20246766C/C++: 167. Visual C++ - 윈도우 환경에서 _execv 동작 [1]
13715정성태8/19/20247383Linux: 78. 리눅스 C/C++ - 특정 버전의 glibc 빌드 (docker-glibc-builder)
13714정성태8/19/20246759닷넷: 2295. C# 12 - 기본 생성자(Primary constructors) (책 오타 수정) [3]
13713정성태8/16/20247487개발 환경 구성: 721. WSL 2에서의 Hyper-V Socket 연동
13712정성태8/14/20247225개발 환경 구성: 720. Synology NAS - docker 원격 제어를 위한 TCP 바인딩 추가
13711정성태8/13/20248074Linux: 77. C# / Linux - zombie process (defunct process) [1]파일 다운로드1
13710정성태8/8/20248000닷넷: 2294. C# 13 - (6) iterator 또는 비동기 메서드에서 ref와 unsafe 사용을 부분적으로 허용파일 다운로드1
13709정성태8/7/20247765닷넷: 2293. C# - safe/unsafe 문맥에 대한 C# 13의 (하위 호환을 깨는) 변화파일 다운로드1
13708정성태8/7/20247548개발 환경 구성: 719. ffmpeg / YoutubeExplode - mp4 동영상 파일로부터 Audio 파일 추출
13707정성태8/6/20247791닷넷: 2292. C# - 자식 프로세스의 출력이 4,096보다 많은 경우 Process.WaitForExit 호출 시 hang 현상파일 다운로드1
13706정성태8/5/20247899개발 환경 구성: 718. Hyper-V - 리눅스 VM에 새로운 디스크 추가
13705정성태8/4/20248167닷넷: 2291. C# 13 - (5) params 인자 타입으로 컬렉션 허용 [2]파일 다운로드1
13704정성태8/2/20248126닷넷: 2290. C# - 간이 dotnet-dump 프로그램 만들기파일 다운로드1
13703정성태8/1/20247450닷넷: 2289. "dotnet-dump ps" 명령어가 닷넷 프로세스를 찾는 방법
13702정성태7/31/20247860닷넷: 2288. Collection 식을 지원하는 사용자 정의 타입을 CollectionBuilder 특성으로 성능 보완파일 다운로드1
13701정성태7/30/20248130닷넷: 2287. C# 13 - (4) Indexer를 이용한 개체 초기화 구문에서 System.Index 연산자 허용파일 다운로드1
13700정성태7/29/20247751디버깅 기술: 200. DLL Export/Import의 Hint 의미
13699정성태7/27/20248251닷넷: 2286. C# 13 - (3) Monitor를 대체할 Lock 타입파일 다운로드1
13698정성태7/27/20248208닷넷: 2285. C# - async 메서드에서의 System.Threading.Lock 잠금 처리파일 다운로드1
13697정성태7/26/20247932닷넷: 2284. C# - async 메서드에서의 lock/Monitor.Enter/Exit 잠금 처리파일 다운로드1
13696정성태7/26/20247468오류 유형: 920. dotnet publish - error NETSDK1047: Assets file '...\obj\project.assets.json' doesn't have a target for '...'
13695정성태7/25/20247455닷넷: 2283. C# - Lock / Wait 상태에서도 STA COM 메서드 호출 처리파일 다운로드1
13694정성태7/25/20247919닷넷: 2282. C# - ASP.NET Core Web App의 Request 용량 상한값 (Kestrel, IIS)
13693정성태7/24/20247244개발 환경 구성: 717. Visual Studio - C# 프로젝트에서 레지스트리에 등록하지 않은 COM 개체 참조 및 사용 방법파일 다운로드1
1  2  3  4  5  6  7  8  [9]  10  11  12  13  14  15  ...