Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Visual Studio 로딩 시 오류 - The 'Scc Display Information' package did not load correctly.

Visual Studio 로딩 시 다음과 같은 오류 창이 뜹니다.

The 'Scc Display Information' package did not load correctly.

The problem may have been caused by a configuration change or by the installation of another extension. You can get more information by examining the file '%APPDATA%\Microsoft\VisualStudio\15.0_2502db9e\ActivityLog.xml'.

Restarting Visual Studio could help resolve this issue.

ActivityLog.xml을 파일을 열어 보면 다음과 같은 내용이 담겨 있습니다.

<entry>
<record>296</record>
<time>2018/10/12 09:58:02.232</time>
<type>Information</type>
<source>VisualStudio</source>
<description>Begin package load [Scc Display Information]</description>
<guid>{D7BB9305-5804-4F92-9CFE-119F4CB0563B}</guid>
</entry>


<entry>
<record>297</record>
<time>2018/10/12 09:58:02.274</time>
<type>Error</type>
<source>VisualStudio</source>
<description>SetSite failed for package [Scc Display Information]Source: &apos;Microsoft.VisualStudio.Shell.15.0&apos; Description: Object reference not set to an instance of an object.&#x000D;&#x000A;System.NullReferenceException: Object reference not set to an instance of an object.&#x000D;&#x000A; at Microsoft.Internal.VisualStudio.Shell.KeyBindingHelper.&lt;GetKeyBindingsImpl&gt;d__4.MoveNext()&#x000D;&#x000A; at System.Linq.Enumerable.FirstOrDefault[TSource](IEnumerable`1 source)&#x000D;&#x000A; at Microsoft.Internal.VisualStudio.Shell.KeyBindingHelper.GetKeyBinding(Guid commandGroup, Int32 commandId, Guid keyBindingScope)&#x000D;&#x000A; at Microsoft.Internal.VisualStudio.Shell.KeyBindingHelper.GetGlobalKeyBinding(Guid commandGroup, Int32 commandId)&#x000D;&#x000A; at Microsoft.VisualStudio.PlatformUI.Packages.Scc.KeyBindingProvider.GetKeyBinding(Guid commandSet, Int32 commandId)&#x000D;&#x000A; at Microsoft.VisualStudio.Services.SccDisplayInformationService.get_PublishKeyBindingText()&#x000D;&#x000A; at Microsoft.VisualStudio.Services.SccDisplayInformationService.&lt;InitializeUIAsync&gt;d__71.MoveNext()&#x000D;&#x000A;--- End of stack trace from previous location where exception was thrown ---&#x000D;&#x000A; at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)&#x000D;&#x000A; at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)&#x000D;&#x000A; at Microsoft.VisualStudio.Services.SccDisplayInformationService.&lt;InitializeAsync&gt;d__17.MoveNext()&#x000D;&#x000A;--- End of stack trace from previous location where exception was thrown ---&#x000D;&#x000A; at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)&#x000D;&#x000A; at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)&#x000D;&#x000A; at Microsoft.VisualStudio.Services.SccDisplayInformationPackage.&lt;InitializeAsync&gt;d__2.MoveNext()&#x000D;&#x000A;--- End of stack trace from previous location where exception was thrown ---&#x000D;&#x000A; at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)&#x000D;&#x000A; at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)&#x000D;&#x000A; at Microsoft.VisualStudio.Shell.AsyncPackage.&lt;&gt;c__DisplayClass17_0.&lt;&lt;Microsoft-VisualStudio-Shell-Interop-IAsyncLoadablePackageInitialize-Initialize&gt;b__1&gt;d.MoveNext()&#x000D;&#x000A;--- End of stack trace from previous location where exception was thrown ---&#x000D;&#x000A; at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)&#x000D;&#x000A; at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)&#x000D;&#x000A; at Microsoft.VisualStudio.Threading.ThreadingTools.&lt;WithCancellationSlow&gt;d__12.MoveNext()&#x000D;&#x000A;--- End of stack trace from previous location where exception was thrown ---&#x000D;&#x000A; at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)&#x000D;&#x000A; at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)&#x000D;&#x000A; at Microsoft.VisualStudio.Threading.JoinableTask.&lt;JoinAsync&gt;d__78.MoveNext()&#x000D;&#x000A;--- End of stack trace from previous location where exception was thrown ---&#x000D;&#x000A; at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)&#x000D;&#x000A; at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)&#x000D;&#x000A; at Microsoft.VisualStudio.Threading.JoinableTask.CompleteOnCurrentThread()&#x000D;&#x000A; at Microsoft.VisualStudio.Threading.JoinableTask.Join(CancellationToken cancellationToken)&#x000D;&#x000A; at Microsoft.VisualStudio.Threading.JoinableTask`1.Join(CancellationToken cancellationToken)&#x000D;&#x000A; at Microsoft.VisualStudio.Shell.VsTaskLibraryHelper.&lt;&gt;c__DisplayClass33_1`1.&lt;AsVsTask&gt;b__3()&#x000D;&#x000A;--- End of stack trace from previous location where exception was thrown ---&#x000D;&#x000A; at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw()&#x000D;&#x000A; at Microsoft.VisualStudio.Services.VsTask.RethrowException(AggregateException e)&#x000D;&#x000A; at Microsoft.VisualStudio.Services.VsTask.InternalGetResult(Boolean ignoreUIThreadCheck)&#x000D;&#x000A; at Microsoft.VisualStudio.Services.VsTask.GetResult()</description>
<guid>{D7BB9305-5804-4F92-9CFE-119F4CB0563B}</guid>
<hr>80004003 - E_POINTER</hr>
<errorinfo></errorinfo>
</entry>


D7BB9305-5804-4F92-9CFE-119F4CB0563B 패키지를 로딩하다 오류가 발생한 것 같은데, 딱히 그게 어떤 패키지인지 레지스트리를 검색해 봐도 안 나옵니다. 문제를 좀 더 쉽게 파악하기 위해 저 오류 메시지의 창이 뜨는 시점에 devenv.exe에 대해 풀 메모리 덤프를 떴습니다.

풀 덤프 파일을 남기는 방법
; https://www.sysnet.pe.kr/2/0/991

Main UI Thread로 보이는 0번 스레드의 call stack이 다음과 같습니다.

DomainNeutralILStubClass.IL_STUB_CLRtoCOM(System.Guid ByRef, Int32, System.Guid ByRef)+ab 
[[InlinedCallFrame]] 
Microsoft.VisualStudio.Services.AsyncQueryService.AsyncServiceProvider+d__18.MoveNext()+1ee 
System.Runtime.CompilerServices.AsyncTaskMethodBuilder`1[[System.Guid, mscorlib]].Start[[Microsoft.VisualStudio.Services.AsyncQueryService.AsyncServiceProvider+d__18, Microsoft.VisualStudio.Shell.UI.Internal]](d__18 ByRef)+43 
Microsoft.VisualStudio.Services.AsyncQueryService.AsyncServiceProvider.LoadServicePackage(System.Guid, Boolean)+85 
Microsoft.VisualStudio.Services.AsyncQueryService.AsyncServiceProvider+d__15.MoveNext()+25e 
System.Runtime.CompilerServices.AsyncTaskMethodBuilder`1[[System.__Canon, mscorlib]].Start[[Microsoft.VisualStudio.Services.AsyncQueryService.AsyncServiceProvider+d__15, Microsoft.VisualStudio.Shell.UI.Internal]](d__15 ByRef)+3e 
Microsoft.VisualStudio.Services.AsyncQueryService.AsyncServiceProvider.GetServiceByGuidThrowing(System.Guid, Boolean)+8a 
Microsoft.VisualStudio.Services.AsyncQueryService.AsyncServiceProvider+<>c__DisplayClass10_0+<b__0>d.MoveNext()+74 
System.Runtime.CompilerServices.AsyncTaskMethodBuilder.Start[[Microsoft.VisualStudio.Services.AsyncQueryService.AsyncServiceProvider+<>c__DisplayClass10_0+<b__0>d, Microsoft.VisualStudio.Shell.UI.Internal]](<b__0>d ByRef)+43 
Microsoft.VisualStudio.Services.AsyncQueryService.AsyncServiceProvider+<>c__DisplayClass10_0.b__0()+6a 
Microsoft.VisualStudio.Threading.JoinableTaskFactory.ExecuteJob[[Microsoft.VisualStudio.Threading.EmptyStruct, Microsoft.VisualStudio.Threading]](System.Func`1, Microsoft.VisualStudio.Threading.JoinableTask)+32 
Microsoft.VisualStudio.Threading.JoinableTaskFactory.RunAsync(System.Func`1, Boolean, Microsoft.VisualStudio.Threading.JoinableTaskCreationOptions, System.Delegate)+76 
Microsoft.VisualStudio.Services.AsyncQueryService.AsyncServiceProvider.Microsoft.VisualStudio.OLE.Interop.IServiceProvider.QueryService(System.Guid ByRef, System.Guid ByRef, IntPtr ByRef)+c5 
Microsoft_VisualStudio_OLE_Interop_ni!DomainNeutralILStubClass.IL_STUB_COMtoCLR(IntPtr, IntPtr, IntPtr)+1f 
[[ComMethodFrame]] 
Microsoft_VisualStudio_OLE_Interop_ni!DomainNeutralILStubClass.IL_STUB_CLRtoCOM(System.Guid ByRef, System.Guid ByRef, IntPtr ByRef)+7c 
[[InlinedCallFrame]] 
Microsoft.VisualStudio.Shell.ServiceProvider.QueryService(System.Guid, System.Type, Boolean, System.Object ByRef)+135 
Microsoft.VisualStudio.Shell.ServiceProvider.QueryService(System.Type, Boolean, System.Object ByRef)+79 
Microsoft.VisualStudio.Shell.ServiceProvider.GetService(System.Type, Boolean)+2f 
Microsoft.VisualStudio.Shell.Package.GetService(System.Type)+39e 
Microsoft.TeamFoundation.Git.Provider.SccProviderPackage.GetService(System.Type)+f0 
Microsoft.VisualStudio.Shell.Package.System.IServiceProvider.GetService(System.Type)+b 
Microsoft.TeamFoundation.Git.Provider.ServiceProviderExtensionMethods.GetService[[System.__Canon, mscorlib],[System.__Canon, mscorlib]](System.IServiceProvider)+3c 
Microsoft.TeamFoundation.Git.Provider.SccProviderPackage.Initialize()+5b9 
Microsoft.VisualStudio.Shell.Package.Microsoft.VisualStudio.Shell.Interop.IVsPackage.SetSite(Microsoft.VisualStudio.OLE.Interop.IServiceProvider)+75 
Microsoft_VisualStudio_Shell_Interop_ni!DomainNeutralILStubClass.IL_STUB_COMtoCLR(IntPtr)+39 
[[ComMethodFrame]] 
DomainNeutralILStubClass.IL_STUB_CLRtoCOM(System.Guid ByRef, Int32, System.Guid ByRef)+ab 
[[InlinedCallFrame]] 
Microsoft.VisualStudio.PlatformUI.UIContextRules.AutoLoadManagerService.AutoLoadPackages(System.Guid ByRef)+2d2 
DomainNeutralILStubClass.IL_STUB_COMtoCLR(IntPtr)+12 
[[ComMethodFrame]] 
Microsoft_VisualStudio_OLE_Interop_ni!DomainNeutralILStubClass.IL_STUB_CLRtoCOM(System.Guid ByRef, System.Guid ByRef, IntPtr ByRef)+7c 
[[InlinedCa
Microsoft.VisualStudio.Shell.ServiceProvider.QueryService(System.Guid, System.Type, Boolean, System.Object ByRef)+135 
Microsoft.VisualStudio.Shell.ServiceProvider.QueryService(System.Type, Boolean, System.Object ByRef)+79 
Microsoft.VisualStudio.Shell.ServiceProvider.GetService(System.Type, Boolean)+2f 
Microsoft.VisualStudio.Shell.Package.GetGlobalService(System.Type, Boolean)+27 
IntelGfxDebug.IntelGfxDbgPackage.Initialize()+b4 
Microsoft.VisualStudio.Shell.Package.Microsoft.VisualStudio.Shell.Interop.IVsPackage.SetSite(Microsoft.VisualStudio.OLE.Interop.IServiceProvider)+75 
Microsoft_VisualStudio_Shell_Interop_ni!DomainNeutralILStubClass.IL_STUB_COMtoCLR(IntPtr)+39 
[[ComMethodFrame]] 
DomainNeutralILStubClass.IL_STUB_CLRtoCOM(System.Guid ByRef, Int32, System.Guid ByRef)+ab 
[[InlinedCallFrame]] 
Microsoft.VisualStudio.PlatformUI.UIContextRules.AutoLoadManagerService.AutoLoadPackages(System.Guid ByRef)+2d2 
DomainNeutralILStubClass.IL_STUB_COMtoCLR(IntPtr)+12 
[[ComMethodFrame]] ]]

그중에 문제의 원인인 듯한 패키지(IntelGfxDebug.IntelGfxDbgPackage)가 하나 눈에 띕니다. "Tools" / "Extensions and Updates..." 메뉴로 들어가면 Intel 관련해서 (제 경우에는) 다음의 패키지가 2개 있습니다.

vss_load_error_1.png

이 중에서 "Intel adapted Microsoft MI-based Debugger"는 제작자가 "Microsoft"인 반면, "Intel Debugger for Heterogeneous Compute"는 "Intel"이 만든 것이었습니다. 대개 이런 경우 제 경험상 ^^ 마이크로소프트보다는 3rd-party 제작자의 확장이 문제를 일으켰습니다. 예상은 빗나가지 않아서, 실제로 "Intel Debugger for Heterogeneous Compute" 확장을 "Disable" 시킨 후부터는 오류 메시지가 더 이상 나타나지 않았습니다. (IntelGfxDebug.IntelGfxDbgPackage.Initialize 메서드가 호출되지 않을 테니 당연한 결과입니다.)




참고로, Visual Studio 2017로 오면서 Redgate의 확장이 기본적으로 몇 개 설치가 됩니다. "Tools" / "Extensions and Updates..." 메뉴로 들어가도 "Revert" 메뉴는 있어도 "삭제(Uninstall)" 메뉴는 없는데요. 이것을 삭제하려면 "Tools" / "Get Tools and Features..." 메뉴로 들어가서 "Individual components" 탭의 "Cloud, database, and server" 범주에 다음의 항목들이 있는데,

  • SQL Prompt Core
  • SQL Search
  • Redgate SQL Change Automation Core

이들의 체크 박스를 해제하시면 됩니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 10/12/2018]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 136  137  [138]  139  140  141  142  143  144  145  146  147  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1604정성태1/23/201421443오류 유형: 216. 윈도우 서버 백업 - Hyper-V 가상 머신이 백업되지 않는 경우 (2)
1603정성태1/23/201433582개발 환경 구성: 211. Hyper-V - Generation 2 유형의 VM 생성 시 ISO 부팅이 안된다면? [1]
1602정성태1/22/201423722디버깅 기술: 62. windbg - 사용자 모드 원격 디버깅
1601정성태1/22/201427363오류 유형: 215. windbg - Symbol file could not be found. Defaulted to export symbols
1600정성태1/19/201423953.NET Framework: 410. C# - 재귀호출을 스택 자료구조와 반복문을 이용해 대체하는 방법을 Paralle.For와 함께? [1]파일 다운로드1
1599정성태1/18/201432080.NET Framework: 409. C# - 재귀호출을 스택 자료구조와 반복문을 이용해 대체하는 방법 [1]파일 다운로드1
1598정성태1/17/201425483디버깅 기술: 61. NT 서비스 시작 단계에서 닷넷 메서드에 BP를 걸어 디버깅하는 방법
1597정성태1/17/201424067Phone: 9. Xamarin Android에 구글 AdMob 사용하는 방법 [1]
1596정성태1/17/201423021오류 유형: 214. Local SYSTEM 계정으로 실행된 IE에서 다운로드가 안 되는 문제
1595정성태1/16/201420008오류 유형: 213. attrib - Not resetting system file
1594정성태1/15/201422175오류 유형: 212. 마이크로소프트 라이브 계정 로그인 실패하는 경우
1593정성태1/14/201420771오류 유형: 211. ASP.NET 응용 프로그램을 IIS Express에서 디버깅할 때 "Requested registry access is not allowed" 오류 발생
1592정성태1/14/201421097오류 유형: 210. 2대의 AD가 있는 경우 도메인에 컴퓨터 추가를 실패한다면? [1]
1591정성태1/14/201423268오류 유형: 209. DebugDiag: Unable to find mscordacwks_x86_x86_[...version...].dll
1590정성태1/14/201423906오류 유형: 208. VSS Writer - NTDS 오류
1589정성태1/14/201432839Windows: 85. 컴퓨터를 껐는데도 어느 순간 자동으로 켜진다면? [2]
1588정성태1/14/201429561Windows: 84. 윈도우 7/8 - 메뉴 항목이 잔상으로 남는 문제
1587정성태1/14/201425557디버깅 기술: 60. NT 서비스가 시작하자마자 디버거를 연결시키는 방법 (2)
1586정성태1/14/201427224디버깅 기술: 59. NT 서비스가 시작하자마자 디버거를 연결시키는 방법 (1) [1]
1585정성태1/14/201430165VS.NET IDE: 84. Visual Studio를 이용한 파일 비교(diff)
1584정성태1/13/201432473Windows: 83. 윈도우 8 - UI가 있는 프로그램을 Local SYSTEM 권한의 세션 0 데스크톱에서 실행하는 방법
1583정성태1/13/201430430Windows: 82. 윈도우 8 - "Interactive Services Detection" 서비스 시작하는 방법 [1]
1582정성태1/12/201428901개발 환경 구성: 210. 원격 데스크톱(RDP) 접속 프로그램 - Royal TS [1]
1581정성태1/12/201430233.NET Framework: 408. 자바와 닷넷의 제네릭 차이점 - 중간 언어 및 공변/반공변 처리 [8]
1580정성태1/12/201440309.NET Framework: 407. 닷넷 사용자 정의 예외 클래스의 최소 구현 코드 [1]
1579정성태1/12/201422287오류 유형: 207. System.ArgumentException was unhandled - Message=[net_WebHeaderInvalidControlChars]
... 136  137  [138]  139  140  141  142  143  144  145  146  147  148  149  150  ...