1 /*
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>
21 #include <binder/IServiceManager.h>
22 #include <media/AudioSystem.h>
23 #include <media/IAudioFlinger.h>
24 #include <media/IAudioPolicyService.h>
25 #include <math.h>
26
27 #include <system/audio.h>
28
29 // ----------------------------------------------------------------------------
30
31 namespace android {
32
33 // client singleton for AudioFlinger binder interface
34 Mutex AudioSystem::gLock;
35 sp<IAudioFlinger> AudioSystem::gAudioFlinger;
36 sp<AudioSystem::AudioFlingerClient> AudioSystem::gAudioFlingerClient;
37 audio_error_callback AudioSystem::gAudioErrorCallback = NULL;
38
39 // Cached values for output handles
40 DefaultKeyedVector<audio_io_handle_t, AudioSystem::OutputDescriptor *> AudioSystem::gOutputs(NULL);
41
42 // Cached values for recording queries, all protected by gLock
43 uint32_t AudioSystem::gPrevInSamplingRate;
44 audio_format_t AudioSystem::gPrevInFormat;
45 audio_channel_mask_t AudioSystem::gPrevInChannelMask;
46 size_t AudioSystem::gInBuffSize = 0; // zero indicates cache is invalid
47
48 sp<AudioSystem::AudioPortCallback> AudioSystem::gAudioPortCallback;
49
50 // establish binder interface to AudioFlinger service
get_audio_flinger()51 const sp<IAudioFlinger>& AudioSystem::get_audio_flinger()
52 {
53 Mutex::Autolock _l(gLock);
54 if (gAudioFlinger == 0) {
55 sp<IServiceManager> sm = defaultServiceManager();
56 sp<IBinder> binder;
57 do {
58 binder = sm->getService(String16("media.audio_flinger"));
59 if (binder != 0)
60 break;
61 ALOGW("AudioFlinger not published, waiting...");
62 usleep(500000); // 0.5 s
63 } while (true);
64 if (gAudioFlingerClient == NULL) {
65 gAudioFlingerClient = new AudioFlingerClient();
66 } else {
67 if (gAudioErrorCallback) {
68 gAudioErrorCallback(NO_ERROR);
69 }
70 }
71 binder->linkToDeath(gAudioFlingerClient);
72 gAudioFlinger = interface_cast<IAudioFlinger>(binder);
73 gAudioFlinger->registerClient(gAudioFlingerClient);
74 }
75 ALOGE_IF(gAudioFlinger==0, "no AudioFlinger!?");
76
77 return gAudioFlinger;
78 }
79
checkAudioFlinger()80 /* static */ status_t AudioSystem::checkAudioFlinger()
81 {
82 if (defaultServiceManager()->checkService(String16("media.audio_flinger")) != 0) {
83 return NO_ERROR;
84 }
85 return DEAD_OBJECT;
86 }
87
muteMicrophone(bool state)88 status_t AudioSystem::muteMicrophone(bool state)
89 {
90 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
91 if (af == 0) return PERMISSION_DENIED;
92 return af->setMicMute(state);
93 }
94
isMicrophoneMuted(bool * state)95 status_t AudioSystem::isMicrophoneMuted(bool* state)
96 {
97 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
98 if (af == 0) return PERMISSION_DENIED;
99 *state = af->getMicMute();
100 return NO_ERROR;
101 }
102
setMasterVolume(float value)103 status_t AudioSystem::setMasterVolume(float value)
104 {
105 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
106 if (af == 0) return PERMISSION_DENIED;
107 af->setMasterVolume(value);
108 return NO_ERROR;
109 }
110
setMasterMute(bool mute)111 status_t AudioSystem::setMasterMute(bool mute)
112 {
113 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
114 if (af == 0) return PERMISSION_DENIED;
115 af->setMasterMute(mute);
116 return NO_ERROR;
117 }
118
getMasterVolume(float * volume)119 status_t AudioSystem::getMasterVolume(float* volume)
120 {
121 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
122 if (af == 0) return PERMISSION_DENIED;
123 *volume = af->masterVolume();
124 return NO_ERROR;
125 }
126
getMasterMute(bool * mute)127 status_t AudioSystem::getMasterMute(bool* mute)
128 {
129 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
130 if (af == 0) return PERMISSION_DENIED;
131 *mute = af->masterMute();
132 return NO_ERROR;
133 }
134
setStreamVolume(audio_stream_type_t stream,float value,audio_io_handle_t output)135 status_t AudioSystem::setStreamVolume(audio_stream_type_t stream, float value,
136 audio_io_handle_t output)
137 {
138 if (uint32_t(stream) >= AUDIO_STREAM_CNT) return BAD_VALUE;
139 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
140 if (af == 0) return PERMISSION_DENIED;
141 af->setStreamVolume(stream, value, output);
142 return NO_ERROR;
143 }
144
setStreamMute(audio_stream_type_t stream,bool mute)145 status_t AudioSystem::setStreamMute(audio_stream_type_t stream, bool mute)
146 {
147 if (uint32_t(stream) >= AUDIO_STREAM_CNT) return BAD_VALUE;
148 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
149 if (af == 0) return PERMISSION_DENIED;
150 af->setStreamMute(stream, mute);
151 return NO_ERROR;
152 }
153
getStreamVolume(audio_stream_type_t stream,float * volume,audio_io_handle_t output)154 status_t AudioSystem::getStreamVolume(audio_stream_type_t stream, float* volume,
155 audio_io_handle_t output)
156 {
157 if (uint32_t(stream) >= AUDIO_STREAM_CNT) return BAD_VALUE;
158 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
159 if (af == 0) return PERMISSION_DENIED;
160 *volume = af->streamVolume(stream, output);
161 return NO_ERROR;
162 }
163
getStreamMute(audio_stream_type_t stream,bool * mute)164 status_t AudioSystem::getStreamMute(audio_stream_type_t stream, bool* mute)
165 {
166 if (uint32_t(stream) >= AUDIO_STREAM_CNT) return BAD_VALUE;
167 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
168 if (af == 0) return PERMISSION_DENIED;
169 *mute = af->streamMute(stream);
170 return NO_ERROR;
171 }
172
setMode(audio_mode_t mode)173 status_t AudioSystem::setMode(audio_mode_t mode)
174 {
175 if (uint32_t(mode) >= AUDIO_MODE_CNT) return BAD_VALUE;
176 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
177 if (af == 0) return PERMISSION_DENIED;
178 return af->setMode(mode);
179 }
180
setParameters(audio_io_handle_t ioHandle,const String8 & keyValuePairs)181 status_t AudioSystem::setParameters(audio_io_handle_t ioHandle, const String8& keyValuePairs)
182 {
183 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
184 if (af == 0) return PERMISSION_DENIED;
185 return af->setParameters(ioHandle, keyValuePairs);
186 }
187
getParameters(audio_io_handle_t ioHandle,const String8 & keys)188 String8 AudioSystem::getParameters(audio_io_handle_t ioHandle, const String8& keys)
189 {
190 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
191 String8 result = String8("");
192 if (af == 0) return result;
193
194 result = af->getParameters(ioHandle, keys);
195 return result;
196 }
197
setParameters(const String8 & keyValuePairs)198 status_t AudioSystem::setParameters(const String8& keyValuePairs)
199 {
200 return setParameters(AUDIO_IO_HANDLE_NONE, keyValuePairs);
201 }
202
getParameters(const String8 & keys)203 String8 AudioSystem::getParameters(const String8& keys)
204 {
205 return getParameters(AUDIO_IO_HANDLE_NONE, keys);
206 }
207
208 // convert volume steps to natural log scale
209
210 // change this value to change volume scaling
211 static const float dBPerStep = 0.5f;
212 // shouldn't need to touch these
213 static const float dBConvert = -dBPerStep * 2.302585093f / 20.0f;
214 static const float dBConvertInverse = 1.0f / dBConvert;
215
linearToLog(int volume)216 float AudioSystem::linearToLog(int volume)
217 {
218 // float v = volume ? exp(float(100 - volume) * dBConvert) : 0;
219 // ALOGD("linearToLog(%d)=%f", volume, v);
220 // return v;
221 return volume ? exp(float(100 - volume) * dBConvert) : 0;
222 }
223
logToLinear(float volume)224 int AudioSystem::logToLinear(float volume)
225 {
226 // int v = volume ? 100 - int(dBConvertInverse * log(volume) + 0.5) : 0;
227 // ALOGD("logTolinear(%d)=%f", v, volume);
228 // return v;
229 return volume ? 100 - int(dBConvertInverse * log(volume) + 0.5) : 0;
230 }
231
getOutputSamplingRate(uint32_t * samplingRate,audio_stream_type_t streamType)232 status_t AudioSystem::getOutputSamplingRate(uint32_t* samplingRate, audio_stream_type_t streamType)
233 {
234 audio_io_handle_t output;
235
236 if (streamType == AUDIO_STREAM_DEFAULT) {
237 streamType = AUDIO_STREAM_MUSIC;
238 }
239
240 output = getOutput(streamType);
241 if (output == 0) {
242 return PERMISSION_DENIED;
243 }
244
245 return getSamplingRate(output, samplingRate);
246 }
247
getOutputSamplingRateForAttr(uint32_t * samplingRate,const audio_attributes_t * attr)248 status_t AudioSystem::getOutputSamplingRateForAttr(uint32_t* samplingRate,
249 const audio_attributes_t *attr)
250 {
251 if (attr == NULL) {
252 return BAD_VALUE;
253 }
254 audio_io_handle_t output = getOutputForAttr(attr);
255 if (output == 0) {
256 return PERMISSION_DENIED;
257 }
258 return getSamplingRate(output, samplingRate);
259 }
260
getSamplingRate(audio_io_handle_t output,uint32_t * samplingRate)261 status_t AudioSystem::getSamplingRate(audio_io_handle_t output,
262 uint32_t* samplingRate)
263 {
264 OutputDescriptor *outputDesc;
265
266 gLock.lock();
267 outputDesc = AudioSystem::gOutputs.valueFor(output);
268 if (outputDesc == NULL) {
269 ALOGV("getOutputSamplingRate() no output descriptor for output %d in gOutputs", output);
270 gLock.unlock();
271 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
272 if (af == 0) return PERMISSION_DENIED;
273 *samplingRate = af->sampleRate(output);
274 } else {
275 ALOGV("getOutputSamplingRate() reading from output desc");
276 *samplingRate = outputDesc->samplingRate;
277 gLock.unlock();
278 }
279 if (*samplingRate == 0) {
280 ALOGE("AudioSystem::getSamplingRate failed for output %d", output);
281 return BAD_VALUE;
282 }
283
284 ALOGV("getSamplingRate() output %d, sampling rate %u", output, *samplingRate);
285
286 return NO_ERROR;
287 }
288
getOutputFrameCount(size_t * frameCount,audio_stream_type_t streamType)289 status_t AudioSystem::getOutputFrameCount(size_t* frameCount, audio_stream_type_t streamType)
290 {
291 audio_io_handle_t output;
292
293 if (streamType == AUDIO_STREAM_DEFAULT) {
294 streamType = AUDIO_STREAM_MUSIC;
295 }
296
297 output = getOutput(streamType);
298 if (output == AUDIO_IO_HANDLE_NONE) {
299 return PERMISSION_DENIED;
300 }
301
302 return getFrameCount(output, frameCount);
303 }
304
getFrameCount(audio_io_handle_t output,size_t * frameCount)305 status_t AudioSystem::getFrameCount(audio_io_handle_t output,
306 size_t* frameCount)
307 {
308 OutputDescriptor *outputDesc;
309
310 gLock.lock();
311 outputDesc = AudioSystem::gOutputs.valueFor(output);
312 if (outputDesc == NULL) {
313 gLock.unlock();
314 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
315 if (af == 0) return PERMISSION_DENIED;
316 *frameCount = af->frameCount(output);
317 } else {
318 *frameCount = outputDesc->frameCount;
319 gLock.unlock();
320 }
321 if (*frameCount == 0) {
322 ALOGE("AudioSystem::getFrameCount failed for output %d", output);
323 return BAD_VALUE;
324 }
325
326 ALOGV("getFrameCount() output %d, frameCount %zu", output, *frameCount);
327
328 return NO_ERROR;
329 }
330
getOutputLatency(uint32_t * latency,audio_stream_type_t streamType)331 status_t AudioSystem::getOutputLatency(uint32_t* latency, audio_stream_type_t streamType)
332 {
333 audio_io_handle_t output;
334
335 if (streamType == AUDIO_STREAM_DEFAULT) {
336 streamType = AUDIO_STREAM_MUSIC;
337 }
338
339 output = getOutput(streamType);
340 if (output == AUDIO_IO_HANDLE_NONE) {
341 return PERMISSION_DENIED;
342 }
343
344 return getLatency(output, latency);
345 }
346
getLatency(audio_io_handle_t output,uint32_t * latency)347 status_t AudioSystem::getLatency(audio_io_handle_t output,
348 uint32_t* latency)
349 {
350 OutputDescriptor *outputDesc;
351
352 gLock.lock();
353 outputDesc = AudioSystem::gOutputs.valueFor(output);
354 if (outputDesc == NULL) {
355 gLock.unlock();
356 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
357 if (af == 0) return PERMISSION_DENIED;
358 *latency = af->latency(output);
359 } else {
360 *latency = outputDesc->latency;
361 gLock.unlock();
362 }
363
364 ALOGV("getLatency() output %d, latency %d", output, *latency);
365
366 return NO_ERROR;
367 }
368
getInputBufferSize(uint32_t sampleRate,audio_format_t format,audio_channel_mask_t channelMask,size_t * buffSize)369 status_t AudioSystem::getInputBufferSize(uint32_t sampleRate, audio_format_t format,
370 audio_channel_mask_t channelMask, size_t* buffSize)
371 {
372 gLock.lock();
373 // Do we have a stale gInBufferSize or are we requesting the input buffer size for new values
374 size_t inBuffSize = gInBuffSize;
375 if ((inBuffSize == 0) || (sampleRate != gPrevInSamplingRate) || (format != gPrevInFormat)
376 || (channelMask != gPrevInChannelMask)) {
377 gLock.unlock();
378 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
379 if (af == 0) {
380 return PERMISSION_DENIED;
381 }
382 inBuffSize = af->getInputBufferSize(sampleRate, format, channelMask);
383 if (inBuffSize == 0) {
384 ALOGE("AudioSystem::getInputBufferSize failed sampleRate %d format %#x channelMask %x",
385 sampleRate, format, channelMask);
386 return BAD_VALUE;
387 }
388 // A benign race is possible here: we could overwrite a fresher cache entry
389 gLock.lock();
390 // save the request params
391 gPrevInSamplingRate = sampleRate;
392 gPrevInFormat = format;
393 gPrevInChannelMask = channelMask;
394
395 gInBuffSize = inBuffSize;
396 }
397 gLock.unlock();
398 *buffSize = inBuffSize;
399
400 return NO_ERROR;
401 }
402
setVoiceVolume(float value)403 status_t AudioSystem::setVoiceVolume(float value)
404 {
405 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
406 if (af == 0) return PERMISSION_DENIED;
407 return af->setVoiceVolume(value);
408 }
409
getRenderPosition(audio_io_handle_t output,uint32_t * halFrames,uint32_t * dspFrames)410 status_t AudioSystem::getRenderPosition(audio_io_handle_t output, uint32_t *halFrames,
411 uint32_t *dspFrames)
412 {
413 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
414 if (af == 0) return PERMISSION_DENIED;
415
416 return af->getRenderPosition(halFrames, dspFrames, output);
417 }
418
getInputFramesLost(audio_io_handle_t ioHandle)419 uint32_t AudioSystem::getInputFramesLost(audio_io_handle_t ioHandle)
420 {
421 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
422 uint32_t result = 0;
423 if (af == 0) return result;
424 if (ioHandle == AUDIO_IO_HANDLE_NONE) return result;
425
426 result = af->getInputFramesLost(ioHandle);
427 return result;
428 }
429
newAudioUniqueId()430 audio_unique_id_t AudioSystem::newAudioUniqueId()
431 {
432 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
433 if (af == 0) return AUDIO_UNIQUE_ID_ALLOCATE;
434 return af->newAudioUniqueId();
435 }
436
acquireAudioSessionId(int audioSession,pid_t pid)437 void AudioSystem::acquireAudioSessionId(int audioSession, pid_t pid)
438 {
439 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
440 if (af != 0) {
441 af->acquireAudioSessionId(audioSession, pid);
442 }
443 }
444
releaseAudioSessionId(int audioSession,pid_t pid)445 void AudioSystem::releaseAudioSessionId(int audioSession, pid_t pid)
446 {
447 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
448 if (af != 0) {
449 af->releaseAudioSessionId(audioSession, pid);
450 }
451 }
452
getAudioHwSyncForSession(audio_session_t sessionId)453 audio_hw_sync_t AudioSystem::getAudioHwSyncForSession(audio_session_t sessionId)
454 {
455 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
456 if (af == 0) return AUDIO_HW_SYNC_INVALID;
457 return af->getAudioHwSyncForSession(sessionId);
458 }
459
460 // ---------------------------------------------------------------------------
461
binderDied(const wp<IBinder> & who __unused)462 void AudioSystem::AudioFlingerClient::binderDied(const wp<IBinder>& who __unused)
463 {
464 Mutex::Autolock _l(AudioSystem::gLock);
465
466 AudioSystem::gAudioFlinger.clear();
467 // clear output handles and stream to output map caches
468 AudioSystem::gOutputs.clear();
469
470 if (gAudioErrorCallback) {
471 gAudioErrorCallback(DEAD_OBJECT);
472 }
473 ALOGW("AudioFlinger server died!");
474 }
475
ioConfigChanged(int event,audio_io_handle_t ioHandle,const void * param2)476 void AudioSystem::AudioFlingerClient::ioConfigChanged(int event, audio_io_handle_t ioHandle,
477 const void *param2) {
478 ALOGV("ioConfigChanged() event %d", event);
479 const OutputDescriptor *desc;
480 audio_stream_type_t stream;
481
482 if (ioHandle == AUDIO_IO_HANDLE_NONE) return;
483
484 Mutex::Autolock _l(AudioSystem::gLock);
485
486 switch (event) {
487 case STREAM_CONFIG_CHANGED:
488 break;
489 case OUTPUT_OPENED: {
490 if (gOutputs.indexOfKey(ioHandle) >= 0) {
491 ALOGV("ioConfigChanged() opening already existing output! %d", ioHandle);
492 break;
493 }
494 if (param2 == NULL) break;
495 desc = (const OutputDescriptor *)param2;
496
497 OutputDescriptor *outputDesc = new OutputDescriptor(*desc);
498 gOutputs.add(ioHandle, outputDesc);
499 ALOGV("ioConfigChanged() new output samplingRate %u, format %#x channel mask %#x frameCount %zu "
500 "latency %d",
501 outputDesc->samplingRate, outputDesc->format, outputDesc->channelMask,
502 outputDesc->frameCount, outputDesc->latency);
503 } break;
504 case OUTPUT_CLOSED: {
505 if (gOutputs.indexOfKey(ioHandle) < 0) {
506 ALOGW("ioConfigChanged() closing unknown output! %d", ioHandle);
507 break;
508 }
509 ALOGV("ioConfigChanged() output %d closed", ioHandle);
510
511 gOutputs.removeItem(ioHandle);
512 } break;
513
514 case OUTPUT_CONFIG_CHANGED: {
515 int index = gOutputs.indexOfKey(ioHandle);
516 if (index < 0) {
517 ALOGW("ioConfigChanged() modifying unknown output! %d", ioHandle);
518 break;
519 }
520 if (param2 == NULL) break;
521 desc = (const OutputDescriptor *)param2;
522
523 ALOGV("ioConfigChanged() new config for output %d samplingRate %u, format %#x channel mask %#x "
524 "frameCount %zu latency %d",
525 ioHandle, desc->samplingRate, desc->format,
526 desc->channelMask, desc->frameCount, desc->latency);
527 OutputDescriptor *outputDesc = gOutputs.valueAt(index);
528 delete outputDesc;
529 outputDesc = new OutputDescriptor(*desc);
530 gOutputs.replaceValueFor(ioHandle, outputDesc);
531 } break;
532 case INPUT_OPENED:
533 case INPUT_CLOSED:
534 case INPUT_CONFIG_CHANGED:
535 break;
536
537 }
538 }
539
setErrorCallback(audio_error_callback cb)540 void AudioSystem::setErrorCallback(audio_error_callback cb)
541 {
542 Mutex::Autolock _l(gLock);
543 gAudioErrorCallback = cb;
544 }
545
546
routedToA2dpOutput(audio_stream_type_t streamType)547 bool AudioSystem::routedToA2dpOutput(audio_stream_type_t streamType)
548 {
549 switch (streamType) {
550 case AUDIO_STREAM_MUSIC:
551 case AUDIO_STREAM_VOICE_CALL:
552 case AUDIO_STREAM_BLUETOOTH_SCO:
553 case AUDIO_STREAM_SYSTEM:
554 return true;
555 default:
556 return false;
557 }
558 }
559
560
561 // client singleton for AudioPolicyService binder interface
562 sp<IAudioPolicyService> AudioSystem::gAudioPolicyService;
563 sp<AudioSystem::AudioPolicyServiceClient> AudioSystem::gAudioPolicyServiceClient;
564
565
566 // establish binder interface to AudioPolicy service
get_audio_policy_service()567 const sp<IAudioPolicyService>& AudioSystem::get_audio_policy_service()
568 {
569 gLock.lock();
570 if (gAudioPolicyService == 0) {
571 sp<IServiceManager> sm = defaultServiceManager();
572 sp<IBinder> binder;
573 do {
574 binder = sm->getService(String16("media.audio_policy"));
575 if (binder != 0)
576 break;
577 ALOGW("AudioPolicyService not published, waiting...");
578 usleep(500000); // 0.5 s
579 } while (true);
580 if (gAudioPolicyServiceClient == NULL) {
581 gAudioPolicyServiceClient = new AudioPolicyServiceClient();
582 }
583 binder->linkToDeath(gAudioPolicyServiceClient);
584 gAudioPolicyService = interface_cast<IAudioPolicyService>(binder);
585 gLock.unlock();
586 // Registering the client takes the AudioPolicyService lock.
587 // Don't hold the AudioSystem lock at the same time.
588 gAudioPolicyService->registerClient(gAudioPolicyServiceClient);
589 } else {
590 // There exists a benign race condition where gAudioPolicyService
591 // is set, but gAudioPolicyServiceClient is not yet registered.
592 gLock.unlock();
593 }
594 return gAudioPolicyService;
595 }
596
597 // ---------------------------------------------------------------------------
598
setDeviceConnectionState(audio_devices_t device,audio_policy_dev_state_t state,const char * device_address)599 status_t AudioSystem::setDeviceConnectionState(audio_devices_t device,
600 audio_policy_dev_state_t state,
601 const char *device_address)
602 {
603 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
604 const char *address = "";
605
606 if (aps == 0) return PERMISSION_DENIED;
607
608 if (device_address != NULL) {
609 address = device_address;
610 }
611
612 return aps->setDeviceConnectionState(device, state, address);
613 }
614
getDeviceConnectionState(audio_devices_t device,const char * device_address)615 audio_policy_dev_state_t AudioSystem::getDeviceConnectionState(audio_devices_t device,
616 const char *device_address)
617 {
618 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
619 if (aps == 0) return AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE;
620
621 return aps->getDeviceConnectionState(device, device_address);
622 }
623
setPhoneState(audio_mode_t state)624 status_t AudioSystem::setPhoneState(audio_mode_t state)
625 {
626 if (uint32_t(state) >= AUDIO_MODE_CNT) return BAD_VALUE;
627 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
628 if (aps == 0) return PERMISSION_DENIED;
629
630 return aps->setPhoneState(state);
631 }
632
setForceUse(audio_policy_force_use_t usage,audio_policy_forced_cfg_t config)633 status_t AudioSystem::setForceUse(audio_policy_force_use_t usage, audio_policy_forced_cfg_t config)
634 {
635 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
636 if (aps == 0) return PERMISSION_DENIED;
637 return aps->setForceUse(usage, config);
638 }
639
getForceUse(audio_policy_force_use_t usage)640 audio_policy_forced_cfg_t AudioSystem::getForceUse(audio_policy_force_use_t usage)
641 {
642 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
643 if (aps == 0) return AUDIO_POLICY_FORCE_NONE;
644 return aps->getForceUse(usage);
645 }
646
647
getOutput(audio_stream_type_t stream,uint32_t samplingRate,audio_format_t format,audio_channel_mask_t channelMask,audio_output_flags_t flags,const audio_offload_info_t * offloadInfo)648 audio_io_handle_t AudioSystem::getOutput(audio_stream_type_t stream,
649 uint32_t samplingRate,
650 audio_format_t format,
651 audio_channel_mask_t channelMask,
652 audio_output_flags_t flags,
653 const audio_offload_info_t *offloadInfo)
654 {
655 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
656 if (aps == 0) return 0;
657 return aps->getOutput(stream, samplingRate, format, channelMask, flags, offloadInfo);
658 }
659
getOutputForAttr(const audio_attributes_t * attr,uint32_t samplingRate,audio_format_t format,audio_channel_mask_t channelMask,audio_output_flags_t flags,const audio_offload_info_t * offloadInfo)660 audio_io_handle_t AudioSystem::getOutputForAttr(const audio_attributes_t *attr,
661 uint32_t samplingRate,
662 audio_format_t format,
663 audio_channel_mask_t channelMask,
664 audio_output_flags_t flags,
665 const audio_offload_info_t *offloadInfo)
666 {
667 if (attr == NULL) return 0;
668 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
669 if (aps == 0) return 0;
670 return aps->getOutputForAttr(attr, samplingRate, format, channelMask, flags, offloadInfo);
671 }
672
startOutput(audio_io_handle_t output,audio_stream_type_t stream,int session)673 status_t AudioSystem::startOutput(audio_io_handle_t output,
674 audio_stream_type_t stream,
675 int session)
676 {
677 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
678 if (aps == 0) return PERMISSION_DENIED;
679 return aps->startOutput(output, stream, session);
680 }
681
stopOutput(audio_io_handle_t output,audio_stream_type_t stream,int session)682 status_t AudioSystem::stopOutput(audio_io_handle_t output,
683 audio_stream_type_t stream,
684 int session)
685 {
686 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
687 if (aps == 0) return PERMISSION_DENIED;
688 return aps->stopOutput(output, stream, session);
689 }
690
releaseOutput(audio_io_handle_t output)691 void AudioSystem::releaseOutput(audio_io_handle_t output)
692 {
693 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
694 if (aps == 0) return;
695 aps->releaseOutput(output);
696 }
697
getInput(audio_source_t inputSource,uint32_t samplingRate,audio_format_t format,audio_channel_mask_t channelMask,int sessionId,audio_input_flags_t flags)698 audio_io_handle_t AudioSystem::getInput(audio_source_t inputSource,
699 uint32_t samplingRate,
700 audio_format_t format,
701 audio_channel_mask_t channelMask,
702 int sessionId,
703 audio_input_flags_t flags)
704 {
705 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
706 if (aps == 0) return 0;
707 return aps->getInput(inputSource, samplingRate, format, channelMask, sessionId, flags);
708 }
709
startInput(audio_io_handle_t input,audio_session_t session)710 status_t AudioSystem::startInput(audio_io_handle_t input,
711 audio_session_t session)
712 {
713 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
714 if (aps == 0) return PERMISSION_DENIED;
715 return aps->startInput(input, session);
716 }
717
stopInput(audio_io_handle_t input,audio_session_t session)718 status_t AudioSystem::stopInput(audio_io_handle_t input,
719 audio_session_t session)
720 {
721 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
722 if (aps == 0) return PERMISSION_DENIED;
723 return aps->stopInput(input, session);
724 }
725
releaseInput(audio_io_handle_t input,audio_session_t session)726 void AudioSystem::releaseInput(audio_io_handle_t input,
727 audio_session_t session)
728 {
729 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
730 if (aps == 0) return;
731 aps->releaseInput(input, session);
732 }
733
initStreamVolume(audio_stream_type_t stream,int indexMin,int indexMax)734 status_t AudioSystem::initStreamVolume(audio_stream_type_t stream,
735 int indexMin,
736 int indexMax)
737 {
738 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
739 if (aps == 0) return PERMISSION_DENIED;
740 return aps->initStreamVolume(stream, indexMin, indexMax);
741 }
742
setStreamVolumeIndex(audio_stream_type_t stream,int index,audio_devices_t device)743 status_t AudioSystem::setStreamVolumeIndex(audio_stream_type_t stream,
744 int index,
745 audio_devices_t device)
746 {
747 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
748 if (aps == 0) return PERMISSION_DENIED;
749 return aps->setStreamVolumeIndex(stream, index, device);
750 }
751
getStreamVolumeIndex(audio_stream_type_t stream,int * index,audio_devices_t device)752 status_t AudioSystem::getStreamVolumeIndex(audio_stream_type_t stream,
753 int *index,
754 audio_devices_t device)
755 {
756 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
757 if (aps == 0) return PERMISSION_DENIED;
758 return aps->getStreamVolumeIndex(stream, index, device);
759 }
760
getStrategyForStream(audio_stream_type_t stream)761 uint32_t AudioSystem::getStrategyForStream(audio_stream_type_t stream)
762 {
763 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
764 if (aps == 0) return 0;
765 return aps->getStrategyForStream(stream);
766 }
767
getDevicesForStream(audio_stream_type_t stream)768 audio_devices_t AudioSystem::getDevicesForStream(audio_stream_type_t stream)
769 {
770 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
771 if (aps == 0) return AUDIO_DEVICE_NONE;
772 return aps->getDevicesForStream(stream);
773 }
774
getOutputForEffect(const effect_descriptor_t * desc)775 audio_io_handle_t AudioSystem::getOutputForEffect(const effect_descriptor_t *desc)
776 {
777 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
778 // FIXME change return type to status_t, and return PERMISSION_DENIED here
779 if (aps == 0) return AUDIO_IO_HANDLE_NONE;
780 return aps->getOutputForEffect(desc);
781 }
782
registerEffect(const effect_descriptor_t * desc,audio_io_handle_t io,uint32_t strategy,int session,int id)783 status_t AudioSystem::registerEffect(const effect_descriptor_t *desc,
784 audio_io_handle_t io,
785 uint32_t strategy,
786 int session,
787 int id)
788 {
789 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
790 if (aps == 0) return PERMISSION_DENIED;
791 return aps->registerEffect(desc, io, strategy, session, id);
792 }
793
unregisterEffect(int id)794 status_t AudioSystem::unregisterEffect(int id)
795 {
796 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
797 if (aps == 0) return PERMISSION_DENIED;
798 return aps->unregisterEffect(id);
799 }
800
setEffectEnabled(int id,bool enabled)801 status_t AudioSystem::setEffectEnabled(int id, bool enabled)
802 {
803 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
804 if (aps == 0) return PERMISSION_DENIED;
805 return aps->setEffectEnabled(id, enabled);
806 }
807
isStreamActive(audio_stream_type_t stream,bool * state,uint32_t inPastMs)808 status_t AudioSystem::isStreamActive(audio_stream_type_t stream, bool* state, uint32_t inPastMs)
809 {
810 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
811 if (aps == 0) return PERMISSION_DENIED;
812 if (state == NULL) return BAD_VALUE;
813 *state = aps->isStreamActive(stream, inPastMs);
814 return NO_ERROR;
815 }
816
isStreamActiveRemotely(audio_stream_type_t stream,bool * state,uint32_t inPastMs)817 status_t AudioSystem::isStreamActiveRemotely(audio_stream_type_t stream, bool* state,
818 uint32_t inPastMs)
819 {
820 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
821 if (aps == 0) return PERMISSION_DENIED;
822 if (state == NULL) return BAD_VALUE;
823 *state = aps->isStreamActiveRemotely(stream, inPastMs);
824 return NO_ERROR;
825 }
826
isSourceActive(audio_source_t stream,bool * state)827 status_t AudioSystem::isSourceActive(audio_source_t stream, bool* state)
828 {
829 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
830 if (aps == 0) return PERMISSION_DENIED;
831 if (state == NULL) return BAD_VALUE;
832 *state = aps->isSourceActive(stream);
833 return NO_ERROR;
834 }
835
getPrimaryOutputSamplingRate()836 uint32_t AudioSystem::getPrimaryOutputSamplingRate()
837 {
838 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
839 if (af == 0) return 0;
840 return af->getPrimaryOutputSamplingRate();
841 }
842
getPrimaryOutputFrameCount()843 size_t AudioSystem::getPrimaryOutputFrameCount()
844 {
845 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
846 if (af == 0) return 0;
847 return af->getPrimaryOutputFrameCount();
848 }
849
setLowRamDevice(bool isLowRamDevice)850 status_t AudioSystem::setLowRamDevice(bool isLowRamDevice)
851 {
852 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
853 if (af == 0) return PERMISSION_DENIED;
854 return af->setLowRamDevice(isLowRamDevice);
855 }
856
clearAudioConfigCache()857 void AudioSystem::clearAudioConfigCache()
858 {
859 Mutex::Autolock _l(gLock);
860 ALOGV("clearAudioConfigCache()");
861 gOutputs.clear();
862 }
863
isOffloadSupported(const audio_offload_info_t & info)864 bool AudioSystem::isOffloadSupported(const audio_offload_info_t& info)
865 {
866 ALOGV("isOffloadSupported()");
867 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
868 if (aps == 0) return false;
869 return aps->isOffloadSupported(info);
870 }
871
listAudioPorts(audio_port_role_t role,audio_port_type_t type,unsigned int * num_ports,struct audio_port * ports,unsigned int * generation)872 status_t AudioSystem::listAudioPorts(audio_port_role_t role,
873 audio_port_type_t type,
874 unsigned int *num_ports,
875 struct audio_port *ports,
876 unsigned int *generation)
877 {
878 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
879 if (aps == 0) return PERMISSION_DENIED;
880 return aps->listAudioPorts(role, type, num_ports, ports, generation);
881 }
882
getAudioPort(struct audio_port * port)883 status_t AudioSystem::getAudioPort(struct audio_port *port)
884 {
885 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
886 if (aps == 0) return PERMISSION_DENIED;
887 return aps->getAudioPort(port);
888 }
889
createAudioPatch(const struct audio_patch * patch,audio_patch_handle_t * handle)890 status_t AudioSystem::createAudioPatch(const struct audio_patch *patch,
891 audio_patch_handle_t *handle)
892 {
893 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
894 if (aps == 0) return PERMISSION_DENIED;
895 return aps->createAudioPatch(patch, handle);
896 }
897
releaseAudioPatch(audio_patch_handle_t handle)898 status_t AudioSystem::releaseAudioPatch(audio_patch_handle_t handle)
899 {
900 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
901 if (aps == 0) return PERMISSION_DENIED;
902 return aps->releaseAudioPatch(handle);
903 }
904
listAudioPatches(unsigned int * num_patches,struct audio_patch * patches,unsigned int * generation)905 status_t AudioSystem::listAudioPatches(unsigned int *num_patches,
906 struct audio_patch *patches,
907 unsigned int *generation)
908 {
909 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
910 if (aps == 0) return PERMISSION_DENIED;
911 return aps->listAudioPatches(num_patches, patches, generation);
912 }
913
setAudioPortConfig(const struct audio_port_config * config)914 status_t AudioSystem::setAudioPortConfig(const struct audio_port_config *config)
915 {
916 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
917 if (aps == 0) return PERMISSION_DENIED;
918 return aps->setAudioPortConfig(config);
919 }
920
setAudioPortCallback(sp<AudioPortCallback> callBack)921 void AudioSystem::setAudioPortCallback(sp<AudioPortCallback> callBack)
922 {
923 Mutex::Autolock _l(gLock);
924 gAudioPortCallback = callBack;
925 }
926
acquireSoundTriggerSession(audio_session_t * session,audio_io_handle_t * ioHandle,audio_devices_t * device)927 status_t AudioSystem::acquireSoundTriggerSession(audio_session_t *session,
928 audio_io_handle_t *ioHandle,
929 audio_devices_t *device)
930 {
931 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
932 if (aps == 0) return PERMISSION_DENIED;
933 return aps->acquireSoundTriggerSession(session, ioHandle, device);
934 }
935
releaseSoundTriggerSession(audio_session_t session)936 status_t AudioSystem::releaseSoundTriggerSession(audio_session_t session)
937 {
938 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
939 if (aps == 0) return PERMISSION_DENIED;
940 return aps->releaseSoundTriggerSession(session);
941 }
942
getPhoneState()943 audio_mode_t AudioSystem::getPhoneState()
944 {
945 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
946 if (aps == 0) return AUDIO_MODE_INVALID;
947 return aps->getPhoneState();
948 }
949
950
951 // ---------------------------------------------------------------------------
952
binderDied(const wp<IBinder> & who __unused)953 void AudioSystem::AudioPolicyServiceClient::binderDied(const wp<IBinder>& who __unused)
954 {
955 Mutex::Autolock _l(gLock);
956 if (gAudioPortCallback != 0) {
957 gAudioPortCallback->onServiceDied();
958 }
959 AudioSystem::gAudioPolicyService.clear();
960
961 ALOGW("AudioPolicyService server died!");
962 }
963
onAudioPortListUpdate()964 void AudioSystem::AudioPolicyServiceClient::onAudioPortListUpdate()
965 {
966 Mutex::Autolock _l(gLock);
967 if (gAudioPortCallback != 0) {
968 gAudioPortCallback->onAudioPortListUpdate();
969 }
970 }
971
onAudioPatchListUpdate()972 void AudioSystem::AudioPolicyServiceClient::onAudioPatchListUpdate()
973 {
974 Mutex::Autolock _l(gLock);
975 if (gAudioPortCallback != 0) {
976 gAudioPortCallback->onAudioPatchListUpdate();
977 }
978 }
979
980 }; // namespace android
981