1 /*
2  * Copyright (C) 2008-2011 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #ifndef ANDROID_AUDIOPARAMETER_H_
18 #define ANDROID_AUDIOPARAMETER_H_
19 
20 #include <utils/Errors.h>
21 #include <utils/KeyedVector.h>
22 #include <utils/String8.h>
23 
24 namespace android {
25 
26 class AudioParameter {
27 
28 public:
AudioParameter()29     AudioParameter() {}
30     AudioParameter(const String8& keyValuePairs);
31     virtual ~AudioParameter();
32 
33     // reserved parameter keys for changing standard parameters with setParameters() function.
34     // Using these keys is mandatory for AudioFlinger to properly monitor audio output/input
35     // configuration changes and act accordingly.
36     //  keyRouting: to change audio routing, value is an int in audio_devices_t
37     //  keySamplingRate: to change sampling rate routing, value is an int
38     //  keyFormat: to change audio format, value is an int in audio_format_t
39     //  keyChannels: to change audio channel configuration, value is an int in audio_channels_t
40     //  keyFrameCount: to change audio output frame count, value is an int
41     //  keyInputSource: to change audio input source, value is an int in audio_source_t
42     //     (defined in media/mediarecorder.h)
43     //  keyScreenState: either "on" or "off"
44     //  keyScreenRotation: one of: 0, 90, 180, 270
45     static const char * const keyRouting;
46     static const char * const keySamplingRate;
47     static const char * const keyFormat;
48     static const char * const keyChannels;
49     static const char * const keyFrameCount;
50     static const char * const keyInputSource;
51     static const char * const keyScreenState;
52     static const char * const keyScreenRotation;
53 
54     // keyClosing: "true" on AudioFlinger Thread preExit.  Used by A2DP HAL.
55     // keyExiting: "1" on AudioFlinger Thread preExit.  Used by remote_submix and A2DP HAL.
56     static const char * const keyClosing;
57     static const char * const keyExiting;
58 
59     //  keyBtSco: Whether BT SCO is 'on' or 'off'
60     //  keyBtScoHeadsetName: BT SCO headset name (for debugging)
61     //  keyBtNrec: BT SCO Noise Reduction + Echo Cancellation parameters
62     //  keyBtScoWb: BT SCO NR wideband mode
63     //  keyHfp...: Parameters of the Hands-Free Profile
64     static const char * const keyBtSco;
65     static const char * const keyBtScoHeadsetName;
66     static const char * const keyBtNrec;
67     static const char * const keyBtScoWb;
68     static const char * const keyBtHfpEnable;
69     static const char * const keyBtHfpSamplingRate;
70     static const char * const keyBtHfpVolume;
71 
72     static const char * const keyTtyMode;
73     static const char * const valueTtyModeOff;
74     static const char * const valueTtyModeFull;
75     static const char * const valueTtyModeHco;
76     static const char * const valueTtyModeVco;
77 
78     static const char * const keyHacSetting;
79     static const char * const valueHacOff;
80     static const char * const valueHacOn;
81 
82     //  keyHwAvSync: get HW synchronization source identifier from a device
83     //  keyMonoOutput: Enable mono audio playback
84     //  keyStreamHwAvSync: set HW synchronization source identifier on a stream
85     static const char * const keyHwAvSync;
86     static const char * const keyMonoOutput;
87     static const char * const keyStreamHwAvSync;
88 
89     //  keys for presentation selection
90     //  keyPresentationId: Audio presentation identifier
91     //  keyProgramId: Audio presentation program identifier
92     static const char * const keyPresentationId;
93     static const char * const keyProgramId;
94 
95     //  keyAudioLanguagePreferred: Preferred audio language
96     static const char * const keyAudioLanguagePreferred;
97 
98     //  keyDeviceConnect / Disconnect: value is an int in audio_devices_t
99     static const char * const keyDeviceConnect;
100     static const char * const keyDeviceDisconnect;
101     //  Need to be here because vendors still use them.
102     static const char * const keyStreamConnect;  // Deprecated: DO NOT USE.
103     static const char * const keyStreamDisconnect;  // Deprecated: DO NOT USE.
104 
105     // For querying stream capabilities. All the returned values are lists.
106     //   keyStreamSupportedFormats: audio_format_t
107     //   keyStreamSupportedChannels: audio_channel_mask_t
108     //   keyStreamSupportedSamplingRates: sampling rate values
109     static const char * const keyStreamSupportedFormats;
110     static const char * const keyStreamSupportedChannels;
111     static const char * const keyStreamSupportedSamplingRates;
112 
113     static const char * const valueOn;
114     static const char * const valueOff;
115     static const char * const valueTrue;
116     static const char * const valueFalse;
117 
118     static const char * const valueListSeparator;
119 
120     // keyBtA2dpSuspended: 'true' or 'false'
121     // keyReconfigA2dp: Ask HwModule to reconfigure A2DP offloaded codec
122     // keyReconfigA2dpSupported: Query if HwModule supports A2DP offload codec config
123     // keyBtLeSuspended: 'true' or 'false'
124     // keyReconfigLe: Ask HwModule to reconfigure LE offloaded codec
125     // keyReconfigLeSupported: Query if HwModule supports LE offload codec config
126     static const char * const keyBtA2dpSuspended;
127     static const char * const keyReconfigA2dp;
128     static const char * const keyReconfigA2dpSupported;
129     static const char * const keyBtLeSuspended;
130     static const char * const keyReconfigLe;
131     static const char * const keyReconfigLeSupported;
132 
133     // For querying device supported encapsulation capabilities. All returned values are integer,
134     // which are bit fields composed from using encapsulation capability values as position bits.
135     // Encapsulation capability values are defined in audio_encapsulation_mode_t and
136     // audio_encapsulation_metadata_type_t. For instance, if the supported encapsulation mode is
137     // AUDIO_ENCAPSULATION_MODE_ELEMENTARY_STREAM, the returned value is
138     // "supEncapsulationModes=1 << AUDIO_ENCAPSULATION_MODE_HANDLE".
139     // When querying device supported encapsulation capabilities, the key should use with device
140     // type and address so that it is able to identify the device. The device will be a key. The
141     // device type will be the value of key AUDIO_PARAMETER_STREAM_ROUTING.
142     // static const char * const keyDeviceSupportedEncapsulationModes;
143     // static const char * const keyDeviceSupportedEncapsulationMetadataTypes;
144 
145     static const char * const keyAdditionalOutputDeviceDelay;
146     static const char * const keyMaxAdditionalOutputDeviceDelay;
147 
148     static const char * const keyOffloadCodecAverageBitRate;
149     static const char * const keyOffloadCodecSampleRate;
150     static const char * const keyOffloadCodecChannels;
151     static const char * const keyOffloadCodecDelaySamples;
152     static const char * const keyOffloadCodecPaddingSamples;
153 
toString()154     String8 toString() const { return toStringImpl(true); }
keysToString()155     String8 keysToString() const { return toStringImpl(false); }
156 
157     status_t add(const String8& key, const String8& value);
158     status_t addInt(const String8& key, const int value);
159     status_t addKey(const String8& key);
160     status_t addFloat(const String8& key, const float value);
161 
162     status_t remove(const String8& key);
163 
get(const String8 & key,int & value)164     status_t get(const String8& key, int& value) const {
165         return getInt(key, value);
166     }
get(const String8 & key,float & value)167     status_t get(const String8& key, float& value) const {
168         return getFloat(key, value);
169     }
170     status_t get(const String8& key, String8& value) const;
171     status_t getInt(const String8& key, int& value) const;
172     status_t getFloat(const String8& key, float& value) const;
173     status_t getAt(size_t index, String8& key) const;
174     status_t getAt(size_t index, String8& key, String8& value) const;
175 
size()176     size_t size() const { return mParameters.size(); }
177 
178     bool containsKey(const String8& key) const;
179 private:
180     String8 mKeyValuePairs;
181     KeyedVector <String8, String8> mParameters;
182 
183     String8 toStringImpl(bool useValues) const;
184 };
185 
186 };  // namespace android
187 
188 #endif  /*ANDROID_AUDIOPARAMETER_H_*/
189