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

Unified Diff: media/filters/decrypting_demuxer_stream.h

Issue 11342031: Add DecryptingDemuxerStream. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 8 years, 1 month 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « media/filters/decrypting_audio_decoder_unittest.cc ('k') | media/filters/decrypting_demuxer_stream.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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..28174beb2b90cd65ef33fc6711b6d4e7ca4f5369
--- /dev/null
+++ b/media/filters/decrypting_demuxer_stream.h
@@ -0,0 +1,148 @@
+// 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.
+ 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_
« no previous file with comments | « media/filters/decrypting_audio_decoder_unittest.cc ('k') | media/filters/decrypting_demuxer_stream.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698