Microsoft MVP성태의 닷넷 이야기
[질문] Windows Error Reporting [링크 복사], [링크+제목 복사],
조회: 25466
글쓴 사람
이창주 (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한 함수를 호출하기 때문에 발생하는 문제입니다. 결국 콜스택에 자신의 코드가 있다면 그것을 의심하는 게 맞습니다.

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

... 16  17  18  19  20  21  22  23  24  25  26  27  28  29  [30]  ...
NoWriterDateCnt.TitleFile(s)
5157김경훈5/8/201917300Task 만들때 넘겨주는 CancellationToken은 어디서 사용 되는 건가요? [4]
5156rysoo5/8/201915860yield return의 리턴 타입 질문 드립니다. [4]
5155세퉁5/7/201918273관리자 권한으로 실행 시 알림창(?) 없이 바로 실행 시킬 수 있는 방법이 있을까요?? [2]파일 다운로드1
5154Soul...5/4/201914172NamedPipe 질문드립니다. [2]
5153개태5/4/201915219WCF RESTful Service에서 enum을 parameter로 쓰는방법 [2]
5152세퉁5/3/201916262인터넷 시간을 불러와 pc에 적용 시키고 싶습니다. [3]파일 다운로드1
5151이대희5/3/201913742C# 7.3으로 개정판 출간 계획이 있으신가요? [1]
5150김이현5/2/201915865C# 딕셔너리 생성에 대해 질문드립니다. [1]
5149민성5/1/201913933ftp 이미지 업로드중 [1]
5148wpf질문4/30/201914215특정 사이트를 wpf에서 popup을 항상 허용하게 할려면 어떻게 해야할까요? [5]
5147민성4/30/201912996wpf에서 작업관리자를 띠울려면 어떻게 해야 하나요? [1]
5146불파겐4/25/201913046하나의 필드를 여러 스레드에서 읽어갈 때 스레드 동기화를 하지 않으면 문제가 생길까요? [2]
5145e구름4/17/201916500Properties.Setting.Default값에 대해 질문드립니다. [2]
5144성태님 ...4/17/201913489질문하시기 전에 10000 페이지 오류 납니다. [1]
5143헌이4/16/201914587윈도우 작업표시줄에 프로그램 띄우기 [2]파일 다운로드1
5142cab2...4/9/201920565C#으로 만든 DLL 배포하기 [10]
5141하늘사랑4/5/201915269Axinterop 래퍼에 관해서 질문드립니다. [7]
5140게스트4/1/201914577안녕하세요. 초보 개발자입니다. SD리더기에서 SD카드를 꽂으면 발생하는 이벤트 문의 [2]
5139김이현3/28/201917858C#에서 CRON 같은 스케줄러를 사용하려면 어떻게 해야 하나요? [3]
5138김지원3/22/201915261유니티 쉐이더에서 오로지 포워드 애드 패스로만 만들 수 있을까요? [1]
5137세퉁3/22/201916961wpf 쓰레드에 대해 질문 있습니다. [4]
5136KGY3/13/201913823안녕하세요 닷넷코어 콘솔 프로그램 관련 질문입니다. [1]
5135러쎌3/13/201914296ASP.NET 공부 관련해서 문의를 드립니다. [1]
5134이정호3/12/201913305SampleProfiler 예제를 이용한 Class 객체의 접근 문의 [1]파일 다운로드1
5133ㅇㅇ3/12/201914361멀티코어사용 방법에 궁금한것이 있습니다. [3]
5132존기미3/3/201914575Physical Disk Access문의 [1]
... 16  17  18  19  20  21  22  23  24  25  26  27  28  29  [30]  ...