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

Windbg - VirtualBox VM의 커널 디버거 연결 시 COM 포트가 없는 경우

이전에, windbg로 Hyper-V VM에 커널 디버거를 연결하는 방법을 설명한 적이 있는데요,

Windbg - Hyper-V 윈도우 7 원격 디버깅 구성
; https://www.sysnet.pe.kr/2/0/938

마찬가지로 VirtualBox에 설치된 VM에 COM 포트 설정을 하고,

windbg_com_port_1.png

[v] Enable Serial Port
    Port Number: COM1
      Port Mode: Host Pipe
                 [v] Connect to existing pipe/socket
    Path/Address: \\.\pipe\com1

VM을 시작했더니 이런 오류가 발생하면서 VM 시작이 안 됩니다.

NamedPipe#0 failed to connect to named pipe \\.\pipe\com1 (VERR_FILE_NOT_FOUND).

Result Code:
E_FAIL (0x80004005)
Component: ConsoleWrap
Interface: IConsole {6ac83d89-6ee7-4e33-8ae6-b257b2e81be8}

VERR_FILE_NOT_FOUND가 나왔는데요, 실제로 저 VirtualBox를 호스팅하고 있는 물리 머신에는 Ports가 하나도 없었습니다. (Device Manager의 "Ports (COM & LPT)" 항목 자체가 없었습니다.)

특이하죠? ^^ 노트북이었는데 MSI 제품의 "Prestige 14 A10SC" 모델이었습니다. 혹시나 해서 Device Manager의 "Action" / "Add legacy hardware" 메뉴로 "(Standard port types)" / "Communications Port"로, 또는 "Microsoft" / "Standard Serial over Bluetooth link"로 추가를 해도 느낌표 있는 마크만 뜰 뿐이었습니다.

이런 경우엔 어떻게 해야 할까요? ^^

다행히 검색해 보니까 저와 동일한 현상을 겪은 글이 나옵니다.

Setting Up Windows 2019 Virtualbox VM for Kernel Mode Debugging
; https://mylearning.medium.com/setting-up-windows-2019virtualbox-vm-for-kernel-mode-debugging-eaef9cafe32a

방법은, 그냥 "Connect to existing pipe/socket" 옵션을 해제하면 되는 것이었습니다.




그나저나, 신기하군요. ^^; 얼핏 생각하기에 저렇게 되면 결국 가상으로만 VM에 COM 포트를 제공하고 VirtualBox 응용 프로그램만 그 사실을 알고 있으므로 Windbg에서 해당 COM 포트로 대기를 한다 해도 동작을 안 할 것 같은데... 잘됩니다.

참고로, VirtualBox VM 역시 원격 디버깅 시 가상 머신을 Break 시켜 두면 (Hyper-V와는 달리) VirtualBoxVM.exe의 CPU 사용량이 100% 치는 현상이 나옵니다.




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







[최초 등록일: ]
[최종 수정일: 11/20/2024]

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

비밀번호

댓글 작성자
 




... 106  107  108  109  110  [111]  112  113  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11183정성태4/19/201720852.NET Framework: 654. UWP 앱에서 FolderPicker 사용 시 유의 사항파일 다운로드1
11182정성태4/19/201724708개발 환경 구성: 313. Nuget Facebook 라이브러리를 이용해 ASP.NET 웹 폼과 로그인 연동하는 방법
11181정성태4/18/201721854개발 환경 구성: 312. Azure Web Role의 AppPool 실행 권한을 Local System으로 바꾸는 방법
11180정성태4/16/201725008Java: 18. Java의 Memory Mapped File 자원 반환이 안 되는 문제
11179정성태4/13/201718061기타: 64. SVG Converter 스토어 앱 개인정보 보호 정책 안내
11178정성태4/10/201720287개발 환경 구성: 311. COM+ 관리자의 DCOM 구성에 나오는 기준
11177정성태4/7/201720417.NET Framework: 653. C# 7 새로운 문법(1) - 더욱 편리해진 Out 변수 사용파일 다운로드1
11176정성태4/5/201717561VC++: 117. Visual Studio - ATL COM 개체를 단위 테스트 하는 방법
11175정성태4/5/201726769.NET Framework: 652. C# 개발자를 위한 C++ COM 객체의 기본 구현 방식 설명파일 다운로드1
11174정성태4/3/201720655VC++: 116. Visual Studio 단위 테스트 - Failed to set up the execution context to run the test
11173정성태4/3/201723801VC++: 115. Visual Studio에서 C++ DLL을 대상으로 단위 테스트할 때 비정상 종료한다면?파일 다운로드1
11172정성태4/3/201722853.NET Framework: 651. C# - 특정 EXE 프로세스를 종료시킨 EXE를 찾아내는 방법파일 다운로드1
11171정성태3/31/201720009VS.NET IDE: 114. Visual Studio 디버깅 경고 창 - You are debugging a Release build of ...
11170정성태3/31/201722291.NET Framework: 650. C# - CachedAnonymousMethodDelegate 유형의 코드 생성
11169정성태3/30/201721916VC++: 114. C++ vtable의 가상 함수 호출 가로채기파일 다운로드1
11168정성태3/29/201724626VC++: 113. C++ 클래스 상속 관계의 vtable 생성 과정
11167정성태3/28/201725074VC++: 112. C++의 가상 함수 테이블 (vtable)은 언제 생성될까요? [2]
11166정성태3/28/201720004오류 유형: 382. System.Data.SqlClient.SqlException - Arithmetic overflow error converting IDENTITY to data type int.
11165정성태3/27/201723144오류 유형: 381. Visual C++에서 min, max 함수를 사용한 경우 C2589, C2059 컴파일 오류 발생
11164정성태3/27/201731616VC++: 111. C++ 클래스의 상속에 따른 메모리 구조 [2]파일 다운로드1
11163정성태3/25/201721273VC++: 110. CreateThread Win32 API에 C++ 클래스의 멤버 함수를 전달하는 방법파일 다운로드1
11162정성태3/24/201725562오류 유형: 380. Visual Studio 빌드 실패 - The OutputPath property is not set for project
11161정성태3/24/201717448오류 유형: 379. ICOMAdminCatalog.GetCollection 호출 시 0x80070422 예외 발생
11160정성태3/23/201723247.NET Framework: 649. ASP.NET - Server cannot append header after HTTP headers have been sent. (HTTP 헤더를 보낸 후에는 서버에서 헤더를 추가할 수 없습니다.)파일 다운로드1
11159정성태3/23/201720491Windows: 136. Memory-mapped File은 Private Bytes 크기에 포함될까요?파일 다운로드1
11158정성태3/22/201719380디버깅 기술: 85. Windbg - SOS 디버깅 사례 System.NullReferenceException 예외 추적
... 106  107  108  109  110  [111]  112  113  114  115  116  117  118  119  120  ...