Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

IMetaDataImport::GetMethodProps가 반환하는 IL 코드 주소(RVA) 문제

IMetaDataImport::GetMethodProps는 IL 코드 주소에 대해 RVA로 반환해 줍니다.

IMetaDataImport::GetMethodProps Method
; https://learn.microsoft.com/ko-kr/dotnet/framework/unmanaged-api/metadata/imetadataimport-getmethodprops-method

가령, 다음과 같이 코드를 사용하면,

DWORD dwImplFlags = 0;
ULONG ulCodeRVA = 0;

hr = m_pMetaDataImport->GetMethodProps(...[생략]..., &ulCodeRVA, &dwImplFlags);

// hr == 0x00131106 (Data value was truncated)

해당 메서드의 IL 바이트 위치가 ulCodeRVA에 어셈블리의 로딩 주소에 대한 상대값으로 나오게 됩니다. 그런데, 재미있는 것은 저 규칙이 ASP.NET Core 2.1 웹 응용 프로그램을 docker container 환경에서 실행했을 때 예외가 발생한다는 점입니다.

실제로 제가 테스트한 환경에서 다음과 같은 구성으로 값이 설정되었는데,

어셈블리 로드 주소: bce29000
ulCodeRVA: 2050

그렇다면 코드 주소가 bce2b050으로 계산이 되지만, IL 코드의 주소를 반환해주는 또 다른 메서드인 GetILFunctionBody를 사용해 보면,

ICorProfilerInfo::GetILFunctionBody Method
; https://learn.microsoft.com/ko-kr/dotnet/framework/unmanaged-api/profiling/icorprofilerinfo-getilfunctionbody-method

pCorProfilerInfo->GetILFunctionBody(...[생략]..., &codeAddress, &codeSize);

그 상황에서 codeAddress == bce29250 값이 출력되었습니다. 0x1e00만큼의 차이가 나는 것인데 재미있는 것은 ulCodeRVA 값이 0x2050이 아닌 0x250이 반환되었으면 정확했을 상황입니다.

어쨌든, 위의 사례를 계기로 모든 코드를 RVA 값을 이용하지 않고 GetILFunctionBody를 한번 더 호출하는 것으로 변경했는데... 어쩌면 저 차이가 제가 모르는 리눅스의 ELF 포맷의 런타임 시 추가적인 오프셋 값으로 인한 것일 수도 있으므로 딱히 .NET Core의 버그라고 단정 짓기도 모호하군요. ^^




이 외에도, GetMethodProps는 윈도우와 리눅스 환경에서 다른 동작을 하나 보이는 것이 있습니다. 일례로, 다음과 같이 코딩을 한 경우,

ULONG count = 0;
uchar16 wszFunctionName[512];

hr = m_pMetaDataImport->GetMethodProps(..., wszFunctionName, 512, &count, ...);

이때 만약 메서드의 이름이 512자를 넘는다면 hr 반환값이 CLDB_S_TRUNCATION(0x00131106 - "Data value was truncated")이 됩니다. 여기서 문제는, 윈도우의 경우 그래도 전달된 wszFunctionName 버퍼에는 512개까지의 문자가 담겨서 넘어오는 반면, 리눅스에서는 아예 빈 문자열로 나온다는 점입니다. 따라서, 저 코드를 유연하게 하려면 애당초 고정 버퍼보다는 동적 할당 버퍼를 쓰는 것이 더 낫습니다.




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







[최초 등록일: ]
[최종 수정일: 10/13/2023]

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

비밀번호

댓글 작성자
 




... 16  17  18  19  [20]  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13439정성태11/10/202311534닷넷: 2158. C# - 소켓 포트를 미리 시스템에 등록/예약해 사용하는 방법(Port Exclusion Ranges)파일 다운로드1
13438정성태11/9/202311049닷넷: 2157. C# - WinRT 기능을 이용해 윈도우에서 실행 중인 Media App 제어
13437정성태11/8/202311257닷넷: 2156. .NET 7 이상의 콘솔 프로그램을 (dockerfile 없이) 로컬 docker에 배포하는 방법
13436정성태11/7/202311341닷넷: 2155. C# - .NET 8 런타임부터 (Reflection 없이) 특성을 이용해 public이 아닌 멤버 호출 가능
13435정성태11/6/202310602닷넷: 2154. C# - 네이티브 자원을 포함한 관리 개체(예: 스레드)의 GC 정리
13434정성태11/1/202310589스크립트: 62. 파이썬 - class의 정적 함수를 동적으로 교체
13433정성태11/1/20239420스크립트: 61. 파이썬 - 함수 오버로딩 미지원
13432정성태10/31/202310223오류 유형: 878. 탐색기의 WSL 디렉터리 접근 시 "Attempt to access invalid address." 오류 발생
13431정성태10/31/202310751스크립트: 60. 파이썬 - 비동기 FastAPI 앱을 gunicorn으로 호스팅
13430정성태10/30/202310951닷넷: 2153. C# - 사용자가 빌드한 ICU dll 파일을 사용하는 방법
13429정성태10/27/202311087닷넷: 2152. Win32 Interop - C/C++ DLL로부터 이중 포인터 버퍼를 C#으로 받는 예제파일 다운로드1
13428정성태10/25/202311233닷넷: 2151. C# 12 - ref readonly 매개변수
13427정성태10/18/202310732닷넷: 2150. C# 12 - 정적 문맥에서 인스턴스 멤버에 대한 nameof 접근 허용(Allow nameof to always access instance members from static context)
13426정성태10/13/202311243스크립트: 59. 파이썬 - 비동기 호출 함수(run_until_complete, run_in_executor, create_task, run_in_threadpool)
13425정성태10/11/202311125닷넷: 2149. C# - PLinq의 Partitioner<T>를 이용한 사용자 정의 분할파일 다운로드1
13423정성태10/6/202311016스크립트: 58. 파이썬 - async/await 기본 사용법
13422정성태10/5/202310765닷넷: 2148. C# - async 유무에 따른 awaitable 메서드의 병렬 및 예외 처리 [1]
13421정성태10/4/202311028닷넷: 2147. C# - 비동기 메서드의 async 예약어 유무에 따른 차이
13420정성태9/26/202319275스크립트: 57. 파이썬 - UnboundLocalError: cannot access local variable '...' where it is not associated with a value
13419정성태9/25/202310871스크립트: 56. 파이썬 - RuntimeError: dictionary changed size during iteration
13418정성태9/25/202312505닷넷: 2146. C# - ConcurrentDictionary 자료 구조의 동기화 방식
13417정성태9/19/202311794닷넷: 2145. C# - 제네릭의 형식 매개변수에 속한 (매개변수를 가진) 생성자를 호출하는 방법
13416정성태9/19/202310392오류 유형: 877. redis-py - MISCONF Redis is configured to save RDB snapshots, ...
13415정성태9/18/202311827닷넷: 2144. C# 12 - 컬렉션 식(Collection Expressions) [2]
13414정성태9/16/202311159디버깅 기술: 193. Windbg - ThreadStatic 필드 값을 조사하는 방법
13413정성태9/14/202311981닷넷: 2143. C# - 시스템 Time Zone 변경 시 이벤트 알림을 받는 방법
... 16  17  18  19  [20]  21  22  23  24  25  26  27  28  29  30  ...