IAMCertifiedOutputProtection::KeyExchange 메서드(strmif.h)

[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngineMedia Foundation의 오디오/비디오 캡처로 대체되었습니다. 이러한 기능은 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드에서 DirectShow 대신 MediaPlayer, IMFMediaEngine오디오/비디오 캡처를 사용하는 것이 좋습니다. 가능한 경우 레거시 API를 사용하는 기존 코드를 다시 작성하여 새 API를 사용하도록 제안합니다.]

KeyExchange 메서드는 그래픽 드라이버의 인증서를 반환합니다.

구문

HRESULT KeyExchange(
  [out] GUID  *pRandom,
  [out] BYTE  **VarLenCertGH,
  [out] DWORD *pdwLengthCertGH
);

매개 변수

[out] pRandom

그래픽 드라이버에서 생성된 128비트 난수를 받습니다. IAMCertifiedOutputProtection::SessionSequenceStart 메서드에서 이 값을 사용합니다.

[out] VarLenCertGH

그래픽 드라이버의 인증서를 포함하는 버퍼에 대한 포인터를 받습니다. 메서드는 버퍼에 대한 메모리를 할당합니다. 호출자는 CoTaskMemFree를 호출하여 메모리를 해제해야 합니다.

[out] pdwLengthCertGH

VarLenCertGH에서 반환된 버퍼의 길이를 받습니다.

반환 값

HRESULT 값을 반환합니다. 가능한 값은 다음과 같습니다.

반환 코드 설명
S_OK
성공.
E_UNEXPECTED
상태가 잘못되었습니다. 애플리케이션이 예기치 않은 데이터를 전달했거나 IAMCertifiedOutputProtection 메서드를 잘못된 순서로 전달했을 수 있습니다. 이 오류가 발생하면 애플리케이션은 VMR의 현재 instance 해제해야 합니다.
VFW_E_NO_COPP_HW
디스플레이 디바이스는 COPP를 지원하지 않습니다. 또는 VMR이 디스플레이 디바이스에 아직 연결되지 않았습니다.
ERROR_GRAPHICS_NO_MONITORS_CORRESPOND_TO_DISPLAY_DEVICE
디스플레이 디바이스에 해당하는 모니터가 없습니다. 표시 모드가 변경되면 이 오류가 발생할 수 있습니다. 또는 사용자가 모니터를 끄거나 모니터를 제거합니다.

설명

그래픽 드라이버의 인증서에는 드라이버의 공개 암호화 키가 포함되어 있습니다.

이 메서드가 E_UNEXPECTED 반환하는 경우 애플리케이션은 VMR을 해제하고, VMR의 새 instance 만들고, 새 instance 다시 호출 KeyExchange 하여 새 COPP 세션을 만들어야 합니다.

요구 사항

   
지원되는 최소 클라이언트 WINDOWS XP SP2 [데스크톱 앱만 해당]
지원되는 최소 서버 Windows Server 2003 R2 [데스크톱 앱만 해당]
대상 플랫폼 Windows
헤더 strmif.h(Dshow.h 포함)
라이브러리 Strmiids.lib

추가 정보

IAMCertifiedOutputProtection 인터페이스

COPP(Certified Output Protection Protocol) 사용