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

Side by Side Diff: chromecast/media/audio/cast_audio_manager.h

Issue 2879703003: [chromecast] Moves CastAudioOutputStream::Backend to CMA thread. (Closed)
Patch Set: addressed comments Created 3 years, 6 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
« no previous file with comments | « chromecast/media/BUILD.gn ('k') | chromecast/media/audio/cast_audio_manager.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 #ifndef CHROMECAST_MEDIA_AUDIO_CAST_AUDIO_MANAGER_H_ 5 #ifndef CHROMECAST_MEDIA_AUDIO_CAST_AUDIO_MANAGER_H_
6 #define CHROMECAST_MEDIA_AUDIO_CAST_AUDIO_MANAGER_H_ 6 #define CHROMECAST_MEDIA_AUDIO_CAST_AUDIO_MANAGER_H_
7 7
8 #include "base/macros.h" 8 #include "base/macros.h"
9 #include "media/audio/audio_manager_base.h" 9 #include "media/audio/audio_manager_base.h"
10 10
11 namespace chromecast { 11 namespace chromecast {
12 12
13 namespace media { 13 namespace media {
14 14
15 class CastAudioMixer; 15 class CastAudioMixer;
16 class MediaPipelineBackend; 16 class MediaPipelineBackendFactory;
17 class MediaPipelineBackendManager;
18 struct MediaPipelineDeviceParams;
19 17
20 class CastAudioManager : public ::media::AudioManagerBase { 18 class CastAudioManager : public ::media::AudioManagerBase {
21 public: 19 public:
22 CastAudioManager(std::unique_ptr<::media::AudioThread> audio_thread, 20 CastAudioManager(
23 ::media::AudioLogFactory* audio_log_factory, 21 std::unique_ptr<::media::AudioThread> audio_thread,
24 MediaPipelineBackendManager* backend_manager); 22 ::media::AudioLogFactory* audio_log_factory,
25 CastAudioManager(std::unique_ptr<::media::AudioThread> audio_thread, 23 std::unique_ptr<MediaPipelineBackendFactory> backend_factory,
26 ::media::AudioLogFactory* audio_log_factory, 24 scoped_refptr<base::SingleThreadTaskRunner> backend_task_runner,
27 MediaPipelineBackendManager* backend_manager, 25 bool use_mixer);
28 CastAudioMixer* audio_mixer);
29 ~CastAudioManager() override; 26 ~CastAudioManager() override;
30 27
31 // AudioManager implementation. 28 // AudioManagerBase implementation.
32 bool HasAudioOutputDevices() override; 29 bool HasAudioOutputDevices() override;
33 bool HasAudioInputDevices() override; 30 bool HasAudioInputDevices() override;
34 void ShowAudioInputSettings() override; 31 void ShowAudioInputSettings() override;
35 void GetAudioInputDeviceNames( 32 void GetAudioInputDeviceNames(
36 ::media::AudioDeviceNames* device_names) override; 33 ::media::AudioDeviceNames* device_names) override;
37 ::media::AudioParameters GetInputStreamParameters( 34 ::media::AudioParameters GetInputStreamParameters(
38 const std::string& device_id) override; 35 const std::string& device_id) override;
39 const char* GetName() override; 36 const char* GetName() override;
40
41 // AudioManagerBase implementation
42 void ReleaseOutputStream(::media::AudioOutputStream* stream) override; 37 void ReleaseOutputStream(::media::AudioOutputStream* stream) override;
43 38
44 // This must be called on audio thread. 39 MediaPipelineBackendFactory* backend_factory() {
45 virtual std::unique_ptr<MediaPipelineBackend> CreateMediaPipelineBackend( 40 return backend_factory_.get();
46 const MediaPipelineDeviceParams& params); 41 }
42 base::SingleThreadTaskRunner* backend_task_runner() {
43 return backend_task_runner_.get();
44 }
47 45
48 private: 46 protected:
49 // AudioManagerBase implementation. 47 // AudioManagerBase implementation.
50 ::media::AudioOutputStream* MakeLinearOutputStream( 48 ::media::AudioOutputStream* MakeLinearOutputStream(
51 const ::media::AudioParameters& params, 49 const ::media::AudioParameters& params,
52 const ::media::AudioManager::LogCallback& log_callback) override; 50 const ::media::AudioManager::LogCallback& log_callback) override;
53 ::media::AudioOutputStream* MakeLowLatencyOutputStream( 51 ::media::AudioOutputStream* MakeLowLatencyOutputStream(
54 const ::media::AudioParameters& params, 52 const ::media::AudioParameters& params,
55 const std::string& device_id, 53 const std::string& device_id,
56 const ::media::AudioManager::LogCallback& log_callback) override; 54 const ::media::AudioManager::LogCallback& log_callback) override;
57 ::media::AudioInputStream* MakeLinearInputStream( 55 ::media::AudioInputStream* MakeLinearInputStream(
58 const ::media::AudioParameters& params, 56 const ::media::AudioParameters& params,
59 const std::string& device_id, 57 const std::string& device_id,
60 const ::media::AudioManager::LogCallback& log_callback) override; 58 const ::media::AudioManager::LogCallback& log_callback) override;
61 ::media::AudioInputStream* MakeLowLatencyInputStream( 59 ::media::AudioInputStream* MakeLowLatencyInputStream(
62 const ::media::AudioParameters& params, 60 const ::media::AudioParameters& params,
63 const std::string& device_id, 61 const std::string& device_id,
64 const ::media::AudioManager::LogCallback& log_callback) override; 62 const ::media::AudioManager::LogCallback& log_callback) override;
65 ::media::AudioParameters GetPreferredOutputStreamParameters( 63 ::media::AudioParameters GetPreferredOutputStreamParameters(
66 const std::string& output_device_id, 64 const std::string& output_device_id,
67 const ::media::AudioParameters& input_params) override; 65 const ::media::AudioParameters& input_params) override;
68 66
69 // Generates a CastAudioOutputStream for |mixer_|. 67 // Generates a CastAudioOutputStream for |mixer_|.
70 ::media::AudioOutputStream* MakeMixerOutputStream( 68 virtual ::media::AudioOutputStream* MakeMixerOutputStream(
71 const ::media::AudioParameters& params); 69 const ::media::AudioParameters& params);
72 70
73 MediaPipelineBackendManager* const backend_manager_; 71 private:
72 friend class CastAudioMixer;
73
74 std::unique_ptr<MediaPipelineBackendFactory> backend_factory_;
75 scoped_refptr<base::SingleThreadTaskRunner> backend_task_runner_;
74 std::unique_ptr<::media::AudioOutputStream> mixer_output_stream_; 76 std::unique_ptr<::media::AudioOutputStream> mixer_output_stream_;
75 std::unique_ptr<CastAudioMixer> mixer_; 77 std::unique_ptr<CastAudioMixer> mixer_;
76
77 DISALLOW_COPY_AND_ASSIGN(CastAudioManager); 78 DISALLOW_COPY_AND_ASSIGN(CastAudioManager);
78 }; 79 };
79 80
80 } // namespace media 81 } // namespace media
81 } // namespace chromecast 82 } // namespace chromecast
82 83
83 #endif // CHROMECAST_MEDIA_AUDIO_CAST_AUDIO_MANAGER_H_ 84 #endif // CHROMECAST_MEDIA_AUDIO_CAST_AUDIO_MANAGER_H_
OLDNEW
« no previous file with comments | « chromecast/media/BUILD.gn ('k') | chromecast/media/audio/cast_audio_manager.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698