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

Side by Side Diff: chromecast/media/cma/backend/media_pipeline_backend_manager.cc

Issue 2173593002: [Chromecast] Limit number of concurrent audio and video decoders (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 5 months 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 unified diff | Download patch
OLDNEW
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 } 19 audio_decoder_count_(0),
20 video_decoder_count_(0) {}
20 21
21 MediaPipelineBackendManager::~MediaPipelineBackendManager() { 22 MediaPipelineBackendManager::~MediaPipelineBackendManager() {
22 } 23 }
23 24
24 std::unique_ptr<MediaPipelineBackend> 25 std::unique_ptr<MediaPipelineBackend>
25 MediaPipelineBackendManager::CreateMediaPipelineBackend( 26 MediaPipelineBackendManager::CreateMediaPipelineBackend(
26 const media::MediaPipelineDeviceParams& params) { 27 const media::MediaPipelineDeviceParams& params) {
27 DCHECK(media_task_runner_->BelongsToCurrentThread()); 28 DCHECK(media_task_runner_->BelongsToCurrentThread());
28 return CreateMediaPipelineBackend(params, 0); 29 return CreateMediaPipelineBackend(params, 0);
29 } 30 }
30 31
31 std::unique_ptr<MediaPipelineBackend> 32 std::unique_ptr<MediaPipelineBackend>
32 MediaPipelineBackendManager::CreateMediaPipelineBackend( 33 MediaPipelineBackendManager::CreateMediaPipelineBackend(
33 const media::MediaPipelineDeviceParams& params, 34 const media::MediaPipelineDeviceParams& params,
34 int stream_type) { 35 int stream_type) {
35 DCHECK(media_task_runner_->BelongsToCurrentThread()); 36 DCHECK(media_task_runner_->BelongsToCurrentThread());
36 std::unique_ptr<MediaPipelineBackend> backend_ptr( 37 std::unique_ptr<MediaPipelineBackend> backend_ptr(
37 new MediaPipelineBackendWrapper( 38 new MediaPipelineBackendWrapper(
38 base::WrapUnique( 39 base::WrapUnique(
39 media::CastMediaShlib::CreateMediaPipelineBackend(params)), 40 media::CastMediaShlib::CreateMediaPipelineBackend(params)),
40 stream_type, GetVolumeMultiplier(stream_type), this)); 41 stream_type, GetVolumeMultiplier(stream_type), this));
41 media_pipeline_backends_.push_back(backend_ptr.get()); 42 media_pipeline_backends_[backend_ptr.get()] = BackendInfo();
42 return backend_ptr; 43 return backend_ptr;
43 } 44 }
44 45
46 bool MediaPipelineBackendManager::CanCreateAudioDecoder(
alokp 2016/07/22 04:59:46 The function name is a bit weird. In addition to r
halliwell 2016/07/22 16:34:50 Agreed :) I moved the count into the wrapper (act
47 MediaPipelineBackend* backend) {
48 DCHECK(media_task_runner_->BelongsToCurrentThread());
49
50 if (audio_decoder_count_ >= 2) {
51 LOG(WARNING) << "Unable to create AudioDecoder: global limit exceeded";
52 return false;
53 }
54
55 auto itr = media_pipeline_backends_.find(backend);
56 DCHECK(itr != media_pipeline_backends_.end());
57 itr->second.audio_decoder_count_++;
58 audio_decoder_count_++;
59
60 return true;
61 }
62
63 bool MediaPipelineBackendManager::CanCreateVideoDecoder(
64 MediaPipelineBackend* backend) {
65 DCHECK(media_task_runner_->BelongsToCurrentThread());
66
67 if (video_decoder_count_ >= 1) {
68 LOG(WARNING) << "Unable to create VideoDecoder: global limit exceeded";
69 return false;
70 }
71
72 auto itr = media_pipeline_backends_.find(backend);
73 DCHECK(itr != media_pipeline_backends_.end());
74 itr->second.video_decoder_count_++;
75 video_decoder_count_++;
76
77 return true;
78 }
79
45 void MediaPipelineBackendManager::OnMediaPipelineBackendDestroyed( 80 void MediaPipelineBackendManager::OnMediaPipelineBackendDestroyed(
46 const MediaPipelineBackend* backend) { 81 MediaPipelineBackend* backend) {
47 DCHECK(media_task_runner_->BelongsToCurrentThread()); 82 DCHECK(media_task_runner_->BelongsToCurrentThread());
48 media_pipeline_backends_.erase( 83
49 std::remove(media_pipeline_backends_.begin(), 84 auto itr = media_pipeline_backends_.find(backend);
50 media_pipeline_backends_.end(), backend), 85 DCHECK(itr != media_pipeline_backends_.end());
51 media_pipeline_backends_.end()); 86
87 audio_decoder_count_ -= itr->second.audio_decoder_count_;
88 video_decoder_count_ -= itr->second.video_decoder_count_;
89
90 media_pipeline_backends_.erase(itr);
52 } 91 }
53 92
54 void MediaPipelineBackendManager::SetVolumeMultiplier(int stream_type, 93 void MediaPipelineBackendManager::SetVolumeMultiplier(int stream_type,
55 float volume) { 94 float volume) {
56 DCHECK(media_task_runner_->BelongsToCurrentThread()); 95 DCHECK(media_task_runner_->BelongsToCurrentThread());
57 volume = std::max(0.0f, std::min(volume, 1.0f)); 96 volume = std::max(0.0f, std::min(volume, 1.0f));
58 volume_by_stream_type_[stream_type] = volume; 97 volume_by_stream_type_[stream_type] = volume;
59 98
60 // Set volume for each open media pipeline backends. 99 // Set volume for each open media pipeline backends.
61 for (auto it = media_pipeline_backends_.begin(); 100 for (auto it = media_pipeline_backends_.begin();
62 it != media_pipeline_backends_.end(); it++) { 101 it != media_pipeline_backends_.end(); it++) {
63 MediaPipelineBackendWrapper* wrapper = 102 MediaPipelineBackendWrapper* wrapper =
64 static_cast<MediaPipelineBackendWrapper*>(*it); 103 static_cast<MediaPipelineBackendWrapper*>(it->first);
65 if (wrapper->GetStreamType() == stream_type) 104 if (wrapper->GetStreamType() == stream_type)
66 wrapper->SetStreamTypeVolume(volume); 105 wrapper->SetStreamTypeVolume(volume);
67 } 106 }
68 } 107 }
69 108
70 float MediaPipelineBackendManager::GetVolumeMultiplier(int stream_type) { 109 float MediaPipelineBackendManager::GetVolumeMultiplier(int stream_type) {
71 DCHECK(media_task_runner_->BelongsToCurrentThread()); 110 DCHECK(media_task_runner_->BelongsToCurrentThread());
72 auto it = volume_by_stream_type_.find(stream_type); 111 auto it = volume_by_stream_type_.find(stream_type);
73 if (it == volume_by_stream_type_.end()) { 112 if (it == volume_by_stream_type_.end()) {
74 return 1.0; 113 return 1.0;
75 } else { 114 } else {
76 return it->second; 115 return it->second;
77 } 116 }
78 } 117 }
79 118
80 } // namespace media 119 } // namespace media
81 } // namespace chromecast 120 } // namespace chromecast
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698