Chromium Code Reviews| Index: media/filters/decrypting_demuxer_stream.h |
| diff --git a/media/filters/decrypting_demuxer_stream.h b/media/filters/decrypting_demuxer_stream.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..775ad36235e6af0f6a1e9f931c25f4c2141d712e |
| --- /dev/null |
| +++ b/media/filters/decrypting_demuxer_stream.h |
| @@ -0,0 +1,146 @@ |
| +// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#ifndef MEDIA_FILTERS_DECRYPTING_DEMUXER_STREAM_H_ |
| +#define MEDIA_FILTERS_DECRYPTING_DEMUXER_STREAM_H_ |
| + |
| +#include "base/callback.h" |
| +#include "base/memory/ref_counted.h" |
| +#include "media/base/decryptor.h" |
| +#include "media/base/demuxer_stream.h" |
| + |
| +namespace base { |
| +class MessageLoopProxy; |
| +} |
| + |
| +namespace media { |
| + |
| +class DecoderBuffer; |
| + |
| +// Decryptor-based DemuxerStream implementation that converts a potentially |
| +// encrypted demuxer stream to a clear demuxer stream. |
| +// All public APIs and callbacks are trampolined to the |message_loop_| so |
| +// that no locks are required for thread safety. |
| +class MEDIA_EXPORT DecryptingDemuxerStream : public DemuxerStream { |
| + public: |
| + // Callback to get a message loop. |
| + typedef base::Callback< |
| + scoped_refptr<base::MessageLoopProxy>()> MessageLoopFactoryCB; |
| + // Callback to notify decryptor creation. |
|
scherkus (not reviewing)
2012/11/14 22:22:30
blank lines between // comments
xhwang
2012/11/15 00:10:00
Done.
|
| + typedef base::Callback<void(Decryptor*)> DecryptorNotificationCB; |
| + // Callback to request/cancel decryptor creation notification. |
| + // Calling this callback with a non-null callback registers decryptor creation |
| + // notification. When the decryptor is created, notification will be sent |
| + // through the provided callback. |
| + // Calling this callback with a null callback cancels previously registered |
| + // decryptor creation notification. Any previously provided callback will be |
| + // fired immediately with NULL. |
| + typedef base::Callback<void(const DecryptorNotificationCB&)> |
| + RequestDecryptorNotificationCB; |
| + |
| + DecryptingDemuxerStream( |
| + const MessageLoopFactoryCB& message_loop_factory_cb, |
| + const RequestDecryptorNotificationCB& request_decryptor_notification_cb); |
| + |
| + void Initialize(const scoped_refptr<DemuxerStream>& stream, |
| + const PipelineStatusCB& status_cb); |
| + void Reset(const base::Closure& closure); |
| + |
| + // DemuxerStream implementation. |
| + virtual void Read(const ReadCB& read_cb) OVERRIDE; |
| + virtual const AudioDecoderConfig& audio_decoder_config() OVERRIDE; |
| + virtual const VideoDecoderConfig& video_decoder_config() OVERRIDE; |
| + virtual Type type() OVERRIDE; |
| + virtual void EnableBitstreamConverter() OVERRIDE; |
| + |
| + protected: |
| + virtual ~DecryptingDemuxerStream(); |
| + |
| + private: |
| + // For a detailed state diagram please see this link: http://goo.gl/8jAok |
| + // TODO(xhwang): Add a ASCII state diagram in this file after this class |
| + // stabilizes. |
| + // TODO(xhwang): Update this diagram for DecryptingDemuxerStream. |
| + enum State { |
| + kUninitialized = 0, |
| + kDecryptorRequested, |
| + kIdle, |
| + kPendingDemuxerRead, |
| + kPendingDecrypt, |
| + kWaitingForKey, |
| + }; |
| + |
| + // Carries out the initialization operation scheduled by Initialize(). |
| + void DoInitialize(const scoped_refptr<DemuxerStream>& stream, |
| + const PipelineStatusCB& status_cb); |
| + |
| + // Callback for DecryptorHost::RequestDecryptor(). |
| + void SetDecryptor(Decryptor* decryptor); |
| + |
| + // Callback for DemuxerStream::Read(). |
| + void DecryptBuffer(DemuxerStream::Status status, |
| + const scoped_refptr<DecoderBuffer>& buffer); |
| + |
| + // Carries out the buffer decryption operation scheduled by DecryptBuffer(). |
| + void DoDecryptBuffer(DemuxerStream::Status status, |
| + const scoped_refptr<DecoderBuffer>& buffer); |
| + |
| + void DecryptPendingBuffer(); |
| + |
| + // Callback for Decryptor::Decrypt(). |
| + void DeliverBuffer(Decryptor::Status status, |
| + const scoped_refptr<DecoderBuffer>& decrypted_buffer); |
| + |
| + // Carries out the frame delivery operation scheduled by DeliverBuffer(). |
| + void DoDeliverBuffer(Decryptor::Status status, |
| + const scoped_refptr<DecoderBuffer>& decrypted_buffer); |
| + |
| + // Callback for the |decryptor_| to notify this object that a new key has been |
| + // added. |
| + void OnKeyAdded(); |
| + |
| + // Resets decoder and calls |reset_cb_|. |
| + void DoReset(); |
| + |
| + // Returns Decryptor::StreamType converted from |stream_type_|. |
| + Decryptor::StreamType GetDecryptorStreamType() const; |
| + |
| + // This is !is_null() iff Initialize() hasn't been called. |
| + MessageLoopFactoryCB message_loop_factory_cb_; |
| + |
| + scoped_refptr<base::MessageLoopProxy> message_loop_; |
| + |
| + State state_; |
| + |
| + PipelineStatusCB init_cb_; |
| + ReadCB read_cb_; |
| + base::Closure reset_cb_; |
| + |
| + // Pointer to the input demuxer stream that will feed us encrypted buffers. |
| + scoped_refptr<DemuxerStream> demuxer_stream_; |
| + |
| + Type stream_type_; |
| + scoped_ptr<AudioDecoderConfig> audio_config_; |
| + scoped_ptr<VideoDecoderConfig> video_config_; |
| + |
| + // Callback to request/cancel decryptor creation notification. |
| + RequestDecryptorNotificationCB request_decryptor_notification_cb_; |
| + |
| + Decryptor* decryptor_; |
| + |
| + // The buffer returned by the demuxer that needs to be decrypted. |
| + scoped_refptr<media::DecoderBuffer> pending_buffer_to_decrypt_; |
| + |
| + // Indicates the situation where new key is added during pending decryption |
| + // (in other words, this variable can only be set in state kPendingDecrypt). |
| + // If this variable is true and kNoKey is returned then we need to try |
| + // decrypting again in case the newly added key is the correct decryption key. |
| + bool key_added_while_decrypt_pending_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(DecryptingDemuxerStream); |
| +}; |
| + |
| +} // namespace media |
| + |
| +#endif // MEDIA_FILTERS_DECRYPTING_DEMUXER_STREAM_H_ |