Microsoft MVP성태의 닷넷 이야기
글쓴 사람
홈페이지
첨부 파일
 

안전하게 eject시킨 USB 장치를 물리적인 재연결 없이 다시 인식시키는 방법

다음과 같은 질문이 있군요. ^^

윈도 10에서 '안전하게 제거' 당한 하드디스크(외장하드, USB)를 물리적인 재삽입 없이 소프트웨어단에서 다시 연결하는 방법
; https://social.msdn.microsoft.com/Forums/ko-KR/2a5f5663-3d8a-48ed-a401-ade7ab2a8d78/50952460205086410-5064049436-50504512045461644172-5122844144?forum=visualcplusko

검색해 보면, Windows SDK에 포함된 devcon.exe에 대한 이야기가 나옵니다.

Windows Device Console (Devcon.exe)
; https://docs.microsoft.com/en-us/windows-hardware/drivers/devtest/devcon

예를 들어, 현재 연결된 USB 장치를 다음과 같이 조회할 수 있습니다.

C:\Program Files (x86)\Windows Kits\10\Tools\x64>devcon findall =usb
USB\ROOT_HUB30\4&1148BC98&0&0                               : USB Root Hub (USB 3.0)
PCI\VEN_8086&DEV_A12F&SUBSYS_86941043&REV_31\3&11583659&0&A0: Intel(R) USB 3.0 eXtensible Host Controller - 1.0 (Microsoft)
USB\VID_05E3&PID_0608\5&521A615&0&8                         : Generic USB Hub
USB\VID_0000&PID_0001\5&521A615&0&23                        : Unknown USB Device (Port Reset Failed)
ROOT\USB\0000                                               : Synology Virtual USB Hub
USB\VID_174C&PID_5106\S2RQJ9CC914742______                  : USB Mass Storage Device
USB\VID_04D9&PID_2525\5&521A615&0&10                        : USB Composite Device
USB\VID_090C&PID_1000\5&521A615&0&1                         : USB Mass Storage Device
8 matching device(s) found.

위의 장치에서 "USB\VID_090C&PID_1000\5&521A615&0&1"로 나오는 것이 제가 사용하는 USB flash 디스크인데, 사실 이 문자열은 "Device Manager"의 속성 창에서 "Last known parent"로도 확인할 수 있습니다.

이 장치 ID만 알고 있으면 이후 devcon 명령어로 작업 표시줄의 USB 아이콘을 이용한 "Safely Remove Hardware and Eject Media" 명령어를 그대로 수행할 수 있습니다.

C:\Program Files (x86)\Windows Kits\10\Tools\x64>devcon remove "USB\VID_090C&PID_1000"
USB\VID_090C&PID_1000\5&521A615&0&1                         : Removed
1 device(s) were removed.

그런데, 해당 장치만 다시 활성화시키는 명령어가 없습니다. 아래의 글에 보면,

How Do I Force Windows to Remove and Re-detect a USB Device?
; https://knowledge.ni.com/KnowledgeArticleDetails?id=kA00Z000000P7bZSAS

restart 명령어로 가능하다고 하는데, 장치 자체를 활성화시키는 것은 아니고 그 장치를 열람할 수 있는 USB Roothub를 재시작하는 식으로 해결하고 있습니다. 따라서 이 방법을 사용하려면 우선 USB 장치 간의 부모/자식 관계를 파악해야 하는데 이를 위해 (역시 Windows SDK에 포함된) usbview.exe를 실행시키고,

C:\Program Files (x86)\Windows Kits\10\Debuggers\x64>usbview

usb_reconnect_1.png

보는 바와 같이 hub의 장치 id를 구할 수 있는데 이것은 앞서 "devcon findall =usb" 명령어로 봤던 내용의 USB 3.0 hub와 동일합니다.

USB\ROOT_HUB30\4&1148BC98&0&0                               : USB Root Hub (USB 3.0)

자, 그럼 이 장치를 restart시키면 되겠지만,

C:\Program Files (x86)\Windows Kits\10\Tools\x64>devcon restart *ROOT_HUB30*
USB\ROOT_HUB30\4&1148BC98&0&0                               : Requires reboot
The 1 device(s) are ready to be restarted. To restart the devices, reboot the system.

아쉽게도 저렇게 재부팅이 필요하다고 나옵니다. 이런 건 방법이라고 볼 수 없죠! ^^;




차선책으로, USB 장치만을 위한 것은 아니지만 전체 장치를 대상으로 수행하는 rescan 명령어를 사용하면,

C:\Program Files (x86)\Windows Kits\10\Tools\x64>devcon rescan
Scanning for new hardware.
Scanning completed.

안전하게 제거되었던 USB disk가 다시 인식되는 것을 볼 수 있습니다. 아쉬운 대로 이 정도 수준에서 만족해야겠습니다. ^^ (혹시 더 나은 방법을 아시는 분은 덧글 부탁드립니다.)

참고로, 장치를 제거하는 방법은 디스크 드라이브의 경우라면 "devcon remove" 명령어보다는 mountvol.exe를 사용하는 것이 더 편리합니다.

mountvol [드라이브:] /D

예)
C:\Windows\System32>mountvol g: /D




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





[최초 등록일: ]
[최종 수정일: 11/12/2019 ]

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

비밀번호

댓글 쓴 사람
 




1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...
NoWriterDateCnt.TitleFile(s)
11906정성태5/21/2019843.NET Framework: 835. .NET Core/C# - 리눅스 syslog에 로그 남기는 방법
11905정성태5/21/20191206.NET Framework: 834. C# - 폴더 경로 문자열에서 "..", "." 표기를 고려한 최종 문자열을 얻는 방법 - 두 번째 이야기
11904정성태5/21/20192394.NET Framework: 833. C# - Open Hardware Monitor를 이용한 CPU 온도 정보파일 다운로드1
11903정성태5/21/20191323오류 유형: 540. .NET Core - System.PlatformNotSupportedException: The named version of this synchronization primitive is not supported on this platform.
11902정성태5/21/2019919오류 유형: 539. mstest 실행 시 "The directory name is invalid." 오류 발생
11901정성태5/21/20191520오류 유형: 538. msbuild 오류 - Could not find a part of the path '%LOCALAPPDATA%\Temp\2\.NETFramework,Version=v4.0.AssemblyAttributes.cs'
11900정성태3/12/20201459오류 유형: 537. "sfc /scannow" 실행 중 시스템이 부팅되는 현상
11899정성태5/17/20191529Linux: 9. Linux에서 윈도우의 OutputDebugString 대신 사용할 수 있는 syslog [1]
11898정성태5/20/20191590VC++: 130. C++ string의 c_str과 data 함수의 차이점 [3]
11897정성태5/16/20192847오류 유형: 536. Visual Studio - "Developer Pack"을 설치했는데도 "대상 프레임워크" 목록에 나오지 않는 경우 [1]
11896정성태5/15/20192227개발 환경 구성: 440. C#, C++ - double의 Infinity, NaN 표현 방식파일 다운로드1
11895정성태5/12/20191555.NET Framework: 832. ML.NET Model Builder - 회귀(Regression), 다중 분류(Multi-class classification) 예제파일 다운로드1
11894정성태5/12/20192064VS.NET IDE: 135. Visual Studio - ML.NET Model Builder 소개 [1]
11893정성태5/10/20191629오류 유형: 535. C# 6.0 이상의 문법을 컴파일 시 오류가 발생한다면?
11892정성태5/10/20191094웹: 38. HTTP Cookie의 expires 시간 형식(RFC7231)
11891정성태5/9/20191384.NET Framework: 831. (번역글) .NET Internals Cookbook Part 12 - Memory structure, attributes, handles
11890정성태5/8/20191113개발 환경 구성: 439. "Visual Studio Enterprise is required to execute the test." 메시지와 관련된 코드 기록
11889정성태5/8/20191242개발 환경 구성: 438. mstest, QTAgent의 로그 파일 설정 방법
11888정성태5/8/20192327.NET Framework: 830. C# - 비동기 호출을 취소하는 CancellationToken의 간단한 예제 코드파일 다운로드1
11887정성태5/8/20191545.NET Framework: 829. C# - yield 문을 사용할 수 있는 메서드의 조건
11886정성태5/8/20191574오류 유형: 534. mstest.exe 실행 시 "Visual Studio Enterprise is required to execute the test." 오류 [2]
11885정성태5/7/20191021오류 유형: 533. mstest.exe 실행 시 "File extension specified '.loadtest' is not a valid test extension." 오류 발생
11884정성태5/5/20191833.NET Framework: 828. C# DLL에서 Win32 C/C++처럼 dllexport 함수를 제공하는 방법 - 두 번째 이야기
11883정성태5/3/20192227.NET Framework: 827. C# - 인터넷 시간 서버로부터 받은 시간을 윈도우에 적용하는 방법파일 다운로드1
11882정성태5/9/20191206.NET Framework: 826. (번역글) .NET Internals Cookbook Part 11 - Various C# riddles파일 다운로드1
11881정성태4/28/20191789오류 유형: 532. .NET Core 프로젝트로 마이그레이션 시 "CS0579 Duplicate 'System.Reflection.AssemblyCompanyAttribute' attribute" 오류 발생
1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...