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(표시 미니포트)는 DxgkDdiAddDevice의 MiniportDeviceContext 출력 매개 변수에서 Dxgkrnl에 이 핸들을 제공했습니다.
[in/out] pCollectDbgInfo
디버그 보고서에 대한 정보를 포함하는 DXGKARG_COLLECTDBGINFO 구조체에 대한 포인터입니다.
반환 값
DxgkDdiCollectDbgInfo 는 다음 값 중 하나를 반환합니다.
반환 코드 | 설명 |
---|---|
STATUS_SUCCESS | DxgkDdiCollectDbgInfo 는 디버그 보고서에 대한 드라이버 정보를 성공적으로 출력합니다. 또는 OS는 pBuffer 가 가리키는 버퍼의 콘텐츠를 무시하고 DxgkDdiCollectDbgInfo 의 정보를 디버그 보고서에 추가하지 않았습니다. |
STATUS_NO_MEMORY | DxgkDdiCollectDbgInfo 가 완료하는 데 필요한 메모리를 할당할 수 없습니다. |
STATUS_UNSUCCESSFUL | 또 다른 오류로 인해 드라이버가 유효한 디버그 정보를 수집할 수 없습니다. |
설명
Dxgkrnl 은 OS가 드라이버 관련 디버그 보고서를 생성하려고 할 때마다 KMD의 DxgkDdiCollectDbgInfo 함수를 호출합니다. DxgkDdiCollectDbgInfo 는 TDR(시간 제한 검색 및 복구)이 작동 하기 직전에 또는 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(설명 참조) |