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비트 기본 사용' 옵션은 크게 의미가 없을 것 같습니다.
정성태

... 61  62  63  64  65  66  67  68  [69]  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12211정성태4/27/202019260개발 환경 구성: 486. WSL에서 Makefile로 공개된 리눅스 환경의 C/C++ 소스 코드 빌드
12210정성태4/20/202020691.NET Framework: 903. .NET Framework의 Strong-named 어셈블리 바인딩 (1) - app.config을 이용한 바인딩 리디렉션 [1]파일 다운로드1
12209정성태4/13/202017405오류 유형: 614. 리눅스 환경에서 C/C++ 프로그램이 Segmentation fault 에러가 발생한 경우 (2)
12208정성태4/12/202015965Linux: 29. 리눅스 환경에서 C/C++ 프로그램이 Segmentation fault 에러가 발생한 경우
12207정성태4/2/202015802스크립트: 19. Windows PowerShell의 NonInteractive 모드
12206정성태4/2/202018425오류 유형: 613. 파일 잠금이 바로 안 풀린다면? - The process cannot access the file '...' because it is being used by another process.
12205정성태4/2/202015094스크립트: 18. Powershell에서는 cmd.exe의 명령어를 지원하진 않습니다.
12204정성태4/1/202015090스크립트: 17. Powershell 명령어에 ';' (semi-colon) 문자가 포함된 경우
12203정성태3/18/202017937오류 유형: 612. warning: 'C:\ProgramData/Git/config' has a dubious owner: '...'.
12202정성태3/18/202021196개발 환경 구성: 486. .NET Framework 프로젝트를 위한 GitLab CI/CD Runner 구성
12201정성태3/18/202018434오류 유형: 611. git-credential-manager.exe: Using credentials for username "Personal Access Token". [1]
12200정성태3/18/202018523VS.NET IDE: 145. NuGet + Github 라이브러리 디버깅 관련 옵션 3가지 - "Enable Just My Code" / "Enable Source Link support" / "Suppress JIT optimization on module load (Managed only)"
12199정성태3/17/202016167오류 유형: 610. C# - CodeDomProvider 사용 시 Unhandled Exception: System.IO.DirectoryNotFoundException: Could not find a part of the path '...\f2_6uod0.tmp'.
12198정성태3/17/202019528오류 유형: 609. SQL 서버 접속 시 "Cannot open user default database. Login failed."
12197정성태3/17/202018811VS.NET IDE: 144. .NET Core 콘솔 응용 프로그램을 배포(publish) 시 docker image 자동 생성 - 두 번째 이야기 [1]
12196정성태3/17/202015942오류 유형: 608. The ServicedComponent being invoked is not correctly configured (Use regsvcs to re-register).
12195정성태3/16/202018262.NET Framework: 902. C# - 프로세스의 모든 핸들을 열람 - 세 번째 이야기
12194정성태3/16/202020993오류 유형: 607. PostgreSQL - Npgsql.NpgsqlException: sorry, too many clients already
12193정성태3/16/202017903개발 환경 구성: 485. docker - SAP Adaptive Server Enterprise 컨테이너 실행 [1]
12192정성태3/14/202019927개발 환경 구성: 484. docker - Sybase Anywhere 16 컨테이너 실행
12191정성태3/14/202021042개발 환경 구성: 483. docker - OracleXE 컨테이너 실행 [1]
12190정성태3/14/202015622오류 유형: 606. Docker Desktop 업그레이드 시 "The process cannot access the file 'C:\Program Files\Docker\Docker\resources\dockerd.exe' because it is being used by another process."
12189정성태3/13/202021212개발 환경 구성: 482. Facebook OAuth 처리 시 상태 정보 전달 방법과 "유효한 OAuth 리디렉션 URI" 설정 규칙
12188정성태3/13/202026020Windows: 169. 부팅 시점에 실행되는 chkdsk 결과를 확인하는 방법
12187정성태3/12/202015579오류 유형: 605. NtpClient was unable to set a manual peer to use as a time source because of duplicate error on '...'.
12186정성태3/12/202017399오류 유형: 604. The SysVol Permissions for one or more GPOs on this domain controller and not in sync with the permissions for the GPOs on the Baseline domain controller.
... 61  62  63  64  65  66  67  68  [69]  70  71  72  73  74  75  ...