blob: f13bcf3279d173fe8bc6112bffa077eca1aa6c4d [file] [log] [blame]
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001/*
2 * Copyright (C) 2006-2007 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#define LOG_TAG "AudioSystem"
18//#define LOG_NDEBUG 0
19
20#include <utils/Log.h>
Mathias Agopian75624082009-05-19 19:08:10 -070021#include <binder/IServiceManager.h>
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080022#include <media/AudioSystem.h>
Glenn Kasten1ab85ec2013-05-31 09:18:43 -070023#include <media/IAudioFlinger.h>
Eric Laurentc2f1f072009-07-17 12:17:14 -070024#include <media/IAudioPolicyService.h>
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080025#include <math.h>
26
Dima Zavin64760242011-05-11 14:15:23 -070027#include <system/audio.h>
Dima Zavinfce7a472011-04-19 22:30:36 -070028
Eric Laurentc2f1f072009-07-17 12:17:14 -070029// ----------------------------------------------------------------------------
Eric Laurentc2f1f072009-07-17 12:17:14 -070030
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080031namespace android {
32
33// client singleton for AudioFlinger binder interface
34Mutex AudioSystem::gLock;
Glenn Kastend2d089f2014-11-05 11:48:12 -080035Mutex AudioSystem::gLockAPS;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080036sp<IAudioFlinger> AudioSystem::gAudioFlinger;
37sp<AudioSystem::AudioFlingerClient> AudioSystem::gAudioFlingerClient;
38audio_error_callback AudioSystem::gAudioErrorCallback = NULL;
Jean-Michel Trivif613d422015-04-23 18:41:29 -070039dynamic_policy_callback AudioSystem::gDynPolicyCallback = NULL;
Glenn Kasten211eeaf2012-01-20 09:37:45 -080040
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080041
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080042// establish binder interface to AudioFlinger service
Eric Laurent0ebd5f92014-11-19 19:04:52 -080043const sp<IAudioFlinger> AudioSystem::get_audio_flinger()
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080044{
Eric Laurent0ebd5f92014-11-19 19:04:52 -080045 sp<IAudioFlinger> af;
46 sp<AudioFlingerClient> afc;
47 {
48 Mutex::Autolock _l(gLock);
49 if (gAudioFlinger == 0) {
50 sp<IServiceManager> sm = defaultServiceManager();
51 sp<IBinder> binder;
52 do {
53 binder = sm->getService(String16("media.audio_flinger"));
54 if (binder != 0)
55 break;
56 ALOGW("AudioFlinger not published, waiting...");
57 usleep(500000); // 0.5 s
58 } while (true);
59 if (gAudioFlingerClient == NULL) {
60 gAudioFlingerClient = new AudioFlingerClient();
61 } else {
62 if (gAudioErrorCallback) {
63 gAudioErrorCallback(NO_ERROR);
64 }
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080065 }
Eric Laurent0ebd5f92014-11-19 19:04:52 -080066 binder->linkToDeath(gAudioFlingerClient);
67 gAudioFlinger = interface_cast<IAudioFlinger>(binder);
68 LOG_ALWAYS_FATAL_IF(gAudioFlinger == 0);
69 afc = gAudioFlingerClient;
Glenn Kastene53b9ea2012-03-12 16:29:55 -070070 }
Eric Laurent0ebd5f92014-11-19 19:04:52 -080071 af = gAudioFlinger;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080072 }
Eric Laurent0ebd5f92014-11-19 19:04:52 -080073 if (afc != 0) {
74 af->registerClient(afc);
75 }
76 return af;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080077}
78
Eric Laurent296fb132015-05-01 11:38:42 -070079const sp<AudioSystem::AudioFlingerClient> AudioSystem::getAudioFlingerClient()
80{
81 // calling get_audio_flinger() will initialize gAudioFlingerClient if needed
82 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
83 if (af == 0) return 0;
84 Mutex::Autolock _l(gLock);
85 return gAudioFlingerClient;
86}
87
88sp<AudioIoDescriptor> AudioSystem::getIoDescriptor(audio_io_handle_t ioHandle)
89{
90 sp<AudioIoDescriptor> desc;
91 const sp<AudioFlingerClient> afc = getAudioFlingerClient();
92 if (afc != 0) {
93 desc = afc->getIoDescriptor(ioHandle);
94 }
95 return desc;
96}
97
Eric Laurent46291612013-07-18 14:38:44 -070098/* static */ status_t AudioSystem::checkAudioFlinger()
99{
100 if (defaultServiceManager()->checkService(String16("media.audio_flinger")) != 0) {
101 return NO_ERROR;
102 }
103 return DEAD_OBJECT;
104}
105
Glenn Kasten4944acb2013-08-19 08:39:20 -0700106status_t AudioSystem::muteMicrophone(bool state)
107{
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800108 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
109 if (af == 0) return PERMISSION_DENIED;
110 return af->setMicMute(state);
111}
112
Glenn Kasten4944acb2013-08-19 08:39:20 -0700113status_t AudioSystem::isMicrophoneMuted(bool* state)
114{
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800115 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
116 if (af == 0) return PERMISSION_DENIED;
117 *state = af->getMicMute();
118 return NO_ERROR;
119}
120
121status_t AudioSystem::setMasterVolume(float value)
122{
123 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
124 if (af == 0) return PERMISSION_DENIED;
125 af->setMasterVolume(value);
126 return NO_ERROR;
127}
128
129status_t AudioSystem::setMasterMute(bool mute)
130{
131 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
132 if (af == 0) return PERMISSION_DENIED;
133 af->setMasterMute(mute);
134 return NO_ERROR;
135}
136
137status_t AudioSystem::getMasterVolume(float* volume)
138{
139 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
140 if (af == 0) return PERMISSION_DENIED;
141 *volume = af->masterVolume();
142 return NO_ERROR;
143}
144
145status_t AudioSystem::getMasterMute(bool* mute)
146{
147 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
148 if (af == 0) return PERMISSION_DENIED;
149 *mute = af->masterMute();
150 return NO_ERROR;
151}
152
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800153status_t AudioSystem::setStreamVolume(audio_stream_type_t stream, float value,
154 audio_io_handle_t output)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800155{
Dima Zavinfce7a472011-04-19 22:30:36 -0700156 if (uint32_t(stream) >= AUDIO_STREAM_CNT) return BAD_VALUE;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800157 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
158 if (af == 0) return PERMISSION_DENIED;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700159 af->setStreamVolume(stream, value, output);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800160 return NO_ERROR;
161}
162
Glenn Kastenfff6d712012-01-12 16:38:12 -0800163status_t AudioSystem::setStreamMute(audio_stream_type_t stream, bool mute)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800164{
Dima Zavinfce7a472011-04-19 22:30:36 -0700165 if (uint32_t(stream) >= AUDIO_STREAM_CNT) return BAD_VALUE;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800166 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
167 if (af == 0) return PERMISSION_DENIED;
168 af->setStreamMute(stream, mute);
169 return NO_ERROR;
170}
171
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800172status_t AudioSystem::getStreamVolume(audio_stream_type_t stream, float* volume,
173 audio_io_handle_t output)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800174{
Dima Zavinfce7a472011-04-19 22:30:36 -0700175 if (uint32_t(stream) >= AUDIO_STREAM_CNT) return BAD_VALUE;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800176 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
177 if (af == 0) return PERMISSION_DENIED;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700178 *volume = af->streamVolume(stream, output);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800179 return NO_ERROR;
180}
181
Glenn Kastenfff6d712012-01-12 16:38:12 -0800182status_t AudioSystem::getStreamMute(audio_stream_type_t stream, bool* mute)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800183{
Dima Zavinfce7a472011-04-19 22:30:36 -0700184 if (uint32_t(stream) >= AUDIO_STREAM_CNT) return BAD_VALUE;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800185 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
186 if (af == 0) return PERMISSION_DENIED;
187 *mute = af->streamMute(stream);
188 return NO_ERROR;
189}
190
Glenn Kastenf78aee72012-01-04 11:00:47 -0800191status_t AudioSystem::setMode(audio_mode_t mode)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800192{
Glenn Kasten930f4ca2012-01-06 16:47:31 -0800193 if (uint32_t(mode) >= AUDIO_MODE_CNT) return BAD_VALUE;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800194 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
195 if (af == 0) return PERMISSION_DENIED;
196 return af->setMode(mode);
197}
198
Glenn Kasten4944acb2013-08-19 08:39:20 -0700199status_t AudioSystem::setParameters(audio_io_handle_t ioHandle, const String8& keyValuePairs)
200{
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800201 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
202 if (af == 0) return PERMISSION_DENIED;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700203 return af->setParameters(ioHandle, keyValuePairs);
204}
205
Glenn Kasten4944acb2013-08-19 08:39:20 -0700206String8 AudioSystem::getParameters(audio_io_handle_t ioHandle, const String8& keys)
207{
Eric Laurentc2f1f072009-07-17 12:17:14 -0700208 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
209 String8 result = String8("");
210 if (af == 0) return result;
211
212 result = af->getParameters(ioHandle, keys);
213 return result;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800214}
215
Glenn Kastenc23885e2013-12-19 16:35:18 -0800216status_t AudioSystem::setParameters(const String8& keyValuePairs)
217{
Glenn Kasten142f5192014-03-25 17:44:59 -0700218 return setParameters(AUDIO_IO_HANDLE_NONE, keyValuePairs);
Glenn Kastenc23885e2013-12-19 16:35:18 -0800219}
220
221String8 AudioSystem::getParameters(const String8& keys)
222{
Glenn Kasten142f5192014-03-25 17:44:59 -0700223 return getParameters(AUDIO_IO_HANDLE_NONE, keys);
Glenn Kastenc23885e2013-12-19 16:35:18 -0800224}
225
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800226// convert volume steps to natural log scale
227
228// change this value to change volume scaling
229static const float dBPerStep = 0.5f;
230// shouldn't need to touch these
231static const float dBConvert = -dBPerStep * 2.302585093f / 20.0f;
232static const float dBConvertInverse = 1.0f / dBConvert;
233
234float AudioSystem::linearToLog(int volume)
235{
236 // float v = volume ? exp(float(100 - volume) * dBConvert) : 0;
Steve Blockb8a80522011-12-20 16:23:08 +0000237 // ALOGD("linearToLog(%d)=%f", volume, v);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800238 // return v;
239 return volume ? exp(float(100 - volume) * dBConvert) : 0;
240}
241
242int AudioSystem::logToLinear(float volume)
243{
244 // int v = volume ? 100 - int(dBConvertInverse * log(volume) + 0.5) : 0;
Steve Blockb8a80522011-12-20 16:23:08 +0000245 // ALOGD("logTolinear(%d)=%f", v, volume);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800246 // return v;
247 return volume ? 100 - int(dBConvertInverse * log(volume) + 0.5) : 0;
248}
249
Glenn Kasten3b16c762012-11-14 08:44:39 -0800250status_t AudioSystem::getOutputSamplingRate(uint32_t* samplingRate, audio_stream_type_t streamType)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800251{
Eric Laurentc2f1f072009-07-17 12:17:14 -0700252 audio_io_handle_t output;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800253
Dima Zavinfce7a472011-04-19 22:30:36 -0700254 if (streamType == AUDIO_STREAM_DEFAULT) {
255 streamType = AUDIO_STREAM_MUSIC;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700256 }
257
Glenn Kastenfff6d712012-01-12 16:38:12 -0800258 output = getOutput(streamType);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700259 if (output == 0) {
260 return PERMISSION_DENIED;
261 }
262
Jean-Michel Trivib7f24b12014-06-11 10:05:30 -0700263 return getSamplingRate(output, samplingRate);
Eric Laurent1a9ed112012-03-20 18:36:01 -0700264}
265
266status_t AudioSystem::getSamplingRate(audio_io_handle_t output,
Glenn Kasten3b16c762012-11-14 08:44:39 -0800267 uint32_t* samplingRate)
Eric Laurent1a9ed112012-03-20 18:36:01 -0700268{
Eric Laurentf6778fd2014-11-18 17:26:58 -0800269 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
270 if (af == 0) return PERMISSION_DENIED;
Eric Laurent296fb132015-05-01 11:38:42 -0700271 sp<AudioIoDescriptor> outputDesc = getIoDescriptor(output);
Eric Laurent73e26b62015-04-27 16:55:58 -0700272 if (outputDesc == 0) {
Steve Block3856b092011-10-20 11:56:00 +0100273 ALOGV("getOutputSamplingRate() no output descriptor for output %d in gOutputs", output);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700274 *samplingRate = af->sampleRate(output);
275 } else {
Steve Block3856b092011-10-20 11:56:00 +0100276 ALOGV("getOutputSamplingRate() reading from output desc");
Eric Laurent73e26b62015-04-27 16:55:58 -0700277 *samplingRate = outputDesc->mSamplingRate;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700278 }
Glenn Kastenf94006c2014-01-08 08:56:06 -0800279 if (*samplingRate == 0) {
Jean-Michel Trivib7f24b12014-06-11 10:05:30 -0700280 ALOGE("AudioSystem::getSamplingRate failed for output %d", output);
Glenn Kastenf94006c2014-01-08 08:56:06 -0800281 return BAD_VALUE;
282 }
Eric Laurentc2f1f072009-07-17 12:17:14 -0700283
Jean-Michel Trivib7f24b12014-06-11 10:05:30 -0700284 ALOGV("getSamplingRate() output %d, sampling rate %u", output, *samplingRate);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700285
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800286 return NO_ERROR;
287}
288
Glenn Kastene33054e2012-11-14 12:54:39 -0800289status_t AudioSystem::getOutputFrameCount(size_t* frameCount, audio_stream_type_t streamType)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800290{
Eric Laurentc2f1f072009-07-17 12:17:14 -0700291 audio_io_handle_t output;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800292
Dima Zavinfce7a472011-04-19 22:30:36 -0700293 if (streamType == AUDIO_STREAM_DEFAULT) {
294 streamType = AUDIO_STREAM_MUSIC;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700295 }
Eric Laurent48f7f5e2009-04-02 09:32:43 -0700296
Glenn Kastenfff6d712012-01-12 16:38:12 -0800297 output = getOutput(streamType);
Glenn Kasten142f5192014-03-25 17:44:59 -0700298 if (output == AUDIO_IO_HANDLE_NONE) {
Eric Laurentc2f1f072009-07-17 12:17:14 -0700299 return PERMISSION_DENIED;
300 }
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800301
Jean-Michel Trivib7f24b12014-06-11 10:05:30 -0700302 return getFrameCount(output, frameCount);
Eric Laurent1a9ed112012-03-20 18:36:01 -0700303}
304
305status_t AudioSystem::getFrameCount(audio_io_handle_t output,
Glenn Kastene33054e2012-11-14 12:54:39 -0800306 size_t* frameCount)
Eric Laurent1a9ed112012-03-20 18:36:01 -0700307{
Eric Laurentf6778fd2014-11-18 17:26:58 -0800308 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
309 if (af == 0) return PERMISSION_DENIED;
Eric Laurent296fb132015-05-01 11:38:42 -0700310 sp<AudioIoDescriptor> outputDesc = getIoDescriptor(output);
Eric Laurent73e26b62015-04-27 16:55:58 -0700311 if (outputDesc == 0) {
Eric Laurentc2f1f072009-07-17 12:17:14 -0700312 *frameCount = af->frameCount(output);
313 } else {
Eric Laurent73e26b62015-04-27 16:55:58 -0700314 *frameCount = outputDesc->mFrameCount;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700315 }
Glenn Kastenf94006c2014-01-08 08:56:06 -0800316 if (*frameCount == 0) {
Jean-Michel Trivib7f24b12014-06-11 10:05:30 -0700317 ALOGE("AudioSystem::getFrameCount failed for output %d", output);
Glenn Kastenf94006c2014-01-08 08:56:06 -0800318 return BAD_VALUE;
319 }
Eric Laurentc2f1f072009-07-17 12:17:14 -0700320
Mark Salyzyn34fb2962014-06-18 16:30:56 -0700321 ALOGV("getFrameCount() output %d, frameCount %zu", output, *frameCount);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700322
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800323 return NO_ERROR;
324}
325
Glenn Kastenfff6d712012-01-12 16:38:12 -0800326status_t AudioSystem::getOutputLatency(uint32_t* latency, audio_stream_type_t streamType)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800327{
Eric Laurentc2f1f072009-07-17 12:17:14 -0700328 audio_io_handle_t output;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800329
Dima Zavinfce7a472011-04-19 22:30:36 -0700330 if (streamType == AUDIO_STREAM_DEFAULT) {
331 streamType = AUDIO_STREAM_MUSIC;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700332 }
Eric Laurent48f7f5e2009-04-02 09:32:43 -0700333
Glenn Kastenfff6d712012-01-12 16:38:12 -0800334 output = getOutput(streamType);
Glenn Kasten142f5192014-03-25 17:44:59 -0700335 if (output == AUDIO_IO_HANDLE_NONE) {
Eric Laurentc2f1f072009-07-17 12:17:14 -0700336 return PERMISSION_DENIED;
337 }
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800338
Glenn Kasten241618f2014-03-25 17:48:57 -0700339 return getLatency(output, latency);
Eric Laurent1a9ed112012-03-20 18:36:01 -0700340}
341
342status_t AudioSystem::getLatency(audio_io_handle_t output,
Eric Laurent1a9ed112012-03-20 18:36:01 -0700343 uint32_t* latency)
344{
Eric Laurentf6778fd2014-11-18 17:26:58 -0800345 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
346 if (af == 0) return PERMISSION_DENIED;
Eric Laurent296fb132015-05-01 11:38:42 -0700347 sp<AudioIoDescriptor> outputDesc = getIoDescriptor(output);
Eric Laurent73e26b62015-04-27 16:55:58 -0700348 if (outputDesc == 0) {
Eric Laurentc2f1f072009-07-17 12:17:14 -0700349 *latency = af->latency(output);
350 } else {
Eric Laurent73e26b62015-04-27 16:55:58 -0700351 *latency = outputDesc->mLatency;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700352 }
353
Glenn Kasten241618f2014-03-25 17:48:57 -0700354 ALOGV("getLatency() output %d, latency %d", output, *latency);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700355
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800356 return NO_ERROR;
357}
358
Glenn Kastendd8104c2012-07-02 12:42:44 -0700359status_t AudioSystem::getInputBufferSize(uint32_t sampleRate, audio_format_t format,
360 audio_channel_mask_t channelMask, size_t* buffSize)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800361{
Eric Laurent296fb132015-05-01 11:38:42 -0700362 const sp<AudioFlingerClient> afc = getAudioFlingerClient();
363 if (afc == 0) {
364 return NO_INIT;
365 }
366 return afc->getInputBufferSize(sampleRate, format, channelMask, buffSize);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800367}
368
Eric Laurentf0ee6f42009-10-21 08:14:22 -0700369status_t AudioSystem::setVoiceVolume(float value)
370{
371 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
372 if (af == 0) return PERMISSION_DENIED;
373 return af->setVoiceVolume(value);
374}
375
Kévin PETIT377b2ec2014-02-03 12:35:36 +0000376status_t AudioSystem::getRenderPosition(audio_io_handle_t output, uint32_t *halFrames,
Glenn Kasten0ed19592014-03-26 07:50:05 -0700377 uint32_t *dspFrames)
Eric Laurent342e9cf2010-01-19 17:37:09 -0800378{
379 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
380 if (af == 0) return PERMISSION_DENIED;
381
Richard Fitzgeraldad3af332013-03-25 16:54:37 +0000382 return af->getRenderPosition(halFrames, dspFrames, output);
Eric Laurent342e9cf2010-01-19 17:37:09 -0800383}
384
Glenn Kasten4944acb2013-08-19 08:39:20 -0700385uint32_t AudioSystem::getInputFramesLost(audio_io_handle_t ioHandle)
386{
Eric Laurent05bca2f2010-02-26 02:47:27 -0800387 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
Glenn Kasten5f972c02014-01-13 09:59:31 -0800388 uint32_t result = 0;
Eric Laurent05bca2f2010-02-26 02:47:27 -0800389 if (af == 0) return result;
Glenn Kasten142f5192014-03-25 17:44:59 -0700390 if (ioHandle == AUDIO_IO_HANDLE_NONE) return result;
Eric Laurent05bca2f2010-02-26 02:47:27 -0800391
392 result = af->getInputFramesLost(ioHandle);
393 return result;
394}
395
Eric Laurentde3f8392014-07-27 18:38:22 -0700396audio_unique_id_t AudioSystem::newAudioUniqueId()
Glenn Kasten4944acb2013-08-19 08:39:20 -0700397{
Eric Laurentbe916aa2010-06-01 23:49:17 -0700398 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
Eric Laurentde3f8392014-07-27 18:38:22 -0700399 if (af == 0) return AUDIO_UNIQUE_ID_ALLOCATE;
400 return af->newAudioUniqueId();
Eric Laurentbe916aa2010-06-01 23:49:17 -0700401}
402
Marco Nelissend457c972014-02-11 08:47:07 -0800403void AudioSystem::acquireAudioSessionId(int audioSession, pid_t pid)
Glenn Kasten4944acb2013-08-19 08:39:20 -0700404{
Marco Nelissen3a34bef2011-08-02 13:33:41 -0700405 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
406 if (af != 0) {
Marco Nelissend457c972014-02-11 08:47:07 -0800407 af->acquireAudioSessionId(audioSession, pid);
Marco Nelissen3a34bef2011-08-02 13:33:41 -0700408 }
409}
410
Marco Nelissend457c972014-02-11 08:47:07 -0800411void AudioSystem::releaseAudioSessionId(int audioSession, pid_t pid)
Glenn Kasten4944acb2013-08-19 08:39:20 -0700412{
Marco Nelissen3a34bef2011-08-02 13:33:41 -0700413 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
414 if (af != 0) {
Marco Nelissend457c972014-02-11 08:47:07 -0800415 af->releaseAudioSessionId(audioSession, pid);
Marco Nelissen3a34bef2011-08-02 13:33:41 -0700416 }
417}
418
Eric Laurent93c3d412014-08-01 14:48:35 -0700419audio_hw_sync_t AudioSystem::getAudioHwSyncForSession(audio_session_t sessionId)
420{
421 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
422 if (af == 0) return AUDIO_HW_SYNC_INVALID;
423 return af->getAudioHwSyncForSession(sessionId);
424}
425
Eric Laurent72e3f392015-05-20 14:43:50 -0700426status_t AudioSystem::systemReady()
427{
428 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
429 if (af == 0) return NO_INIT;
430 return af->systemReady();
431}
432
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800433// ---------------------------------------------------------------------------
434
Eric Laurent73e26b62015-04-27 16:55:58 -0700435
436void AudioSystem::AudioFlingerClient::clearIoCache()
437{
438 Mutex::Autolock _l(mLock);
439 mIoDescriptors.clear();
440 mInBuffSize = 0;
441 mInSamplingRate = 0;
442 mInFormat = AUDIO_FORMAT_DEFAULT;
443 mInChannelMask = AUDIO_CHANNEL_NONE;
444}
445
Glenn Kasten4944acb2013-08-19 08:39:20 -0700446void AudioSystem::AudioFlingerClient::binderDied(const wp<IBinder>& who __unused)
447{
Eric Laurentf6778fd2014-11-18 17:26:58 -0800448 audio_error_callback cb = NULL;
449 {
450 Mutex::Autolock _l(AudioSystem::gLock);
451 AudioSystem::gAudioFlinger.clear();
452 cb = gAudioErrorCallback;
453 }
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800454
Eric Laurent73e26b62015-04-27 16:55:58 -0700455 // clear output handles and stream to output map caches
456 clearIoCache();
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800457
Eric Laurentf6778fd2014-11-18 17:26:58 -0800458 if (cb) {
459 cb(DEAD_OBJECT);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800460 }
Steve Block5ff1dd52012-01-05 23:22:43 +0000461 ALOGW("AudioFlinger server died!");
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800462}
463
Eric Laurent73e26b62015-04-27 16:55:58 -0700464void AudioSystem::AudioFlingerClient::ioConfigChanged(audio_io_config_event event,
465 const sp<AudioIoDescriptor>& ioDesc) {
Steve Block3856b092011-10-20 11:56:00 +0100466 ALOGV("ioConfigChanged() event %d", event);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700467
Eric Laurent73e26b62015-04-27 16:55:58 -0700468 if (ioDesc == 0 || ioDesc->mIoHandle == AUDIO_IO_HANDLE_NONE) return;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700469
Eric Laurent296fb132015-05-01 11:38:42 -0700470 audio_port_handle_t deviceId = AUDIO_PORT_HANDLE_NONE;
471 Vector < sp<AudioDeviceCallback> > callbacks;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700472
Eric Laurent296fb132015-05-01 11:38:42 -0700473 {
474 Mutex::Autolock _l(mLock);
475
476 switch (event) {
477 case AUDIO_OUTPUT_OPENED:
478 case AUDIO_INPUT_OPENED: {
479 if (getIoDescriptor(ioDesc->mIoHandle) != 0) {
480 ALOGV("ioConfigChanged() opening already existing output! %d", ioDesc->mIoHandle);
481 break;
482 }
483 mIoDescriptors.add(ioDesc->mIoHandle, ioDesc);
484
485 if (ioDesc->getDeviceId() != AUDIO_PORT_HANDLE_NONE) {
486 deviceId = ioDesc->getDeviceId();
487 ssize_t ioIndex = mAudioDeviceCallbacks.indexOfKey(ioDesc->mIoHandle);
488 if (ioIndex >= 0) {
489 callbacks = mAudioDeviceCallbacks.valueAt(ioIndex);
490 }
491 }
492 ALOGV("ioConfigChanged() new %s opened %d samplingRate %u, format %#x channel mask %#x "
493 "frameCount %zu deviceId %d", event == AUDIO_OUTPUT_OPENED ? "output" : "input",
494 ioDesc->mIoHandle, ioDesc->mSamplingRate, ioDesc->mFormat, ioDesc->mChannelMask,
495 ioDesc->mFrameCount, ioDesc->getDeviceId());
496 } break;
497 case AUDIO_OUTPUT_CLOSED:
498 case AUDIO_INPUT_CLOSED: {
499 if (getIoDescriptor(ioDesc->mIoHandle) == 0) {
500 ALOGW("ioConfigChanged() closing unknown %s %d",
501 event == AUDIO_OUTPUT_CLOSED ? "output" : "input", ioDesc->mIoHandle);
502 break;
503 }
504 ALOGV("ioConfigChanged() %s %d closed",
Eric Laurent73e26b62015-04-27 16:55:58 -0700505 event == AUDIO_OUTPUT_CLOSED ? "output" : "input", ioDesc->mIoHandle);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700506
Eric Laurent296fb132015-05-01 11:38:42 -0700507 mIoDescriptors.removeItem(ioDesc->mIoHandle);
508 mAudioDeviceCallbacks.removeItem(ioDesc->mIoHandle);
509 } break;
510
511 case AUDIO_OUTPUT_CONFIG_CHANGED:
512 case AUDIO_INPUT_CONFIG_CHANGED: {
513 sp<AudioIoDescriptor> oldDesc = getIoDescriptor(ioDesc->mIoHandle);
514 if (oldDesc == 0) {
515 ALOGW("ioConfigChanged() modifying unknown output! %d", ioDesc->mIoHandle);
516 break;
517 }
518
519 deviceId = oldDesc->getDeviceId();
520 mIoDescriptors.replaceValueFor(ioDesc->mIoHandle, ioDesc);
521
522 if (deviceId != ioDesc->getDeviceId()) {
523 deviceId = ioDesc->getDeviceId();
524 ssize_t ioIndex = mAudioDeviceCallbacks.indexOfKey(ioDesc->mIoHandle);
525 if (ioIndex >= 0) {
526 callbacks = mAudioDeviceCallbacks.valueAt(ioIndex);
527 }
528 }
529 ALOGV("ioConfigChanged() new config for %s %d samplingRate %u, format %#x "
530 "channel mask %#x frameCount %zu deviceId %d",
531 event == AUDIO_OUTPUT_CONFIG_CHANGED ? "output" : "input",
532 ioDesc->mIoHandle, ioDesc->mSamplingRate, ioDesc->mFormat,
533 ioDesc->mChannelMask, ioDesc->mFrameCount, ioDesc->getDeviceId());
534
Eric Laurentc2f1f072009-07-17 12:17:14 -0700535 } break;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700536 }
Eric Laurent296fb132015-05-01 11:38:42 -0700537 }
538 // callbacks.size() != 0 => ioDesc->mIoHandle and deviceId are valid
539 for (size_t i = 0; i < callbacks.size(); i++) {
540 callbacks[i]->onAudioDeviceUpdate(ioDesc->mIoHandle, deviceId);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700541 }
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800542}
543
Eric Laurent73e26b62015-04-27 16:55:58 -0700544status_t AudioSystem::AudioFlingerClient::getInputBufferSize(
545 uint32_t sampleRate, audio_format_t format,
546 audio_channel_mask_t channelMask, size_t* buffSize)
547{
548 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
549 if (af == 0) {
550 return PERMISSION_DENIED;
551 }
552 Mutex::Autolock _l(mLock);
553 // Do we have a stale mInBuffSize or are we requesting the input buffer size for new values
554 if ((mInBuffSize == 0) || (sampleRate != mInSamplingRate) || (format != mInFormat)
555 || (channelMask != mInChannelMask)) {
556 size_t inBuffSize = af->getInputBufferSize(sampleRate, format, channelMask);
557 if (inBuffSize == 0) {
558 ALOGE("AudioSystem::getInputBufferSize failed sampleRate %d format %#x channelMask %x",
559 sampleRate, format, channelMask);
560 return BAD_VALUE;
561 }
562 // A benign race is possible here: we could overwrite a fresher cache entry
563 // save the request params
564 mInSamplingRate = sampleRate;
565 mInFormat = format;
566 mInChannelMask = channelMask;
567
568 mInBuffSize = inBuffSize;
569 }
570
571 *buffSize = mInBuffSize;
572
573 return NO_ERROR;
574}
575
576sp<AudioIoDescriptor> AudioSystem::AudioFlingerClient::getIoDescriptor(audio_io_handle_t ioHandle)
577{
578 sp<AudioIoDescriptor> desc;
579 ssize_t index = mIoDescriptors.indexOfKey(ioHandle);
580 if (index >= 0) {
581 desc = mIoDescriptors.valueAt(index);
582 }
583 return desc;
584}
585
Eric Laurent296fb132015-05-01 11:38:42 -0700586status_t AudioSystem::AudioFlingerClient::addAudioDeviceCallback(
587 const sp<AudioDeviceCallback>& callback, audio_io_handle_t audioIo)
588{
589 Mutex::Autolock _l(mLock);
590 Vector < sp<AudioDeviceCallback> > callbacks;
591 ssize_t ioIndex = mAudioDeviceCallbacks.indexOfKey(audioIo);
592 if (ioIndex >= 0) {
593 callbacks = mAudioDeviceCallbacks.valueAt(ioIndex);
594 }
595
596 for (size_t cbIndex = 0; cbIndex < callbacks.size(); cbIndex++) {
597 if (callbacks[cbIndex] == callback) {
598 return INVALID_OPERATION;
599 }
600 }
601 callbacks.add(callback);
602
603 mAudioDeviceCallbacks.replaceValueFor(audioIo, callbacks);
604 return NO_ERROR;
605}
606
607status_t AudioSystem::AudioFlingerClient::removeAudioDeviceCallback(
608 const sp<AudioDeviceCallback>& callback, audio_io_handle_t audioIo)
609{
610 Mutex::Autolock _l(mLock);
611 ssize_t ioIndex = mAudioDeviceCallbacks.indexOfKey(audioIo);
612 if (ioIndex < 0) {
613 return INVALID_OPERATION;
614 }
615 Vector < sp<AudioDeviceCallback> > callbacks = mAudioDeviceCallbacks.valueAt(ioIndex);
616
617 size_t cbIndex;
618 for (cbIndex = 0; cbIndex < callbacks.size(); cbIndex++) {
619 if (callbacks[cbIndex] == callback) {
620 break;
621 }
622 }
623 if (cbIndex == callbacks.size()) {
624 return INVALID_OPERATION;
625 }
626 callbacks.removeAt(cbIndex);
627 if (callbacks.size() != 0) {
628 mAudioDeviceCallbacks.replaceValueFor(audioIo, callbacks);
629 } else {
630 mAudioDeviceCallbacks.removeItem(audioIo);
631 }
632 return NO_ERROR;
633}
634
635/* static */ void AudioSystem::setErrorCallback(audio_error_callback cb)
Glenn Kasten4944acb2013-08-19 08:39:20 -0700636{
Eric Laurentc2f1f072009-07-17 12:17:14 -0700637 Mutex::Autolock _l(gLock);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800638 gAudioErrorCallback = cb;
639}
640
Jean-Michel Trivif613d422015-04-23 18:41:29 -0700641/*static*/ void AudioSystem::setDynPolicyCallback(dynamic_policy_callback cb)
642{
643 Mutex::Autolock _l(gLock);
644 gDynPolicyCallback = cb;
645}
646
Eric Laurentc2f1f072009-07-17 12:17:14 -0700647// client singleton for AudioPolicyService binder interface
Glenn Kastend2d089f2014-11-05 11:48:12 -0800648// protected by gLockAPS
Eric Laurentc2f1f072009-07-17 12:17:14 -0700649sp<IAudioPolicyService> AudioSystem::gAudioPolicyService;
650sp<AudioSystem::AudioPolicyServiceClient> AudioSystem::gAudioPolicyServiceClient;
651
652
Glenn Kasten18a6d902012-09-24 11:27:56 -0700653// establish binder interface to AudioPolicy service
Eric Laurent0ebd5f92014-11-19 19:04:52 -0800654const sp<IAudioPolicyService> AudioSystem::get_audio_policy_service()
Eric Laurentc2f1f072009-07-17 12:17:14 -0700655{
Eric Laurent0ebd5f92014-11-19 19:04:52 -0800656 sp<IAudioPolicyService> ap;
657 sp<AudioPolicyServiceClient> apc;
658 {
659 Mutex::Autolock _l(gLockAPS);
660 if (gAudioPolicyService == 0) {
661 sp<IServiceManager> sm = defaultServiceManager();
662 sp<IBinder> binder;
663 do {
664 binder = sm->getService(String16("media.audio_policy"));
665 if (binder != 0)
666 break;
667 ALOGW("AudioPolicyService not published, waiting...");
668 usleep(500000); // 0.5 s
669 } while (true);
670 if (gAudioPolicyServiceClient == NULL) {
671 gAudioPolicyServiceClient = new AudioPolicyServiceClient();
672 }
673 binder->linkToDeath(gAudioPolicyServiceClient);
674 gAudioPolicyService = interface_cast<IAudioPolicyService>(binder);
675 LOG_ALWAYS_FATAL_IF(gAudioPolicyService == 0);
676 apc = gAudioPolicyServiceClient;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700677 }
Eric Laurent0ebd5f92014-11-19 19:04:52 -0800678 ap = gAudioPolicyService;
679 }
680 if (apc != 0) {
681 ap->registerClient(apc);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700682 }
Glenn Kastend2d089f2014-11-05 11:48:12 -0800683
Eric Laurent0ebd5f92014-11-19 19:04:52 -0800684 return ap;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700685}
686
Glenn Kastenfb1fdc92013-07-10 17:03:19 -0700687// ---------------------------------------------------------------------------
688
Dima Zavinfce7a472011-04-19 22:30:36 -0700689status_t AudioSystem::setDeviceConnectionState(audio_devices_t device,
690 audio_policy_dev_state_t state,
Paul McLeane743a472015-01-28 11:07:31 -0800691 const char *device_address,
692 const char *device_name)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700693{
694 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
Eric Laurent71b63e32011-09-02 14:20:56 -0700695 const char *address = "";
Paul McLeane743a472015-01-28 11:07:31 -0800696 const char *name = "";
Eric Laurent71b63e32011-09-02 14:20:56 -0700697
Eric Laurentc2f1f072009-07-17 12:17:14 -0700698 if (aps == 0) return PERMISSION_DENIED;
699
Eric Laurent71b63e32011-09-02 14:20:56 -0700700 if (device_address != NULL) {
701 address = device_address;
702 }
Paul McLeane743a472015-01-28 11:07:31 -0800703 if (device_name != NULL) {
704 name = device_name;
705 }
706 return aps->setDeviceConnectionState(device, state, address, name);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700707}
708
Dima Zavinfce7a472011-04-19 22:30:36 -0700709audio_policy_dev_state_t AudioSystem::getDeviceConnectionState(audio_devices_t device,
Eric Laurentc2f1f072009-07-17 12:17:14 -0700710 const char *device_address)
711{
712 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
Dima Zavinfce7a472011-04-19 22:30:36 -0700713 if (aps == 0) return AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700714
715 return aps->getDeviceConnectionState(device, device_address);
716}
717
Glenn Kastenf78aee72012-01-04 11:00:47 -0800718status_t AudioSystem::setPhoneState(audio_mode_t state)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700719{
Glenn Kasten347966c2012-01-18 14:58:32 -0800720 if (uint32_t(state) >= AUDIO_MODE_CNT) return BAD_VALUE;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700721 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
722 if (aps == 0) return PERMISSION_DENIED;
723
724 return aps->setPhoneState(state);
725}
726
Dima Zavinfce7a472011-04-19 22:30:36 -0700727status_t AudioSystem::setForceUse(audio_policy_force_use_t usage, audio_policy_forced_cfg_t config)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700728{
729 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
730 if (aps == 0) return PERMISSION_DENIED;
731 return aps->setForceUse(usage, config);
732}
733
Dima Zavinfce7a472011-04-19 22:30:36 -0700734audio_policy_forced_cfg_t AudioSystem::getForceUse(audio_policy_force_use_t usage)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700735{
736 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
Dima Zavinfce7a472011-04-19 22:30:36 -0700737 if (aps == 0) return AUDIO_POLICY_FORCE_NONE;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700738 return aps->getForceUse(usage);
739}
740
741
Dima Zavinfce7a472011-04-19 22:30:36 -0700742audio_io_handle_t AudioSystem::getOutput(audio_stream_type_t stream,
Eric Laurentc2f1f072009-07-17 12:17:14 -0700743 uint32_t samplingRate,
Glenn Kasten58f30212012-01-12 12:27:51 -0800744 audio_format_t format,
Glenn Kasten254af182012-07-03 14:59:05 -0700745 audio_channel_mask_t channelMask,
Richard Fitzgeraldad3af332013-03-25 16:54:37 +0000746 audio_output_flags_t flags,
747 const audio_offload_info_t *offloadInfo)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700748{
Eric Laurent1a9ed112012-03-20 18:36:01 -0700749 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
750 if (aps == 0) return 0;
Richard Fitzgeraldad3af332013-03-25 16:54:37 +0000751 return aps->getOutput(stream, samplingRate, format, channelMask, flags, offloadInfo);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700752}
753
Eric Laurente83b55d2014-11-14 10:06:21 -0800754status_t AudioSystem::getOutputForAttr(const audio_attributes_t *attr,
755 audio_io_handle_t *output,
756 audio_session_t session,
757 audio_stream_type_t *stream,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700758 uid_t uid,
Eric Laurente83b55d2014-11-14 10:06:21 -0800759 uint32_t samplingRate,
760 audio_format_t format,
761 audio_channel_mask_t channelMask,
762 audio_output_flags_t flags,
Paul McLeanaa981192015-03-21 09:55:15 -0700763 audio_port_handle_t selectedDeviceId,
Eric Laurente83b55d2014-11-14 10:06:21 -0800764 const audio_offload_info_t *offloadInfo)
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700765{
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700766 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
Eric Laurente83b55d2014-11-14 10:06:21 -0800767 if (aps == 0) return NO_INIT;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700768 return aps->getOutputForAttr(attr, output, session, stream, uid,
Eric Laurente83b55d2014-11-14 10:06:21 -0800769 samplingRate, format, channelMask,
Paul McLeanaa981192015-03-21 09:55:15 -0700770 flags, selectedDeviceId, offloadInfo);
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700771}
772
Eric Laurentde070132010-07-13 04:45:46 -0700773status_t AudioSystem::startOutput(audio_io_handle_t output,
Dima Zavinfce7a472011-04-19 22:30:36 -0700774 audio_stream_type_t stream,
Eric Laurente83b55d2014-11-14 10:06:21 -0800775 audio_session_t session)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700776{
777 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
778 if (aps == 0) return PERMISSION_DENIED;
Eric Laurentde070132010-07-13 04:45:46 -0700779 return aps->startOutput(output, stream, session);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700780}
781
Eric Laurentde070132010-07-13 04:45:46 -0700782status_t AudioSystem::stopOutput(audio_io_handle_t output,
Dima Zavinfce7a472011-04-19 22:30:36 -0700783 audio_stream_type_t stream,
Eric Laurente83b55d2014-11-14 10:06:21 -0800784 audio_session_t session)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700785{
786 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
787 if (aps == 0) return PERMISSION_DENIED;
Eric Laurentde070132010-07-13 04:45:46 -0700788 return aps->stopOutput(output, stream, session);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700789}
790
Eric Laurente83b55d2014-11-14 10:06:21 -0800791void AudioSystem::releaseOutput(audio_io_handle_t output,
792 audio_stream_type_t stream,
793 audio_session_t session)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700794{
795 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
796 if (aps == 0) return;
Eric Laurente83b55d2014-11-14 10:06:21 -0800797 aps->releaseOutput(output, stream, session);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700798}
799
Eric Laurentcaf7f482014-11-25 17:50:47 -0800800status_t AudioSystem::getInputForAttr(const audio_attributes_t *attr,
801 audio_io_handle_t *input,
802 audio_session_t session,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700803 uid_t uid,
Eric Laurentcaf7f482014-11-25 17:50:47 -0800804 uint32_t samplingRate,
805 audio_format_t format,
806 audio_channel_mask_t channelMask,
Paul McLean466dc8e2015-04-17 13:15:36 -0600807 audio_input_flags_t flags,
808 audio_port_handle_t selectedDeviceId)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700809{
810 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
Eric Laurentcaf7f482014-11-25 17:50:47 -0800811 if (aps == 0) return NO_INIT;
Paul McLean466dc8e2015-04-17 13:15:36 -0600812 return aps->getInputForAttr(
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700813 attr, input, session, uid, samplingRate, format, channelMask, flags, selectedDeviceId);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700814}
815
Eric Laurent4dc68062014-07-28 17:26:49 -0700816status_t AudioSystem::startInput(audio_io_handle_t input,
817 audio_session_t session)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700818{
819 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
820 if (aps == 0) return PERMISSION_DENIED;
Eric Laurent4dc68062014-07-28 17:26:49 -0700821 return aps->startInput(input, session);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700822}
823
Eric Laurent4dc68062014-07-28 17:26:49 -0700824status_t AudioSystem::stopInput(audio_io_handle_t input,
825 audio_session_t session)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700826{
827 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
828 if (aps == 0) return PERMISSION_DENIED;
Eric Laurent4dc68062014-07-28 17:26:49 -0700829 return aps->stopInput(input, session);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700830}
831
Eric Laurent4dc68062014-07-28 17:26:49 -0700832void AudioSystem::releaseInput(audio_io_handle_t input,
833 audio_session_t session)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700834{
835 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
836 if (aps == 0) return;
Eric Laurent4dc68062014-07-28 17:26:49 -0700837 aps->releaseInput(input, session);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700838}
839
Dima Zavinfce7a472011-04-19 22:30:36 -0700840status_t AudioSystem::initStreamVolume(audio_stream_type_t stream,
Eric Laurentc2f1f072009-07-17 12:17:14 -0700841 int indexMin,
842 int indexMax)
843{
844 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
845 if (aps == 0) return PERMISSION_DENIED;
846 return aps->initStreamVolume(stream, indexMin, indexMax);
847}
848
Eric Laurent83844cc2011-11-18 16:43:31 -0800849status_t AudioSystem::setStreamVolumeIndex(audio_stream_type_t stream,
850 int index,
851 audio_devices_t device)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700852{
853 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
854 if (aps == 0) return PERMISSION_DENIED;
Eric Laurent83844cc2011-11-18 16:43:31 -0800855 return aps->setStreamVolumeIndex(stream, index, device);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700856}
857
Eric Laurent83844cc2011-11-18 16:43:31 -0800858status_t AudioSystem::getStreamVolumeIndex(audio_stream_type_t stream,
859 int *index,
860 audio_devices_t device)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700861{
862 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
863 if (aps == 0) return PERMISSION_DENIED;
Eric Laurent83844cc2011-11-18 16:43:31 -0800864 return aps->getStreamVolumeIndex(stream, index, device);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700865}
866
Dima Zavinfce7a472011-04-19 22:30:36 -0700867uint32_t AudioSystem::getStrategyForStream(audio_stream_type_t stream)
Eric Laurentde070132010-07-13 04:45:46 -0700868{
869 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
870 if (aps == 0) return 0;
871 return aps->getStrategyForStream(stream);
872}
873
Eric Laurent63742522012-03-08 13:42:42 -0800874audio_devices_t AudioSystem::getDevicesForStream(audio_stream_type_t stream)
Glenn Kasten6b2718c2011-02-04 13:54:26 -0800875{
876 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
Glenn Kasten45faf7e2014-01-17 10:23:01 -0800877 if (aps == 0) return AUDIO_DEVICE_NONE;
Glenn Kasten6b2718c2011-02-04 13:54:26 -0800878 return aps->getDevicesForStream(stream);
879}
880
Glenn Kasten58e5aa32012-06-20 14:08:14 -0700881audio_io_handle_t AudioSystem::getOutputForEffect(const effect_descriptor_t *desc)
Eric Laurentde070132010-07-13 04:45:46 -0700882{
883 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
Glenn Kastenefa6ea92014-01-08 09:10:43 -0800884 // FIXME change return type to status_t, and return PERMISSION_DENIED here
Glenn Kasten142f5192014-03-25 17:44:59 -0700885 if (aps == 0) return AUDIO_IO_HANDLE_NONE;
Eric Laurentde070132010-07-13 04:45:46 -0700886 return aps->getOutputForEffect(desc);
887}
888
Glenn Kasten58e5aa32012-06-20 14:08:14 -0700889status_t AudioSystem::registerEffect(const effect_descriptor_t *desc,
Eric Laurent7c7f10b2011-06-17 21:29:58 -0700890 audio_io_handle_t io,
Eric Laurentde070132010-07-13 04:45:46 -0700891 uint32_t strategy,
892 int session,
893 int id)
894{
895 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
896 if (aps == 0) return PERMISSION_DENIED;
Eric Laurent7c7f10b2011-06-17 21:29:58 -0700897 return aps->registerEffect(desc, io, strategy, session, id);
Eric Laurentde070132010-07-13 04:45:46 -0700898}
899
900status_t AudioSystem::unregisterEffect(int id)
901{
902 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
903 if (aps == 0) return PERMISSION_DENIED;
904 return aps->unregisterEffect(id);
905}
906
Eric Laurentdb7c0792011-08-10 10:37:50 -0700907status_t AudioSystem::setEffectEnabled(int id, bool enabled)
908{
909 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
910 if (aps == 0) return PERMISSION_DENIED;
911 return aps->setEffectEnabled(id, enabled);
912}
913
Glenn Kastenfff6d712012-01-12 16:38:12 -0800914status_t AudioSystem::isStreamActive(audio_stream_type_t stream, bool* state, uint32_t inPastMs)
Eric Laurent7c7f10b2011-06-17 21:29:58 -0700915{
Eric Laurenteda6c362011-02-02 09:33:30 -0800916 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
917 if (aps == 0) return PERMISSION_DENIED;
Eric Laurent7c7f10b2011-06-17 21:29:58 -0700918 if (state == NULL) return BAD_VALUE;
Eric Laurenteda6c362011-02-02 09:33:30 -0800919 *state = aps->isStreamActive(stream, inPastMs);
920 return NO_ERROR;
921}
922
Jean-Michel Trivi272ab542013-02-04 16:26:02 -0800923status_t AudioSystem::isStreamActiveRemotely(audio_stream_type_t stream, bool* state,
924 uint32_t inPastMs)
925{
926 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
927 if (aps == 0) return PERMISSION_DENIED;
928 if (state == NULL) return BAD_VALUE;
929 *state = aps->isStreamActiveRemotely(stream, inPastMs);
930 return NO_ERROR;
931}
932
Jean-Michel Trivid7086032012-10-10 12:11:16 -0700933status_t AudioSystem::isSourceActive(audio_source_t stream, bool* state)
934{
935 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
936 if (aps == 0) return PERMISSION_DENIED;
937 if (state == NULL) return BAD_VALUE;
938 *state = aps->isSourceActive(stream);
939 return NO_ERROR;
940}
941
Glenn Kasten3b16c762012-11-14 08:44:39 -0800942uint32_t AudioSystem::getPrimaryOutputSamplingRate()
Glenn Kastencc0f1cf2012-09-24 11:27:18 -0700943{
944 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
945 if (af == 0) return 0;
946 return af->getPrimaryOutputSamplingRate();
947}
948
Glenn Kastene33054e2012-11-14 12:54:39 -0800949size_t AudioSystem::getPrimaryOutputFrameCount()
Glenn Kastencc0f1cf2012-09-24 11:27:18 -0700950{
951 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
952 if (af == 0) return 0;
953 return af->getPrimaryOutputFrameCount();
954}
Eric Laurenteda6c362011-02-02 09:33:30 -0800955
Glenn Kasten4182c4e2013-07-15 14:45:07 -0700956status_t AudioSystem::setLowRamDevice(bool isLowRamDevice)
957{
958 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
959 if (af == 0) return PERMISSION_DENIED;
960 return af->setLowRamDevice(isLowRamDevice);
961}
962
Eric Laurent9f6530f2011-08-30 10:18:54 -0700963void AudioSystem::clearAudioConfigCache()
964{
Glenn Kastend2d089f2014-11-05 11:48:12 -0800965 // called by restoreTrack_l(), which needs new IAudioFlinger and IAudioPolicyService instances
Steve Block3856b092011-10-20 11:56:00 +0100966 ALOGV("clearAudioConfigCache()");
Eric Laurentf6778fd2014-11-18 17:26:58 -0800967 {
968 Mutex::Autolock _l(gLock);
Eric Laurent296fb132015-05-01 11:38:42 -0700969 if (gAudioFlingerClient != 0) {
970 gAudioFlingerClient->clearIoCache();
971 }
Glenn Kastend2d089f2014-11-05 11:48:12 -0800972 gAudioFlinger.clear();
973 }
974 {
975 Mutex::Autolock _l(gLockAPS);
976 gAudioPolicyService.clear();
977 }
Eric Laurent9f6530f2011-08-30 10:18:54 -0700978}
979
Richard Fitzgeraldad3af332013-03-25 16:54:37 +0000980bool AudioSystem::isOffloadSupported(const audio_offload_info_t& info)
981{
982 ALOGV("isOffloadSupported()");
983 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
984 if (aps == 0) return false;
985 return aps->isOffloadSupported(info);
986}
987
Eric Laurent203b1a12014-04-01 10:34:16 -0700988status_t AudioSystem::listAudioPorts(audio_port_role_t role,
989 audio_port_type_t type,
990 unsigned int *num_ports,
991 struct audio_port *ports,
992 unsigned int *generation)
993{
994 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
995 if (aps == 0) return PERMISSION_DENIED;
996 return aps->listAudioPorts(role, type, num_ports, ports, generation);
997}
998
999status_t AudioSystem::getAudioPort(struct audio_port *port)
1000{
1001 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
1002 if (aps == 0) return PERMISSION_DENIED;
1003 return aps->getAudioPort(port);
1004}
1005
1006status_t AudioSystem::createAudioPatch(const struct audio_patch *patch,
1007 audio_patch_handle_t *handle)
1008{
1009 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
1010 if (aps == 0) return PERMISSION_DENIED;
1011 return aps->createAudioPatch(patch, handle);
1012}
1013
1014status_t AudioSystem::releaseAudioPatch(audio_patch_handle_t handle)
1015{
1016 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
1017 if (aps == 0) return PERMISSION_DENIED;
1018 return aps->releaseAudioPatch(handle);
1019}
1020
1021status_t AudioSystem::listAudioPatches(unsigned int *num_patches,
1022 struct audio_patch *patches,
1023 unsigned int *generation)
1024{
1025 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
1026 if (aps == 0) return PERMISSION_DENIED;
1027 return aps->listAudioPatches(num_patches, patches, generation);
1028}
1029
1030status_t AudioSystem::setAudioPortConfig(const struct audio_port_config *config)
1031{
1032 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
1033 if (aps == 0) return PERMISSION_DENIED;
1034 return aps->setAudioPortConfig(config);
1035}
1036
Eric Laurent296fb132015-05-01 11:38:42 -07001037status_t AudioSystem::addAudioPortCallback(const sp<AudioPortCallback>& callback)
Eric Laurentb52c1522014-05-20 11:27:36 -07001038{
Eric Laurentb28753e2015-04-01 13:06:28 -07001039 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
1040 if (aps == 0) return PERMISSION_DENIED;
1041
1042 Mutex::Autolock _l(gLockAPS);
1043 if (gAudioPolicyServiceClient == 0) {
1044 return NO_INIT;
1045 }
Eric Laurente8726fe2015-06-26 09:39:24 -07001046 int ret = gAudioPolicyServiceClient->addAudioPortCallback(callback);
1047 if (ret == 1) {
1048 aps->setAudioPortCallbacksEnabled(true);
1049 }
1050 return (ret < 0) ? INVALID_OPERATION : NO_ERROR;
Eric Laurentb52c1522014-05-20 11:27:36 -07001051}
1052
Jean-Michel Trivif613d422015-04-23 18:41:29 -07001053/*static*/
Eric Laurent296fb132015-05-01 11:38:42 -07001054status_t AudioSystem::removeAudioPortCallback(const sp<AudioPortCallback>& callback)
Eric Laurentb28753e2015-04-01 13:06:28 -07001055{
1056 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
1057 if (aps == 0) return PERMISSION_DENIED;
1058
1059 Mutex::Autolock _l(gLockAPS);
1060 if (gAudioPolicyServiceClient == 0) {
1061 return NO_INIT;
1062 }
Eric Laurente8726fe2015-06-26 09:39:24 -07001063 int ret = gAudioPolicyServiceClient->removeAudioPortCallback(callback);
1064 if (ret == 0) {
1065 aps->setAudioPortCallbacksEnabled(false);
1066 }
1067 return (ret < 0) ? INVALID_OPERATION : NO_ERROR;
Eric Laurent296fb132015-05-01 11:38:42 -07001068}
1069
1070status_t AudioSystem::addAudioDeviceCallback(
1071 const sp<AudioDeviceCallback>& callback, audio_io_handle_t audioIo)
1072{
1073 const sp<AudioFlingerClient> afc = getAudioFlingerClient();
1074 if (afc == 0) {
1075 return NO_INIT;
1076 }
1077 return afc->addAudioDeviceCallback(callback, audioIo);
1078}
1079
1080status_t AudioSystem::removeAudioDeviceCallback(
1081 const sp<AudioDeviceCallback>& callback, audio_io_handle_t audioIo)
1082{
1083 const sp<AudioFlingerClient> afc = getAudioFlingerClient();
1084 if (afc == 0) {
1085 return NO_INIT;
1086 }
1087 return afc->removeAudioDeviceCallback(callback, audioIo);
1088}
1089
1090audio_port_handle_t AudioSystem::getDeviceIdForIo(audio_io_handle_t audioIo)
1091{
1092 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
1093 if (af == 0) return PERMISSION_DENIED;
1094 const sp<AudioIoDescriptor> desc = getIoDescriptor(audioIo);
1095 if (desc == 0) {
1096 return AUDIO_PORT_HANDLE_NONE;
1097 }
1098 return desc->getDeviceId();
Eric Laurentb28753e2015-04-01 13:06:28 -07001099}
1100
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001101status_t AudioSystem::acquireSoundTriggerSession(audio_session_t *session,
1102 audio_io_handle_t *ioHandle,
1103 audio_devices_t *device)
1104{
1105 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
1106 if (aps == 0) return PERMISSION_DENIED;
1107 return aps->acquireSoundTriggerSession(session, ioHandle, device);
1108}
1109
1110status_t AudioSystem::releaseSoundTriggerSession(audio_session_t session)
1111{
1112 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
1113 if (aps == 0) return PERMISSION_DENIED;
1114 return aps->releaseSoundTriggerSession(session);
1115}
Eric Laurentbb6c9a02014-09-25 14:11:47 -07001116
1117audio_mode_t AudioSystem::getPhoneState()
1118{
1119 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
1120 if (aps == 0) return AUDIO_MODE_INVALID;
1121 return aps->getPhoneState();
1122}
1123
Eric Laurentbaac1832014-12-01 17:52:59 -08001124status_t AudioSystem::registerPolicyMixes(Vector<AudioMix> mixes, bool registration)
1125{
1126 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
1127 if (aps == 0) return PERMISSION_DENIED;
1128 return aps->registerPolicyMixes(mixes, registration);
1129}
Eric Laurentbb6c9a02014-09-25 14:11:47 -07001130
Eric Laurent554a2772015-04-10 11:29:24 -07001131status_t AudioSystem::startAudioSource(const struct audio_port_config *source,
1132 const audio_attributes_t *attributes,
1133 audio_io_handle_t *handle)
1134{
1135 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
1136 if (aps == 0) return PERMISSION_DENIED;
1137 return aps->startAudioSource(source, attributes, handle);
1138}
1139
1140status_t AudioSystem::stopAudioSource(audio_io_handle_t handle)
1141{
1142 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
1143 if (aps == 0) return PERMISSION_DENIED;
1144 return aps->stopAudioSource(handle);
1145}
1146
Eric Laurentc2f1f072009-07-17 12:17:14 -07001147// ---------------------------------------------------------------------------
1148
Eric Laurente8726fe2015-06-26 09:39:24 -07001149int AudioSystem::AudioPolicyServiceClient::addAudioPortCallback(
Eric Laurent296fb132015-05-01 11:38:42 -07001150 const sp<AudioPortCallback>& callback)
Eric Laurentb28753e2015-04-01 13:06:28 -07001151{
1152 Mutex::Autolock _l(mLock);
1153 for (size_t i = 0; i < mAudioPortCallbacks.size(); i++) {
Eric Laurent296fb132015-05-01 11:38:42 -07001154 if (mAudioPortCallbacks[i] == callback) {
Eric Laurente8726fe2015-06-26 09:39:24 -07001155 return -1;
Eric Laurentb28753e2015-04-01 13:06:28 -07001156 }
1157 }
Eric Laurent296fb132015-05-01 11:38:42 -07001158 mAudioPortCallbacks.add(callback);
Eric Laurente8726fe2015-06-26 09:39:24 -07001159 return mAudioPortCallbacks.size();
Eric Laurentb28753e2015-04-01 13:06:28 -07001160}
1161
Eric Laurente8726fe2015-06-26 09:39:24 -07001162int AudioSystem::AudioPolicyServiceClient::removeAudioPortCallback(
Eric Laurent296fb132015-05-01 11:38:42 -07001163 const sp<AudioPortCallback>& callback)
Eric Laurentb28753e2015-04-01 13:06:28 -07001164{
1165 Mutex::Autolock _l(mLock);
1166 size_t i;
1167 for (i = 0; i < mAudioPortCallbacks.size(); i++) {
Eric Laurent296fb132015-05-01 11:38:42 -07001168 if (mAudioPortCallbacks[i] == callback) {
Eric Laurentb28753e2015-04-01 13:06:28 -07001169 break;
1170 }
1171 }
1172 if (i == mAudioPortCallbacks.size()) {
Eric Laurente8726fe2015-06-26 09:39:24 -07001173 return -1;
Eric Laurentb28753e2015-04-01 13:06:28 -07001174 }
1175 mAudioPortCallbacks.removeAt(i);
Eric Laurente8726fe2015-06-26 09:39:24 -07001176 return mAudioPortCallbacks.size();
Eric Laurentb28753e2015-04-01 13:06:28 -07001177}
1178
Eric Laurent296fb132015-05-01 11:38:42 -07001179
Eric Laurentb28753e2015-04-01 13:06:28 -07001180void AudioSystem::AudioPolicyServiceClient::onAudioPortListUpdate()
1181{
1182 Mutex::Autolock _l(mLock);
1183 for (size_t i = 0; i < mAudioPortCallbacks.size(); i++) {
1184 mAudioPortCallbacks[i]->onAudioPortListUpdate();
1185 }
1186}
1187
1188void AudioSystem::AudioPolicyServiceClient::onAudioPatchListUpdate()
1189{
1190 Mutex::Autolock _l(mLock);
1191 for (size_t i = 0; i < mAudioPortCallbacks.size(); i++) {
1192 mAudioPortCallbacks[i]->onAudioPatchListUpdate();
1193 }
1194}
1195
Jean-Michel Trivide801052015-04-14 19:10:14 -07001196void AudioSystem::AudioPolicyServiceClient::onDynamicPolicyMixStateUpdate(
1197 String8 regId, int32_t state)
1198{
Jean-Michel Trivif613d422015-04-23 18:41:29 -07001199 ALOGV("AudioPolicyServiceClient::onDynamicPolicyMixStateUpdate(%s, %d)", regId.string(), state);
1200 dynamic_policy_callback cb = NULL;
1201 {
1202 Mutex::Autolock _l(AudioSystem::gLock);
1203 cb = gDynPolicyCallback;
1204 }
1205
1206 if (cb != NULL) {
1207 cb(DYNAMIC_POLICY_EVENT_MIX_STATE_UPDATE, regId, state);
1208 }
Jean-Michel Trivide801052015-04-14 19:10:14 -07001209}
1210
Glenn Kasten4944acb2013-08-19 08:39:20 -07001211void AudioSystem::AudioPolicyServiceClient::binderDied(const wp<IBinder>& who __unused)
1212{
Glenn Kastend2d089f2014-11-05 11:48:12 -08001213 {
Eric Laurentb28753e2015-04-01 13:06:28 -07001214 Mutex::Autolock _l(mLock);
1215 for (size_t i = 0; i < mAudioPortCallbacks.size(); i++) {
1216 mAudioPortCallbacks[i]->onServiceDied();
Glenn Kastend2d089f2014-11-05 11:48:12 -08001217 }
Eric Laurentb52c1522014-05-20 11:27:36 -07001218 }
Glenn Kastend2d089f2014-11-05 11:48:12 -08001219 {
1220 Mutex::Autolock _l(gLockAPS);
1221 AudioSystem::gAudioPolicyService.clear();
1222 }
Eric Laurentc2f1f072009-07-17 12:17:14 -07001223
Steve Block5ff1dd52012-01-05 23:22:43 +00001224 ALOGW("AudioPolicyService server died!");
Eric Laurentc2f1f072009-07-17 12:17:14 -07001225}
1226
Glenn Kasten40bc9062015-03-20 09:09:33 -07001227} // namespace android