| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chromecast/renderer/media/audio_pipeline_proxy.h" | 5 #include "chromecast/renderer/media/audio_pipeline_proxy.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/callback_helpers.h" | 8 #include "base/callback_helpers.h" |
| 9 #include "base/memory/shared_memory.h" | 9 #include "base/memory/shared_memory.h" |
| 10 #include "base/message_loop/message_loop.h" | 10 #include "base/message_loop/message_loop.h" |
| (...skipping 177 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 188 kAudioTrackId, volume))); | 188 kAudioTrackId, volume))); |
| 189 } | 189 } |
| 190 | 190 |
| 191 void AudioPipelineProxyInternal::OnStateChanged( | 191 void AudioPipelineProxyInternal::OnStateChanged( |
| 192 ::media::PipelineStatus status) { | 192 ::media::PipelineStatus status) { |
| 193 DCHECK(thread_checker_.CalledOnValidThread()); | 193 DCHECK(thread_checker_.CalledOnValidThread()); |
| 194 DCHECK(!status_cb_.is_null()); | 194 DCHECK(!status_cb_.is_null()); |
| 195 base::ResetAndReturn(&status_cb_).Run(status); | 195 base::ResetAndReturn(&status_cb_).Run(status); |
| 196 } | 196 } |
| 197 | 197 |
| 198 | 198 // A macro runs current member function on |io_task_runner_| thread. |
| 199 // A macro runs current member function on |io_message_loop_proxy_| thread. | 199 #define FORWARD_ON_IO_THREAD(param_fn, ...) \ |
| 200 #define FORWARD_ON_IO_THREAD(param_fn, ...) \ | 200 io_task_runner_->PostTask( \ |
| 201 io_message_loop_proxy_->PostTask( \ | 201 FROM_HERE, base::Bind(&AudioPipelineProxyInternal::param_fn, \ |
| 202 FROM_HERE, \ | 202 base::Unretained(proxy_.get()), ##__VA_ARGS__)) |
| 203 base::Bind(&AudioPipelineProxyInternal::param_fn, \ | |
| 204 base::Unretained(proxy_.get()), ##__VA_ARGS__)) | |
| 205 | 203 |
| 206 AudioPipelineProxy::AudioPipelineProxy( | 204 AudioPipelineProxy::AudioPipelineProxy( |
| 207 scoped_refptr<base::MessageLoopProxy> io_message_loop_proxy, | 205 scoped_refptr<base::SingleThreadTaskRunner> io_task_runner, |
| 208 scoped_refptr<MediaChannelProxy> media_channel_proxy) | 206 scoped_refptr<MediaChannelProxy> media_channel_proxy) |
| 209 : io_message_loop_proxy_(io_message_loop_proxy), | 207 : io_task_runner_(io_task_runner), |
| 210 proxy_(new AudioPipelineProxyInternal(media_channel_proxy)), | 208 proxy_(new AudioPipelineProxyInternal(media_channel_proxy)), |
| 211 audio_streamer_(new AvStreamerProxy()), | 209 audio_streamer_(new AvStreamerProxy()), |
| 212 weak_factory_(this) { | 210 weak_factory_(this) { |
| 213 DCHECK(io_message_loop_proxy_.get()); | 211 DCHECK(io_task_runner_.get()); |
| 214 weak_this_ = weak_factory_.GetWeakPtr(); | 212 weak_this_ = weak_factory_.GetWeakPtr(); |
| 215 thread_checker_.DetachFromThread(); | 213 thread_checker_.DetachFromThread(); |
| 216 } | 214 } |
| 217 | 215 |
| 218 AudioPipelineProxy::~AudioPipelineProxy() { | 216 AudioPipelineProxy::~AudioPipelineProxy() { |
| 219 DCHECK(thread_checker_.CalledOnValidThread()); | 217 DCHECK(thread_checker_.CalledOnValidThread()); |
| 220 // Release the underlying object on the right thread. | 218 // Release the underlying object on the right thread. |
| 221 io_message_loop_proxy_->PostTask( | 219 io_task_runner_->PostTask( |
| 222 FROM_HERE, | 220 FROM_HERE, |
| 223 base::Bind(&AudioPipelineProxyInternal::Release, base::Passed(&proxy_))); | 221 base::Bind(&AudioPipelineProxyInternal::Release, base::Passed(&proxy_))); |
| 224 } | 222 } |
| 225 | 223 |
| 226 void AudioPipelineProxy::SetClient( | 224 void AudioPipelineProxy::SetClient( |
| 227 const AvPipelineClient& client) { | 225 const AvPipelineClient& client) { |
| 228 DCHECK(thread_checker_.CalledOnValidThread()); | 226 DCHECK(thread_checker_.CalledOnValidThread()); |
| 229 base::Closure pipe_read_cb = ::media::BindToCurrentLoop( | 227 base::Closure pipe_read_cb = ::media::BindToCurrentLoop( |
| 230 base::Bind(&AudioPipelineProxy::OnPipeRead, weak_this_)); | 228 base::Bind(&AudioPipelineProxy::OnPipeRead, weak_this_)); |
| 231 FORWARD_ON_IO_THREAD(SetClient, pipe_read_cb, client); | 229 FORWARD_ON_IO_THREAD(SetClient, pipe_read_cb, client); |
| (...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 302 } | 300 } |
| 303 | 301 |
| 304 void AudioPipelineProxy::OnPipeRead() { | 302 void AudioPipelineProxy::OnPipeRead() { |
| 305 DCHECK(thread_checker_.CalledOnValidThread()); | 303 DCHECK(thread_checker_.CalledOnValidThread()); |
| 306 if (audio_streamer_) | 304 if (audio_streamer_) |
| 307 audio_streamer_->OnFifoReadEvent(); | 305 audio_streamer_->OnFifoReadEvent(); |
| 308 } | 306 } |
| 309 | 307 |
| 310 } // namespace cma | 308 } // namespace cma |
| 311 } // namespace chromecast | 309 } // namespace chromecast |
| OLD | NEW |