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

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: use enum for decoder type 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 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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698