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

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

1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5832김지우2/21/20232918event와 delegate의 차이 , event를 써야하는 이유 [1]
5831이우람2/20/20233149ref 전역변수가 pinned가 될수 있나요? [2]
5830냉수마찰2/19/20233441C# GridView에 Column별 데이터 추가하는 방법에 대해 [1]
5829수박942/19/20233436키움 API를 윈폼과 WPF의 네임스페이스 없이 콘솔이나 WinUI3에서 사용할 수 있는 방법이 있나요? [2]파일 다운로드1
5828김재영2/19/20233227장기적으로는 this 구문을 안쓰는게 맞을까요? [2]
5827lee2/18/20233157파이썬 설치 오류 질문입니다 [1]
5826Syong2/14/20233734Socket 관련 Leak (OverlappedAsyncResult, OverlappedData) 관련 문의 [7]파일 다운로드1
5825박성원2/14/20233297Listview 컨트롤의 화면 전환 시 갱신 속도 [1]
5823검은콩2/13/20233902catch(Exception ex)의 line번호를 쉽게 알 수 없는지요? [7]
5822김지우2/11/20233161책을 보면서 sync, async 이해가 되지 않는 부분이 있습니다. [5]파일 다운로드2
5821검은콩2/9/20233179Async 신뢰성과 소켓데이터 [4]
5820차가워2/8/20233269다른 프로세스 실행 후 포커스 가져오기 [3]
5819취준생2/7/20233380WPF 관련 실무가 궁금합니다. [3]
5818윤길2/7/20232834ObservableCollection 에서 INotifyPropertyChanged 구현해야하나요? [2]
5817흰털너부리2/7/20232969배포 시 winform 실행 콘솔로그 보는 방법 [1]
5816흰털너부리2/6/20232790.net core json array validation 질문 드립니다. [1]
5815김재영2/6/20232908종단간 암호화에 대해 시나리오인데 타당한 시나리오일까요? [2]
5814한예지 donator2/6/20233260decompile? [9]
5813김재영2/5/20233150openssl genrsa 2048시 키 생성이 다르게 됩니다. - 파일첨부 [4]파일 다운로드1
5812김재영2/5/20233410openssl genrsa 2048시 키 생성이 다르게 됩니다. [2]
5811치르바2/3/20233238MiniDumpWriteDump API로 덤프수집을 했는데요.. [3]
5810이건우1/31/20233356윈도우서비스를 통한 웹통신관련 질문입니다 [3]
5809이상훈1/31/20233782다채널 영상 디스플레이어 개발 관련 질문입니다. [3]
5808근우1/30/20233454WPF 에서 UserControl 과 ControlTemplate 의 차이점은 무엇인가요? [6]
5807궁금맨1/28/20234617C# 10 책에 나온 예제의 결과가 제 컴에서는 좀 달라서요. 이유가 궁금합니다. [1]
5806스레드1/25/20233143총정리 - 다양한 스레드들 [초안] [1]파일 다운로드1
1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...