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

Error VSP1033: The file '...' does not contain a recognized executable image.

특정 DLL의 Code Coverage를 위해 vsinstr.exe를 실행했는데,

d:\temp>vsinstr -coverage .\bin\Test.dll
Microsoft (R) VSInstr Post-Link Instrumentation 14.0.25420 x86
Copyright (C) Microsoft Corp. All rights reserved.

Error VSP1033: The file 'd:\temp\UnitTest\bin\Test.dll' does not contain a recognized executable image.

보는 바와 같이 실행 가능한 이미지가 아니라면서 instrumentation 코드 삽입에 실패를 합니다. 딱히 검색을 해봐도 이에 대한 글이 없습니다.

실행된 vsinstr.exe는 32비트 버전임을 where 명령어를 통해서 알 수 있었고,

d:\temp>where vsinstr.exe
C:\Program Files (x86)\Microsoft Visual Studio 14.0\Team Tools\Performance Tools\vsinstr.exe

혹시나 싶어 명시적으로 x64 버전의 vsinstr.exe를 실행해 봤더니 이렇게 잘 됩니다. ^^;

d:\temp>"C:\Program Files (x86)\Microsoft Visual Studio 14.0\Team Tools\Performance Tools\x64\vsinstr.exe" -coverage Test.dll

Microsoft (R) VSInstr Post-Link Instrumentation 14.0.25420 x64
Copyright (C) Microsoft Corp. All rights reserved.

File to Process:
   d:\temp\Test.dll --> d:\temp\Test.dll
Original file backed up to d:\temp\Test.dll.orig

Warning VSP2001: d:\temp\Test.dll is a strongly named assembly.  It will need to be re-signed before it can be executed.
Successfully instrumented file d:\temp\Test.dll.

이상하군요. 분명히 Test.dll은 AnyCPU 모드로 빌드했는데 저렇게 vsinstr.exe의 플랫폼 영향을 받다니!

더욱 이상한 것은, 동일한 DLL을 Visual Studio가 설치된 다른 컴퓨터에서 32비트 버전의 vsinstr.exe를 실행했더니... 잘 됩니다. ^^; 그렇다면 DLL 자체의 문제는 아닌 듯싶고, 뭔가 환경적인 요인이 있는 듯한데 일단 더 이상의 파악은 할 수 없었습니다.

참고로, vsinstr.exe의 32/64비트 실행 파일은 각각 다음의 폴더에 있습니다.

C:\Program Files (x86)\Microsoft Visual Studio 14.0\Team Tools\Performance Tools
C:\Program Files (x86)\Microsoft Visual Studio 14.0\Team Tools\Performance Tools\x64




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







[최초 등록일: ]
[최종 수정일: 2/19/2017]

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

비밀번호

댓글 작성자
 



2017-02-20 03시58분
[ryujh] 안녕하세요.

vs 2008 에는 없지만
vs 2012 에서 확인해보니

프로젝트 - 속성 - 빌드 - 플랫폼 대상 : Any CPU

아래에 32비트 기본 사용이 체크 되어 있다면 32비트로 빌드된 적이 있습니다.

본문의 vsinstr.exe 와 관련이 있는지는 모르겠습니다.



[guest]
2017-02-20 07시19분
ryujh님의 보충 설명도 도움이 되겠습니다. 단지, 본문의 경우 dll에 대해서 테스트한 것인데, "32비트 기본 사용" 옵션은 DLL 프로젝트에 대해서는 비활성화되어 있습니다. 확신할 수는 없지만, vsinstr.exe 자체가 이미 32/64비트로 결정되었기 때문에 아마도 닷넷 exe에 대해서도 '32비트 기본 사용' 옵션은 크게 의미가 없을 것 같습니다.
정성태

... 46  47  48  49  50  [51]  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12341정성태9/23/20209669.NET Framework: 944. C# - 인스턴스가 살아 있어 메모리 누수가 발생하고 있는지 확인하는 방법파일 다운로드1
12340정성태9/23/20209366.NET Framework: 943. WPF - WindowsFormsHost를 담은 윈도우 생성 시 메모리 누수
12339정성태9/21/20209335오류 유형: 655. 코어 모드의 윈도우는 GUI 모드의 윈도우로 교체가 안 됩니다.
12338정성태9/21/20208845오류 유형: 654. 우분투 설치 시 "CHS: Error 2001 reading sector ..." 오류 발생
12337정성태9/21/202010160오류 유형: 653. Windows - Time zone 설정을 바꿔도 반영이 안 되는 경우
12336정성태9/21/202012664.NET Framework: 942. C# - WOL(Wake On Lan) 구현
12335정성태9/21/202022076Linux: 31. 우분투 20.04 초기 설정 - 고정 IP 및 SSH 설치
12334정성태9/21/20207576오류 유형: 652. windbg - !py 확장 명령어 실행 시 "failed to find python interpreter"
12333정성태9/20/20208016.NET Framework: 941. C# - 전위/후위 증감 연산자에 대한 오버로딩 구현 (2)
12332정성태9/18/20209998.NET Framework: 940. C# - Windows Forms ListView와 DataGridView의 예제 코드파일 다운로드1
12331정성태9/18/20209181오류 유형: 651. repadmin /syncall - 0x80090322 The target principal name is incorrect.
12330정성태9/18/202010221.NET Framework: 939. C# - 전위/후위 증감 연산자에 대한 오버로딩 구현 [2]파일 다운로드1
12329정성태9/16/202012140오류 유형: 650. ASUS 메인보드 관련 소프트웨어 설치 후 ArmouryCrate.UserSessionHelper.exe 프로세스 무한 종료 현상
12328정성태9/16/202012344VS.NET IDE: 150. TFS의 이력에서 "Get This Version"과 같은 기능을 Git으로 처리한다면?
12327정성태9/12/20209945.NET Framework: 938. C# - ICS(Internet Connection Sharing) 제어파일 다운로드1
12326정성태9/12/20209490개발 환경 구성: 516. Azure VM의 Network Adapter를 실수로 비활성화한 경우
12325정성태9/12/20209040개발 환경 구성: 515. OpenVPN - 재부팅 후 ICS(Internet Connection Sharing) 기능이 동작 안하는 문제
12324정성태9/11/202010234개발 환경 구성: 514. smigdeploy.exe를 이용한 Windows Server 2016에서 2019로 마이그레이션 방법
12323정성태9/11/20209176오류 유형: 649. Copy Database Wizard - The job failed. Check the event log on the destination server for details.
12322정성태9/11/20209975개발 환경 구성: 513. Azure VM의 RDP 접속 위치 제한 [1]
12321정성태9/11/20208528오류 유형: 648. netsh http add urlacl - Error: 183 Cannot create a file when that file already exists.
12320정성태9/11/20209676개발 환경 구성: 512. RDP(원격 데스크톱) 접속 시 비밀 번호를 한 번 더 입력해야 하는 경우
12319정성태9/10/20209421오류 유형: 647. smigdeploy.exe를 Windows Server 2016에서 실행할 때 .NET Framework 미설치 오류 발생
12318정성태9/9/20208965오류 유형: 646. OpenVPN - "TAP-Windows Adapter V9" 어댑터의 "Network cable unplugged" 현상
12317정성태9/9/202011218개발 환경 구성: 511. Beats용 Kibana 기본 대시 보드 구성 방법
12316정성태9/8/20209653디버깅 기술: 170. WinDbg Preview 버전부터 닷넷 코어 3.0 이후의 메모리 덤프에 대해 sos.dll 자동 로드
... 46  47  48  49  50  [51]  52  53  54  55  56  57  58  59  60  ...