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

Unified Diff: chromecast/browser/media/media_pipeline_host.cc

Issue 823923002: [Chromecast] Add IPC code on brower process side (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years 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 | « chromecast/browser/media/media_pipeline_host.h ('k') | chromecast/chromecast.gyp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chromecast/browser/media/media_pipeline_host.cc
diff --git a/chromecast/browser/media/media_pipeline_host.cc b/chromecast/browser/media/media_pipeline_host.cc
new file mode 100644
index 0000000000000000000000000000000000000000..9d3c29a67983cf407e2cf2d58985e913a607b000
--- /dev/null
+++ b/chromecast/browser/media/media_pipeline_host.cc
@@ -0,0 +1,178 @@
+// 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.
+
+#include "chromecast/browser/media/media_pipeline_host.h"
+
+#include <utility>
+
+#include "base/bind.h"
+#include "base/callback.h"
+#include "base/location.h"
+#include "base/memory/shared_memory.h"
+#include "base/single_thread_task_runner.h"
+#include "chromecast/common/media/shared_memory_chunk.h"
+#include "chromecast/media/cma/backend/media_pipeline_device.h"
+#include "chromecast/media/cma/backend/media_pipeline_device_params.h"
+#include "chromecast/media/cma/ipc/media_message_fifo.h"
+#include "chromecast/media/cma/ipc_streamer/coded_frame_provider_host.h"
+#include "chromecast/media/cma/pipeline/audio_pipeline_impl.h"
+#include "chromecast/media/cma/pipeline/media_pipeline_impl.h"
+#include "chromecast/media/cma/pipeline/video_pipeline_impl.h"
+
+namespace chromecast {
+namespace media {
+
+struct MediaPipelineHost::MediaTrackHost {
+ MediaTrackHost();
+ ~MediaTrackHost();
+
+ base::Closure pipe_write_cb;
+};
+
+MediaPipelineHost::MediaTrackHost::MediaTrackHost() {
+}
+
+MediaPipelineHost::MediaTrackHost::~MediaTrackHost() {
+}
+
+MediaPipelineHost::MediaPipelineHost() {
+ thread_checker_.DetachFromThread();
+}
+
+MediaPipelineHost::~MediaPipelineHost() {
+ DCHECK(thread_checker_.CalledOnValidThread());
+
+ for (MediaTrackMap::iterator it = media_track_map_.begin();
+ it != media_track_map_.end(); ++it) {
+ scoped_ptr<MediaTrackHost> media_track(it->second);
+ }
+ media_track_map_.clear();
+}
+
+void MediaPipelineHost::Initialize(
+ LoadType load_type,
+ const MediaPipelineClient& client) {
+ DCHECK(thread_checker_.CalledOnValidThread());
+ media_pipeline_.reset(new MediaPipelineImpl());
+ MediaPipelineDeviceParams default_parameters;
+ if (load_type == kLoadTypeMediaStream)
+ default_parameters.disable_synchronization = true;
+ media_pipeline_->Initialize(
+ load_type,
+ CreateMediaPipelineDevice(default_parameters).Pass());
+ media_pipeline_->SetClient(client);
+}
+
+void MediaPipelineHost::SetAvPipe(
+ TrackId track_id,
+ scoped_ptr<base::SharedMemory> shared_mem,
+ const base::Closure& pipe_read_activity_cb,
+ const base::Closure& av_pipe_set_cb) {
+ DCHECK(thread_checker_.CalledOnValidThread());
+ CHECK(track_id == kAudioTrackId || track_id == kVideoTrackId);
+
+ size_t shared_mem_size = shared_mem->requested_size();
+ scoped_ptr<MediaMemoryChunk> shared_memory_chunk(
+ new SharedMemoryChunk(shared_mem.Pass(), shared_mem_size));
+ scoped_ptr<MediaMessageFifo> media_message_fifo(
+ new MediaMessageFifo(shared_memory_chunk.Pass(), shared_mem_size));
+ media_message_fifo->ObserveReadActivity(pipe_read_activity_cb);
+ scoped_ptr<CodedFrameProviderHost> frame_provider_host(
+ new CodedFrameProviderHost(media_message_fifo.Pass()));
+
+ MediaTrackMap::iterator it = media_track_map_.find(track_id);
+ MediaTrackHost* media_track_host;
+ if (it == media_track_map_.end()) {
+ media_track_host = new MediaTrackHost();
+ media_track_map_.insert(
+ std::pair<TrackId, MediaTrackHost*>(track_id, media_track_host));
+ } else {
+ media_track_host = it->second;
+ }
+ media_track_host->pipe_write_cb = frame_provider_host->GetFifoWriteEventCb();
+
+ scoped_ptr<CodedFrameProvider> frame_provider(frame_provider_host.release());
+ if (track_id == kAudioTrackId) {
+ media_pipeline_->GetAudioPipelineImpl()->SetCodedFrameProvider(
+ frame_provider.Pass());
+ } else {
+ media_pipeline_->GetVideoPipelineImpl()->SetCodedFrameProvider(
+ frame_provider.Pass());
+ }
+ av_pipe_set_cb.Run();
+}
+
+void MediaPipelineHost::AudioInitialize(
+ TrackId track_id,
+ const AvPipelineClient& client,
+ const ::media::AudioDecoderConfig& config,
+ const ::media::PipelineStatusCB& status_cb) {
+ DCHECK(thread_checker_.CalledOnValidThread());
+ CHECK(track_id == kAudioTrackId);
+ media_pipeline_->GetAudioPipeline()->SetClient(client);
+ media_pipeline_->InitializeAudio(
+ config, scoped_ptr<CodedFrameProvider>(), status_cb);
+}
+
+void MediaPipelineHost::VideoInitialize(
+ TrackId track_id,
+ const VideoPipelineClient& client,
+ const ::media::VideoDecoderConfig& config,
+ const ::media::PipelineStatusCB& status_cb) {
+ DCHECK(thread_checker_.CalledOnValidThread());
+ CHECK(track_id == kVideoTrackId);
+ media_pipeline_->GetVideoPipeline()->SetClient(client);
+ media_pipeline_->InitializeVideo(
+ config, scoped_ptr<CodedFrameProvider>(), status_cb);
+}
+
+void MediaPipelineHost::StartPlayingFrom(base::TimeDelta time) {
+ DCHECK(thread_checker_.CalledOnValidThread());
+ media_pipeline_->StartPlayingFrom(time);
+}
+
+void MediaPipelineHost::Flush(const ::media::PipelineStatusCB& status_cb) {
+ DCHECK(thread_checker_.CalledOnValidThread());
+ media_pipeline_->Flush(status_cb);
+}
+
+void MediaPipelineHost::Stop() {
+ DCHECK(thread_checker_.CalledOnValidThread());
+ media_pipeline_->Stop();
+}
+
+void MediaPipelineHost::SetPlaybackRate(float playback_rate) {
+ DCHECK(thread_checker_.CalledOnValidThread());
+ media_pipeline_->SetPlaybackRate(playback_rate);
+}
+
+void MediaPipelineHost::SetVolume(TrackId track_id, float volume) {
+ DCHECK(thread_checker_.CalledOnValidThread());
+ CHECK(track_id == kAudioTrackId);
+ media_pipeline_->GetAudioPipeline()->SetVolume(volume);
+}
+
+void MediaPipelineHost::SetCdm(
+ int render_process_id, int render_frame_id, int cdm_id) {
+ DCHECK(thread_checker_.CalledOnValidThread());
+
+ // TODO(gunsch): crbug.com/444930. Find a way to get
+ // content::BrowserCdmManager since it is not under content/public/.
+ NOTIMPLEMENTED();
+}
+
+void MediaPipelineHost::NotifyPipeWrite(TrackId track_id) {
+ DCHECK(thread_checker_.CalledOnValidThread());
+ MediaTrackMap::iterator it = media_track_map_.find(track_id);
+ if (it == media_track_map_.end())
+ return;
+
+ MediaTrackHost* media_track_host = it->second;
+ if (!media_track_host->pipe_write_cb.is_null())
+ media_track_host->pipe_write_cb.Run();
+}
+
+} // namespace media
+} // namespace chromecast
+
« no previous file with comments | « chromecast/browser/media/media_pipeline_host.h ('k') | chromecast/chromecast.gyp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698