blob: 008d655e7ab0fc0f8c5a57bfd76b07c045864340 [file] [log] [blame]
Eric Laurent2d388ec2014-03-07 13:25:54 -08001/*
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
Eric Laurentdce54a12014-03-10 12:19:46 -070017#define LOG_TAG "AudioPolicyIntefaceImpl"
Eric Laurent2d388ec2014-03-07 13:25:54 -080018//#define LOG_NDEBUG 0
19
20#include <utils/Log.h>
Ray Essick84e84a52018-05-03 18:45:07 -070021#include <media/MediaAnalyticsItem.h>
22
Eric Laurent2d388ec2014-03-07 13:25:54 -080023#include "AudioPolicyService.h"
24#include "ServiceUtilities.h"
Ray Essick84e84a52018-05-03 18:45:07 -070025#include "TypeConverter.h"
Eric Laurent2d388ec2014-03-07 13:25:54 -080026
Eric Laurent2d388ec2014-03-07 13:25:54 -080027namespace android {
28
29
30// ----------------------------------------------------------------------------
31
32status_t AudioPolicyService::setDeviceConnectionState(audio_devices_t device,
33 audio_policy_dev_state_t state,
Paul McLeane743a472015-01-28 11:07:31 -080034 const char *device_address,
35 const char *device_name)
Eric Laurent2d388ec2014-03-07 13:25:54 -080036{
Eric Laurentdce54a12014-03-10 12:19:46 -070037 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080038 return NO_INIT;
39 }
40 if (!settingsAllowed()) {
41 return PERMISSION_DENIED;
42 }
Eric Laurent2d388ec2014-03-07 13:25:54 -080043 if (state != AUDIO_POLICY_DEVICE_STATE_AVAILABLE &&
44 state != AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE) {
45 return BAD_VALUE;
46 }
47
48 ALOGV("setDeviceConnectionState()");
49 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -070050 AutoCallerClear acc;
Paul McLeane743a472015-01-28 11:07:31 -080051 return mAudioPolicyManager->setDeviceConnectionState(device, state,
52 device_address, device_name);
Eric Laurent2d388ec2014-03-07 13:25:54 -080053}
54
55audio_policy_dev_state_t AudioPolicyService::getDeviceConnectionState(
56 audio_devices_t device,
57 const char *device_address)
58{
Eric Laurentdce54a12014-03-10 12:19:46 -070059 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080060 return AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE;
61 }
Eric Laurent10b71232018-04-13 18:14:44 -070062 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -070063 return mAudioPolicyManager->getDeviceConnectionState(device,
Eric Laurent2d388ec2014-03-07 13:25:54 -080064 device_address);
65}
66
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080067status_t AudioPolicyService::handleDeviceConfigChange(audio_devices_t device,
68 const char *device_address,
69 const char *device_name)
70{
71 if (mAudioPolicyManager == NULL) {
72 return NO_INIT;
73 }
74 if (!settingsAllowed()) {
75 return PERMISSION_DENIED;
76 }
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080077
78 ALOGV("handleDeviceConfigChange()");
79 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -070080 AutoCallerClear acc;
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080081 return mAudioPolicyManager->handleDeviceConfigChange(device, device_address,
82 device_name);
83}
84
Eric Laurent2d388ec2014-03-07 13:25:54 -080085status_t AudioPolicyService::setPhoneState(audio_mode_t state)
86{
Eric Laurentdce54a12014-03-10 12:19:46 -070087 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080088 return NO_INIT;
89 }
90 if (!settingsAllowed()) {
91 return PERMISSION_DENIED;
92 }
93 if (uint32_t(state) >= AUDIO_MODE_CNT) {
94 return BAD_VALUE;
95 }
96
97 ALOGV("setPhoneState()");
98
Eric Laurentbeb07fe2015-09-16 15:49:30 -070099 // acquire lock before calling setMode() so that setMode() + setPhoneState() are an atomic
100 // operation from policy manager standpoint (no other operation (e.g track start or stop)
101 // can be interleaved).
102 Mutex::Autolock _l(mLock);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800103 // TODO: check if it is more appropriate to do it in platform specific policy manager
104 AudioSystem::setMode(state);
105
Eric Laurent10b71232018-04-13 18:14:44 -0700106 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700107 mAudioPolicyManager->setPhoneState(state);
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700108 mPhoneState = state;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800109 return NO_ERROR;
110}
111
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700112audio_mode_t AudioPolicyService::getPhoneState()
113{
114 Mutex::Autolock _l(mLock);
115 return mPhoneState;
116}
117
Eric Laurent2d388ec2014-03-07 13:25:54 -0800118status_t AudioPolicyService::setForceUse(audio_policy_force_use_t usage,
119 audio_policy_forced_cfg_t config)
120{
Eric Laurentdce54a12014-03-10 12:19:46 -0700121 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800122 return NO_INIT;
123 }
124 if (!settingsAllowed()) {
125 return PERMISSION_DENIED;
126 }
127 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
128 return BAD_VALUE;
129 }
130 if (config < 0 || config >= AUDIO_POLICY_FORCE_CFG_CNT) {
131 return BAD_VALUE;
132 }
133 ALOGV("setForceUse()");
134 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700135 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700136 mAudioPolicyManager->setForceUse(usage, config);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800137 return NO_ERROR;
138}
139
140audio_policy_forced_cfg_t AudioPolicyService::getForceUse(audio_policy_force_use_t usage)
141{
Eric Laurentdce54a12014-03-10 12:19:46 -0700142 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800143 return AUDIO_POLICY_FORCE_NONE;
144 }
145 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
146 return AUDIO_POLICY_FORCE_NONE;
147 }
Eric Laurent10b71232018-04-13 18:14:44 -0700148 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700149 return mAudioPolicyManager->getForceUse(usage);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800150}
151
Eric Laurentf4e63452017-11-06 19:31:46 +0000152audio_io_handle_t AudioPolicyService::getOutput(audio_stream_type_t stream)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800153{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800154 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700155 return AUDIO_IO_HANDLE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700156 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700157 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700158 return AUDIO_IO_HANDLE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800159 }
160 ALOGV("getOutput()");
161 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700162 AutoCallerClear acc;
Eric Laurentf4e63452017-11-06 19:31:46 +0000163 return mAudioPolicyManager->getOutput(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800164}
165
Eric Laurente83b55d2014-11-14 10:06:21 -0800166status_t AudioPolicyService::getOutputForAttr(const audio_attributes_t *attr,
167 audio_io_handle_t *output,
168 audio_session_t session,
169 audio_stream_type_t *stream,
Nadav Bar766fb022018-01-07 12:18:03 +0200170 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700171 uid_t uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800172 const audio_config_t *config,
Eric Laurente83b55d2014-11-14 10:06:21 -0800173 audio_output_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700174 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800175 audio_port_handle_t *portId)
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700176{
177 if (mAudioPolicyManager == NULL) {
Eric Laurente83b55d2014-11-14 10:06:21 -0800178 return NO_INIT;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700179 }
Eric Laurentf4e63452017-11-06 19:31:46 +0000180 ALOGV("getOutputForAttr()");
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700181 Mutex::Autolock _l(mLock);
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700182
Marco Nelissendcb346b2015-09-09 10:47:29 -0700183 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
184 if (!isTrustedCallingUid(callingUid) || uid == (uid_t)-1) {
185 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
186 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
187 uid = callingUid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700188 }
Nadav Bar766fb022018-01-07 12:18:03 +0200189 audio_output_flags_t originalFlags = flags;
Eric Laurent10b71232018-04-13 18:14:44 -0700190 AutoCallerClear acc;
Nadav Bar766fb022018-01-07 12:18:03 +0200191 status_t result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800192 config,
Nadav Bar766fb022018-01-07 12:18:03 +0200193 &flags, selectedDeviceId, portId);
194
195 // FIXME: Introduce a way to check for the the telephony device before opening the output
196 if ((result == NO_ERROR) &&
197 (flags & AUDIO_OUTPUT_FLAG_INCALL_MUSIC) &&
198 !modifyPhoneStateAllowed(pid, uid)) {
199 // If the app tries to play music through the telephony device and doesn't have permission
200 // the fallback to the default output device.
201 mAudioPolicyManager->releaseOutput(*output, *stream, session);
202 flags = originalFlags;
203 *selectedDeviceId = AUDIO_PORT_HANDLE_NONE;
204 *portId = AUDIO_PORT_HANDLE_NONE;
205 result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
206 config,
207 &flags, selectedDeviceId, portId);
208 }
209 return result;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700210}
211
Eric Laurent2d388ec2014-03-07 13:25:54 -0800212status_t AudioPolicyService::startOutput(audio_io_handle_t output,
213 audio_stream_type_t stream,
Eric Laurente83b55d2014-11-14 10:06:21 -0800214 audio_session_t session)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800215{
Eric Laurentdea15412014-10-28 15:46:45 -0700216 if (uint32_t(stream) >= AUDIO_STREAM_CNT) {
217 return BAD_VALUE;
218 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700219 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800220 return NO_INIT;
221 }
222 ALOGV("startOutput()");
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700223 sp<AudioPolicyEffects>audioPolicyEffects;
224 {
225 Mutex::Autolock _l(mLock);
226 audioPolicyEffects = mAudioPolicyEffects;
bryant_liuba2b4392014-06-11 16:49:30 +0800227 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700228 if (audioPolicyEffects != 0) {
229 // create audio processors according to stream
230 status_t status = audioPolicyEffects->addOutputSessionEffects(output, stream, session);
231 if (status != NO_ERROR && status != ALREADY_EXISTS) {
232 ALOGW("Failed to add effects on session %d", session);
233 }
234 }
235 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700236 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700237 return mAudioPolicyManager->startOutput(output, stream, session);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800238}
239
240status_t AudioPolicyService::stopOutput(audio_io_handle_t output,
241 audio_stream_type_t stream,
Eric Laurente83b55d2014-11-14 10:06:21 -0800242 audio_session_t session)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800243{
Eric Laurentdea15412014-10-28 15:46:45 -0700244 if (uint32_t(stream) >= AUDIO_STREAM_CNT) {
245 return BAD_VALUE;
246 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700247 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800248 return NO_INIT;
249 }
250 ALOGV("stopOutput()");
251 mOutputCommandThread->stopOutputCommand(output, stream, session);
252 return NO_ERROR;
253}
254
255status_t AudioPolicyService::doStopOutput(audio_io_handle_t output,
256 audio_stream_type_t stream,
Eric Laurente83b55d2014-11-14 10:06:21 -0800257 audio_session_t session)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800258{
259 ALOGV("doStopOutput from tid %d", gettid());
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700260 sp<AudioPolicyEffects>audioPolicyEffects;
261 {
262 Mutex::Autolock _l(mLock);
263 audioPolicyEffects = mAudioPolicyEffects;
bryant_liuba2b4392014-06-11 16:49:30 +0800264 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700265 if (audioPolicyEffects != 0) {
266 // release audio processors from the stream
267 status_t status = audioPolicyEffects->releaseOutputSessionEffects(output, stream, session);
268 if (status != NO_ERROR && status != ALREADY_EXISTS) {
269 ALOGW("Failed to release effects on session %d", session);
270 }
271 }
272 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700273 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700274 return mAudioPolicyManager->stopOutput(output, stream, session);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800275}
276
Eric Laurente83b55d2014-11-14 10:06:21 -0800277void AudioPolicyService::releaseOutput(audio_io_handle_t output,
278 audio_stream_type_t stream,
279 audio_session_t session)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800280{
Eric Laurentdce54a12014-03-10 12:19:46 -0700281 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800282 return;
283 }
284 ALOGV("releaseOutput()");
Eric Laurente83b55d2014-11-14 10:06:21 -0800285 mOutputCommandThread->releaseOutputCommand(output, stream, session);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800286}
287
Eric Laurente83b55d2014-11-14 10:06:21 -0800288void AudioPolicyService::doReleaseOutput(audio_io_handle_t output,
289 audio_stream_type_t stream,
290 audio_session_t session)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800291{
292 ALOGV("doReleaseOutput from tid %d", gettid());
293 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700294 // called from internal thread: no need to clear caller identity
Eric Laurente83b55d2014-11-14 10:06:21 -0800295 mAudioPolicyManager->releaseOutput(output, stream, session);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800296}
297
Eric Laurentcaf7f482014-11-25 17:50:47 -0800298status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
299 audio_io_handle_t *input,
300 audio_session_t session,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700301 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700302 uid_t uid,
Eric Laurentfee19762018-01-29 18:44:13 -0800303 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800304 const audio_config_base_t *config,
Paul McLean466dc8e2015-04-17 13:15:36 -0600305 audio_input_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700306 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800307 audio_port_handle_t *portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800308{
Eric Laurentdce54a12014-03-10 12:19:46 -0700309 if (mAudioPolicyManager == NULL) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800310 return NO_INIT;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800311 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800312
Eric Laurent2d388ec2014-03-07 13:25:54 -0800313 // already checked by client, but double-check in case the client wrapper is bypassed
Eric Laurentfe231122017-11-17 17:48:06 -0800314 if (attr->source < AUDIO_SOURCE_DEFAULT && attr->source >= AUDIO_SOURCE_CNT &&
315 attr->source != AUDIO_SOURCE_HOTWORD && attr->source != AUDIO_SOURCE_FM_TUNER) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800316 return BAD_VALUE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800317 }
318
Eric Laurentb2379ba2016-05-23 17:42:12 -0700319 bool updatePid = (pid == -1);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700320 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Eric Laurentb2379ba2016-05-23 17:42:12 -0700321 if (!isTrustedCallingUid(callingUid)) {
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700322 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Marco Nelissendcb346b2015-09-09 10:47:29 -0700323 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
324 uid = callingUid;
Eric Laurentb2379ba2016-05-23 17:42:12 -0700325 updatePid = true;
326 }
327
328 if (updatePid) {
329 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700330 ALOGW_IF(pid != (pid_t)-1 && pid != callingPid,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700331 "%s uid %d pid %d tried to pass itself off as pid %d",
332 __func__, callingUid, callingPid, pid);
333 pid = callingPid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700334 }
335
Eric Laurent7dca8a82018-01-29 18:44:26 -0800336 // check calling permissions
337 if (!recordingAllowed(opPackageName, pid, uid)) {
338 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
339 __func__, uid, pid);
340 return PERMISSION_DENIED;
341 }
342
Eric Laurent7504b9e2017-08-15 18:17:26 -0700343 if ((attr->source == AUDIO_SOURCE_HOTWORD) && !captureHotwordAllowed(pid, uid)) {
344 return BAD_VALUE;
345 }
346
347 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700348 {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700349 status_t status;
350 AudioPolicyInterface::input_type_t inputType;
351
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700352 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700353 {
354 AutoCallerClear acc;
355 // the audio_in_acoustics_t parameter is ignored by get_input()
356 status = mAudioPolicyManager->getInputForAttr(attr, input, session, uid,
357 config,
358 flags, selectedDeviceId,
359 &inputType, portId);
360 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700361 audioPolicyEffects = mAudioPolicyEffects;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800362
363 if (status == NO_ERROR) {
364 // enforce permission (if any) required for each type of input
365 switch (inputType) {
366 case AudioPolicyInterface::API_INPUT_LEGACY:
367 break;
Eric Laurent82db2692015-08-07 13:59:42 -0700368 case AudioPolicyInterface::API_INPUT_TELEPHONY_RX:
369 // FIXME: use the same permission as for remote submix for now.
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800370 case AudioPolicyInterface::API_INPUT_MIX_CAPTURE:
Eric Laurentb2379ba2016-05-23 17:42:12 -0700371 if (!captureAudioOutputAllowed(pid, uid)) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800372 ALOGE("getInputForAttr() permission denied: capture not allowed");
373 status = PERMISSION_DENIED;
374 }
375 break;
376 case AudioPolicyInterface::API_INPUT_MIX_EXT_POLICY_REROUTE:
377 if (!modifyAudioRoutingAllowed()) {
378 ALOGE("getInputForAttr() permission denied: modify audio routing not allowed");
379 status = PERMISSION_DENIED;
380 }
381 break;
382 case AudioPolicyInterface::API_INPUT_INVALID:
383 default:
384 LOG_ALWAYS_FATAL("getInputForAttr() encountered an invalid input type %d",
385 (int)inputType);
386 }
387 }
388
389 if (status != NO_ERROR) {
390 if (status == PERMISSION_DENIED) {
Eric Laurent10b71232018-04-13 18:14:44 -0700391 AutoCallerClear acc;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800392 mAudioPolicyManager->releaseInput(*input, session);
393 }
394 return status;
395 }
Eric Laurentfee19762018-01-29 18:44:13 -0800396
397 sp<AudioRecordClient> client =
398 new AudioRecordClient(*attr, *input, uid, pid, opPackageName, session);
399 client->active = false;
400 client->isConcurrent = false;
401 client->isVirtualDevice = false; //TODO : update from APM->getInputForAttr()
402 mAudioRecordClients.add(*portId, client);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700403 }
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800404
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700405 if (audioPolicyEffects != 0) {
406 // create audio pre processors according to input source
Eric Laurentcaf7f482014-11-25 17:50:47 -0800407 status_t status = audioPolicyEffects->addInputEffects(*input, attr->source, session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700408 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800409 ALOGW("Failed to add effects on input %d", *input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700410 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800411 }
Eric Laurentcaf7f482014-11-25 17:50:47 -0800412 return NO_ERROR;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800413}
414
Ray Essick84e84a52018-05-03 18:45:07 -0700415// this is replicated from frameworks/av/media/libaudioclient/AudioRecord.cpp
416// XXX -- figure out how to put it into a common, shared location
417
418static std::string audioSourceString(audio_source_t value) {
419 std::string source;
420 if (SourceTypeConverter::toString(value, source)) {
421 return source;
422 }
423 char rawbuffer[16]; // room for "%d"
424 snprintf(rawbuffer, sizeof(rawbuffer), "%d", value);
425 return rawbuffer;
426}
427
428static std::string audioConcurrencyString(AudioPolicyInterface::concurrency_type__mask_t concurrency)
429{
430 char buffer[64]; // oversized
431 if (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_ALL) {
432 snprintf(buffer, sizeof(buffer), "%s%s%s%s",
433 (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_CALL)? ",call":"",
434 (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_CAPTURE)? ",capture":"",
435 (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_HOTWORD)? ",hotword":"",
436 (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_PREEMPT)? ",preempt":"");
437 } else {
438 snprintf(buffer, sizeof(buffer), ",none");
439 }
440
441 return &buffer[1];
442}
443
Eric Laurentfee19762018-01-29 18:44:13 -0800444status_t AudioPolicyService::startInput(audio_port_handle_t portId, bool *silenced)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800445{
Eric Laurentdce54a12014-03-10 12:19:46 -0700446 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800447 return NO_INIT;
448 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800449 sp<AudioRecordClient> client;
450 {
451 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800452
Eric Laurent7dca8a82018-01-29 18:44:26 -0800453 ssize_t index = mAudioRecordClients.indexOfKey(portId);
454 if (index < 0) {
455 return INVALID_OPERATION;
456 }
457 client = mAudioRecordClients.valueAt(index);
Eric Laurentfee19762018-01-29 18:44:13 -0800458 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800459
460 // check calling permissions
Svet Ganov6e641372018-03-02 09:21:30 -0800461 if (!startRecording(client->opPackageName, client->pid, client->uid)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800462 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
463 __func__, client->uid, client->pid);
464 return PERMISSION_DENIED;
465 }
Eric Laurentfee19762018-01-29 18:44:13 -0800466
467 // If UID inactive it records silence until becoming active
468 *silenced = !mUidPolicy->isUidActive(client->uid) && !client->isVirtualDevice;
469
Eric Laurent7dca8a82018-01-29 18:44:26 -0800470 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800471 AudioPolicyInterface::concurrency_type__mask_t concurrency =
472 AudioPolicyInterface::API_INPUT_CONCURRENCY_NONE;
Eric Laurentfee19762018-01-29 18:44:13 -0800473
Eric Laurent10b71232018-04-13 18:14:44 -0700474 status_t status;
475 {
476 AutoCallerClear acc;
477 status = mAudioPolicyManager->startInput(
478 client->input, client->session, *silenced, &concurrency);
Ray Essick84e84a52018-05-03 18:45:07 -0700479
480 }
481
482 // XXX log them all for a while, during some dogfooding.
483 if (1 || status != NO_ERROR) {
484
485 static constexpr char kAudioPolicy[] = "audiopolicy";
486
487 static constexpr char kAudioPolicyReason[] = "android.media.audiopolicy.reason";
488 static constexpr char kAudioPolicyStatus[] = "android.media.audiopolicy.status";
489 static constexpr char kAudioPolicyRqstSrc[] = "android.media.audiopolicy.rqst.src";
490 static constexpr char kAudioPolicyRqstPkg[] = "android.media.audiopolicy.rqst.pkg";
491 static constexpr char kAudioPolicyRqstSession[] = "android.media.audiopolicy.rqst.session";
492 static constexpr char kAudioPolicyActiveSrc[] = "android.media.audiopolicy.active.src";
493 static constexpr char kAudioPolicyActivePkg[] = "android.media.audiopolicy.active.pkg";
494 static constexpr char kAudioPolicyActiveSession[] = "android.media.audiopolicy.active.session";
495
496 MediaAnalyticsItem *item = new MediaAnalyticsItem(kAudioPolicy);
497 if (item != NULL) {
498
499 item->setCString(kAudioPolicyReason, audioConcurrencyString(concurrency).c_str());
500 item->setInt32(kAudioPolicyStatus, status);
501
502 item->setCString(kAudioPolicyRqstSrc, audioSourceString(client->attributes.source).c_str());
503 item->setCString(kAudioPolicyRqstPkg, std::string(String8(client->opPackageName).string()).c_str());
504 item->setInt32(kAudioPolicyRqstSession, client->session);
505
506 // figure out who is active
507 // NB: might the other party have given up the microphone since then? how sure.
508 // perhaps could have given up on it.
509 // we hold mLock, so perhaps we're safe for this looping
510 if (concurrency != AudioPolicyInterface::API_INPUT_CONCURRENCY_NONE) {
511 int count = mAudioRecordClients.size();
512 for (int i = 0; i<count ; i++) {
513 if (portId == mAudioRecordClients.keyAt(i)) {
514 continue;
515 }
516 sp<AudioRecordClient> other = mAudioRecordClients.valueAt(i);
517 if (other->active) {
518 // keeps the last of the clients marked active
519 item->setCString(kAudioPolicyActiveSrc,
520 audioSourceString(other->attributes.source).c_str());
521 item->setCString(kAudioPolicyActivePkg, std::string(String8(other->opPackageName).string()).c_str());
522 item->setInt32(kAudioPolicyActiveSession, other->session);
523 }
524 }
525 }
526 item->selfrecord();
527 delete item;
528 item = NULL;
529 }
Eric Laurent10b71232018-04-13 18:14:44 -0700530 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800531
Eric Laurentfb66dd92016-01-28 18:32:03 -0800532 if (status == NO_ERROR) {
Eric Laurent43423352016-02-05 11:57:57 -0800533 LOG_ALWAYS_FATAL_IF(concurrency & ~AudioPolicyInterface::API_INPUT_CONCURRENCY_ALL,
534 "startInput(): invalid concurrency type %d", (int)concurrency);
535
Eric Laurentfb66dd92016-01-28 18:32:03 -0800536 // enforce permission (if any) required for each type of concurrency
Eric Laurent43423352016-02-05 11:57:57 -0800537 if (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_CALL) {
Eric Laurentfb66dd92016-01-28 18:32:03 -0800538 //TODO: check incall capture permission
Eric Laurent43423352016-02-05 11:57:57 -0800539 }
540 if (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_CAPTURE) {
Eric Laurentfb66dd92016-01-28 18:32:03 -0800541 //TODO: check concurrent capture permission
Eric Laurentfb66dd92016-01-28 18:32:03 -0800542 }
Ray Essick84e84a52018-05-03 18:45:07 -0700543
544 client->active = true;
Svet Ganov6e641372018-03-02 09:21:30 -0800545 } else {
546 finishRecording(client->opPackageName, client->uid);
Eric Laurentfb66dd92016-01-28 18:32:03 -0800547 }
548
549 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800550}
551
Eric Laurentfee19762018-01-29 18:44:13 -0800552status_t AudioPolicyService::stopInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800553{
Eric Laurentdce54a12014-03-10 12:19:46 -0700554 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800555 return NO_INIT;
556 }
557 Mutex::Autolock _l(mLock);
558
Eric Laurentfee19762018-01-29 18:44:13 -0800559 ssize_t index = mAudioRecordClients.indexOfKey(portId);
560 if (index < 0) {
561 return INVALID_OPERATION;
562 }
563 sp<AudioRecordClient> client = mAudioRecordClients.valueAt(index);
564
Ray Essick84e84a52018-05-03 18:45:07 -0700565 client->active = false;
566
Svet Ganov6e641372018-03-02 09:21:30 -0800567 // finish the recording app op
568 finishRecording(client->opPackageName, client->uid);
Eric Laurent10b71232018-04-13 18:14:44 -0700569 AutoCallerClear acc;
Eric Laurentfee19762018-01-29 18:44:13 -0800570 return mAudioPolicyManager->stopInput(client->input, client->session);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800571}
572
Eric Laurentfee19762018-01-29 18:44:13 -0800573void AudioPolicyService::releaseInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800574{
Eric Laurentdce54a12014-03-10 12:19:46 -0700575 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800576 return;
577 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700578 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800579 sp<AudioRecordClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700580 {
581 Mutex::Autolock _l(mLock);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700582 audioPolicyEffects = mAudioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800583 ssize_t index = mAudioRecordClients.indexOfKey(portId);
584 if (index < 0) {
585 return;
586 }
587 client = mAudioRecordClients.valueAt(index);
588 mAudioRecordClients.removeItem(portId);
589 }
590 if (client == 0) {
591 return;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700592 }
593 if (audioPolicyEffects != 0) {
594 // release audio processors from the input
Eric Laurentfee19762018-01-29 18:44:13 -0800595 status_t status = audioPolicyEffects->releaseInputEffects(client->input, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700596 if(status != NO_ERROR) {
Eric Laurentfee19762018-01-29 18:44:13 -0800597 ALOGW("Failed to release effects on input %d", client->input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700598 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800599 }
Eric Laurentf10c7092016-12-06 17:09:56 -0800600 {
601 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700602 AutoCallerClear acc;
Eric Laurentfee19762018-01-29 18:44:13 -0800603 mAudioPolicyManager->releaseInput(client->input, client->session);
Eric Laurentf10c7092016-12-06 17:09:56 -0800604 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800605}
606
607status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
608 int indexMin,
609 int indexMax)
610{
Eric Laurentdce54a12014-03-10 12:19:46 -0700611 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800612 return NO_INIT;
613 }
614 if (!settingsAllowed()) {
615 return PERMISSION_DENIED;
616 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800617 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800618 return BAD_VALUE;
619 }
620 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700621 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700622 mAudioPolicyManager->initStreamVolume(stream, indexMin, indexMax);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800623 return NO_ERROR;
624}
625
626status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
627 int index,
628 audio_devices_t device)
629{
Eric Laurentdce54a12014-03-10 12:19:46 -0700630 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800631 return NO_INIT;
632 }
633 if (!settingsAllowed()) {
634 return PERMISSION_DENIED;
635 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800636 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800637 return BAD_VALUE;
638 }
639 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700640 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700641 return mAudioPolicyManager->setStreamVolumeIndex(stream,
642 index,
643 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800644}
645
646status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
647 int *index,
648 audio_devices_t device)
649{
Eric Laurentdce54a12014-03-10 12:19:46 -0700650 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800651 return NO_INIT;
652 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800653 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800654 return BAD_VALUE;
655 }
656 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700657 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700658 return mAudioPolicyManager->getStreamVolumeIndex(stream,
659 index,
660 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800661}
662
663uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
664{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800665 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700666 return 0;
Eric Laurentdea15412014-10-28 15:46:45 -0700667 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700668 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800669 return 0;
670 }
Eric Laurent10b71232018-04-13 18:14:44 -0700671 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700672 return mAudioPolicyManager->getStrategyForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800673}
674
675//audio policy: use audio_device_t appropriately
676
677audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
678{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800679 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700680 return AUDIO_DEVICE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700681 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700682 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700683 return AUDIO_DEVICE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800684 }
Haynes Mathew Georgedfb9f3b2015-10-26 18:22:13 -0700685 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700686 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700687 return mAudioPolicyManager->getDevicesForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800688}
689
690audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
691{
692 // FIXME change return type to status_t, and return NO_INIT here
Eric Laurentdce54a12014-03-10 12:19:46 -0700693 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800694 return 0;
695 }
696 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700697 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700698 return mAudioPolicyManager->getOutputForEffect(desc);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800699}
700
701status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
702 audio_io_handle_t io,
703 uint32_t strategy,
Glenn Kastend848eb42016-03-08 13:42:11 -0800704 audio_session_t session,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800705 int id)
706{
Eric Laurentdce54a12014-03-10 12:19:46 -0700707 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800708 return NO_INIT;
709 }
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700710 Mutex::Autolock _l(mEffectsLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700711 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700712 return mAudioPolicyManager->registerEffect(desc, io, strategy, session, id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800713}
714
715status_t AudioPolicyService::unregisterEffect(int id)
716{
Eric Laurentdce54a12014-03-10 12:19:46 -0700717 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800718 return NO_INIT;
719 }
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700720 Mutex::Autolock _l(mEffectsLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700721 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700722 return mAudioPolicyManager->unregisterEffect(id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800723}
724
725status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
726{
Eric Laurentdce54a12014-03-10 12:19:46 -0700727 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800728 return NO_INIT;
729 }
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700730 Mutex::Autolock _l(mEffectsLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700731 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700732 return mAudioPolicyManager->setEffectEnabled(id, enabled);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800733}
734
735bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
736{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800737 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700738 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700739 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700740 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700741 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800742 }
743 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700744 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700745 return mAudioPolicyManager->isStreamActive(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800746}
747
748bool AudioPolicyService::isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs) const
749{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800750 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700751 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700752 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700753 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700754 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800755 }
756 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700757 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700758 return mAudioPolicyManager->isStreamActiveRemotely(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800759}
760
761bool AudioPolicyService::isSourceActive(audio_source_t source) const
762{
Eric Laurentdce54a12014-03-10 12:19:46 -0700763 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800764 return false;
765 }
766 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700767 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700768 return mAudioPolicyManager->isSourceActive(source);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800769}
770
Glenn Kastend848eb42016-03-08 13:42:11 -0800771status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800772 effect_descriptor_t *descriptors,
773 uint32_t *count)
774{
Eric Laurentdce54a12014-03-10 12:19:46 -0700775 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800776 *count = 0;
777 return NO_INIT;
778 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700779 sp<AudioPolicyEffects>audioPolicyEffects;
780 {
781 Mutex::Autolock _l(mLock);
782 audioPolicyEffects = mAudioPolicyEffects;
783 }
784 if (audioPolicyEffects == 0) {
785 *count = 0;
786 return NO_INIT;
787 }
Eric Laurentfb66dd92016-01-28 18:32:03 -0800788 return audioPolicyEffects->queryDefaultInputEffects(
789 (audio_session_t)audioSession, descriptors, count);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800790}
791
792bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
793{
Eric Laurentdce54a12014-03-10 12:19:46 -0700794 if (mAudioPolicyManager == NULL) {
795 ALOGV("mAudioPolicyManager == NULL");
Eric Laurent2d388ec2014-03-07 13:25:54 -0800796 return false;
797 }
Andy Hung2ddee192015-12-18 17:34:44 -0800798 Mutex::Autolock _l(mLock);
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700799 Mutex::Autolock _le(mEffectsLock); // isOffloadSupported queries for
800 // non-offloadable effects
Eric Laurent10b71232018-04-13 18:14:44 -0700801 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700802 return mAudioPolicyManager->isOffloadSupported(info);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800803}
804
Eric Laurent6a94d692014-05-20 11:18:06 -0700805status_t AudioPolicyService::listAudioPorts(audio_port_role_t role,
806 audio_port_type_t type,
Eric Laurent203b1a12014-04-01 10:34:16 -0700807 unsigned int *num_ports,
Eric Laurent6a94d692014-05-20 11:18:06 -0700808 struct audio_port *ports,
809 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -0700810{
Eric Laurent6a94d692014-05-20 11:18:06 -0700811 Mutex::Autolock _l(mLock);
812 if (mAudioPolicyManager == NULL) {
813 return NO_INIT;
814 }
Eric Laurent10b71232018-04-13 18:14:44 -0700815 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700816 return mAudioPolicyManager->listAudioPorts(role, type, num_ports, ports, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -0700817}
818
Eric Laurent6a94d692014-05-20 11:18:06 -0700819status_t AudioPolicyService::getAudioPort(struct audio_port *port)
Eric Laurent203b1a12014-04-01 10:34:16 -0700820{
Eric Laurent6a94d692014-05-20 11:18:06 -0700821 Mutex::Autolock _l(mLock);
822 if (mAudioPolicyManager == NULL) {
823 return NO_INIT;
824 }
Eric Laurent10b71232018-04-13 18:14:44 -0700825 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700826 return mAudioPolicyManager->getAudioPort(port);
Eric Laurent203b1a12014-04-01 10:34:16 -0700827}
828
Eric Laurent6a94d692014-05-20 11:18:06 -0700829status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch,
830 audio_patch_handle_t *handle)
Eric Laurent203b1a12014-04-01 10:34:16 -0700831{
Eric Laurent6a94d692014-05-20 11:18:06 -0700832 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -0700833 if(!modifyAudioRoutingAllowed()) {
834 return PERMISSION_DENIED;
835 }
Eric Laurent6a94d692014-05-20 11:18:06 -0700836 if (mAudioPolicyManager == NULL) {
837 return NO_INIT;
838 }
Eric Laurent10b71232018-04-13 18:14:44 -0700839 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700840 return mAudioPolicyManager->createAudioPatch(patch, handle,
841 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -0700842}
843
Eric Laurent6a94d692014-05-20 11:18:06 -0700844status_t AudioPolicyService::releaseAudioPatch(audio_patch_handle_t handle)
Eric Laurent203b1a12014-04-01 10:34:16 -0700845{
Eric Laurent6a94d692014-05-20 11:18:06 -0700846 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -0700847 if(!modifyAudioRoutingAllowed()) {
848 return PERMISSION_DENIED;
849 }
Eric Laurent6a94d692014-05-20 11:18:06 -0700850 if (mAudioPolicyManager == NULL) {
851 return NO_INIT;
852 }
Eric Laurent10b71232018-04-13 18:14:44 -0700853 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700854 return mAudioPolicyManager->releaseAudioPatch(handle,
855 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -0700856}
857
858status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
Eric Laurent6a94d692014-05-20 11:18:06 -0700859 struct audio_patch *patches,
860 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -0700861{
Eric Laurent6a94d692014-05-20 11:18:06 -0700862 Mutex::Autolock _l(mLock);
863 if (mAudioPolicyManager == NULL) {
864 return NO_INIT;
865 }
Eric Laurent10b71232018-04-13 18:14:44 -0700866 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700867 return mAudioPolicyManager->listAudioPatches(num_patches, patches, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -0700868}
869
Eric Laurent6a94d692014-05-20 11:18:06 -0700870status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config)
Eric Laurent203b1a12014-04-01 10:34:16 -0700871{
Eric Laurent6a94d692014-05-20 11:18:06 -0700872 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -0700873 if(!modifyAudioRoutingAllowed()) {
874 return PERMISSION_DENIED;
875 }
Eric Laurent6a94d692014-05-20 11:18:06 -0700876 if (mAudioPolicyManager == NULL) {
877 return NO_INIT;
878 }
Eric Laurent10b71232018-04-13 18:14:44 -0700879 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700880 return mAudioPolicyManager->setAudioPortConfig(config);
Eric Laurent203b1a12014-04-01 10:34:16 -0700881}
Eric Laurent2d388ec2014-03-07 13:25:54 -0800882
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700883status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session,
884 audio_io_handle_t *ioHandle,
885 audio_devices_t *device)
886{
Andy Hungf759b8c2017-08-15 12:48:54 -0700887 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700888 if (mAudioPolicyManager == NULL) {
889 return NO_INIT;
890 }
Eric Laurent10b71232018-04-13 18:14:44 -0700891 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700892 return mAudioPolicyManager->acquireSoundTriggerSession(session, ioHandle, device);
893}
894
895status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session)
896{
Andy Hungf759b8c2017-08-15 12:48:54 -0700897 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700898 if (mAudioPolicyManager == NULL) {
899 return NO_INIT;
900 }
Eric Laurent10b71232018-04-13 18:14:44 -0700901 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700902 return mAudioPolicyManager->releaseSoundTriggerSession(session);
903}
904
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -0700905status_t AudioPolicyService::registerPolicyMixes(const Vector<AudioMix>& mixes, bool registration)
Eric Laurentbaac1832014-12-01 17:52:59 -0800906{
907 Mutex::Autolock _l(mLock);
908 if(!modifyAudioRoutingAllowed()) {
909 return PERMISSION_DENIED;
910 }
911 if (mAudioPolicyManager == NULL) {
912 return NO_INIT;
913 }
Eric Laurent10b71232018-04-13 18:14:44 -0700914 AutoCallerClear acc;
Eric Laurentbaac1832014-12-01 17:52:59 -0800915 if (registration) {
916 return mAudioPolicyManager->registerPolicyMixes(mixes);
917 } else {
918 return mAudioPolicyManager->unregisterPolicyMixes(mixes);
919 }
920}
921
Eric Laurent554a2772015-04-10 11:29:24 -0700922status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
923 const audio_attributes_t *attributes,
Glenn Kasten559d4392016-03-29 13:42:57 -0700924 audio_patch_handle_t *handle)
Eric Laurent554a2772015-04-10 11:29:24 -0700925{
926 Mutex::Autolock _l(mLock);
927 if (mAudioPolicyManager == NULL) {
928 return NO_INIT;
929 }
Eric Laurent10b71232018-04-13 18:14:44 -0700930 AutoCallerClear acc;
Eric Laurentd60560a2015-04-10 11:31:20 -0700931 return mAudioPolicyManager->startAudioSource(source, attributes, handle,
932 IPCThreadState::self()->getCallingUid());
Eric Laurent554a2772015-04-10 11:29:24 -0700933}
934
Glenn Kasten559d4392016-03-29 13:42:57 -0700935status_t AudioPolicyService::stopAudioSource(audio_patch_handle_t handle)
Eric Laurent554a2772015-04-10 11:29:24 -0700936{
937 Mutex::Autolock _l(mLock);
938 if (mAudioPolicyManager == NULL) {
939 return NO_INIT;
940 }
Eric Laurent10b71232018-04-13 18:14:44 -0700941 AutoCallerClear acc;
Eric Laurent554a2772015-04-10 11:29:24 -0700942 return mAudioPolicyManager->stopAudioSource(handle);
943}
944
Andy Hung2ddee192015-12-18 17:34:44 -0800945status_t AudioPolicyService::setMasterMono(bool mono)
946{
947 if (mAudioPolicyManager == NULL) {
948 return NO_INIT;
949 }
950 if (!settingsAllowed()) {
951 return PERMISSION_DENIED;
952 }
953 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700954 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -0800955 return mAudioPolicyManager->setMasterMono(mono);
956}
957
958status_t AudioPolicyService::getMasterMono(bool *mono)
959{
960 if (mAudioPolicyManager == NULL) {
961 return NO_INIT;
962 }
963 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700964 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -0800965 return mAudioPolicyManager->getMasterMono(mono);
966}
967
Eric Laurentac9cef52017-06-09 15:46:26 -0700968
969float AudioPolicyService::getStreamVolumeDB(
970 audio_stream_type_t stream, int index, audio_devices_t device)
971{
972 if (mAudioPolicyManager == NULL) {
973 return NAN;
974 }
975 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700976 AutoCallerClear acc;
Eric Laurentac9cef52017-06-09 15:46:26 -0700977 return mAudioPolicyManager->getStreamVolumeDB(stream, index, device);
978}
979
980
Mikhail Naganov1b2a7942017-12-08 10:18:09 -0800981} // namespace android