Using Certified Output Protection Protocol (COPP)
Certified Output Protection Protocol (COPP) enables an application to protect a video stream as it travels from the graphics adapter to the display device. An application can use COPP to discover what kind of physical connector is attached to the display device, and what types of output protection are available. Protection mechanisms include the following:
- High-Bandwidth Digital Content Protection (HDCP)
- Copy Generation Management System — Analog (CGMS-A)
- Analog Copy Protection (ACP)
If the graphics adapter supports one of these mechanisms, the application can use COPP to set the protection level.
COPP defines a protocol that is used to establish a secure communications channel with the graphics driver. It uses Message Authentication Codes (MACs) to verify the integrity of the COPP commands that are passed between the application and the display driver. The application uses COPP by calling methods on the IAMCertifiedOutputProtection interface of the DirectShow Video Mixing Renderer filter (VMR-7 or VMR-9).
COPP does not define anything about the digital rights policies that might apply to digital media content. Also, COPP itself does not implement any output protection systems. The COPP protocol simply provides a way to set and query protection levels on the graphics adapter, using the protection systems provided by the adapter.
This section assumes that you are familiar with the following technologies:
- Windows Media Format SDK
- Public-key cryptography and symmetric cryptography
The code examples in this section use Microsoft's CryptoAPI to perform cryptographic operations. This section contains the following topics:
- Overview of COPP
- Obtaining the Driver's Certificate Chain
- Validating the Certificate Chain
- Certificate Revocation Lists
- Importing the Driver's Public Key
- Initiating a COPP Session
- Sending COPP Status Requests
- Sending COPP Commands
- Testing Whether a Graphics Driver Supports COPP
- COPP Query Reference
- COPP Command Reference