다음을 통해 공유


DXGKDDI_COLLECTDBGINFO 콜백 함수(d3dkmddi.h)

DxgkDdiCollectDbgInfo 함수는 디버그 보고서에 대한 드라이버 정보를 출력합니다.

구문

DXGKDDI_COLLECTDBGINFO DxgkddiCollectdbginfo;

NTSTATUS DxgkddiCollectdbginfo(
  [in]     IN_CONST_HANDLE hAdapter,
  [in/out] IN_CONST_PDXGKARG_COLLECTDBGINFO pCollectDbgInfo
)
{...}

매개 변수

[in] hAdapter

디스플레이 어댑터와 연결된 컨텍스트 블록에 대한 핸들입니다. 이전에 KMD(표시 미니포트)는 DxgkDdiAddDeviceMiniportDeviceContext 출력 매개 변수에서 Dxgkrnl에 이 핸들을 제공했습니다.

[in/out] pCollectDbgInfo

디버그 보고서에 대한 정보를 포함하는 DXGKARG_COLLECTDBGINFO 구조체에 대한 포인터입니다.

반환 값

DxgkDdiCollectDbgInfo 는 다음 값 중 하나를 반환합니다.

반환 코드 설명
STATUS_SUCCESS DxgkDdiCollectDbgInfo 는 디버그 보고서에 대한 드라이버 정보를 성공적으로 출력합니다. 또는 OS는 pBuffer 가 가리키는 버퍼의 콘텐츠를 무시하고 DxgkDdiCollectDbgInfo 의 정보를 디버그 보고서에 추가하지 않았습니다.
STATUS_NO_MEMORY DxgkDdiCollectDbgInfo 가 완료하는 데 필요한 메모리를 할당할 수 없습니다.
STATUS_UNSUCCESSFUL 또 다른 오류로 인해 드라이버가 유효한 디버그 정보를 수집할 수 없습니다.

설명

Dxgkrnl 은 OS가 드라이버 관련 디버그 보고서를 생성하려고 할 때마다 KMD의 DxgkDdiCollectDbgInfo 함수를 호출합니다. DxgkDdiCollectDbgInfoTDR(시간 제한 검색 및 복구)이 작동 하기 직전에 또는 OS 버그 검사 직전에 호출될 수 있습니다. DxgkDdiCollectDbgInfo는 가능한 한 빨리 반환해야 하지만 드라이버가 이 함수에 사용할 수 있는 시스템 정의 최대 시간은 없습니다.

KMD는 디버그 정보를 수집해야 합니다. DxgkDdiCollectDbgInfo가 호출되면 드라이버는 디버그 보고서에 필요한 정보 유형을 나타내는 pCollectDbgInfo-Reason>의 버그 검사 코드를 받습니다. 드라이버는 pCollectDbgInfo-pBuffer>가 가리키는 버퍼에 필요한 디버그 정보를 복사합니다. 드라이버에서 복사할 수 있는 정보의 최대 바이트 수는 pCollectDbgInfo-BufferSize>에 의해 지정됩니다.

DxgkDdiCollectDbgInfo 는 일반적으로 정의되지 않은 IRQL에서 실행됩니다. 그러나 pCollectDbgInfo-Reason>VIDEO_TDR_TIMEOUT_DETECTED(어댑터 전체 재설정을 나타내기 위해) 또는 VIDEO_ENGINE_TIMEOUT_DETECTED(물리적 어댑터 내에서 하나 이상의 노드 재설정을 나타내기 위해 Windows 8 시작)로 설정된 경우 드라이버는 DxgkDdiCollectDbgInfo가 페이징 가능하고 IRQL = PASSIVE_LEVEL 실행되며 동기화 제로 수준을 지원해야 합니다.

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows Vista
대상 플랫폼 데스크톱
머리글 d3dkmddi.h
IRQL PASSIVE_LEVEL(설명 참조)

추가 정보

DXGKARG_COLLECTDBGINFO

DxgkDdiAddDevice

DxgkDdiResetFromTimeout