Index: chromecast/media/cma/pipeline/av_pipeline_impl.h |
diff --git a/chromecast/media/cma/pipeline/av_pipeline_impl.h b/chromecast/media/cma/pipeline/av_pipeline_impl.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..4b8856f07f1856fe345b09c61a21c88d8e4cb3d1 |
--- /dev/null |
+++ b/chromecast/media/cma/pipeline/av_pipeline_impl.h |
@@ -0,0 +1,172 @@ |
+// Copyright 2014 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 CHROMECAST_MEDIA_CMA_BASE_AV_PIPELINE_IMPL_H_ |
+#define CHROMECAST_MEDIA_CMA_BASE_AV_PIPELINE_IMPL_H_ |
+ |
+#include <list> |
+ |
+#include "base/callback.h" |
+#include "base/macros.h" |
+#include "base/memory/ref_counted.h" |
+#include "base/memory/weak_ptr.h" |
+#include "base/threading/thread_checker.h" |
+#include "chromecast/media/cma/backend/media_component_device.h" |
+#include "chromecast/media/cma/pipeline/av_pipeline_client.h" |
+ |
+namespace media { |
+class AudioDecoderConfig; |
+class VideoDecoderConfig; |
+} |
+ |
+namespace chromecast { |
+namespace media { |
+class BrowserCdmCast; |
+class BufferingFrameProvider; |
+class BufferingState; |
+class CodedFrameProvider; |
+class DecoderBufferBase; |
+class MediaComponentDevice; |
+ |
+class AvPipelineImpl { |
+ public: |
+ // Pipeline states. |
+ enum State { |
+ kUninitialized, |
+ kPlaying, |
+ kFlushing, |
+ kFlushed, |
+ kStopped, |
+ kError, |
+ }; |
+ |
+ typedef base::Callback< |
+ void(const ::media::AudioDecoderConfig&, |
+ const ::media::VideoDecoderConfig&)> UpdateConfigCB; |
+ |
+ AvPipelineImpl( |
+ MediaComponentDevice* media_component_device, |
+ const UpdateConfigCB& update_config_cb); |
+ ~AvPipelineImpl(); |
+ |
+ // Setting the frame provider or the client must be done in the |
+ // |kUninitialized| state. |
+ void SetCodedFrameProvider(scoped_ptr<CodedFrameProvider> frame_provider, |
+ size_t max_buffer_size, |
+ size_t max_frame_size); |
+ void SetClient(const AvPipelineClient& client); |
+ |
+ // Initialize the pipeline. |
+ bool Initialize(); |
+ |
+ // Setup the pipeline and ensure samples are available for the given media |
+ // time, then start rendering samples. |
+ bool StartPlayingFrom(base::TimeDelta time, |
+ const scoped_refptr<BufferingState>& buffering_state); |
+ |
+ // Flush any remaining samples in the pipeline. |
+ // Invoke |done_cb| when flush is completed. |
+ void Flush(const base::Closure& done_cb); |
+ |
+ // Tear down the pipeline and release the hardware resources. |
+ void Stop(); |
+ |
+ State GetState() const { return state_; } |
+ void TransitionToState(State state); |
+ |
+ void SetCdm(BrowserCdmCast* media_keys); |
+ |
+ private: |
+ // Callback invoked when the CDM state has changed in a way that might |
+ // impact media playback. |
+ void OnCdmStateChange(); |
+ |
+ // Callback invoked when playback has reached the end of stream. |
+ void OnEos(); |
+ |
+ // Feed the pipeline, getting the frames from |frame_provider_|. |
+ void FetchBufferIfNeeded(); |
+ |
+ // Callback invoked when receiving a new frame from |frame_provider_|. |
+ void OnNewFrame(const scoped_refptr<DecoderBufferBase>& buffer, |
+ const ::media::AudioDecoderConfig& audio_config, |
+ const ::media::VideoDecoderConfig& video_config); |
+ |
+ // Process a pending buffer. |
+ void ProcessPendingBuffer(); |
+ |
+ void OnFramePushed(MediaComponentDevice::FrameStatus status); |
+ |
+ // Callbacks: |
+ // - when BrowserCdm updated its state. |
+ // - when BrowserCdm has been destroyed. |
+ void OnCdmStateChanged(); |
+ void OnCdmDestroyed(); |
+ |
+ // Callback invoked when a frame has been buffered by |frame_provider_| |
+ // which is a BufferingFrameProvider. |
+ void OnFrameBuffered(const scoped_refptr<DecoderBufferBase>& buffer, |
+ bool is_at_max_capacity); |
+ void UpdatePlayableFrames(); |
+ |
+ base::ThreadChecker thread_checker_; |
+ |
+ UpdateConfigCB update_config_cb_; |
+ |
+ AvPipelineClient client_; |
+ |
+ // Backends. |
+ MediaComponentDevice* media_component_device_; |
+ |
+ // AV pipeline state. |
+ State state_; |
+ |
+ // Buffering state. |
+ // Can be NULL if there is no buffering strategy. |
+ scoped_refptr<BufferingState> buffering_state_; |
+ |
+ // |buffered_time_| is the maximum timestamp of buffered frames. |
+ // |playable_buffered_time_| is the maximum timestamp of buffered and |
+ // playable frames (i.e. the key id is available for those frames). |
+ base::TimeDelta buffered_time_; |
+ base::TimeDelta playable_buffered_time_; |
+ |
+ // List of frames buffered but not playable right away due to a missing |
+ // key id. |
+ std::list<scoped_refptr<DecoderBufferBase> > non_playable_frames_; |
+ |
+ // Buffer provider. |
+ scoped_ptr<BufferingFrameProvider> frame_provider_; |
+ |
+ // Indicate whether the frame fetching process is active. |
+ bool enable_feeding_; |
+ |
+ // Indicate whether there is a pending buffer read. |
+ bool pending_read_; |
+ |
+ // Pending buffer. |
+ scoped_refptr<DecoderBufferBase> pending_buffer_; |
+ |
+ // Indicate if there is a frame being pushed to the audio device. |
+ bool pending_push_; |
+ |
+ // The media time is retrieved at regular intervals. |
+ // Indicate whether time update is enabled. |
+ bool enable_time_update_; |
+ bool pending_time_update_task_; |
+ |
+ // Decryption keys, if available. |
+ BrowserCdmCast* media_keys_; |
+ int media_keys_callback_id_; |
+ |
+ base::WeakPtrFactory<AvPipelineImpl> weak_factory_; |
+ base::WeakPtr<AvPipelineImpl> weak_this_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(AvPipelineImpl); |
+}; |
+ |
+} // namespace media |
+} // namespace chromecast |
+ |
+#endif // CHROMECAST_MEDIA_CMA_BASE_AV_PIPELINE_IMPL_H_ |