Microsoft MVP성태의 닷넷 이야기
GPU 디바이스 재시작시 WPF + .NET 3.5 기반 어플리케이션 UI 문제 [링크 복사], [링크+제목 복사],
조회: 10830
글쓴 사람
푸우 (none at none.com)
홈페이지
첨부 파일
 

굉장히 특이한 경우에 생기는 문제라 어떻게 해결해야 할 지 감을 잡지 못하고 있어서 고민하던 중에 여쭈어 보고자 글을 쓰게 되었습니다.

WPF + .NET 3.5sp1 기반으로 제작되는 어플리케이션이고, 상시 구동되고 있어야 하는 조건을 가지고 있습니다.
헌데 특정한 상황에서 유저나 시스템 스크립트가 GPU 드라이버를 업데이트하는 경우가 있는데, 이런 경우 구동중인 어플리케이션의 UI 렌더러가 동작을 멈추고 사용자 이벤트에 반응을 하지 않는 상황이 생기고 있습니다. DX 런타임을 디버깅용 모듈로 교체하고 로그를 찾아보니 GPU가 드라이버를 업데이트 하는 과정에서 Device Restart를 할 때 UI렌더러가 정상적으로 CreateDevice()를 Fail한 다음, 일정한 시간 (Timeout Detection and Recovery, TDR) 이후에도 다시 CreateDevice를 하지 못하고 무한정 시도하면서 생기는 문제로 보입니다. (.net 4 타겟의 경우 TDR이후 정상적으로 디바이스를 enumeration한 다음 다시 복구합니다)

문제는,
1. 강제로 SW 렌더링으로 지정해도 Device Restart 시에 이 설정을 무시하고 WPF UI렌더러가 create device를 시도하기 때문에 SW렌더링으로 해결할 수 없음
2. .NET 3.5에서만 발생하는 문제

라는 점인데, 특히 2번의 경우 동일한 환경에서 .net 4 / .net 4.5기반으로 타겟만 변경하고 재빌드한 어플리케이션은 정상 구동되고 있습니다. 배포 요구사항때문에 Framework 타겟을 변경할 수는 없는 상태라서 어떤 방식으로든 돌아갈 수 있는 방법이 있으면 좋겠다는 심정인데, 해결책이 없을지요?

현재 문제가 생기는 환경은 주로 NVIDIA 기반의 그래픽 카드로, 296.10 (최신 릴리즈 드라이버)에서 301.24Beta (Non-WHQL)로 업그레이드하는 경우에 종종 발생하고 있습니다.








[최초 등록일: ]
[최종 수정일: 5/21/2012]


비밀번호

댓글 작성자
 



2012-05-21 05시19분
글쓰신 것을 보니, 저보다 더욱 수준있게 ^^ 디버깅을 하셔서 뭐라고 조언드릴 것이 없습니다.

다만, 아직 너무 성급한 걱정을 하는 것이 아닌가 싶습니다. 아직 베타 버전으로 테스트를 하셨는데, 개인적으로 WHQL 인증 시에 얼마나 자세한 내부 테스트가 들어갈지는 모르겠지만 일단 기다려보는 것도 좋지 않을까 싶은데요. 제품 개발상에서 베타 버전은 얼마든지 버그의 가능성이 있습니다. (사실, 정식 버전도 버그가 있는 경우가 많으니까요. ^^)

또한, 사용자(또는 시스템 스크립트?)가 GPU 드라이버를 얼마나 업데이트할 지에 대한 확률적인 면도 그다지 높지 않을 듯 합니다만... 현재 단계에서 꼭 해결해야 한다면, 어쩔 수 없이 드라이버 업데이트를 감지하고 응용 프로그램을 재시작시키는 방법으로 해결해야 하지 않을까 싶습니다.

(Re-)Start Me Up ...
; http://blogs.technet.com/b/richard_macdonald/archive/2007/04/13/756894.aspx

Windows Vista - Exploring the Restart Manager in C#
; http://community.bartdesmet.net/blogs/bart/archive/2006/11/12/Exploring-Windows-Vista_2700_s-Restart-Manager-in-C_2300_.aspx

Windows Vista - Application Recovery with C#
; http://community.bartdesmet.net/blogs/bart/archive/2006/11/11/Windows-Vista-Application-Recovery-with-C_2300_.aspx


정성태
2012-05-22 09시13분
[푸우] 답변 감사드립니다. 질문드린 이후 몇 가지 더 확인해본 끝에 http://support.microsoft.com/kb/2667241/en-us 이 hotfix가 문제를 해결하는 것으로 확인하였습니다. 물론 여러 범위의 환경으로 추가 확인을 더 해야겠지만, 현재까지는 정상 작동하고 있습니다.
[guest]

... [91]  92  93  94  95  96 
NoWriterDateCnt.TitleFile(s)
155최성우4/18/20058046[질문(--),(__)]BHO로 자동 로그인 기능 구현.. 패스워드를 읽어오지를 못합니다.
156정성태4/19/20056988    답변글 [답변]: [질문(--),(__)]BHO로 자동 로그인 기능 구현.. 패스워드를 읽어오지를 못합니다.
161최성우4/21/20057831        답변글 [답변]: [답변]: [질문(--),(__)]BHO로 자동 로그인 기능 구현.. 패스워드를 읽어오지를 못합니다.
164정성태4/22/20056769            답변글 [답변]: [답변]: [답변]: [질문(--),(__)]BHO로 자동 로그인 기능 구현.. 패스워드를 읽어오지를 못합니다.
176최성우5/3/20057178                답변글 [답변]: [답변]: [답변]: [답변]: [질문(--),(__)]BHO로 자동 로그인 기능 구현.. 패스워드를 읽어오지를 못합니다.
146안연준4/14/20057954컴포넌트 안에 컴포넌트 삽입? 헐 ! -_-;;
147정성태4/14/20056822    답변글 [답변]: 컴포넌트 안에 컴포넌트 삽입? 헐 ! -_-;;
148안연준4/15/20057130        답변글 [답변]: [답변]: 컴포넌트 안에 컴포넌트 삽입? 헐 ! -_-;; [2]
142김용국4/13/20057017SmartClient 방식에서 이미지(바이너리)파일을 DataBased에 저장하기위한 방안에 대한 문의
143정성태4/14/20056620    답변글 [답변]: SmartClient 방식에서 이미지(바이너리)파일을 DataBased에 저장하기위한 방안에 대한 문의
141김종욱4/12/20056995웹하드 시스템을 ACTIVEX 로 짜고 있습니다
144정성태4/14/20056777    답변글 [답변]: 웹하드 시스템을 ACTIVEX 로 짜고 있습니다
149김종욱4/15/20056465        답변글 [답변]: [답변]: 웹하드 시스템을 ACTIVEX 로 짜고 있습니다 [1]
150정성태4/15/20056799            답변글 [답변]: [답변]: [답변]: 웹하드 시스템을 ACTIVEX 로 짜고 있습니다 [1]
151김종욱4/16/20056954                답변글 [답변]: [답변]: [답변]: [답변]: 웹하드 시스템을 ACTIVEX 로 짜고 있습니다
152정성태4/16/20056842                    답변글 [답변]: [답변]: [답변]: [답변]: [답변]: 웹하드 시스템을 ACTIVEX 로 짜고 있습니다
153김종욱4/18/20058519                        답변글 [답변]: [답변]: [답변]: [답변]: [답변]: [답변]: 웹하드 시스템을 ACTIVEX 로 짜고 있습니다
154정성태4/18/20057875                            답변글 [답변]: [답변]: [답변]: [답변]: [답변]: [답변]: [답변]: 웹하드 시스템을 ACTIVEX 로 짜고 있습니다 [3]
140안연준4/11/20056703Smart Client 에서 오프라인 글 중...의문점
145정성태4/14/20056473    답변글 [답변]: Smart Client 에서 오프라인 글 중...의문점 [1]
134김용국4/6/200511006c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
135정성태4/6/20059108    답변글 [답변]: c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
136김용국4/6/20057732        답변글 [답변]: [답변]: c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
137정성태4/7/20056979            답변글 [답변]: [답변]: [답변]: c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
138김용국4/7/20056000                답변글 [답변]: [답변]: [답변]: [답변]: c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
139김용국4/11/20056411                    답변글 잘 해결 되었습니다... 감사합니다 [한줄답변]
... [91]  92  93  94  95  96