• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2009 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #define LOG_TAG "AudioPolicyService"
18 //#define LOG_NDEBUG 0
19 
20 #include <utils/Log.h>
21 #include "AudioPolicyService.h"
22 #include "ServiceUtilities.h"
23 
24 #include <system/audio.h>
25 #include <system/audio_policy.h>
26 #include <hardware/audio_policy.h>
27 #include <media/AudioPolicyHelper.h>
28 
29 namespace android {
30 
31 
32 // ----------------------------------------------------------------------------
33 
setDeviceConnectionState(audio_devices_t device,audio_policy_dev_state_t state,const char * device_address,const char * device_name __unused)34 status_t AudioPolicyService::setDeviceConnectionState(audio_devices_t device,
35                                                   audio_policy_dev_state_t state,
36                                                   const char *device_address,
37                                                   const char *device_name __unused)
38 {
39     if (mpAudioPolicy == NULL) {
40         return NO_INIT;
41     }
42     if (!settingsAllowed()) {
43         return PERMISSION_DENIED;
44     }
45     if (!audio_is_output_device(device) && !audio_is_input_device(device)) {
46         return BAD_VALUE;
47     }
48     if (state != AUDIO_POLICY_DEVICE_STATE_AVAILABLE &&
49             state != AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE) {
50         return BAD_VALUE;
51     }
52 
53     ALOGV("setDeviceConnectionState()");
54     Mutex::Autolock _l(mLock);
55     return mpAudioPolicy->set_device_connection_state(mpAudioPolicy, device,
56                                                       state, device_address);
57 }
58 
getDeviceConnectionState(audio_devices_t device,const char * device_address)59 audio_policy_dev_state_t AudioPolicyService::getDeviceConnectionState(
60                                                               audio_devices_t device,
61                                                               const char *device_address)
62 {
63     if (mpAudioPolicy == NULL) {
64         return AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE;
65     }
66     return mpAudioPolicy->get_device_connection_state(mpAudioPolicy, device,
67                                                       device_address);
68 }
69 
setPhoneState(audio_mode_t state)70 status_t AudioPolicyService::setPhoneState(audio_mode_t state)
71 {
72     if (mpAudioPolicy == NULL) {
73         return NO_INIT;
74     }
75     if (!settingsAllowed()) {
76         return PERMISSION_DENIED;
77     }
78     if (uint32_t(state) >= AUDIO_MODE_CNT) {
79         return BAD_VALUE;
80     }
81 
82     ALOGV("setPhoneState()");
83 
84     // TODO: check if it is more appropriate to do it in platform specific policy manager
85     AudioSystem::setMode(state);
86 
87     Mutex::Autolock _l(mLock);
88     mpAudioPolicy->set_phone_state(mpAudioPolicy, state);
89     mPhoneState = state;
90     return NO_ERROR;
91 }
92 
getPhoneState()93 audio_mode_t AudioPolicyService::getPhoneState()
94 {
95     Mutex::Autolock _l(mLock);
96     return mPhoneState;
97 }
98 
setForceUse(audio_policy_force_use_t usage,audio_policy_forced_cfg_t config)99 status_t AudioPolicyService::setForceUse(audio_policy_force_use_t usage,
100                                          audio_policy_forced_cfg_t config)
101 {
102     if (mpAudioPolicy == NULL) {
103         return NO_INIT;
104     }
105     if (!settingsAllowed()) {
106         return PERMISSION_DENIED;
107     }
108     if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
109         return BAD_VALUE;
110     }
111     if (config < 0 || config >= AUDIO_POLICY_FORCE_CFG_CNT) {
112         return BAD_VALUE;
113     }
114     ALOGV("setForceUse()");
115     Mutex::Autolock _l(mLock);
116     mpAudioPolicy->set_force_use(mpAudioPolicy, usage, config);
117     return NO_ERROR;
118 }
119 
getForceUse(audio_policy_force_use_t usage)120 audio_policy_forced_cfg_t AudioPolicyService::getForceUse(audio_policy_force_use_t usage)
121 {
122     if (mpAudioPolicy == NULL) {
123         return AUDIO_POLICY_FORCE_NONE;
124     }
125     if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
126         return AUDIO_POLICY_FORCE_NONE;
127     }
128     return mpAudioPolicy->get_force_use(mpAudioPolicy, usage);
129 }
130 
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)131 audio_io_handle_t AudioPolicyService::getOutput(audio_stream_type_t stream,
132                                     uint32_t samplingRate,
133                                     audio_format_t format,
134                                     audio_channel_mask_t channelMask,
135                                     audio_output_flags_t flags,
136                                     const audio_offload_info_t *offloadInfo)
137 {
138     if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
139         return AUDIO_IO_HANDLE_NONE;
140     }
141     if (mpAudioPolicy == NULL) {
142         return AUDIO_IO_HANDLE_NONE;
143     }
144     ALOGV("getOutput()");
145     Mutex::Autolock _l(mLock);
146     return mpAudioPolicy->get_output(mpAudioPolicy, stream, samplingRate,
147                                     format, channelMask, flags, offloadInfo);
148 }
149 
startOutput(audio_io_handle_t output,audio_stream_type_t stream,audio_session_t session)150 status_t AudioPolicyService::startOutput(audio_io_handle_t output,
151                                          audio_stream_type_t stream,
152                                          audio_session_t session)
153 {
154     if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
155         return BAD_VALUE;
156     }
157     if (mpAudioPolicy == NULL) {
158         return NO_INIT;
159     }
160     ALOGV("startOutput()");
161     // create audio processors according to stream
162     sp<AudioPolicyEffects>audioPolicyEffects;
163     {
164         Mutex::Autolock _l(mLock);
165         audioPolicyEffects = mAudioPolicyEffects;
166     }
167     if (audioPolicyEffects != 0) {
168         status_t status = audioPolicyEffects->addOutputSessionEffects(output, stream, session);
169         if (status != NO_ERROR && status != ALREADY_EXISTS) {
170             ALOGW("Failed to add effects on session %d", session);
171         }
172     }
173 
174     Mutex::Autolock _l(mLock);
175     return mpAudioPolicy->start_output(mpAudioPolicy, output, stream, session);
176 }
177 
stopOutput(audio_io_handle_t output,audio_stream_type_t stream,audio_session_t session)178 status_t AudioPolicyService::stopOutput(audio_io_handle_t output,
179                                         audio_stream_type_t stream,
180                                         audio_session_t session)
181 {
182     if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
183         return BAD_VALUE;
184     }
185     if (mpAudioPolicy == NULL) {
186         return NO_INIT;
187     }
188     ALOGV("stopOutput()");
189     mOutputCommandThread->stopOutputCommand(output, stream, session);
190     return NO_ERROR;
191 }
192 
doStopOutput(audio_io_handle_t output,audio_stream_type_t stream,audio_session_t session)193 status_t  AudioPolicyService::doStopOutput(audio_io_handle_t output,
194                                       audio_stream_type_t stream,
195                                       audio_session_t session)
196 {
197     ALOGV("doStopOutput from tid %d", gettid());
198     // release audio processors from the stream
199     sp<AudioPolicyEffects>audioPolicyEffects;
200     {
201         Mutex::Autolock _l(mLock);
202         audioPolicyEffects = mAudioPolicyEffects;
203     }
204     if (audioPolicyEffects != 0) {
205         status_t status = audioPolicyEffects->releaseOutputSessionEffects(output, stream, session);
206         if (status != NO_ERROR && status != ALREADY_EXISTS) {
207             ALOGW("Failed to release effects on session %d", session);
208         }
209     }
210     Mutex::Autolock _l(mLock);
211     return mpAudioPolicy->stop_output(mpAudioPolicy, output, stream, session);
212 }
213 
releaseOutput(audio_io_handle_t output,audio_stream_type_t stream,audio_session_t session)214 void AudioPolicyService::releaseOutput(audio_io_handle_t output,
215                                        audio_stream_type_t stream,
216                                        audio_session_t session)
217 {
218     if (mpAudioPolicy == NULL) {
219         return;
220     }
221     ALOGV("releaseOutput()");
222     mOutputCommandThread->releaseOutputCommand(output, stream, session);
223 }
224 
doReleaseOutput(audio_io_handle_t output,audio_stream_type_t stream __unused,audio_session_t session __unused)225 void AudioPolicyService::doReleaseOutput(audio_io_handle_t output,
226                                          audio_stream_type_t stream __unused,
227                                          audio_session_t session __unused)
228 {
229     ALOGV("doReleaseOutput from tid %d", gettid());
230     Mutex::Autolock _l(mLock);
231     mpAudioPolicy->release_output(mpAudioPolicy, output);
232 }
233 
getInputForAttr(const audio_attributes_t * attr,audio_io_handle_t * input,audio_session_t session,pid_t pid __unused,uid_t uid __unused,uint32_t samplingRate,audio_format_t format,audio_channel_mask_t channelMask,audio_input_flags_t flags __unused,audio_port_handle_t selectedDeviceId __unused)234 status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
235                                              audio_io_handle_t *input,
236                                              audio_session_t session,
237                                              pid_t pid __unused,
238                                              uid_t uid __unused,
239                                              uint32_t samplingRate,
240                                              audio_format_t format,
241                                              audio_channel_mask_t channelMask,
242                                              audio_input_flags_t flags __unused,
243                                              audio_port_handle_t selectedDeviceId __unused)
244 {
245     if (mpAudioPolicy == NULL) {
246         return NO_INIT;
247     }
248 
249     audio_source_t inputSource = attr->source;
250 
251     // already checked by client, but double-check in case the client wrapper is bypassed
252     if (inputSource >= AUDIO_SOURCE_CNT && inputSource != AUDIO_SOURCE_HOTWORD &&
253         inputSource != AUDIO_SOURCE_FM_TUNER) {
254         return BAD_VALUE;
255     }
256 
257     if (inputSource == AUDIO_SOURCE_DEFAULT) {
258         inputSource = AUDIO_SOURCE_MIC;
259     }
260 
261     if ((inputSource == AUDIO_SOURCE_HOTWORD) && !captureHotwordAllowed()) {
262         return BAD_VALUE;
263     }
264 
265     sp<AudioPolicyEffects>audioPolicyEffects;
266     {
267         Mutex::Autolock _l(mLock);
268         // the audio_in_acoustics_t parameter is ignored by get_input()
269         *input = mpAudioPolicy->get_input(mpAudioPolicy, inputSource, samplingRate,
270                                              format, channelMask, (audio_in_acoustics_t) 0);
271         audioPolicyEffects = mAudioPolicyEffects;
272     }
273     if (*input == AUDIO_IO_HANDLE_NONE) {
274         return INVALID_OPERATION;
275     }
276 
277     if (audioPolicyEffects != 0) {
278         // create audio pre processors according to input source
279         status_t status = audioPolicyEffects->addInputEffects(*input, inputSource, session);
280         if (status != NO_ERROR && status != ALREADY_EXISTS) {
281             ALOGW("Failed to add effects on input %d", input);
282         }
283     }
284     return NO_ERROR;
285 }
286 
startInput(audio_io_handle_t input,audio_session_t session __unused)287 status_t AudioPolicyService::startInput(audio_io_handle_t input,
288                                         audio_session_t session __unused)
289 {
290     if (mpAudioPolicy == NULL) {
291         return NO_INIT;
292     }
293     Mutex::Autolock _l(mLock);
294 
295     return mpAudioPolicy->start_input(mpAudioPolicy, input);
296 }
297 
stopInput(audio_io_handle_t input,audio_session_t session __unused)298 status_t AudioPolicyService::stopInput(audio_io_handle_t input,
299                                        audio_session_t session __unused)
300 {
301     if (mpAudioPolicy == NULL) {
302         return NO_INIT;
303     }
304     Mutex::Autolock _l(mLock);
305 
306     return mpAudioPolicy->stop_input(mpAudioPolicy, input);
307 }
308 
releaseInput(audio_io_handle_t input,audio_session_t session __unused)309 void AudioPolicyService::releaseInput(audio_io_handle_t input,
310                                       audio_session_t session __unused)
311 {
312     if (mpAudioPolicy == NULL) {
313         return;
314     }
315 
316     sp<AudioPolicyEffects>audioPolicyEffects;
317     {
318         Mutex::Autolock _l(mLock);
319         mpAudioPolicy->release_input(mpAudioPolicy, input);
320         audioPolicyEffects = mAudioPolicyEffects;
321     }
322     if (audioPolicyEffects != 0) {
323         // release audio processors from the input
324         status_t status = audioPolicyEffects->releaseInputEffects(input);
325         if(status != NO_ERROR) {
326             ALOGW("Failed to release effects on input %d", input);
327         }
328     }
329 }
330 
initStreamVolume(audio_stream_type_t stream,int indexMin,int indexMax)331 status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
332                                             int indexMin,
333                                             int indexMax)
334 {
335     if (mpAudioPolicy == NULL) {
336         return NO_INIT;
337     }
338     if (!settingsAllowed()) {
339         return PERMISSION_DENIED;
340     }
341     if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
342         return BAD_VALUE;
343     }
344     Mutex::Autolock _l(mLock);
345     mpAudioPolicy->init_stream_volume(mpAudioPolicy, stream, indexMin, indexMax);
346     return NO_ERROR;
347 }
348 
setStreamVolumeIndex(audio_stream_type_t stream,int index,audio_devices_t device)349 status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
350                                                   int index,
351                                                   audio_devices_t device)
352 {
353     if (mpAudioPolicy == NULL) {
354         return NO_INIT;
355     }
356     if (!settingsAllowed()) {
357         return PERMISSION_DENIED;
358     }
359     if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
360         return BAD_VALUE;
361     }
362     Mutex::Autolock _l(mLock);
363     if (mpAudioPolicy->set_stream_volume_index_for_device) {
364         return mpAudioPolicy->set_stream_volume_index_for_device(mpAudioPolicy,
365                                                                 stream,
366                                                                 index,
367                                                                 device);
368     } else {
369         return mpAudioPolicy->set_stream_volume_index(mpAudioPolicy, stream, index);
370     }
371 }
372 
getStreamVolumeIndex(audio_stream_type_t stream,int * index,audio_devices_t device)373 status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
374                                                   int *index,
375                                                   audio_devices_t device)
376 {
377     if (mpAudioPolicy == NULL) {
378         return NO_INIT;
379     }
380     if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
381         return BAD_VALUE;
382     }
383     Mutex::Autolock _l(mLock);
384     if (mpAudioPolicy->get_stream_volume_index_for_device) {
385         return mpAudioPolicy->get_stream_volume_index_for_device(mpAudioPolicy,
386                                                                 stream,
387                                                                 index,
388                                                                 device);
389     } else {
390         return mpAudioPolicy->get_stream_volume_index(mpAudioPolicy, stream, index);
391     }
392 }
393 
getStrategyForStream(audio_stream_type_t stream)394 uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
395 {
396     if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
397         return 0;
398     }
399     if (mpAudioPolicy == NULL) {
400         return 0;
401     }
402     return mpAudioPolicy->get_strategy_for_stream(mpAudioPolicy, stream);
403 }
404 
405 //audio policy: use audio_device_t appropriately
406 
getDevicesForStream(audio_stream_type_t stream)407 audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
408 {
409     if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
410         return AUDIO_DEVICE_NONE;
411     }
412     if (mpAudioPolicy == NULL) {
413         return AUDIO_DEVICE_NONE;
414     }
415     return mpAudioPolicy->get_devices_for_stream(mpAudioPolicy, stream);
416 }
417 
getOutputForEffect(const effect_descriptor_t * desc)418 audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
419 {
420     // FIXME change return type to status_t, and return NO_INIT here
421     if (mpAudioPolicy == NULL) {
422         return 0;
423     }
424     Mutex::Autolock _l(mLock);
425     return mpAudioPolicy->get_output_for_effect(mpAudioPolicy, desc);
426 }
427 
registerEffect(const effect_descriptor_t * desc,audio_io_handle_t io,uint32_t strategy,audio_session_t session,int id)428 status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
429                                 audio_io_handle_t io,
430                                 uint32_t strategy,
431                                 audio_session_t session,
432                                 int id)
433 {
434     if (mpAudioPolicy == NULL) {
435         return NO_INIT;
436     }
437     return mpAudioPolicy->register_effect(mpAudioPolicy, desc, io, strategy, session, id);
438 }
439 
unregisterEffect(int id)440 status_t AudioPolicyService::unregisterEffect(int id)
441 {
442     if (mpAudioPolicy == NULL) {
443         return NO_INIT;
444     }
445     return mpAudioPolicy->unregister_effect(mpAudioPolicy, id);
446 }
447 
setEffectEnabled(int id,bool enabled)448 status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
449 {
450     if (mpAudioPolicy == NULL) {
451         return NO_INIT;
452     }
453     return mpAudioPolicy->set_effect_enabled(mpAudioPolicy, id, enabled);
454 }
455 
isStreamActive(audio_stream_type_t stream,uint32_t inPastMs) const456 bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
457 {
458     if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
459         return false;
460     }
461     if (mpAudioPolicy == NULL) {
462         return false;
463     }
464     Mutex::Autolock _l(mLock);
465     return mpAudioPolicy->is_stream_active(mpAudioPolicy, stream, inPastMs);
466 }
467 
isStreamActiveRemotely(audio_stream_type_t stream,uint32_t inPastMs) const468 bool AudioPolicyService::isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs) const
469 {
470     if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
471         return false;
472     }
473     if (mpAudioPolicy == NULL) {
474         return false;
475     }
476     Mutex::Autolock _l(mLock);
477     return mpAudioPolicy->is_stream_active_remotely(mpAudioPolicy, stream, inPastMs);
478 }
479 
isSourceActive(audio_source_t source) const480 bool AudioPolicyService::isSourceActive(audio_source_t source) const
481 {
482     if (mpAudioPolicy == NULL) {
483         return false;
484     }
485     if (mpAudioPolicy->is_source_active == 0) {
486         return false;
487     }
488     Mutex::Autolock _l(mLock);
489     return mpAudioPolicy->is_source_active(mpAudioPolicy, source);
490 }
491 
queryDefaultPreProcessing(audio_session_t audioSession,effect_descriptor_t * descriptors,uint32_t * count)492 status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
493                                                        effect_descriptor_t *descriptors,
494                                                        uint32_t *count)
495 {
496     if (mpAudioPolicy == NULL) {
497         *count = 0;
498         return NO_INIT;
499     }
500     sp<AudioPolicyEffects>audioPolicyEffects;
501     {
502         Mutex::Autolock _l(mLock);
503         audioPolicyEffects = mAudioPolicyEffects;
504     }
505     if (audioPolicyEffects == 0) {
506         *count = 0;
507         return NO_INIT;
508     }
509     return audioPolicyEffects->queryDefaultInputEffects(audioSession, descriptors, count);
510 }
511 
isOffloadSupported(const audio_offload_info_t & info)512 bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
513 {
514     if (mpAudioPolicy == NULL) {
515         ALOGV("mpAudioPolicy == NULL");
516         return false;
517     }
518 
519     if (mpAudioPolicy->is_offload_supported == NULL) {
520         ALOGV("HAL does not implement is_offload_supported");
521         return false;
522     }
523 
524     return mpAudioPolicy->is_offload_supported(mpAudioPolicy, &info);
525 }
526 
listAudioPorts(audio_port_role_t role __unused,audio_port_type_t type __unused,unsigned int * num_ports,struct audio_port * ports __unused,unsigned int * generation __unused)527 status_t AudioPolicyService::listAudioPorts(audio_port_role_t role __unused,
528                                             audio_port_type_t type __unused,
529                                             unsigned int *num_ports,
530                                             struct audio_port *ports __unused,
531                                             unsigned int *generation __unused)
532 {
533     *num_ports = 0;
534     return INVALID_OPERATION;
535 }
536 
getAudioPort(struct audio_port * port __unused)537 status_t AudioPolicyService::getAudioPort(struct audio_port *port __unused)
538 {
539     return INVALID_OPERATION;
540 }
541 
createAudioPatch(const struct audio_patch * patch __unused,audio_patch_handle_t * handle __unused)542 status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch __unused,
543         audio_patch_handle_t *handle __unused)
544 {
545     return INVALID_OPERATION;
546 }
547 
releaseAudioPatch(audio_patch_handle_t handle __unused)548 status_t AudioPolicyService::releaseAudioPatch(audio_patch_handle_t handle __unused)
549 {
550     return INVALID_OPERATION;
551 }
552 
listAudioPatches(unsigned int * num_patches,struct audio_patch * patches __unused,unsigned int * generation __unused)553 status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
554         struct audio_patch *patches __unused,
555         unsigned int *generation __unused)
556 {
557     *num_patches = 0;
558     return INVALID_OPERATION;
559 }
560 
setAudioPortConfig(const struct audio_port_config * config __unused)561 status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config __unused)
562 {
563     return INVALID_OPERATION;
564 }
565 
getOutputForAttr(const audio_attributes_t * attr,audio_io_handle_t * output,audio_session_t session __unused,audio_stream_type_t * stream,uid_t uid __unused,uint32_t samplingRate,audio_format_t format,audio_channel_mask_t channelMask,audio_output_flags_t flags,audio_port_handle_t selectedDeviceId __unused,const audio_offload_info_t * offloadInfo)566 status_t AudioPolicyService::getOutputForAttr(const audio_attributes_t *attr,
567                                               audio_io_handle_t *output,
568                                               audio_session_t session __unused,
569                                               audio_stream_type_t *stream,
570                                               uid_t uid __unused,
571                                               uint32_t samplingRate,
572                                               audio_format_t format,
573                                               audio_channel_mask_t channelMask,
574                                               audio_output_flags_t flags,
575                                               audio_port_handle_t selectedDeviceId __unused,
576                                               const audio_offload_info_t *offloadInfo)
577 {
578     if (attr != NULL) {
579         *stream = audio_attributes_to_stream_type(attr);
580     } else {
581         if (*stream == AUDIO_STREAM_DEFAULT) {
582             return BAD_VALUE;
583         }
584     }
585     *output = getOutput(*stream, samplingRate, format, channelMask,
586                                           flags, offloadInfo);
587     if (*output == AUDIO_IO_HANDLE_NONE) {
588         return INVALID_OPERATION;
589     }
590     return NO_ERROR;
591 }
592 
acquireSoundTriggerSession(audio_session_t * session __unused,audio_io_handle_t * ioHandle __unused,audio_devices_t * device __unused)593 status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session __unused,
594                                        audio_io_handle_t *ioHandle __unused,
595                                        audio_devices_t *device __unused)
596 {
597     return INVALID_OPERATION;
598 }
599 
releaseSoundTriggerSession(audio_session_t session __unused)600 status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session __unused)
601 {
602     return INVALID_OPERATION;
603 }
604 
registerPolicyMixes(Vector<AudioMix> mixes __unused,bool registration __unused)605 status_t AudioPolicyService::registerPolicyMixes(Vector<AudioMix> mixes __unused,
606                                                  bool registration __unused)
607 {
608     return INVALID_OPERATION;
609 }
610 
startAudioSource(const struct audio_port_config * source,const audio_attributes_t * attributes,audio_io_handle_t * handle)611 status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
612                                   const audio_attributes_t *attributes,
613                                   audio_io_handle_t *handle)
614 {
615     return INVALID_OPERATION;
616 }
617 
stopAudioSource(audio_io_handle_t handle)618 status_t AudioPolicyService::stopAudioSource(audio_io_handle_t handle)
619 {
620     return INVALID_OPERATION;
621 }
622 
setMasterMono(bool mono)623 status_t AudioPolicyService::setMasterMono(bool mono)
624 {
625     return INVALID_OPERATION;
626 }
627 
getMasterMono(bool * mono)628 status_t AudioPolicyService::getMasterMono(bool *mono)
629 {
630     return INVALID_OPERATION;
631 }
632 
633 }; // namespace android
634