| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/media/cma/backend/media_pipeline_backend_manager.h" | 5 #include "chromecast/media/cma/backend/media_pipeline_backend_manager.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/memory/ptr_util.h" | 9 #include "base/memory/ptr_util.h" |
| 10 #include "chromecast/media/cma/backend/media_pipeline_backend_wrapper.h" | 10 #include "chromecast/media/cma/backend/media_pipeline_backend_wrapper.h" |
| 11 #include "chromecast/public/cast_media_shlib.h" | 11 #include "chromecast/public/cast_media_shlib.h" |
| 12 | 12 |
| 13 namespace chromecast { | 13 namespace chromecast { |
| 14 namespace media { | 14 namespace media { |
| 15 | 15 |
| 16 MediaPipelineBackendManager::MediaPipelineBackendManager( | 16 MediaPipelineBackendManager::MediaPipelineBackendManager( |
| 17 scoped_refptr<base::SingleThreadTaskRunner> media_task_runner) | 17 scoped_refptr<base::SingleThreadTaskRunner> media_task_runner) |
| 18 : media_task_runner_(std::move(media_task_runner)) { | 18 : media_task_runner_(std::move(media_task_runner)) { |
| 19 DCHECK_EQ(2, NUM_DECODER_TYPES); |
| 20 decoder_count_[AUDIO_DECODER] = 0; |
| 21 decoder_count_[VIDEO_DECODER] = 0; |
| 19 } | 22 } |
| 20 | 23 |
| 21 MediaPipelineBackendManager::~MediaPipelineBackendManager() { | 24 MediaPipelineBackendManager::~MediaPipelineBackendManager() { |
| 22 } | 25 } |
| 23 | 26 |
| 24 std::unique_ptr<MediaPipelineBackend> | 27 std::unique_ptr<MediaPipelineBackend> |
| 25 MediaPipelineBackendManager::CreateMediaPipelineBackend( | 28 MediaPipelineBackendManager::CreateMediaPipelineBackend( |
| 26 const media::MediaPipelineDeviceParams& params) { | 29 const media::MediaPipelineDeviceParams& params) { |
| 27 DCHECK(media_task_runner_->BelongsToCurrentThread()); | 30 DCHECK(media_task_runner_->BelongsToCurrentThread()); |
| 28 return CreateMediaPipelineBackend(params, 0); | 31 return CreateMediaPipelineBackend(params, 0); |
| 29 } | 32 } |
| 30 | 33 |
| 31 std::unique_ptr<MediaPipelineBackend> | 34 std::unique_ptr<MediaPipelineBackend> |
| 32 MediaPipelineBackendManager::CreateMediaPipelineBackend( | 35 MediaPipelineBackendManager::CreateMediaPipelineBackend( |
| 33 const media::MediaPipelineDeviceParams& params, | 36 const media::MediaPipelineDeviceParams& params, |
| 34 int stream_type) { | 37 int stream_type) { |
| 35 DCHECK(media_task_runner_->BelongsToCurrentThread()); | 38 DCHECK(media_task_runner_->BelongsToCurrentThread()); |
| 36 std::unique_ptr<MediaPipelineBackend> backend_ptr( | 39 std::unique_ptr<MediaPipelineBackend> backend_ptr( |
| 37 new MediaPipelineBackendWrapper( | 40 new MediaPipelineBackendWrapper( |
| 38 base::WrapUnique( | 41 base::WrapUnique( |
| 39 media::CastMediaShlib::CreateMediaPipelineBackend(params)), | 42 media::CastMediaShlib::CreateMediaPipelineBackend(params)), |
| 40 stream_type, GetVolumeMultiplier(stream_type), this)); | 43 stream_type, GetVolumeMultiplier(stream_type), this)); |
| 41 media_pipeline_backends_.push_back(backend_ptr.get()); | 44 media_pipeline_backends_.push_back(backend_ptr.get()); |
| 42 return backend_ptr; | 45 return backend_ptr; |
| 43 } | 46 } |
| 44 | 47 |
| 48 bool MediaPipelineBackendManager::IncrementDecoderCount(DecoderType type) { |
| 49 DCHECK(media_task_runner_->BelongsToCurrentThread()); |
| 50 DCHECK(type < NUM_DECODER_TYPES); |
| 51 const int limit = (type == AUDIO_DECODER) ? 2 : 1; |
| 52 if (decoder_count_[type] >= limit) { |
| 53 LOG(WARNING) << "Decoder limit reached for type " << type; |
| 54 return false; |
| 55 } |
| 56 |
| 57 ++decoder_count_[type]; |
| 58 return true; |
| 59 } |
| 60 |
| 61 void MediaPipelineBackendManager::DecrementDecoderCount(DecoderType type) { |
| 62 DCHECK(media_task_runner_->BelongsToCurrentThread()); |
| 63 DCHECK(type < NUM_DECODER_TYPES); |
| 64 DCHECK(decoder_count_[type] > 0); |
| 65 decoder_count_[type]--; |
| 66 } |
| 67 |
| 45 void MediaPipelineBackendManager::OnMediaPipelineBackendDestroyed( | 68 void MediaPipelineBackendManager::OnMediaPipelineBackendDestroyed( |
| 46 const MediaPipelineBackend* backend) { | 69 const MediaPipelineBackend* backend) { |
| 47 DCHECK(media_task_runner_->BelongsToCurrentThread()); | 70 DCHECK(media_task_runner_->BelongsToCurrentThread()); |
| 48 media_pipeline_backends_.erase( | 71 media_pipeline_backends_.erase( |
| 49 std::remove(media_pipeline_backends_.begin(), | 72 std::remove(media_pipeline_backends_.begin(), |
| 50 media_pipeline_backends_.end(), backend), | 73 media_pipeline_backends_.end(), backend), |
| 51 media_pipeline_backends_.end()); | 74 media_pipeline_backends_.end()); |
| 52 } | 75 } |
| 53 | 76 |
| 54 void MediaPipelineBackendManager::SetVolumeMultiplier(int stream_type, | 77 void MediaPipelineBackendManager::SetVolumeMultiplier(int stream_type, |
| (...skipping 17 matching lines...) Expand all Loading... |
| 72 auto it = volume_by_stream_type_.find(stream_type); | 95 auto it = volume_by_stream_type_.find(stream_type); |
| 73 if (it == volume_by_stream_type_.end()) { | 96 if (it == volume_by_stream_type_.end()) { |
| 74 return 1.0; | 97 return 1.0; |
| 75 } else { | 98 } else { |
| 76 return it->second; | 99 return it->second; |
| 77 } | 100 } |
| 78 } | 101 } |
| 79 | 102 |
| 80 } // namespace media | 103 } // namespace media |
| 81 } // namespace chromecast | 104 } // namespace chromecast |
| OLD | NEW |