다음을 통해 공유


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->이유VIDEO_TDR_TIMEOUT_DETECTED(어댑터 전체 재설정을 나타내기 위해) 또는 VIDEO_ENGINE_TIMEOUT_DETECTED(실제 어댑터 내에서 하나 이상의 노드 재설정을 나타내기 위해 Windows 8부터 사용 가능) 드라이버는 DxgkDdiCollectDbgInfo 페이징할 수 있는지 확인해야 합니다. 는 IRQL = PASSIVE_LEVEL실행되며 동기화 0 수준지원합니다.

요구 사항

요구
지원되는 최소 클라이언트 Windows Vista
대상 플랫폼 바탕 화면
헤더 d3dkmddi.h
IRQL PASSIVE_LEVEL(설명 참조)

참고 항목

DXGKARG_COLLECTDBGINFO

DxgkDdiAddDevice

DxgkDdiResetFromTimeout