• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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
3 // found in the LICENSE file.
4 
5 #ifndef MEDIA_BASE_DECRYPTOR_H_
6 #define MEDIA_BASE_DECRYPTOR_H_
7 
8 #include <list>
9 
10 #include "base/basictypes.h"
11 #include "base/callback.h"
12 #include "base/memory/ref_counted.h"
13 #include "media/base/audio_buffer.h"
14 #include "media/base/media_export.h"
15 
16 namespace media {
17 
18 class AudioDecoderConfig;
19 class DecoderBuffer;
20 class VideoDecoderConfig;
21 class VideoFrame;
22 
23 // Decrypts (and decodes) encrypted buffer.
24 //
25 // All methods are called on the (video/audio) decoder thread. Decryptor
26 // implementations must be thread safe when methods are called this way.
27 // Depending on the implementation callbacks may be fired synchronously or
28 // asynchronously.
29 class MEDIA_EXPORT Decryptor {
30  public:
31   // TODO(xhwang): Replace kError with kDecryptError and kDecodeError.
32   // TODO(xhwang): Replace kNeedMoreData with kNotEnoughData.
33   enum Status {
34     kSuccess,  // Decryption successfully completed. Decrypted buffer ready.
35     kNoKey,  // No key is available to decrypt.
36     kNeedMoreData,  // Decoder needs more data to produce a frame.
37     kError  // Key is available but an error occurred during decryption.
38   };
39 
40   // TODO(xhwang): Unify this with DemuxerStream::Type.
41   enum StreamType {
42     kAudio,
43     kVideo
44   };
45 
46   Decryptor();
47   virtual ~Decryptor();
48 
49   // Indicates that a new key has been added to the MediaKeys object associated
50   // with the Decryptor.
51   typedef base::Callback<void()> NewKeyCB;
52 
53   // Registers a NewKeyCB which should be called when a new key is added to the
54   // decryptor. Only one NewKeyCB can be registered for one |stream_type|.
55   // If this function is called multiple times for the same |stream_type|, the
56   // previously registered callback will be replaced. In other words,
57   // registering a null callback cancels the originally registered callback.
58   virtual void RegisterNewKeyCB(StreamType stream_type,
59                                 const NewKeyCB& key_added_cb) = 0;
60 
61   // Indicates completion of a decryption operation.
62   //
63   // First parameter: The status of the decryption operation.
64   // - Set to kSuccess if the encrypted buffer is successfully decrypted and
65   //   the decrypted buffer is ready to be read.
66   // - Set to kNoKey if no decryption key is available to decrypt the encrypted
67   //   buffer. In this case the decrypted buffer must be NULL.
68   // - Set to kError if unexpected error has occurred. In this case the
69   //   decrypted buffer must be NULL.
70   // - This parameter should not be set to kNeedMoreData.
71   // Second parameter: The decrypted buffer.
72   typedef base::Callback<void(Status,
73                               const scoped_refptr<DecoderBuffer>&)> DecryptCB;
74 
75   // Decrypts the |encrypted| buffer. The decrypt status and decrypted buffer
76   // are returned via the provided callback |decrypt_cb|. The |encrypted| buffer
77   // must not be NULL.
78   // Decrypt() should not be called until any previous DecryptCB of the same
79   // |stream_type| has completed. Thus, only one DecryptCB may be pending at
80   // a time for a given |stream_type|.
81   virtual void Decrypt(StreamType stream_type,
82                        const scoped_refptr<DecoderBuffer>& encrypted,
83                        const DecryptCB& decrypt_cb) = 0;
84 
85   // Cancels the scheduled decryption operation for |stream_type| and fires the
86   // pending DecryptCB immediately with kSuccess and NULL.
87   // Decrypt() should not be called again before the pending DecryptCB for the
88   // same |stream_type| is fired.
89   virtual void CancelDecrypt(StreamType stream_type) = 0;
90 
91   // Indicates completion of audio/video decoder initialization.
92   //
93   // First Parameter: Indicates initialization success.
94   // - Set to true if initialization was successful. False if an error occurred.
95   typedef base::Callback<void(bool)> DecoderInitCB;
96 
97   // Initializes a decoder with the given |config|, executing the |init_cb|
98   // upon completion.
99   virtual void InitializeAudioDecoder(const AudioDecoderConfig& config,
100                                       const DecoderInitCB& init_cb) = 0;
101   virtual void InitializeVideoDecoder(const VideoDecoderConfig& config,
102                                       const DecoderInitCB& init_cb) = 0;
103 
104   // Helper structure for managing multiple decoded audio buffers per input.
105   // TODO(xhwang): Rename this to AudioFrames.
106   typedef std::list<scoped_refptr<AudioBuffer> > AudioBuffers;
107 
108   // Indicates completion of audio/video decrypt-and-decode operation.
109   //
110   // First parameter: The status of the decrypt-and-decode operation.
111   // - Set to kSuccess if the encrypted buffer is successfully decrypted and
112   //   decoded. In this case, the decoded frame/buffers can be/contain:
113   //   1) NULL, which means the operation has been aborted.
114   //   2) End-of-stream (EOS) frame, which means that the decoder has hit EOS,
115   //      flushed all internal buffers and cannot produce more video frames.
116   //   3) Decrypted and decoded video frame or audio buffer.
117   // - Set to kNoKey if no decryption key is available to decrypt the encrypted
118   //   buffer. In this case the returned frame(s) must be NULL/empty.
119   // - Set to kNeedMoreData if more data is needed to produce a video frame. In
120   //   this case the returned frame(s) must be NULL/empty.
121   // - Set to kError if unexpected error has occurred. In this case the
122   //   returned frame(s) must be NULL/empty.
123   // Second parameter: The decoded video frame or audio buffers.
124   typedef base::Callback<void(Status, const AudioBuffers&)> AudioDecodeCB;
125   typedef base::Callback<void(Status,
126                               const scoped_refptr<VideoFrame>&)> VideoDecodeCB;
127 
128   // Decrypts and decodes the |encrypted| buffer. The status and the decrypted
129   // buffer are returned via the provided callback.
130   // The |encrypted| buffer must not be NULL.
131   // At end-of-stream, this method should be called repeatedly with
132   // end-of-stream DecoderBuffer until no frame/buffer can be produced.
133   // These methods can only be called after the corresponding decoder has
134   // been successfully initialized.
135   virtual void DecryptAndDecodeAudio(
136       const scoped_refptr<DecoderBuffer>& encrypted,
137       const AudioDecodeCB& audio_decode_cb) = 0;
138   virtual void DecryptAndDecodeVideo(
139       const scoped_refptr<DecoderBuffer>& encrypted,
140       const VideoDecodeCB& video_decode_cb) = 0;
141 
142   // Resets the decoder to an initialized clean state, cancels any scheduled
143   // decrypt-and-decode operations, and fires any pending
144   // AudioDecodeCB/VideoDecodeCB immediately with kError and NULL.
145   // This method can only be called after the corresponding decoder has been
146   // successfully initialized.
147   virtual void ResetDecoder(StreamType stream_type) = 0;
148 
149   // Releases decoder resources, deinitializes the decoder, cancels any
150   // scheduled initialization or decrypt-and-decode operations, and fires
151   // any pending DecoderInitCB/AudioDecodeCB/VideoDecodeCB immediately.
152   // DecoderInitCB should be fired with false. AudioDecodeCB/VideoDecodeCB
153   // should be fired with kError.
154   // This method can be called any time after Initialize{Audio|Video}Decoder()
155   // has been called (with the correct stream type).
156   // After this operation, the decoder is set to an uninitialized state.
157   // The decoder can be reinitialized after it is uninitialized.
158   virtual void DeinitializeDecoder(StreamType stream_type) = 0;
159 
160  private:
161   DISALLOW_COPY_AND_ASSIGN(Decryptor);
162 };
163 
164 // Callback to notify that the decryptor has been completely attached into the
165 // pipeline. Parameter indicates whether the operation succeeded.
166 typedef base::Callback<void(bool)> DecryptorAttachedCB;
167 
168 // Callback to notify that a decryptor is ready. DecryptorAttachedCB is called
169 // when the decryptor has been completely inserted into the pipeline.
170 typedef base::Callback<void(Decryptor*, const DecryptorAttachedCB&)>
171     DecryptorReadyCB;
172 
173 // Callback to set/cancel a DecryptorReadyCB.
174 // Calling this callback with a non-null callback registers decryptor ready
175 // notification. When the decryptor is ready, notification will be sent
176 // through the provided callback.
177 // Calling this callback with a null callback cancels previously registered
178 // decryptor ready notification. Any previously provided callback will be
179 // fired immediately with NULL.
180 typedef base::Callback<void(const DecryptorReadyCB&)> SetDecryptorReadyCB;
181 
182 }  // namespace media
183 
184 #endif  // MEDIA_BASE_DECRYPTOR_H_
185