2008년 11월 10일 월요일

Visual C++ 6.0에서 열기(open), 프로젝트에 추가 할때 MSDEV.exe오류(devshl.dll) 뜨는 문제 해결법

일단.. 크게 3가지 방법을 시도 할 수 있다...
방법 #1번부터 차례대로 따라해보고.. .해결이 안되면 최후의 수단으로 방법 #3으로... 기존의 Open과 Add Project를 대체하여 사용할 수 있다.
난 방법 #1과 방법 #2가 다 되지 않아 현재는 방법 #3으로 대체하여 사용중이다!
완전 불편함 없이 똑같다.


방법 #1

서비스팩 6.0을 설치한다
서비스팩 다운로드 : http://www.microsoft.com/Korea/MSDN/vstudio/downloads/updates/sp/vs6/sp6/



방법 #2

결국 devshl.dll 문제인듯 한데... 아래의 방법대로 차근차근 따라해보자! 그래도 안되면 방법#3으로 넘어간다.

펼쳐보기



방법 #3

이래도 해결이 되지 않는다면 기존의 Open과 Add Project를 과감히 포기하고! 새로 추가해서 사용하자.
아래방법은 영어로 되어 있지만 하나하나 차근차근 따라하면 된다.
간추려 보면
아래 링크에 있는 filetool.exe를 다운받아서 압축풀고
거기있는 코드를 비주얼 스튜디오상에서 컴파일-빌드 하시면 새로운 툴바요소가 만들어 지는데,
1. 그걸 Tool메뉴에서 추가(단축키로 생성됩니다.) - 여기서 생성된 단축키로만 쓰셔도 되고
2. 기존의 open, add in project메뉴를 제거
3. 새로 만든 Open, Add in project를 실제 메뉴자리에 추가
하시면 끝

FileTool.exe

펼쳐보기



아래의.. 댓글에 링크된 방법이 제일 좋을듯 합니다..^^

방법 4

 [Bug Fix] VC++ 6.0 Devshl.dll (at 0x5003eaed) 0xC0000005: Access Denied 오류 해결법 (NULL pointer reference)

 이 버그는 VC++ 6.0에서 File-Open을 클릭하거나, 프로젝트에서 Add File...을 클릭하면 발생하는 VC++ 6.0 Crash에 대한 부분입니다.

예전에 wz1054님이랑 넷미팅 중이였을 때, wz1054님도 같은 증상이 있던것으로 생각되는데, 저 역시 포맷 후에 XP SP3 무인설치로 깔아주니 같은 현상이 일어나네요. ( 게다가 커널 드라이버 역시 ntoskrnl.exe이 아닌 ntkrnlpa.exe로 wz1054님이랑 상황이 완전 비슷하다랄까... )

일단, MS 기술문서(KB)에도 해결책이 써져있습니다만, 미봉책적인 방법인데다가 해결이 안되는 경우도 있어서 글을 쓴겁니다. (MS 기술문서: http://support.microsoft.com/kb/231655)

MS 기술문서엔 아래 두가지 방법을 권고하네요.

1. 별도의 ToolBox Add-in 사용 ( 근데 이건 비추합니다.File-Open의 기능보다 너무 간소해서... 별로 쓰기가 싫은(?) )
2. SP4 이상(SP4~SP6)으로 Visual Studio 6.0을 패치한다. ( 제 컴퓨터에서는 SP6인데도 이런 증상이 일어나는군요. )

일단 이 문제는 컴퓨터에 너무 많은 Component Server(COM)들이 설치되어있어서 발생한다고 써져있었습니다. (근데 왜 과거에 쓰던 시스템에서는 많았는데도 잘됐을까... 쿨럭)

여튼, 직접 Debugger로 Reversing을 해보니까, 아래 코드가
문제였습니다.

0x5003eaed: repe cmps dword ptr [edi],dword ptr [esi]

edi가 0x00000000인 상태에서 Referencing을 하려니까 오류가 생긴것이였습니다.

이를 NOP으로 패치하고 그 밑에 여타 Jump Code를 crash가 발생 안하게끔 패치해주니,

정상 동작하였습니다. (단, File Format선택 콤보박스에 괴상한 문자 몇개 뜨는것쯤은 감수하셔야할듯)

패치 성공한 DLL파일은 아래에 있습니다.

위에 제시한 방법들로 성공하지 못하신 분들은, 아래 DLL 파일을 다운받으셔서

이를 C:\Program Files\Microsoft Visual Studio\COMMON\MSDev98\Bin에 덮어씌우시면 됩니다.

댓글 6개:

  1. 저의 경우 아예 devshl.dll 를 패치해버렸습니다~ 1,2번도 안되고, 3번은... 툴바가 솔직히 너무 부실해서 -_-; (Open 창에 Auto,Text,Binary,Resource 선택 콤보상자가 없어서 쓰기가 싫더군요...) ...



    괜찮으시면 아래 주소에 한번 들어가보세요...^^

    http://vbdream.tistory.com/entry/Bug-Fix-VC-60-Devshldll-at-0x5003eaed-0xC0000005-Access-Denied-%EC%98%A4%EB%A5%98-%ED%95%B4%EA%B2%B0%EB%B2%95-NULL-pointer-reference

    답글삭제
  2. 정말 감사합니다^^ 이 문제 때문에 골치 아팠거든요.. 마지막 링크된 파일 덮어 씌우니까 말끔하게 해결 되네요^ㅡ^/~

    답글삭제
  3. 컴퓨터 포멧하고 프로그램 삭제하고... 고생고생 하다가... 발견했네요.

    감사합니다. 덕분에 이젠 프로그램이 돌아가네요. 정말... (^^)(__)(^^)

    가끔 발생하는 VC의 이런 문제들은 정말... ㅡㅡ+

    답글삭제
  4. 정말 감사합니다!! ㅜㅜ 이 문제 때문에 골치 많았는데 devshl.dll파일 붙여넣으니까 되는군요!



    정말정말감사합니다~!

    답글삭제
  5. 별짓 다하다가 이글을 발견했습니다... 정말 좋은 정보 감사합니다.... 4번으로 해결했습니다.

    답글삭제
  6. 정말 감사합니다...꽤 오래 고생했는데..



    까먹을 거 같아 제 블로그에 퍼감니다..

    답글삭제