Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(153)

Side by Side Diff: ppapi/api/private/ppp_content_decryptor_private.idl

Issue 11028087: Add decoder de-initialize and reset to the Pepper CDM API. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Finish first pass. Created 8 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 /* Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 /* Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 * Use of this source code is governed by a BSD-style license that can be 2 * Use of this source code is governed by a BSD-style license that can be
3 * found in the LICENSE file. 3 * found in the LICENSE file.
4 */ 4 */
5 5
6 /** 6 /**
7 * This file defines the <code>PPP_ContentDecryptor_Private</code> 7 * This file defines the <code>PPP_ContentDecryptor_Private</code>
8 * interface. Note: This is a special interface, only to be used for Content 8 * interface. Note: This is a special interface, only to be used for Content
9 * Decryption Modules, not normal plugins. 9 * Decryption Modules, not normal plugins.
10 */ 10 */
11 label Chrome { 11 label Chrome {
12 M23 = 0.2 12 M24 = 0.3
13 }; 13 };
14 14
15 /** 15 /**
16 * <code>PPP_ContentDecryptor_Private</code> structure contains the function 16 * <code>PPP_ContentDecryptor_Private</code> structure contains the function
17 * pointers the decryption plugin must implement to provide services needed by 17 * pointers the decryption plugin must implement to provide services needed by
18 * the browser. This interface provides the plugin side support for the Content 18 * the browser. This interface provides the plugin side support for the Content
19 * Decryption Module (CDM) for v0.1 of the proposed Encrypted Media Extensions: 19 * Decryption Module (CDM) for v0.1 of the proposed Encrypted Media Extensions:
20 * http://goo.gl/rbdnR 20 * http://goo.gl/rbdnR
21 */ 21 */
22 interface PPP_ContentDecryptor_Private { 22 interface PPP_ContentDecryptor_Private {
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after
93 * @param[in] encrypted_block_info A <code>PP_EncryptedBlockInfo</code> that 93 * @param[in] encrypted_block_info A <code>PP_EncryptedBlockInfo</code> that
94 * contains all auxiliary information needed for decryption of the 94 * contains all auxiliary information needed for decryption of the
95 * <code>encrypted_block</code>. 95 * <code>encrypted_block</code>.
96 */ 96 */
97 void Decrypt( 97 void Decrypt(
98 [in] PP_Instance instance, 98 [in] PP_Instance instance,
99 [in] PP_Resource encrypted_block, 99 [in] PP_Resource encrypted_block,
100 [in] PP_EncryptedBlockInfo encrypted_block_info); 100 [in] PP_EncryptedBlockInfo encrypted_block_info);
101 101
102 /** 102 /**
103 * Resets the video decoder. Reset completion is reported to the browser
104 * using the <code>DecoderReset()</code> method on the
105 * <code>PPB_ContentDecryptor_Private</code> interface.
106 *
107 * @param[in] request_id A request ID that allows the browser to associate a
108 * request to reset the video decoder with the corresponding call to the
109 * <code>DecoderReset()</code> method on the
xhwang 2012/10/09 16:27:27 It looks like the PPB interfaces are sharing APIs
Tom Finegan 2012/10/10 00:39:32 +ddorwin,fischman: We still need audio and video s
110 * <code>PPB_ContentDecryptor_Private</code> interface.
111 */
112 void ResetVideoDecoder(
113 [in] PP_Instance instance,
114 [in] uint32_t request_id);
115
116 /**
117 * Stops the video decoder. Stop completion is reported to the browser using
118 * the <code>DecoderStopped()</code> method on the
119 * <code>PPB_ContentDecryptor_Private</code> interface.
120 *
121 * @param[in] request_id A request ID that allows the browser to associate a
122 * request to stop the video decoder with the corresponding call to the
123 * <code>DecoderStopped()</code> method on the
124 * <code>PPB_ContentDecryptor_Private</code> interface.
125 */
126 void StopVideoDecoder(
Ami GONE FROM CHROMIUM 2012/10/09 07:25:54 Is there a reason this is "Stop" and not "Destroy"
xhwang 2012/10/09 16:27:27 In the CDM world, a video decoder can be reinitial
Ami GONE FROM CHROMIUM 2012/10/09 16:41:05 Then how about DeinitializeVideoDecoder()? Stop i
Tom Finegan 2012/10/10 00:39:32 Agreed, discussing this in the above comment.
127 [in] PP_Instance instance,
128 [in] uint32_t request_id);
129
130 /**
103 * Decrypts encrypted_video_frame, decodes it, and returns the unencrypted 131 * Decrypts encrypted_video_frame, decodes it, and returns the unencrypted
104 * uncompressed (decoded) video frame to the browser via the 132 * uncompressed (decoded) video frame to the browser via the
105 * <code>DeliverFrame()</code> method on the 133 * <code>DeliverFrame()</code> method on the
106 * <code>PPB_ContentDecryptor_Private</code> interface. 134 * <code>PPB_ContentDecryptor_Private</code> interface.
107 * 135 *
108 * @param[in] encrypted_video_frame A <code>PP_Resource</code> corresponding 136 * @param[in] encrypted_video_frame A <code>PP_Resource</code> corresponding
109 * to a <code>PPB_Buffer_Dev</code> resource that contains an encrypted video 137 * to a <code>PPB_Buffer_Dev</code> resource that contains an encrypted video
110 * frame. 138 * frame.
111 * 139 *
112 * @param[in] encrypted_video_frame_info A 140 * @param[in] encrypted_video_frame_info A
113 * <code>PP_EncryptedVideoFrameInfo</code> that contains all information 141 * <code>PP_EncryptedVideoFrameInfo</code> that contains all information
114 * needed to decrypt and decode <code>encrypted_video_frame</code>. 142 * needed to decrypt and decode <code>encrypted_video_frame</code>.
115 */ 143 */
116 void DecryptAndDecodeFrame( 144 void DecryptAndDecodeFrame(
117 [in] PP_Instance instance, 145 [in] PP_Instance instance,
118 [in] PP_Resource encrypted_video_frame, 146 [in] PP_Resource encrypted_video_frame,
119 [in] PP_EncryptedVideoFrameInfo encrypted_video_frame_info); 147 [in] PP_EncryptedVideoFrameInfo encrypted_video_frame_info);
120 }; 148 };
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698