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

비밀번호

댓글 작성자
 




... 46  47  48  49  [50]  51  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12721정성태7/20/202121062오류 유형: 738. The trust relationship between this workstation and the primary domain failed. - 세 번째 이야기
12720정성태7/19/202116379Linux: 43. .NET Core/5+ 응용 프로그램의 Ubuntu (Debian) 패키지 준비
12719정성태7/19/202115367오류 유형: 737. SharePoint 설치 시 "0x800710D8 The object identifier does not represent a valid object." 오류 발생
12718정성태7/19/202114993개발 환경 구성: 581. Windows에서 WSL로 파일 복사 시 root 소유권으로 적용되는 문제파일 다운로드1
12717정성태7/18/202115571Windows: 195. robocopy에서 파일의 ADS(Alternate Data Stream) 정보 복사를 제외하는 방법
12716정성태7/17/202116020개발 환경 구성: 580. msbuild의 Exec Task에 robocopy를 사용하는 방법파일 다운로드1
12715정성태7/17/202123436오류 유형: 736. Windows - MySQL zip 파일 버전의 "mysqld --skip-grant-tables" 실행 시 비정상 종료 [1]
12714정성태7/16/202116612오류 유형: 735. VCRUNTIME140.dll, MSVCP140.dll, VCRUNTIME140.dll, VCRUNTIME140_1.dll이 없어 exe 실행이 안 되는 경우
12713정성태7/16/202118792.NET Framework: 1077. C# - 동기 방식이면서 비동기 규약을 따르게 만드는 Task.FromResult파일 다운로드1
12712정성태7/15/202117390개발 환경 구성: 579. Azure - 리눅스 호스팅의 Site Extension 제작 방법
12711정성태7/15/202116868개발 환경 구성: 578. Azure - Java Web App Service를 위한 Site Extension 제작 방법
12710정성태7/15/202120196개발 환경 구성: 577. MQTT - emqx.io 서비스 소개
12709정성태7/14/202115726Linux: 42. 실행 중인 docker 컨테이너에 대한 구동 시점의 docker run 명령어를 확인하는 방법
12708정성태7/14/202120079Linux: 41. 리눅스 환경에서 디스크 용량 부족 시 원인 분석 방법
12707정성태7/14/202186649오류 유형: 734. MySQL - Authentication method 'caching_sha2_password' not supported by any of the available plugins.
12706정성태7/14/202118031.NET Framework: 1076. C# - AsyncLocal 기능을 CallContext만으로 구현하는 방법 [2]파일 다운로드1
12705정성태7/13/202118811VS.NET IDE: 168. x64 DLL 프로젝트의 컨트롤이 Visual Studio의 Designer에서 보이지 않는 문제 - 두 번째 이야기
12704정성태7/12/202117355개발 환경 구성: 576. Azure VM의 서비스를 Azure Web App Service에서만 접근하도록 NSG 설정을 제한하는 방법
12703정성태7/11/202122359개발 환경 구성: 575. Azure VM에 (ICMP) ping을 허용하는 방법
12702정성태7/11/202118621오류 유형: 733. TaskScheduler에 등록된 wacs.exe의 Let's Encrypt 인증서 업데이트 문제
12701정성태7/9/202118194.NET Framework: 1075. C# - ThreadPool의 스레드는 반환 시 ThreadStatic과 AsyncLocal 값이 초기화 될까요?파일 다운로드1
12700정성태7/8/202118688.NET Framework: 1074. RuntimeType의 메모리 누수? [1]
12699정성태7/8/202117333VS.NET IDE: 167. Visual Studio 디버깅 중 GC Heap 상태를 보여주는 "Show Diagnostic Tools" 메뉴 사용법
12698정성태7/7/202121414오류 유형: 732. Windows 11 업데이트 시 3% 또는 0%에서 다운로드가 멈춘 경우
12697정성태7/7/202116004개발 환경 구성: 574. Windows 11 (Insider Preview) 설치하는 방법
12696정성태7/6/202117391VC++: 146. 운영체제의 스레드 문맥 교환(Context Switch)을 유사하게 구현하는 방법파일 다운로드2
... 46  47  48  49  [50]  51  52  53  54  55  56  57  58  59  60  ...