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 |