Microsoft MVP성태의 닷넷 이야기
[질문] Windows Error Reporting [링크 복사], [링크+제목 복사]
조회: 18053
글쓴 사람
이창주 (changju.rhee at gmail.com)
홈페이지
첨부 파일
 

아래와 같은 이벤트 에러 로그가 있어 질문 올립니다.

ImageDelegateSample.exe 라는 프로그램은 제가 만든 것인데요. 프로그램이 랜덤하게 죽는 경향이 있습니다.
이미지 버퍼에 복사하는 코드에서 자꾸 AccessViolation이 발생하는 이유를 모르겠네요.

이벤트 로그1 --

오류 버킷 , 유형 0
이벤트 이름: APPCRASH
응답: 사용할 수 없음
Cab ID: 0

문제 서명:
P1: ImageDelegateSample.exe
P2: 0.0.0.0
P3: 52e109aa
P4: ATL100.DLL
P5: 10.0.40219.325
P6: 4df2bce8
P7: c0000005
P8: 000000000000109d
P9:
P10:

첨부 파일:
C:\Users\user\AppData\Local\Temp\WER383A.tmp.WERInternalMetadata.xml
C:\Users\user\AppData\Local\Temp\WER4323.tmp.appcompat.txt
C:\Users\user\AppData\Local\Temp\WER4382.tmp.hdmp
C:\Users\user\AppData\Local\Temp\WER5EB1.tmp.mdmp

이 파일은 다음에서 사용할 수 있습니다.
C:\Users\user\AppData\Local\Microsoft\Windows\WER\ReportQueue\AppCrash_ImageDelegateSam_40fcc6b3c772e8594950f7eed6a25231ad1e562_cab_0a93614c

분석 기호:
해결 방법 재확인: 0
보고서 ID: ae0c7bbc-84d8-11e3-aaf1-e0de2fe65149
보고서 상태: 4

이벤트 로그2 --

오류 있는 응용 프로그램 이름: ImageDelegateSample.exe, 버전: 0.0.0.0, 타임스탬프: 0x52e109aa
오류 있는 모듈 이름: ATL100.DLL, 버전: 10.0.40219.325, 타임스탬프: 0x4df2bce8
예외 코드: 0xc0000005
오류 오프셋: 0x000000000000109d
오류 있는 프로세스 ID: 0x10f0
오류 있는 응용 프로그램 시작 시간: 0x01cf1835e8c36de7
오류 있는 응용 프로그램 경로: C:\02 program\work\bin\ImageDelegateSample.exe
오류 있는 모듈 경로: C:\Windows\system32\ATL100.DLL
보고서 ID: ae0c7bbc-84d8-11e3-aaf1-e0de2fe65149

이벤트 로그3 --

응용 프로그램: ImageDelegateSample.exe
Framework 버전: v4.0.30319
설명: 처리되지 않은 예외로 인해 프로세스가 종료되었습니다.
예외 정보:System.AccessViolationException
스택:
   위치: Cognex.VisionPro.CogImage8Grey.Copy(Cognex.VisionPro.CogImageCopyModeConstants)
   위치: ImageDelegateSample.ClientManager.CopyToCogBuffer(IntPtr)
   위치: ImageDelegateSample.ClientManager.HandleImage(ImageInfo ByRef)
   위치: Jai_FactoryDotNET.CCamera.HandleImage(ImageInfo ByRef)
   위치: Jai_FactoryDotNET.CCamera+StreamWork.StreamThread()
   위치: System.Threading.ExecutionContext.Run(System.Threading.ExecutionContext, System.Threading.ContextCallback, System.Object, Boolean)
   위치: System.Threading.ExecutionContext.Run(System.Threading.ExecutionContext, System.Threading.ContextCallback, System.Object)
   위치: System.Threading.ThreadHelper.ThreadStart()


이벤트가 발생한 시스템 정보는 아래와 같습니다.

?운영 체제 버전
Windows 7 Pro K (64 bit)

?CPU 또는 프로세서
Intel(R) Xeon(R) CPU E5620 @ 2.40 GHz, 2.40 GHz (2개 프로세서)

?비디오 카드 (도: 그래픽 장치, 비디오 어댑터 또는 GPU)
NVidia GeForce GT 610

?시스템 메모리 (RAM)의 양
16 GB

?하드 디스크의 크기와 모델
1 TB

?모델을 사용 하고 문제를 관련이 있을 수 있습니다 하드웨어 또는 소프트웨어의 버전
VS2010 Pro에서 개발하였고, C#, .NET4.0

?바이러스 검색 프로그램이 나 사용 중인 맬웨어 검사의 버전

 








[최초 등록일: ]
[최종 수정일: 1/25/2014]


비밀번호

댓글 작성자
 



2014-01-25 01시18분
콜스택에 이미 힌트가 나와 있고 소스코드는 이창주님이 가지고 있으므로 더 잘 아셔야 할 것 같은데요. 저는 이 정도의 정보로는 알 수 없습니다.
정성태
2014-01-26 02시31분
[이창주] 포스팅하셨던 글들을 주욱 보니...아래 글에 대한 정성태님의 답변을 보았습니다. 저두 64비트 OS에 VS2010으로 빌드 시 빌드 구성을 AnyCPU로 설정을 해서 빌드를 하는데요. 이게 문제가 아닐까 싶어 x64로 구성을 바꿔 빌드 해서 돌려 봤는데요. 아직까지는 죽지 않더라구요. 보통 12시간 이내에 프로그램이 죽었는데 말이죠... 개발한 프로그램을 32비트와 64비트 모두 사용을 하다보니 AnyCPU로 설정을 하게 되었는데... 이게 문제가 있을 줄이야...하고

http://www.sysnet.pe.kr/Default.aspx?mode=3&sub=0&pageno=0&detail=1&wid=996
http://blogs.msdn.com/b/rmbyers/archive/2009/06/08/anycpu-exes-are-usually-more-trouble-then-they-re-worth.aspx

[guest]
2014-01-26 10시53분
그 글은 이 문제와 상관이 없습니다. 지금 문제가 없으시다면 다른 방법으로 인해 수정되었거나, 아니면 운이 좋은 상태로 아직까지 살아있을 확률이 높습니다.

32비트/64비트가 문제였을 정도라면 그다지 시간이 걸리지 않고 곧바로 종료되었을 것입니다.
정성태
2014-02-03 03시10분
[이창주] 네, 그 문제가 아니었네요. 포스팅 하고 확인해 보니, 또 죽더군요. 포스팅 글 삭제가 안되어서 그냥 나뒀는데..역시나...
VS2010에선 아무튼 x64로 빌드하는게 맞겠지요 ?
[guest]
2014-02-03 01시08분
VS2010에서 빌드한다고 x64로 하라는 기준은 없습니다. 서버 용 프로그램을 개발하는 경우라면 x64가 좋겠고, 대상이 정해지지 않은 클라이언트에 배포하는 것이라면 x86으로 해도 좋습니다. x64 빌드는 개발툴에 의해 좌우되는 것이 아닙니다. ^^

지금 문제는, 랜덤하게 죽는다고 했는데요. 그렇다면 이를 x86으로 빌드해도 마찬가지로 발생할 수 있습니다.

대충 콜스택을 보니 native와 연동하는 것 같은데요. 그 쪽에 전달하는 버퍼를 고정(pin)시키고 보내는 것 맞나요? 관리 코드에서 비관리 코드로 버퍼의 포인터를 전달할 때는 반드시 pinning을 해야 합니다.
정성태
2014-02-03 01시19분
[이창주] 관리코드에서 비관리코드로 버퍼의 포인터를 아래와 코드와 같이 pinning을 사용하여 전달하고 있습니다.
private void HandleImage(ref Jai_FactoryWrapper.ImageInfo ImageInfo)
        {
            try
            {
                if (recipe.CameraInfo[indexID].Use)
                {
                    byte[] byteArray = null;
                    if (ImageInfo.ImageBuffer != IntPtr.Zero && ImageInfo.ImageSize == int.Parse(myWidthNode.Value.ToString()) * int.Parse(myHeightNode.Value.ToString()))
                    {
                        byteArray = new byte[ImageInfo.ImageSize];
                        GCHandle pinnedArray = GCHandle.Alloc(byteArray, GCHandleType.Pinned);
                        IntPtr pointer = pinnedArray.AddrOfPinnedObject();
                        CopyMemory(pointer, ImageInfo.ImageBuffer, ImageInfo.ImageSize);
                        CopyToCogBuffer(pointer);
                        pinnedArray.Free();
                    }
                }
            }
            catch (Exception ex)
            {
                log.AddErrorLog(this.Name, MethodBase.GetCurrentMethod().Name, string.Format("Error Occured : MESASGE[{0}]\r\nSOURCE[{1}]\r\nTRACE[{2}]", ex.Message, ex.Source, ex.StackTrace));
            }
        }
[guest]
2014-02-03 01시23분
[이창주] 이벤트 로그를 보면 항상 오류있는 모듈 경로로 ATL100.dll 에서 Application Error 가 같이 발생하는 데요. 이것과는 정말 무관한 것인지 ?
[guest]
2014-02-04 01시54분
이 정도면 단순 질문답변으로 풀기에는 어려울 듯 싶군요. atl dll에서 오류가 나는 것은 atl의 잘못이 아니고, 대개의 경우 atl에서 export한 함수를 호출하기 때문에 발생하는 문제입니다. 결국 콜스택에 자신의 코드가 있다면 그것을 의심하는 게 맞습니다.

암튼, 꼭 해결하시길 바라겠습니다. ^^
정성태

... 31  32  33  34  35  36  37  38  39  40  41  42  43  44  [45]  ...
NoWriterDateCnt.TitleFile(s)
4719이민구4/29/201612042[시작하세요! C# 프로그래밍] 4.5.1.6 열거형 마지막 예제 질문입니다. [4]파일 다운로드1
4718ds4/27/201610355오라클 DB 칼럼에 있는 특정 데이터를 가져올수가 있나여? [1]
4717최령진4/26/20169432모바일 웹 앱 관련문의 드립니다 [1]
4715과객4/7/201611433TFS 와 Stylecop Integration 시 체크인 정책 적용 방법이 궁금합니다. [1]
4714임형복4/7/201611366DLL 을 프로세스처럼 사용하기 [3]파일 다운로드1
4713김태훈4/5/201611574하위 폴더 권한 상속 문제 [1]
4712차가워4/5/201613281멀티코어 스레드 문의 [1]
4711이대희4/1/201610765Xamarin 라이센스 변경 (Visual Sutuio 무료 사용) [2]
4709가가멜3/25/201635159국내 WPF 책은 왜 2010 년 이후로 전멸인지요? [1]
4704최훈3/15/201615068C# 6.0 예제 7.1 관련 질문입니다. [2]
4702popo3/14/201614565C# WeakReference이 CPU 플랫폼 설정 마다 결과가 틀리게 나옵니다. [9]
4701쌉쓰릅3/13/201612278uwp에서 그림판의 지우개 기능을 구현하려고하는데요 참고할 만한 정보가 있을가요? [2]
4700정우진3/12/201610681안녕하세요. 10049소켓에러의 해결법을 알고싶습니다. - 수정본 [1]파일 다운로드1
4699정우진3/11/201613469안녕하세요. 10049소켓에러의 해결법을 알고싶습니다. [1]
4698지나가는3/10/201612070안녕하세요. 주기적으로 일어나는 .net 관련 질문이 있습니다 [1]
4697정우진3/9/20169688안녕하세요. AWS EC2를 이용한 서버 개발에 대해 질문드립니다. [1]
4696삽질맨3/9/201614258Winform Cold Start 로딩 속도 개선 방법이 없을까요? [1]
4695popo3/9/201612016wpf의 ICommand 질문 입니다. [5]파일 다운로드1
4694아무개2/28/201611635책 잘보고있습니다~ [1]
4693초보2/25/20169828카카오톡 오류 질문 [1]
3701강준2/19/2016193052개의 DataTable Join 결과 전체 컬럼을 DataTable 로 리턴하기 [5]
3700박성훈2/18/201610913시작하세요! C# 6.0 프로그래밍 105쪽 예제 질문 [1]
3699박성훈2/18/201610520공부 방향성 질문 [2]
3698강준2/16/201611131Entity Framework 에서 Select for Update 가 가능한가요??? [1]
3697ds2/16/201610673어느 정도 문법을 알고 나면 [6]
3695Bere...2/15/201612922호출당한 메서드가 호출한 메서드를 알 수 있는 방법이 일반적인 방법 말고도 있을까요? [2]
... 31  32  33  34  35  36  37  38  39  40  41  42  43  44  [45]  ...