CM_Query_And_Remove_SubTreeW 함수(cfgmgr32.h)
CM_Query_And_Remove_SubTree 함수는 디바이스 instance 및 해당 자식을 제거할 수 있는지 여부를 확인하고 제거합니다.
구문
CMAPI CONFIGRET CM_Query_And_Remove_SubTreeW(
[in] DEVINST dnAncestor,
[out, optional] PPNP_VETO_TYPE pVetoType,
[out, optional] LPWSTR pszVetoName,
[in] ULONG ulNameLength,
[in] ULONG ulFlags
);
매개 변수
[in] dnAncestor
호출자가 제공한 디바이스는 제거할 하위 트리의 루트에 있는 디바이스에 대한 핸들을 instance. 이 디바이스 instance 핸들은 로컬 컴퓨터에 바인딩됩니다.
[out, optional] pVetoType
(선택 사항) 호출자가 NULL 을 통과하지 못하고 제거 요청이 거부되면(즉, 함수가 CR_REMOVE_VETOED 반환) 이 값을 반환하면 이 값은 거부권의 이유를 나타내는 PNP_VETO_TYPE 형식의 값을 가리킵니다.
[out, optional] pszVetoName
(선택 사항) 호출자가 NULL 을 전달하지 않고 제거 요청이 거부되면(즉, 함수가 CR_REMOVE_VETOED 반환함) 이 반환은 거부 유형과 연결된 텍스트 문자열을 가리킵니다. 이 문자열에서 제공하는 정보의 형식은 pVetoType에서 받은 값에 따라 달라집니다. 이러한 문자열에 대한 자세한 내용은 PNP_VETO_TYPE.
[in] ulNameLength
pszVetoName에서 제공하는 문자열 버퍼의 길이(문자 수)를 나타내는 호출자 제공 값입니다. MAX_PATH 설정해야 합니다.
[in] ulFlags
설명 섹션에 설명된 호출자 제공 플래그 상수의 비트 OR 입니다 .
반환 값
작업이 성공하면 함수는 CR_SUCCESS 반환합니다. 그렇지 않으면 Cfgmgr32.h에 정의된 다른 CR_ 접두사 오류 코드 중 하나를 반환합니다.
설명
CM_Query_And_Remove_SubTree 함수의 목적은 애플리케이션이 로컬 컴퓨터에서 안전하게 제거할 수 있도록 디바이스를 준비할 수 있도록 하는 것입니다. 드라이버가 DEVICE_CAPABILITIESSurpriseRemovalOK 멤버를 설정하지 않은 경우에만 이 함수를 사용하여 디바이스를 제거합니다. 드라이버가 SurpriseRemovalOK를 설정한 경우 애플리케이션은 CM_Query_And_Remove_SubTree 대신 CM_Request_Device_Eject 호출해야 합니다.
CM_Query_And_Remove_SubTree 다음 두 플래그 중 하나를 사용하여 flags 매개 변수 ulFlags 설정을 지원합니다. 이러한 플래그는 Windows 또는 설치 관리자가 디바이스 제거를 거부하는 경우에만 적용됩니다.
플래그 | 설명 |
---|---|
CM_REMOVE_UI_OK | 함수를 사용하면 거부 이유를 나타내기 위해 사용자 대화 상자를 표시할 수 있습니다. 기본 플래그 설정입니다. |
CM_REMOVE_UI_NOT_OK | 함수는 거부 이유를 나타내는 사용자 대화 상자의 표시를 표시하지 않습니다. |
Windows XP부터 CM_Query_And_Remove_SubTree 다음과 같은 추가 플래그 설정도 지원합니다. 이 플래그는 함수가 디바이스 instance 성공적으로 제거한 경우에만 적용됩니다.
플래그 | 설명 |
---|---|
CM_REMOVE_NO_RESTART | 이 플래그가 설정된 경우 함수는 디바이스 상태 다시 설정될 때까지 디바이스를 다시 시작할 수 없하도록 디바이스 상태 구성합니다. |
디바이스 상태 다음 중 하나에 의해 다시 설정됩니다.
- 디바이스에 대한 CM_Setup_DevNode 호출하고 CM_SETUP_DEVNODE_RESET 지정합니다. 이러한 방식으로 디바이스 상태 다시 설정되면 디바이스 instance 대한 CM_Reenumerate_DevNode 호출하여 디바이스를 다시 시작할 수 있습니다. 디바이스 상태 다시 설정하면 디바이스를 열거하는 다른 작업도 디바이스를 다시 시작합니다(예: 장치 관리자 디바이스를 다시 열거하는 데 사용되는 경우).
- 디바이스가 분리되어 다시 연결되었거나 컴퓨터가 다시 시작됩니다. 이 경우 디바이스 상태 다시 설정되고 디바이스가 다시 시작됩니다.
- 이 플래그를 설정하지 않으면 디바이스 상태 다시 설정할 필요가 없습니다. 디바이스에 대한 호출 CM_Setup_DevNode CM_SETUP_DEVNODE_READY 지정하여 제거된 디바이스를 다시 시작할 수 있습니다. 디바이스를 다시 활성화하는 다른 작업도 디바이스를 다시 시작합니다. 디바이스를 다시 열거하는 작업의 예로는 디바이스에 대한 CM_Reenumerate_DevNode 호출하거나, 디바이스를 분리 및 다시 연결하거나, 컴퓨터를 다시 시작하는 작업이 있습니다. |
하위 수준 작업 CM_Query_And_Remove_SubTree 필요하지 않은 Windows 애플리케이션은 CM_Query_And_Remove_SubTree 사용하여 디바이스를 제거하는 대신 DIF_PROPERTYCHANGE 요청을 사용하여 디바이스를 사용하지 않도록 설정해야 합니다. DIF_PROPERTYCHANGE 요청을 사용하여 디바이스의 속성을 활성화, 비활성화, 다시 시작, 중지 또는 변경할 수 있습니다.
이 함수의 호출자에게 는 SeLoadDriverPrivilege가 있어야 합니다. 권한은 Microsoft Windows SDK 설명서에 설명되어 있습니다.
로컬 컴퓨터에 바인딩된 디바이스 instance 핸들을 사용하는 방법에 대한 자세한 내용은 CM_Get_Child 참조하세요.
요구 사항
요구 사항 | 값 |
---|---|
지원되는 최소 클라이언트 | Microsoft Windows 2000 이상 버전의 Windows에서 사용할 수 있습니다. |
대상 플랫폼 | 유니버설 |
헤더 | cfgmgr32.h(Cfgmgr32.h 포함) |
라이브러리 | Cfgmgr32.lib |