Microsoft MVP성태의 닷넷 이야기
오류 유형: 315. 닷넷 프로파일러의 오류 코드 정보 [링크 복사], [링크+제목 복사],
조회: 12468
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

닷넷 프로파일러의 오류 코드 정보

오픈 소스가 좋긴 좋군요. ^^

.NET Profiler 관련해서 ICorProfilerInfo4 인터페이스의 메서드를 호출하는 데 HRESULT 반환값이 0x8013137B로 나왔습니다. 깜깜하군요. ^^;

그런데, 검색해 보니 github에 공개된 CoreCLR 소스코드의 XML 문서에,

CoreCLR
; https://github.com/dotnet/coreclr/blob/master/src/inc/corerror.xml

다음의 설명이 있습니다.

<HRESULT NumericValue="0x8013137B"> 
    <SymbolicName>CORPROF_E_CALLBACK4_REQUIRED</SymbolicName> 
    <Comment> Profiler must implement ICorProfilerCallback4 interface for this call to be supported. </Comment> 
</HRESULT> 

그렇습니다. 프로파일러 측에서 ICorProfilerCallback4 인터페이스를 구현하지 않았다고 설명해주니 문제를 빠르게 인지할 수 있었습니다. 하다 보니, 0x80131363 오류 코드도 만나게 되었는데요, 마찬가지로 해당 문서를 보면,

<HRESULT NumericValue="0x80131363"> 
    <SymbolicName>CORPROF_E_UNSUPPORTED_CALL_SEQUENCE</SymbolicName> 
    <Comment> A call was made at an unsupported time.  Examples include illegally calling a profiling API method asynchronously, calling a method that might trigger a GC at an unsafe time, and calling a method at a time that could cause locks to be taken out of order.  </Comment> 
</HRESULT> 

원인은, C# 코드에서 P/Invoke를 통해 닷넷 프로파일러의 ICorProfilerInfo4의 메서드를 호출했기 때문입니다. (해당 메서드는 절대로 닷넷측의 콜스택 상에서 호출되어서는 안됩니다.)

이 정도면 엄청 상세한 오류 설명입니다. ^^ 닷넷 프로파일러 만드시는 분들은 github의 CoreCLR (소스 코드까지는 아니더라도) 내부 오류 코드 설명을 꼭 참조하시기 바랍니다. ^^




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 3/22/2016]

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

비밀번호

댓글 작성자
 




... 46  47  48  49  [50]  51  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12379정성태10/21/202010643.NET Framework: 955. .NET 메서드의 Signature 바이트 코드 분석 [1]파일 다운로드2
12378정성태10/15/202010114.NET Framework: 954. C# - x86/x64 환경에 따라 달라지는 P/Invoke 함수의 export 이름파일 다운로드1
12377정성태10/15/202011413디버깅 기술: 172. windbg - 파일 열기 시점에 bp를 걸어 파일명 알아내는 방법(Managed/Unmanaged)
12376정성태10/15/20208174오류 유형: 669. windbg - sos의 name2ee 명령어 실행 시 "Failed to request module list." 오류
12375정성태10/15/20209501Windows: 177. 윈도우 탐색기에서 띄우는 cmd.exe 창의 디렉터리 구분 문자가 'Yen(&#0165;)' 기호로 나오는 경우 [1]
12374정성태10/14/202014112.NET Framework: 953. C# 9.0 - (6) 함수 포인터(Function pointers) [1]파일 다운로드2
12373정성태10/14/20209424.NET Framework: 952. OpCodes.Box와 관련해 IL 형식으로 직접 코딩 시 유의할 점
12372정성태10/13/202011335.NET Framework: 951. C# 9.0 - (5) 로컬 함수에 특성 지정 가능(Attributes on local functions)파일 다운로드1
12371정성태10/13/202010028개발 환경 구성: 519. Visual Studio의 Ctrl+Shift+U (Edit.MakeUppercase) 단축키가 동작하지 않는 경우
12370정성태10/13/202010890Linux: 33. Linux - nmcli를 이용한 고정 IP 설정
12369정성태10/12/202013714Windows: 176. Raymond Chen이 한글날에 밝히는 윈도우의 한글 자모 분리 현상 [3]
12368정성태10/12/20209736오류 유형: 668. VSIX 확장 빌드 - The "GetDeploymentPathFromVsixManifest" task failed unexpectedly.
12367정성태10/12/202022494오류 유형: 667. Ubuntu - Temporary failure resolving 'kr.archive.ubuntu.com' [2]
12366정성태10/12/202011555.NET Framework: 950. C# 9.0 - (4) 원시 크기 정수(Native ints) [1]파일 다운로드1
12365정성태10/12/202010500.NET Framework: 949. C# 9.0 - (3) 람다 메서드의 매개 변수 무시(Lambda discard parameters)파일 다운로드1
12364정성태10/11/202011708.NET Framework: 948. C# 9.0 - (2) localsinit 플래그 내보내기 무시(Suppress emitting localsinit flag)파일 다운로드1
12363정성태10/11/202012615.NET Framework: 947. C# 9.0 - (1) 대상으로 형식화된 new 식(Target-typed new expressions) [2]파일 다운로드1
12362정성태10/11/20209382VS.NET IDE: 151. Visual Studio 2019에 .NET 5 rc/preview 적용하는 방법
12361정성태10/11/202010973.NET Framework: 946. C# 9.0을 위한 개발 환경 구성
12360정성태10/8/20208211오류 유형: 666. The type or namespace name '...' does not exist in the namespace 'Microsoft.VisualStudio.TestTools' (are you missing an assembly reference?)
12359정성태10/7/20209727오류 유형: 665. Windows - 재부팅 후 iSCSI 연결이 끊기는 문제
12358정성태10/7/20209748오류 유형: 664. Web Deploy 설치 시 "A newer version of Microsoft Web Deploy 3.6 was found on this machine." 오류 [3]
12357정성태10/7/20207826오류 유형: 663. 이벤트 로그 - The storage optimizer couldn't complete retrim on New Volume
12356정성태10/7/202022662오류 유형: 662. ASP.NET Core와 500.19, 500.21 오류 (0x8007000d)
12355정성태10/3/20207903오류 유형: 661. Hyper-V Linux VM의 Internal 유형의 가상 Switch에 대한 IP 연결이 되지 않는 경우
12354정성태10/2/202020742오류 유형: 660. Web Deploy (msdeploy.axd) 실행 시 오류 기록 [1]
... 46  47  48  49  [50]  51  52  53  54  55  56  57  58  59  60  ...