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

Side by Side Diff: media/base/audio_hardware_config.h

Issue 12662038: Revert 187936 "Pass more detailed audio hardware configuration i..." (Closed) Base URL: svn://svn.chromium.org/chrome/branches/1440/src/
Patch Set: Created 7 years, 9 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 | Annotate | Revision Log
« no previous file with comments | « media/base/audio_converter.cc ('k') | media/base/audio_hardware_config.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 (c) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2013 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 MEDIA_BASE_AUDIO_HARDWARE_CONFIG_H_ 5 #ifndef MEDIA_BASE_AUDIO_HARDWARE_CONFIG_H_
6 #define MEDIA_BASE_AUDIO_HARDWARE_CONFIG_H_ 6 #define MEDIA_BASE_AUDIO_HARDWARE_CONFIG_H_
7 7
8 #include "base/compiler_specific.h" 8 #include "base/compiler_specific.h"
9 #include "base/synchronization/lock.h" 9 #include "base/synchronization/lock.h"
10 #include "media/audio/audio_parameters.h"
11 #include "media/base/channel_layout.h" 10 #include "media/base/channel_layout.h"
12 #include "media/base/media_export.h" 11 #include "media/base/media_export.h"
13 12
14 namespace media { 13 namespace media {
15 14
16 // Provides thread safe access to the audio hardware configuration. 15 // Provides thread safe access to the audio hardware configuration.
17 class MEDIA_EXPORT AudioHardwareConfig { 16 class MEDIA_EXPORT AudioHardwareConfig {
18 public: 17 public:
19 AudioHardwareConfig(const media::AudioParameters& input_params, 18 AudioHardwareConfig(int output_buffer_size, int output_sample_rate,
20 const media::AudioParameters& output_params); 19 int input_sample_rate,
20 ChannelLayout input_channel_layout);
21 virtual ~AudioHardwareConfig(); 21 virtual ~AudioHardwareConfig();
22 22
23 // Accessors for the currently cached hardware configuration. Safe to call 23 // Accessors for the currently cached hardware configuration. Safe to call
24 // from any thread. 24 // from any thread.
25 int GetOutputBufferSize() const; 25 int GetOutputBufferSize();
26 int GetOutputSampleRate() const; 26 int GetOutputSampleRate();
27 ChannelLayout GetOutputChannelLayout() const; 27 int GetInputSampleRate();
28 int GetOutputChannels() const; 28 ChannelLayout GetInputChannelLayout();
29
30 int GetInputSampleRate() const;
31 ChannelLayout GetInputChannelLayout() const;
32 int GetInputChannels() const;
33
34 media::AudioParameters GetInputConfig() const;
35 media::AudioParameters GetOutputConfig() const;
36 29
37 // Allows callers to update the cached values for either input or output. The 30 // Allows callers to update the cached values for either input or output. The
38 // values are paired under the assumption that these values will only be set 31 // values are paired under the assumption that these values will only be set
39 // after an input or output device change respectively. Safe to call from 32 // after an input or output device change respectively. Safe to call from
40 // any thread. 33 // any thread.
41 void UpdateInputConfig(const media::AudioParameters& input_params); 34 void UpdateInputConfig(int sample_rate, media::ChannelLayout channel_layout);
42 void UpdateOutputConfig(const media::AudioParameters& output_params); 35 void UpdateOutputConfig(int buffer_size, int sample_rate);
43 36
44 private: 37 private:
45 // Cached values; access is protected by |config_lock_|. 38 // Cached values; access is protected by |config_lock_|.
46 mutable base::Lock config_lock_; 39 base::Lock config_lock_;
47 media::AudioParameters input_params_; 40 int output_buffer_size_;
48 media::AudioParameters output_params_; 41 int output_sample_rate_;
42 int input_sample_rate_;
43 ChannelLayout input_channel_layout_;
49 44
50 DISALLOW_COPY_AND_ASSIGN(AudioHardwareConfig); 45 DISALLOW_COPY_AND_ASSIGN(AudioHardwareConfig);
51 }; 46 };
52 47
53 } // namespace media 48 } // namespace media
54 49
55 #endif // MEDIA_BASE_AUDIO_HARDWARE_CONFIG_H_ 50 #endif // MEDIA_BASE_AUDIO_HARDWARE_CONFIG_H_
OLDNEW
« no previous file with comments | « media/base/audio_converter.cc ('k') | media/base/audio_hardware_config.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698