blob: adf1b339ad02fe78948842919863dcf2a584a489 [file] [log] [blame]
Eric Laurente552edb2014-03-10 17:42:56 -07001/*
2 * Copyright (C) 2009 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
18#include <stdint.h>
19#include <sys/types.h>
20#include <cutils/config_utils.h>
21#include <cutils/misc.h>
22#include <utils/Timers.h>
23#include <utils/Errors.h>
24#include <utils/KeyedVector.h>
25#include <utils/SortedVector.h>
Eric Laurent3b73df72014-03-11 09:06:29 -070026#include "AudioPolicyInterface.h"
Eric Laurente552edb2014-03-10 17:42:56 -070027
28
Eric Laurent3b73df72014-03-11 09:06:29 -070029namespace android {
Eric Laurente552edb2014-03-10 17:42:56 -070030
31// ----------------------------------------------------------------------------
32
Eric Laurente552edb2014-03-10 17:42:56 -070033// Attenuation applied to STRATEGY_SONIFICATION streams when a headset is connected: 6dB
34#define SONIFICATION_HEADSET_VOLUME_FACTOR 0.5
35// Min volume for STRATEGY_SONIFICATION streams when limited by music volume: -36dB
36#define SONIFICATION_HEADSET_VOLUME_MIN 0.016
37// Time in milliseconds during which we consider that music is still active after a music
38// track was stopped - see computeVolume()
39#define SONIFICATION_HEADSET_MUSIC_DELAY 5000
40// Time in milliseconds after media stopped playing during which we consider that the
41// sonification should be as unobtrusive as during the time media was playing.
42#define SONIFICATION_RESPECTFUL_AFTER_MUSIC_DELAY 5000
43// Time in milliseconds during witch some streams are muted while the audio path
44// is switched
45#define MUTE_TIME_MS 2000
46
47#define NUM_TEST_OUTPUTS 5
48
49#define NUM_VOL_CURVE_KNEES 2
50
51// Default minimum length allowed for offloading a compressed track
52// Can be overridden by the audio.offload.min.duration.secs property
53#define OFFLOAD_DEFAULT_MIN_DURATION_SECS 60
54
55// ----------------------------------------------------------------------------
Eric Laurente0720872014-03-11 09:30:41 -070056// AudioPolicyManager implements audio policy manager behavior common to all platforms.
Eric Laurente552edb2014-03-10 17:42:56 -070057// ----------------------------------------------------------------------------
58
Eric Laurente0720872014-03-11 09:30:41 -070059class AudioPolicyManager: public AudioPolicyInterface
Eric Laurente552edb2014-03-10 17:42:56 -070060#ifdef AUDIO_POLICY_TEST
61 , public Thread
62#endif //AUDIO_POLICY_TEST
63{
64
65public:
Eric Laurente0720872014-03-11 09:30:41 -070066 AudioPolicyManager(AudioPolicyClientInterface *clientInterface);
67 virtual ~AudioPolicyManager();
Eric Laurente552edb2014-03-10 17:42:56 -070068
69 // AudioPolicyInterface
70 virtual status_t setDeviceConnectionState(audio_devices_t device,
Eric Laurent3b73df72014-03-11 09:06:29 -070071 audio_policy_dev_state_t state,
Eric Laurente552edb2014-03-10 17:42:56 -070072 const char *device_address);
Eric Laurent3b73df72014-03-11 09:06:29 -070073 virtual audio_policy_dev_state_t getDeviceConnectionState(audio_devices_t device,
Eric Laurente552edb2014-03-10 17:42:56 -070074 const char *device_address);
Eric Laurent3b73df72014-03-11 09:06:29 -070075 virtual void setPhoneState(audio_mode_t state);
76 virtual void setForceUse(audio_policy_force_use_t usage,
77 audio_policy_forced_cfg_t config);
78 virtual audio_policy_forced_cfg_t getForceUse(audio_policy_force_use_t usage);
Eric Laurente552edb2014-03-10 17:42:56 -070079 virtual void setSystemProperty(const char* property, const char* value);
80 virtual status_t initCheck();
Eric Laurent3b73df72014-03-11 09:06:29 -070081 virtual audio_io_handle_t getOutput(audio_stream_type_t stream,
Eric Laurente552edb2014-03-10 17:42:56 -070082 uint32_t samplingRate,
83 audio_format_t format,
84 audio_channel_mask_t channelMask,
Eric Laurent3b73df72014-03-11 09:06:29 -070085 audio_output_flags_t flags,
Eric Laurente552edb2014-03-10 17:42:56 -070086 const audio_offload_info_t *offloadInfo);
87 virtual status_t startOutput(audio_io_handle_t output,
Eric Laurent3b73df72014-03-11 09:06:29 -070088 audio_stream_type_t stream,
Eric Laurente552edb2014-03-10 17:42:56 -070089 int session = 0);
90 virtual status_t stopOutput(audio_io_handle_t output,
Eric Laurent3b73df72014-03-11 09:06:29 -070091 audio_stream_type_t stream,
Eric Laurente552edb2014-03-10 17:42:56 -070092 int session = 0);
93 virtual void releaseOutput(audio_io_handle_t output);
Eric Laurent3b73df72014-03-11 09:06:29 -070094 virtual audio_io_handle_t getInput(audio_source_t inputSource,
Eric Laurente552edb2014-03-10 17:42:56 -070095 uint32_t samplingRate,
96 audio_format_t format,
97 audio_channel_mask_t channelMask,
Eric Laurent3b73df72014-03-11 09:06:29 -070098 audio_in_acoustics_t acoustics);
Eric Laurente552edb2014-03-10 17:42:56 -070099
100 // indicates to the audio policy manager that the input starts being used.
101 virtual status_t startInput(audio_io_handle_t input);
102
103 // indicates to the audio policy manager that the input stops being used.
104 virtual status_t stopInput(audio_io_handle_t input);
105 virtual void releaseInput(audio_io_handle_t input);
Eric Laurentd4692962014-05-05 18:13:44 -0700106 virtual void closeAllInputs();
Eric Laurent3b73df72014-03-11 09:06:29 -0700107 virtual void initStreamVolume(audio_stream_type_t stream,
Eric Laurente552edb2014-03-10 17:42:56 -0700108 int indexMin,
109 int indexMax);
Eric Laurent3b73df72014-03-11 09:06:29 -0700110 virtual status_t setStreamVolumeIndex(audio_stream_type_t stream,
Eric Laurente552edb2014-03-10 17:42:56 -0700111 int index,
112 audio_devices_t device);
Eric Laurent3b73df72014-03-11 09:06:29 -0700113 virtual status_t getStreamVolumeIndex(audio_stream_type_t stream,
Eric Laurente552edb2014-03-10 17:42:56 -0700114 int *index,
115 audio_devices_t device);
116
117 // return the strategy corresponding to a given stream type
Eric Laurent3b73df72014-03-11 09:06:29 -0700118 virtual uint32_t getStrategyForStream(audio_stream_type_t stream);
Eric Laurente552edb2014-03-10 17:42:56 -0700119
120 // return the enabled output devices for the given stream type
Eric Laurent3b73df72014-03-11 09:06:29 -0700121 virtual audio_devices_t getDevicesForStream(audio_stream_type_t stream);
Eric Laurente552edb2014-03-10 17:42:56 -0700122
123 virtual audio_io_handle_t getOutputForEffect(const effect_descriptor_t *desc = NULL);
124 virtual status_t registerEffect(const effect_descriptor_t *desc,
125 audio_io_handle_t io,
126 uint32_t strategy,
127 int session,
128 int id);
129 virtual status_t unregisterEffect(int id);
130 virtual status_t setEffectEnabled(int id, bool enabled);
131
Eric Laurent3b73df72014-03-11 09:06:29 -0700132 virtual bool isStreamActive(audio_stream_type_t stream, uint32_t inPastMs = 0) const;
Eric Laurente552edb2014-03-10 17:42:56 -0700133 // return whether a stream is playing remotely, override to change the definition of
134 // local/remote playback, used for instance by notification manager to not make
135 // media players lose audio focus when not playing locally
Eric Laurent3b73df72014-03-11 09:06:29 -0700136 virtual bool isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs = 0) const;
Eric Laurente552edb2014-03-10 17:42:56 -0700137 virtual bool isSourceActive(audio_source_t source) const;
138
139 virtual status_t dump(int fd);
140
141 virtual bool isOffloadSupported(const audio_offload_info_t& offloadInfo);
142
Eric Laurent6a94d692014-05-20 11:18:06 -0700143 virtual status_t listAudioPorts(audio_port_role_t role,
144 audio_port_type_t type,
145 unsigned int *num_ports,
146 struct audio_port *ports,
147 unsigned int *generation);
148 virtual status_t getAudioPort(struct audio_port *port);
149 virtual status_t createAudioPatch(const struct audio_patch *patch,
150 audio_patch_handle_t *handle,
151 uid_t uid);
152 virtual status_t releaseAudioPatch(audio_patch_handle_t handle,
153 uid_t uid);
154 virtual status_t listAudioPatches(unsigned int *num_patches,
155 struct audio_patch *patches,
156 unsigned int *generation);
157 virtual status_t setAudioPortConfig(const struct audio_port_config *config);
158 virtual void clearAudioPatches(uid_t uid);
159
Eric Laurente552edb2014-03-10 17:42:56 -0700160protected:
161
162 enum routing_strategy {
163 STRATEGY_MEDIA,
164 STRATEGY_PHONE,
165 STRATEGY_SONIFICATION,
166 STRATEGY_SONIFICATION_RESPECTFUL,
167 STRATEGY_DTMF,
168 STRATEGY_ENFORCED_AUDIBLE,
169 NUM_STRATEGIES
170 };
171
172 // 4 points to define the volume attenuation curve, each characterized by the volume
173 // index (from 0 to 100) at which they apply, and the attenuation in dB at that index.
174 // we use 100 steps to avoid rounding errors when computing the volume in volIndexToAmpl()
175
176 enum { VOLMIN = 0, VOLKNEE1 = 1, VOLKNEE2 = 2, VOLMAX = 3, VOLCNT = 4};
177
178 class VolumeCurvePoint
179 {
180 public:
181 int mIndex;
182 float mDBAttenuation;
183 };
184
185 // device categories used for volume curve management.
186 enum device_category {
187 DEVICE_CATEGORY_HEADSET,
188 DEVICE_CATEGORY_SPEAKER,
189 DEVICE_CATEGORY_EARPIECE,
190 DEVICE_CATEGORY_CNT
191 };
192
Eric Laurent1afeecb2014-05-14 08:52:28 -0700193 class HwModule;
Eric Laurente552edb2014-03-10 17:42:56 -0700194
Eric Laurent1afeecb2014-05-14 08:52:28 -0700195 class AudioGain: public RefBase
196 {
Eric Laurente552edb2014-03-10 17:42:56 -0700197 public:
Eric Laurenta121f902014-06-03 13:32:54 -0700198 AudioGain(int index, bool useInChannelMask);
Eric Laurent1afeecb2014-05-14 08:52:28 -0700199 virtual ~AudioGain() {}
Eric Laurente552edb2014-03-10 17:42:56 -0700200
Eric Laurent1afeecb2014-05-14 08:52:28 -0700201 void dump(int fd, int spaces, int index) const;
Eric Laurente552edb2014-03-10 17:42:56 -0700202
Eric Laurenta121f902014-06-03 13:32:54 -0700203 void getDefaultConfig(struct audio_gain_config *config);
204 status_t checkConfig(const struct audio_gain_config *config);
205 int mIndex;
Eric Laurent1afeecb2014-05-14 08:52:28 -0700206 struct audio_gain mGain;
Eric Laurenta121f902014-06-03 13:32:54 -0700207 bool mUseInChannelMask;
Eric Laurent951f4552014-05-20 10:48:17 -0700208 };
209
Eric Laurent1f2f2232014-06-02 12:01:23 -0700210 class AudioPort: public virtual RefBase
Eric Laurent951f4552014-05-20 10:48:17 -0700211 {
212 public:
Eric Laurent1afeecb2014-05-14 08:52:28 -0700213 AudioPort(const String8& name, audio_port_type_t type,
Eric Laurenta121f902014-06-03 13:32:54 -0700214 audio_port_role_t role, const sp<HwModule>& module);
Eric Laurent951f4552014-05-20 10:48:17 -0700215 virtual ~AudioPort() {}
216
217 virtual void toAudioPort(struct audio_port *port) const;
218
219 void loadSamplingRates(char *name);
220 void loadFormats(char *name);
221 void loadOutChannels(char *name);
222 void loadInChannels(char *name);
223
Eric Laurent1afeecb2014-05-14 08:52:28 -0700224 audio_gain_mode_t loadGainMode(char *name);
Eric Laurenta121f902014-06-03 13:32:54 -0700225 void loadGain(cnode *root, int index);
Eric Laurent1afeecb2014-05-14 08:52:28 -0700226 void loadGains(cnode *root);
227
Eric Laurenta121f902014-06-03 13:32:54 -0700228 status_t checkSamplingRate(uint32_t samplingRate) const;
229 status_t checkChannelMask(audio_channel_mask_t channelMask) const;
230 status_t checkFormat(audio_format_t format) const;
231 status_t checkGain(const struct audio_gain_config *gainConfig, int index) const;
232
Eric Laurent1afeecb2014-05-14 08:52:28 -0700233 void dump(int fd, int spaces) const;
234
235 String8 mName;
236 audio_port_type_t mType;
237 audio_port_role_t mRole;
Eric Laurenta121f902014-06-03 13:32:54 -0700238 bool mUseInChannelMask;
Eric Laurent951f4552014-05-20 10:48:17 -0700239 // by convention, "0' in the first entry in mSamplingRates, mChannelMasks or mFormats
240 // indicates the supported parameters should be read from the output stream
241 // after it is opened for the first time
242 Vector <uint32_t> mSamplingRates; // supported sampling rates
243 Vector <audio_channel_mask_t> mChannelMasks; // supported channel masks
244 Vector <audio_format_t> mFormats; // supported audio formats
Eric Laurent1afeecb2014-05-14 08:52:28 -0700245 Vector < sp<AudioGain> > mGains; // gain controllers
Eric Laurent1f2f2232014-06-02 12:01:23 -0700246 sp<HwModule> mModule; // audio HW module exposing this I/O stream
Eric Laurent951f4552014-05-20 10:48:17 -0700247 };
248
Eric Laurent1f2f2232014-06-02 12:01:23 -0700249 class AudioPortConfig: public virtual RefBase
250 {
251 public:
252 AudioPortConfig();
253 virtual ~AudioPortConfig() {}
254
Eric Laurenta121f902014-06-03 13:32:54 -0700255 status_t applyAudioPortConfig(const struct audio_port_config *config,
256 struct audio_port_config *backupConfig = NULL);
Eric Laurent1f2f2232014-06-02 12:01:23 -0700257 virtual void toAudioPortConfig(struct audio_port_config *dstConfig,
258 const struct audio_port_config *srcConfig = NULL) const = 0;
259 sp<AudioPort> mAudioPort;
260 uint32_t mSamplingRate;
261 audio_format_t mFormat;
262 audio_channel_mask_t mChannelMask;
263 struct audio_gain_config mGain;
264 };
265
266
Eric Laurent6a94d692014-05-20 11:18:06 -0700267 class AudioPatch: public RefBase
268 {
269 public:
270 AudioPatch(audio_patch_handle_t handle,
271 const struct audio_patch *patch, uid_t uid) :
272 mHandle(handle), mPatch(*patch), mUid(uid), mAfPatchHandle(0) {}
273
274 audio_patch_handle_t mHandle;
275 struct audio_patch mPatch;
276 uid_t mUid;
277 audio_patch_handle_t mAfPatchHandle;
278 };
Eric Laurent951f4552014-05-20 10:48:17 -0700279
Eric Laurent1f2f2232014-06-02 12:01:23 -0700280 class DeviceDescriptor: public AudioPort, public AudioPortConfig
Eric Laurent951f4552014-05-20 10:48:17 -0700281 {
282 public:
Eric Laurent1f2f2232014-06-02 12:01:23 -0700283 DeviceDescriptor(const String8& name, audio_devices_t type);
Eric Laurent951f4552014-05-20 10:48:17 -0700284
Eric Laurent951f4552014-05-20 10:48:17 -0700285 virtual ~DeviceDescriptor() {}
286
287 bool equals(const sp<DeviceDescriptor>& other) const;
Eric Laurent1f2f2232014-06-02 12:01:23 -0700288 virtual void toAudioPortConfig(struct audio_port_config *dstConfig,
Eric Laurent6a94d692014-05-20 11:18:06 -0700289 const struct audio_port_config *srcConfig = NULL) const;
Eric Laurent1afeecb2014-05-14 08:52:28 -0700290
Eric Laurent951f4552014-05-20 10:48:17 -0700291 virtual void toAudioPort(struct audio_port *port) const;
292
Eric Laurent1afeecb2014-05-14 08:52:28 -0700293 status_t dump(int fd, int spaces, int index) const;
Eric Laurent951f4552014-05-20 10:48:17 -0700294
295 audio_devices_t mDeviceType;
296 String8 mAddress;
297 audio_channel_mask_t mChannelMask;
298 audio_port_handle_t mId;
299 };
300
301 class DeviceVector : public SortedVector< sp<DeviceDescriptor> >
302 {
303 public:
304 DeviceVector() : SortedVector(), mDeviceTypes(AUDIO_DEVICE_NONE) {}
305
306 ssize_t add(const sp<DeviceDescriptor>& item);
307 ssize_t remove(const sp<DeviceDescriptor>& item);
308 ssize_t indexOf(const sp<DeviceDescriptor>& item) const;
309
310 audio_devices_t types() const { return mDeviceTypes; }
311
312 void loadDevicesFromType(audio_devices_t types);
Eric Laurent1afeecb2014-05-14 08:52:28 -0700313 void loadDevicesFromName(char *name, const DeviceVector& declaredDevices);
314
Eric Laurent951f4552014-05-20 10:48:17 -0700315 sp<DeviceDescriptor> getDevice(audio_devices_t type, String8 address) const;
316 DeviceVector getDevicesFromType(audio_devices_t types) const;
Eric Laurent6a94d692014-05-20 11:18:06 -0700317 sp<DeviceDescriptor> getDeviceFromId(audio_port_handle_t id) const;
Eric Laurent1afeecb2014-05-14 08:52:28 -0700318 sp<DeviceDescriptor> getDeviceFromName(const String8& name) const;
Eric Laurent951f4552014-05-20 10:48:17 -0700319
320 private:
321 void refreshTypes();
322 audio_devices_t mDeviceTypes;
Eric Laurente552edb2014-03-10 17:42:56 -0700323 };
324
325 // the IOProfile class describes the capabilities of an output or input stream.
326 // It is currently assumed that all combination of listed parameters are supported.
327 // It is used by the policy manager to determine if an output or input is suitable for
328 // a given use case, open/close it accordingly and connect/disconnect audio tracks
329 // to/from it.
Eric Laurent951f4552014-05-20 10:48:17 -0700330 class IOProfile : public AudioPort
Eric Laurente552edb2014-03-10 17:42:56 -0700331 {
332 public:
Eric Laurent1f2f2232014-06-02 12:01:23 -0700333 IOProfile(const String8& name, audio_port_role_t role, const sp<HwModule>& module);
Eric Laurent951f4552014-05-20 10:48:17 -0700334 virtual ~IOProfile();
Eric Laurente552edb2014-03-10 17:42:56 -0700335
336 bool isCompatibleProfile(audio_devices_t device,
337 uint32_t samplingRate,
338 audio_format_t format,
339 audio_channel_mask_t channelMask,
340 audio_output_flags_t flags) const;
341
342 void dump(int fd);
Eric Laurentd4692962014-05-05 18:13:44 -0700343 void log();
Eric Laurente552edb2014-03-10 17:42:56 -0700344
Eric Laurent3a4311c2014-03-17 12:00:47 -0700345 DeviceVector mSupportedDevices; // supported devices
346 // (devices this output can be routed to)
Eric Laurente552edb2014-03-10 17:42:56 -0700347 audio_output_flags_t mFlags; // attribute flags (e.g primary output,
348 // direct output...). For outputs only.
Eric Laurente552edb2014-03-10 17:42:56 -0700349 };
350
Eric Laurent1f2f2232014-06-02 12:01:23 -0700351 class HwModule : public RefBase{
Eric Laurent1afeecb2014-05-14 08:52:28 -0700352 public:
353 HwModule(const char *name);
354 ~HwModule();
355
356 status_t loadOutput(cnode *root);
357 status_t loadInput(cnode *root);
358 status_t loadDevice(cnode *root);
359
360 void dump(int fd);
361
Eric Laurenteb108a42014-06-06 14:56:52 -0700362 const char *const mName; // base name of the audio HW module (primary, a2dp ...)
363 uint32_t mHalVersion; // audio HAL API version
364 audio_module_handle_t mHandle;
Eric Laurent1afeecb2014-05-14 08:52:28 -0700365 Vector < sp<IOProfile> > mOutputProfiles; // output profiles exposed by this module
366 Vector < sp<IOProfile> > mInputProfiles; // input profiles exposed by this module
367 DeviceVector mDeclaredDevices; // devices declared in audio_policy.conf
368
369 };
370
Eric Laurente552edb2014-03-10 17:42:56 -0700371 // default volume curve
Eric Laurente0720872014-03-11 09:30:41 -0700372 static const VolumeCurvePoint sDefaultVolumeCurve[AudioPolicyManager::VOLCNT];
Eric Laurente552edb2014-03-10 17:42:56 -0700373 // default volume curve for media strategy
Eric Laurente0720872014-03-11 09:30:41 -0700374 static const VolumeCurvePoint sDefaultMediaVolumeCurve[AudioPolicyManager::VOLCNT];
Eric Laurente552edb2014-03-10 17:42:56 -0700375 // volume curve for media strategy on speakers
Eric Laurente0720872014-03-11 09:30:41 -0700376 static const VolumeCurvePoint sSpeakerMediaVolumeCurve[AudioPolicyManager::VOLCNT];
Eric Laurente552edb2014-03-10 17:42:56 -0700377 // volume curve for sonification strategy on speakers
Eric Laurente0720872014-03-11 09:30:41 -0700378 static const VolumeCurvePoint sSpeakerSonificationVolumeCurve[AudioPolicyManager::VOLCNT];
379 static const VolumeCurvePoint sSpeakerSonificationVolumeCurveDrc[AudioPolicyManager::VOLCNT];
380 static const VolumeCurvePoint sDefaultSystemVolumeCurve[AudioPolicyManager::VOLCNT];
381 static const VolumeCurvePoint sDefaultSystemVolumeCurveDrc[AudioPolicyManager::VOLCNT];
382 static const VolumeCurvePoint sHeadsetSystemVolumeCurve[AudioPolicyManager::VOLCNT];
383 static const VolumeCurvePoint sDefaultVoiceVolumeCurve[AudioPolicyManager::VOLCNT];
384 static const VolumeCurvePoint sSpeakerVoiceVolumeCurve[AudioPolicyManager::VOLCNT];
Eric Laurente552edb2014-03-10 17:42:56 -0700385 // default volume curves per stream and device category. See initializeVolumeCurves()
386 static const VolumeCurvePoint *sVolumeProfiles[AUDIO_STREAM_CNT][DEVICE_CATEGORY_CNT];
387
388 // descriptor for audio outputs. Used to maintain current configuration of each opened audio output
389 // and keep track of the usage of this output by each audio stream type.
Eric Laurent1f2f2232014-06-02 12:01:23 -0700390 class AudioOutputDescriptor: public AudioPortConfig
Eric Laurente552edb2014-03-10 17:42:56 -0700391 {
392 public:
Eric Laurent951f4552014-05-20 10:48:17 -0700393 AudioOutputDescriptor(const sp<IOProfile>& profile);
Eric Laurente552edb2014-03-10 17:42:56 -0700394
395 status_t dump(int fd);
396
397 audio_devices_t device() const;
Eric Laurent3b73df72014-03-11 09:06:29 -0700398 void changeRefCount(audio_stream_type_t stream, int delta);
Eric Laurente552edb2014-03-10 17:42:56 -0700399
400 bool isDuplicated() const { return (mOutput1 != NULL && mOutput2 != NULL); }
401 audio_devices_t supportedDevices();
402 uint32_t latency();
Eric Laurent1f2f2232014-06-02 12:01:23 -0700403 bool sharesHwModuleWith(const sp<AudioOutputDescriptor> outputDesc);
Eric Laurente552edb2014-03-10 17:42:56 -0700404 bool isActive(uint32_t inPastMs = 0) const;
Eric Laurent3b73df72014-03-11 09:06:29 -0700405 bool isStreamActive(audio_stream_type_t stream,
Eric Laurente552edb2014-03-10 17:42:56 -0700406 uint32_t inPastMs = 0,
407 nsecs_t sysTime = 0) const;
408 bool isStrategyActive(routing_strategy strategy,
409 uint32_t inPastMs = 0,
410 nsecs_t sysTime = 0) const;
411
Eric Laurent1f2f2232014-06-02 12:01:23 -0700412 virtual void toAudioPortConfig(struct audio_port_config *dstConfig,
Eric Laurent6a94d692014-05-20 11:18:06 -0700413 const struct audio_port_config *srcConfig = NULL) const;
Eric Laurent951f4552014-05-20 10:48:17 -0700414 void toAudioPort(struct audio_port *port) const;
415
416 audio_port_handle_t mId;
417 audio_io_handle_t mIoHandle; // output handle
Eric Laurente552edb2014-03-10 17:42:56 -0700418 uint32_t mLatency; //
419 audio_output_flags_t mFlags; //
420 audio_devices_t mDevice; // current device this output is routed to
Eric Laurent951f4552014-05-20 10:48:17 -0700421 audio_patch_handle_t mPatchHandle;
Eric Laurent3b73df72014-03-11 09:06:29 -0700422 uint32_t mRefCount[AUDIO_STREAM_CNT]; // number of streams of each type using this output
423 nsecs_t mStopTime[AUDIO_STREAM_CNT];
Eric Laurent1f2f2232014-06-02 12:01:23 -0700424 sp<AudioOutputDescriptor> mOutput1; // used by duplicated outputs: first output
425 sp<AudioOutputDescriptor> mOutput2; // used by duplicated outputs: second output
Eric Laurent3b73df72014-03-11 09:06:29 -0700426 float mCurVolume[AUDIO_STREAM_CNT]; // current stream volume
427 int mMuteCount[AUDIO_STREAM_CNT]; // mute request counter
Eric Laurent951f4552014-05-20 10:48:17 -0700428 const sp<IOProfile> mProfile; // I/O profile this output derives from
Eric Laurente552edb2014-03-10 17:42:56 -0700429 bool mStrategyMutedByDevice[NUM_STRATEGIES]; // strategies muted because of incompatible
430 // device selection. See checkDeviceMuteStrategies()
431 uint32_t mDirectOpenCount; // number of clients using this output (direct outputs only)
432 };
433
434 // descriptor for audio inputs. Used to maintain current configuration of each opened audio input
435 // and keep track of the usage of this input.
Eric Laurent1f2f2232014-06-02 12:01:23 -0700436 class AudioInputDescriptor: public AudioPortConfig
Eric Laurente552edb2014-03-10 17:42:56 -0700437 {
438 public:
Eric Laurent951f4552014-05-20 10:48:17 -0700439 AudioInputDescriptor(const sp<IOProfile>& profile);
Eric Laurente552edb2014-03-10 17:42:56 -0700440
441 status_t dump(int fd);
442
Eric Laurent951f4552014-05-20 10:48:17 -0700443 audio_port_handle_t mId;
444 audio_io_handle_t mIoHandle; // input handle
Eric Laurente552edb2014-03-10 17:42:56 -0700445 audio_devices_t mDevice; // current device this input is routed to
Eric Laurent951f4552014-05-20 10:48:17 -0700446 audio_patch_handle_t mPatchHandle;
Eric Laurente552edb2014-03-10 17:42:56 -0700447 uint32_t mRefCount; // number of AudioRecord clients using this output
Eric Laurent3b73df72014-03-11 09:06:29 -0700448 audio_source_t mInputSource; // input source selected by application (mediarecorder.h)
Eric Laurent951f4552014-05-20 10:48:17 -0700449 const sp<IOProfile> mProfile; // I/O profile this output derives from
450
Eric Laurent1f2f2232014-06-02 12:01:23 -0700451 virtual void toAudioPortConfig(struct audio_port_config *dstConfig,
Eric Laurent6a94d692014-05-20 11:18:06 -0700452 const struct audio_port_config *srcConfig = NULL) const;
Eric Laurent951f4552014-05-20 10:48:17 -0700453 void toAudioPort(struct audio_port *port) const;
Eric Laurente552edb2014-03-10 17:42:56 -0700454 };
455
456 // stream descriptor used for volume control
457 class StreamDescriptor
458 {
459 public:
460 StreamDescriptor();
461
462 int getVolumeIndex(audio_devices_t device);
463 void dump(int fd);
464
465 int mIndexMin; // min volume index
466 int mIndexMax; // max volume index
467 KeyedVector<audio_devices_t, int> mIndexCur; // current volume index per device
468 bool mCanBeMuted; // true is the stream can be muted
469
470 const VolumeCurvePoint *mVolumeCurve[DEVICE_CATEGORY_CNT];
471 };
472
473 // stream descriptor used for volume control
Eric Laurent1f2f2232014-06-02 12:01:23 -0700474 class EffectDescriptor : public RefBase
Eric Laurente552edb2014-03-10 17:42:56 -0700475 {
476 public:
477
478 status_t dump(int fd);
479
480 int mIo; // io the effect is attached to
481 routing_strategy mStrategy; // routing strategy the effect is associated to
482 int mSession; // audio session the effect is on
483 effect_descriptor_t mDesc; // effect descriptor
484 bool mEnabled; // enabled state: CPU load being used or not
485 };
486
Eric Laurent1f2f2232014-06-02 12:01:23 -0700487 void addOutput(audio_io_handle_t output, sp<AudioOutputDescriptor> outputDesc);
488 void addInput(audio_io_handle_t input, sp<AudioInputDescriptor> inputDesc);
Eric Laurente552edb2014-03-10 17:42:56 -0700489
490 // return the strategy corresponding to a given stream type
Eric Laurent3b73df72014-03-11 09:06:29 -0700491 static routing_strategy getStrategy(audio_stream_type_t stream);
Eric Laurente552edb2014-03-10 17:42:56 -0700492
493 // return appropriate device for streams handled by the specified strategy according to current
494 // phone state, connected devices...
495 // if fromCache is true, the device is returned from mDeviceForStrategy[],
496 // otherwise it is determine by current state
497 // (device connected,phone state, force use, a2dp output...)
498 // This allows to:
499 // 1 speed up process when the state is stable (when starting or stopping an output)
500 // 2 access to either current device selection (fromCache == true) or
501 // "future" device selection (fromCache == false) when called from a context
502 // where conditions are changing (setDeviceConnectionState(), setPhoneState()...) AND
503 // before updateDevicesAndOutputs() is called.
504 virtual audio_devices_t getDeviceForStrategy(routing_strategy strategy,
505 bool fromCache);
506
507 // change the route of the specified output. Returns the number of ms we have slept to
508 // allow new routing to take effect in certain cases.
509 uint32_t setOutputDevice(audio_io_handle_t output,
510 audio_devices_t device,
511 bool force = false,
Eric Laurent6a94d692014-05-20 11:18:06 -0700512 int delayMs = 0,
513 audio_patch_handle_t *patchHandle = NULL);
Eric Laurent951f4552014-05-20 10:48:17 -0700514 status_t resetOutputDevice(audio_io_handle_t output,
Eric Laurent6a94d692014-05-20 11:18:06 -0700515 int delayMs = 0,
516 audio_patch_handle_t *patchHandle = NULL);
Eric Laurent951f4552014-05-20 10:48:17 -0700517 status_t setInputDevice(audio_io_handle_t input,
518 audio_devices_t device,
Eric Laurent6a94d692014-05-20 11:18:06 -0700519 bool force = false,
520 audio_patch_handle_t *patchHandle = NULL);
521 status_t resetInputDevice(audio_io_handle_t input,
522 audio_patch_handle_t *patchHandle = NULL);
Eric Laurente552edb2014-03-10 17:42:56 -0700523
524 // select input device corresponding to requested audio source
Eric Laurent3b73df72014-03-11 09:06:29 -0700525 virtual audio_devices_t getDeviceForInputSource(audio_source_t inputSource);
Eric Laurente552edb2014-03-10 17:42:56 -0700526
527 // return io handle of active input or 0 if no input is active
528 // Only considers inputs from physical devices (e.g. main mic, headset mic) when
529 // ignoreVirtualInputs is true.
530 audio_io_handle_t getActiveInput(bool ignoreVirtualInputs = true);
531
532 // initialize volume curves for each strategy and device category
533 void initializeVolumeCurves();
534
535 // compute the actual volume for a given stream according to the requested index and a particular
536 // device
Eric Laurent3b73df72014-03-11 09:06:29 -0700537 virtual float computeVolume(audio_stream_type_t stream, int index,
538 audio_io_handle_t output, audio_devices_t device);
Eric Laurente552edb2014-03-10 17:42:56 -0700539
540 // check that volume change is permitted, compute and send new volume to audio hardware
Eric Laurent3b73df72014-03-11 09:06:29 -0700541 status_t checkAndSetVolume(audio_stream_type_t stream, int index, audio_io_handle_t output,
542 audio_devices_t device, int delayMs = 0, bool force = false);
Eric Laurente552edb2014-03-10 17:42:56 -0700543
544 // apply all stream volumes to the specified output and device
545 void applyStreamVolumes(audio_io_handle_t output, audio_devices_t device, int delayMs = 0, bool force = false);
546
547 // Mute or unmute all streams handled by the specified strategy on the specified output
548 void setStrategyMute(routing_strategy strategy,
549 bool on,
550 audio_io_handle_t output,
551 int delayMs = 0,
552 audio_devices_t device = (audio_devices_t)0);
553
554 // Mute or unmute the stream on the specified output
Eric Laurent3b73df72014-03-11 09:06:29 -0700555 void setStreamMute(audio_stream_type_t stream,
Eric Laurente552edb2014-03-10 17:42:56 -0700556 bool on,
557 audio_io_handle_t output,
558 int delayMs = 0,
559 audio_devices_t device = (audio_devices_t)0);
560
561 // handle special cases for sonification strategy while in call: mute streams or replace by
562 // a special tone in the device used for communication
Eric Laurent3b73df72014-03-11 09:06:29 -0700563 void handleIncallSonification(audio_stream_type_t stream, bool starting, bool stateChange);
Eric Laurente552edb2014-03-10 17:42:56 -0700564
565 // true if device is in a telephony or VoIP call
566 virtual bool isInCall();
567
568 // true if given state represents a device in a telephony or VoIP call
569 virtual bool isStateInCall(int state);
570
571 // when a device is connected, checks if an open output can be routed
572 // to this device. If none is open, tries to open one of the available outputs.
573 // Returns an output suitable to this device or 0.
574 // when a device is disconnected, checks if an output is not used any more and
575 // returns its handle if any.
576 // transfers the audio tracks and effects from one output thread to another accordingly.
577 status_t checkOutputsForDevice(audio_devices_t device,
Eric Laurent3b73df72014-03-11 09:06:29 -0700578 audio_policy_dev_state_t state,
Eric Laurente552edb2014-03-10 17:42:56 -0700579 SortedVector<audio_io_handle_t>& outputs,
Eric Laurent3a4311c2014-03-17 12:00:47 -0700580 const String8 address);
Eric Laurente552edb2014-03-10 17:42:56 -0700581
Eric Laurentd4692962014-05-05 18:13:44 -0700582 status_t checkInputsForDevice(audio_devices_t device,
583 audio_policy_dev_state_t state,
584 SortedVector<audio_io_handle_t>& inputs,
585 const String8 address);
586
Eric Laurente552edb2014-03-10 17:42:56 -0700587 // close an output and its companion duplicating output.
588 void closeOutput(audio_io_handle_t output);
589
590 // checks and if necessary changes outputs used for all strategies.
591 // must be called every time a condition that affects the output choice for a given strategy
592 // changes: connected device, phone state, force use...
593 // Must be called before updateDevicesAndOutputs()
594 void checkOutputForStrategy(routing_strategy strategy);
595
596 // Same as checkOutputForStrategy() but for a all strategies in order of priority
597 void checkOutputForAllStrategies();
598
599 // manages A2DP output suspend/restore according to phone state and BT SCO usage
600 void checkA2dpSuspend();
601
602 // returns the A2DP output handle if it is open or 0 otherwise
603 audio_io_handle_t getA2dpOutput();
604
605 // selects the most appropriate device on output for current state
606 // must be called every time a condition that affects the device choice for a given output is
607 // changed: connected device, phone state, force use, output start, output stop..
608 // see getDeviceForStrategy() for the use of fromCache parameter
Eric Laurent951f4552014-05-20 10:48:17 -0700609 audio_devices_t getNewOutputDevice(audio_io_handle_t output, bool fromCache);
Eric Laurente552edb2014-03-10 17:42:56 -0700610
Eric Laurente552edb2014-03-10 17:42:56 -0700611 // updates cache of device used by all strategies (mDeviceForStrategy[])
612 // must be called every time a condition that affects the device choice for a given strategy is
613 // changed: connected device, phone state, force use...
614 // cached values are used by getDeviceForStrategy() if parameter fromCache is true.
615 // Must be called after checkOutputForAllStrategies()
Eric Laurente552edb2014-03-10 17:42:56 -0700616 void updateDevicesAndOutputs();
617
Eric Laurent951f4552014-05-20 10:48:17 -0700618 // selects the most appropriate device on input for current state
619 audio_devices_t getNewInputDevice(audio_io_handle_t input);
620
Eric Laurente552edb2014-03-10 17:42:56 -0700621 virtual uint32_t getMaxEffectsCpuLoad();
622 virtual uint32_t getMaxEffectsMemory();
623#ifdef AUDIO_POLICY_TEST
624 virtual bool threadLoop();
625 void exit();
626 int testOutputIndex(audio_io_handle_t output);
627#endif //AUDIO_POLICY_TEST
628
Eric Laurent1f2f2232014-06-02 12:01:23 -0700629 status_t setEffectEnabled(const sp<EffectDescriptor>& effectDesc, bool enabled);
Eric Laurente552edb2014-03-10 17:42:56 -0700630
631 // returns the category the device belongs to with regard to volume curve management
632 static device_category getDeviceCategory(audio_devices_t device);
633
634 // extract one device relevant for volume control from multiple device selection
635 static audio_devices_t getDeviceForVolume(audio_devices_t device);
636
637 SortedVector<audio_io_handle_t> getOutputsForDevice(audio_devices_t device,
Eric Laurent1f2f2232014-06-02 12:01:23 -0700638 DefaultKeyedVector<audio_io_handle_t, sp<AudioOutputDescriptor> > openOutputs);
Eric Laurente552edb2014-03-10 17:42:56 -0700639 bool vectorsEqual(SortedVector<audio_io_handle_t>& outputs1,
640 SortedVector<audio_io_handle_t>& outputs2);
641
642 // mute/unmute strategies using an incompatible device combination
643 // if muting, wait for the audio in pcm buffer to be drained before proceeding
644 // if unmuting, unmute only after the specified delay
645 // Returns the number of ms waited
Eric Laurent1f2f2232014-06-02 12:01:23 -0700646 uint32_t checkDeviceMuteStrategies(sp<AudioOutputDescriptor> outputDesc,
Eric Laurente552edb2014-03-10 17:42:56 -0700647 audio_devices_t prevDevice,
648 uint32_t delayMs);
649
650 audio_io_handle_t selectOutput(const SortedVector<audio_io_handle_t>& outputs,
Eric Laurent3b73df72014-03-11 09:06:29 -0700651 audio_output_flags_t flags);
Eric Laurent951f4552014-05-20 10:48:17 -0700652 sp<IOProfile> getInputProfile(audio_devices_t device,
Eric Laurente552edb2014-03-10 17:42:56 -0700653 uint32_t samplingRate,
654 audio_format_t format,
655 audio_channel_mask_t channelMask);
Eric Laurent951f4552014-05-20 10:48:17 -0700656 sp<IOProfile> getProfileForDirectOutput(audio_devices_t device,
Eric Laurente552edb2014-03-10 17:42:56 -0700657 uint32_t samplingRate,
658 audio_format_t format,
659 audio_channel_mask_t channelMask,
660 audio_output_flags_t flags);
661
662 audio_io_handle_t selectOutputForEffects(const SortedVector<audio_io_handle_t>& outputs);
663
664 bool isNonOffloadableEffectEnabled();
665
Eric Laurent6a94d692014-05-20 11:18:06 -0700666 status_t addAudioPatch(audio_patch_handle_t handle,
667 const sp<AudioPatch>& patch);
668 status_t removeAudioPatch(audio_patch_handle_t handle);
669
Eric Laurent1f2f2232014-06-02 12:01:23 -0700670 sp<AudioOutputDescriptor> getOutputFromId(audio_port_handle_t id) const;
671 sp<AudioInputDescriptor> getInputFromId(audio_port_handle_t id) const;
672 sp<HwModule> getModuleForDevice(audio_devices_t device) const;
673 sp<HwModule> getModuleFromName(const char *name) const;
Eric Laurente552edb2014-03-10 17:42:56 -0700674 //
675 // Audio policy configuration file parsing (audio_policy.conf)
676 //
677 static uint32_t stringToEnum(const struct StringToEnum *table,
678 size_t size,
679 const char *name);
Eric Laurent3a4311c2014-03-17 12:00:47 -0700680 static const char *enumToString(const struct StringToEnum *table,
681 size_t size,
682 uint32_t value);
Eric Laurente552edb2014-03-10 17:42:56 -0700683 static bool stringToBool(const char *value);
684 static audio_output_flags_t parseFlagNames(char *name);
685 static audio_devices_t parseDeviceNames(char *name);
Eric Laurente552edb2014-03-10 17:42:56 -0700686 void loadHwModule(cnode *root);
687 void loadHwModules(cnode *root);
Eric Laurent1f2f2232014-06-02 12:01:23 -0700688 void loadGlobalConfig(cnode *root, const sp<HwModule>& module);
Eric Laurente552edb2014-03-10 17:42:56 -0700689 status_t loadAudioPolicyConfig(const char *path);
690 void defaultAudioPolicyConfig(void);
691
692
Eric Laurent6a94d692014-05-20 11:18:06 -0700693 uid_t mUidCached;
Eric Laurente552edb2014-03-10 17:42:56 -0700694 AudioPolicyClientInterface *mpClientInterface; // audio policy client interface
695 audio_io_handle_t mPrimaryOutput; // primary output handle
696 // list of descriptors for outputs currently opened
Eric Laurent1f2f2232014-06-02 12:01:23 -0700697 DefaultKeyedVector<audio_io_handle_t, sp<AudioOutputDescriptor> > mOutputs;
Eric Laurente552edb2014-03-10 17:42:56 -0700698 // copy of mOutputs before setDeviceConnectionState() opens new outputs
699 // reset to mOutputs when updateDevicesAndOutputs() is called.
Eric Laurent1f2f2232014-06-02 12:01:23 -0700700 DefaultKeyedVector<audio_io_handle_t, sp<AudioOutputDescriptor> > mPreviousOutputs;
701 DefaultKeyedVector<audio_io_handle_t, sp<AudioInputDescriptor> > mInputs; // list of input descriptors
Eric Laurent1afeecb2014-05-14 08:52:28 -0700702 DeviceVector mAvailableOutputDevices; // all available output devices
703 DeviceVector mAvailableInputDevices; // all available input devices
Eric Laurente552edb2014-03-10 17:42:56 -0700704 int mPhoneState; // current phone state
Eric Laurent3b73df72014-03-11 09:06:29 -0700705 audio_policy_forced_cfg_t mForceUse[AUDIO_POLICY_FORCE_USE_CNT]; // current forced use configuration
Eric Laurente552edb2014-03-10 17:42:56 -0700706
Eric Laurent3b73df72014-03-11 09:06:29 -0700707 StreamDescriptor mStreams[AUDIO_STREAM_CNT]; // stream descriptors for volume control
Eric Laurente552edb2014-03-10 17:42:56 -0700708 bool mLimitRingtoneVolume; // limit ringtone volume to music volume if headset connected
709 audio_devices_t mDeviceForStrategy[NUM_STRATEGIES];
710 float mLastVoiceVolume; // last voice volume value sent to audio HAL
711
712 // Maximum CPU load allocated to audio effects in 0.1 MIPS (ARMv5TE, 0 WS memory) units
713 static const uint32_t MAX_EFFECTS_CPU_LOAD = 1000;
714 // Maximum memory allocated to audio effects in KB
715 static const uint32_t MAX_EFFECTS_MEMORY = 512;
716 uint32_t mTotalEffectsCpuLoad; // current CPU load used by effects
717 uint32_t mTotalEffectsMemory; // current memory used by effects
Eric Laurent1f2f2232014-06-02 12:01:23 -0700718 KeyedVector<int, sp<EffectDescriptor> > mEffects; // list of registered audio effects
Eric Laurente552edb2014-03-10 17:42:56 -0700719 bool mA2dpSuspended; // true if A2DP output is suspended
Eric Laurent3a4311c2014-03-17 12:00:47 -0700720 sp<DeviceDescriptor> mDefaultOutputDevice; // output device selected by default at boot time
Eric Laurente552edb2014-03-10 17:42:56 -0700721 bool mSpeakerDrcEnabled;// true on devices that use DRC on the DEVICE_CATEGORY_SPEAKER path
722 // to boost soft sounds, used to adjust volume curves accordingly
723
Eric Laurent1f2f2232014-06-02 12:01:23 -0700724 Vector < sp<HwModule> > mHwModules;
Eric Laurent3a4311c2014-03-17 12:00:47 -0700725 volatile int32_t mNextUniqueId;
Eric Laurent6a94d692014-05-20 11:18:06 -0700726 volatile int32_t mAudioPortGeneration;
727
728 DefaultKeyedVector<audio_patch_handle_t, sp<AudioPatch> > mAudioPatches;
Eric Laurente552edb2014-03-10 17:42:56 -0700729
730#ifdef AUDIO_POLICY_TEST
731 Mutex mLock;
732 Condition mWaitWorkCV;
733
734 int mCurOutput;
735 bool mDirectOutput;
736 audio_io_handle_t mTestOutputs[NUM_TEST_OUTPUTS];
737 int mTestInput;
738 uint32_t mTestDevice;
739 uint32_t mTestSamplingRate;
740 uint32_t mTestFormat;
741 uint32_t mTestChannels;
742 uint32_t mTestLatencyMs;
743#endif //AUDIO_POLICY_TEST
744
745private:
746 static float volIndexToAmpl(audio_devices_t device, const StreamDescriptor& streamDesc,
747 int indexInUi);
748 // updates device caching and output for streams that can influence the
749 // routing of notifications
Eric Laurent3b73df72014-03-11 09:06:29 -0700750 void handleNotificationRoutingForStream(audio_stream_type_t stream);
Eric Laurente552edb2014-03-10 17:42:56 -0700751 static bool isVirtualInputDevice(audio_devices_t device);
Eric Laurent3a4311c2014-03-17 12:00:47 -0700752 uint32_t nextUniqueId();
Eric Laurent6a94d692014-05-20 11:18:06 -0700753 uint32_t nextAudioPortGeneration();
754 uint32_t curAudioPortGeneration() const { return mAudioPortGeneration; }
Eric Laurent3a4311c2014-03-17 12:00:47 -0700755 // converts device address to string sent to audio HAL via setParameters
756 static String8 addressToParameter(audio_devices_t device, const String8 address);
Eric Laurente552edb2014-03-10 17:42:56 -0700757};
758
759};