blob: d2bc40d9e95c63d203a09bc17f16063c159e3709 [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"
Andy Hungab7ef302018-05-15 19:35:29 -070024#include <mediautils/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 }
Eric Laurente17378d2018-05-09 14:43:01 -0700124
125 if (!modifyAudioRoutingAllowed()) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800126 return PERMISSION_DENIED;
127 }
Eric Laurente17378d2018-05-09 14:43:01 -0700128
Eric Laurent2d388ec2014-03-07 13:25:54 -0800129 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
130 return BAD_VALUE;
131 }
132 if (config < 0 || config >= AUDIO_POLICY_FORCE_CFG_CNT) {
133 return BAD_VALUE;
134 }
135 ALOGV("setForceUse()");
136 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700137 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700138 mAudioPolicyManager->setForceUse(usage, config);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800139 return NO_ERROR;
140}
141
142audio_policy_forced_cfg_t AudioPolicyService::getForceUse(audio_policy_force_use_t usage)
143{
Eric Laurentdce54a12014-03-10 12:19:46 -0700144 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800145 return AUDIO_POLICY_FORCE_NONE;
146 }
147 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
148 return AUDIO_POLICY_FORCE_NONE;
149 }
Eric Laurent10b71232018-04-13 18:14:44 -0700150 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700151 return mAudioPolicyManager->getForceUse(usage);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800152}
153
Eric Laurentf4e63452017-11-06 19:31:46 +0000154audio_io_handle_t AudioPolicyService::getOutput(audio_stream_type_t stream)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800155{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800156 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700157 return AUDIO_IO_HANDLE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700158 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700159 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700160 return AUDIO_IO_HANDLE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800161 }
162 ALOGV("getOutput()");
163 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700164 AutoCallerClear acc;
Eric Laurentf4e63452017-11-06 19:31:46 +0000165 return mAudioPolicyManager->getOutput(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800166}
167
Eric Laurente83b55d2014-11-14 10:06:21 -0800168status_t AudioPolicyService::getOutputForAttr(const audio_attributes_t *attr,
169 audio_io_handle_t *output,
170 audio_session_t session,
171 audio_stream_type_t *stream,
Nadav Bar766fb022018-01-07 12:18:03 +0200172 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700173 uid_t uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800174 const audio_config_t *config,
Eric Laurente83b55d2014-11-14 10:06:21 -0800175 audio_output_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700176 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800177 audio_port_handle_t *portId)
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700178{
179 if (mAudioPolicyManager == NULL) {
Eric Laurente83b55d2014-11-14 10:06:21 -0800180 return NO_INIT;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700181 }
Eric Laurentf4e63452017-11-06 19:31:46 +0000182 ALOGV("getOutputForAttr()");
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700183 Mutex::Autolock _l(mLock);
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700184
Marco Nelissendcb346b2015-09-09 10:47:29 -0700185 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700186 if (!isAudioServerOrMediaServerUid(callingUid) || uid == (uid_t)-1) {
Marco Nelissendcb346b2015-09-09 10:47:29 -0700187 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
188 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
189 uid = callingUid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700190 }
Nadav Bar766fb022018-01-07 12:18:03 +0200191 audio_output_flags_t originalFlags = flags;
Eric Laurent10b71232018-04-13 18:14:44 -0700192 AutoCallerClear acc;
Nadav Bar766fb022018-01-07 12:18:03 +0200193 status_t result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800194 config,
Nadav Bar766fb022018-01-07 12:18:03 +0200195 &flags, selectedDeviceId, portId);
196
197 // FIXME: Introduce a way to check for the the telephony device before opening the output
198 if ((result == NO_ERROR) &&
199 (flags & AUDIO_OUTPUT_FLAG_INCALL_MUSIC) &&
200 !modifyPhoneStateAllowed(pid, uid)) {
201 // If the app tries to play music through the telephony device and doesn't have permission
202 // the fallback to the default output device.
203 mAudioPolicyManager->releaseOutput(*output, *stream, session);
204 flags = originalFlags;
205 *selectedDeviceId = AUDIO_PORT_HANDLE_NONE;
206 *portId = AUDIO_PORT_HANDLE_NONE;
207 result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
208 config,
209 &flags, selectedDeviceId, portId);
210 }
211 return result;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700212}
213
Eric Laurent2d388ec2014-03-07 13:25:54 -0800214status_t AudioPolicyService::startOutput(audio_io_handle_t output,
215 audio_stream_type_t stream,
Eric Laurente83b55d2014-11-14 10:06:21 -0800216 audio_session_t session)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800217{
Eric Laurentdea15412014-10-28 15:46:45 -0700218 if (uint32_t(stream) >= AUDIO_STREAM_CNT) {
219 return BAD_VALUE;
220 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700221 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800222 return NO_INIT;
223 }
224 ALOGV("startOutput()");
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700225 sp<AudioPolicyEffects>audioPolicyEffects;
226 {
227 Mutex::Autolock _l(mLock);
228 audioPolicyEffects = mAudioPolicyEffects;
bryant_liuba2b4392014-06-11 16:49:30 +0800229 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700230 if (audioPolicyEffects != 0) {
231 // create audio processors according to stream
232 status_t status = audioPolicyEffects->addOutputSessionEffects(output, stream, session);
233 if (status != NO_ERROR && status != ALREADY_EXISTS) {
234 ALOGW("Failed to add effects on session %d", session);
235 }
236 }
237 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700238 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700239 return mAudioPolicyManager->startOutput(output, stream, session);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800240}
241
242status_t AudioPolicyService::stopOutput(audio_io_handle_t output,
243 audio_stream_type_t stream,
Eric Laurente83b55d2014-11-14 10:06:21 -0800244 audio_session_t session)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800245{
Eric Laurentdea15412014-10-28 15:46:45 -0700246 if (uint32_t(stream) >= AUDIO_STREAM_CNT) {
247 return BAD_VALUE;
248 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700249 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800250 return NO_INIT;
251 }
252 ALOGV("stopOutput()");
253 mOutputCommandThread->stopOutputCommand(output, stream, session);
254 return NO_ERROR;
255}
256
257status_t AudioPolicyService::doStopOutput(audio_io_handle_t output,
258 audio_stream_type_t stream,
Eric Laurente83b55d2014-11-14 10:06:21 -0800259 audio_session_t session)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800260{
261 ALOGV("doStopOutput from tid %d", gettid());
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700262 sp<AudioPolicyEffects>audioPolicyEffects;
263 {
264 Mutex::Autolock _l(mLock);
265 audioPolicyEffects = mAudioPolicyEffects;
bryant_liuba2b4392014-06-11 16:49:30 +0800266 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700267 if (audioPolicyEffects != 0) {
268 // release audio processors from the stream
269 status_t status = audioPolicyEffects->releaseOutputSessionEffects(output, stream, session);
270 if (status != NO_ERROR && status != ALREADY_EXISTS) {
271 ALOGW("Failed to release effects on session %d", session);
272 }
273 }
274 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700275 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700276 return mAudioPolicyManager->stopOutput(output, stream, session);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800277}
278
Eric Laurente83b55d2014-11-14 10:06:21 -0800279void AudioPolicyService::releaseOutput(audio_io_handle_t output,
280 audio_stream_type_t stream,
281 audio_session_t session)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800282{
Eric Laurentdce54a12014-03-10 12:19:46 -0700283 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800284 return;
285 }
286 ALOGV("releaseOutput()");
Eric Laurente83b55d2014-11-14 10:06:21 -0800287 mOutputCommandThread->releaseOutputCommand(output, stream, session);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800288}
289
Eric Laurente83b55d2014-11-14 10:06:21 -0800290void AudioPolicyService::doReleaseOutput(audio_io_handle_t output,
291 audio_stream_type_t stream,
292 audio_session_t session)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800293{
294 ALOGV("doReleaseOutput from tid %d", gettid());
295 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700296 // called from internal thread: no need to clear caller identity
Eric Laurente83b55d2014-11-14 10:06:21 -0800297 mAudioPolicyManager->releaseOutput(output, stream, session);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800298}
299
Eric Laurentcaf7f482014-11-25 17:50:47 -0800300status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
301 audio_io_handle_t *input,
302 audio_session_t session,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700303 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700304 uid_t uid,
Eric Laurentfee19762018-01-29 18:44:13 -0800305 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800306 const audio_config_base_t *config,
Paul McLean466dc8e2015-04-17 13:15:36 -0600307 audio_input_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700308 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800309 audio_port_handle_t *portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800310{
Eric Laurentdce54a12014-03-10 12:19:46 -0700311 if (mAudioPolicyManager == NULL) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800312 return NO_INIT;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800313 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800314
Eric Laurent2d388ec2014-03-07 13:25:54 -0800315 // already checked by client, but double-check in case the client wrapper is bypassed
Eric Laurentfe231122017-11-17 17:48:06 -0800316 if (attr->source < AUDIO_SOURCE_DEFAULT && attr->source >= AUDIO_SOURCE_CNT &&
317 attr->source != AUDIO_SOURCE_HOTWORD && attr->source != AUDIO_SOURCE_FM_TUNER) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800318 return BAD_VALUE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800319 }
320
Eric Laurentb2379ba2016-05-23 17:42:12 -0700321 bool updatePid = (pid == -1);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700322 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700323 if (!isAudioServerOrMediaServerUid(callingUid)) {
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700324 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Marco Nelissendcb346b2015-09-09 10:47:29 -0700325 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
326 uid = callingUid;
Eric Laurentb2379ba2016-05-23 17:42:12 -0700327 updatePid = true;
328 }
329
330 if (updatePid) {
331 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700332 ALOGW_IF(pid != (pid_t)-1 && pid != callingPid,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700333 "%s uid %d pid %d tried to pass itself off as pid %d",
334 __func__, callingUid, callingPid, pid);
335 pid = callingPid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700336 }
337
Eric Laurent7dca8a82018-01-29 18:44:26 -0800338 // check calling permissions
339 if (!recordingAllowed(opPackageName, pid, uid)) {
340 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
341 __func__, uid, pid);
342 return PERMISSION_DENIED;
343 }
344
Nadav Bar744be482018-05-08 13:26:21 +0300345 if ((attr->source == AUDIO_SOURCE_VOICE_UPLINK ||
346 attr->source == AUDIO_SOURCE_VOICE_DOWNLINK ||
347 attr->source == AUDIO_SOURCE_VOICE_CALL) &&
348 !captureAudioOutputAllowed(pid, uid)) {
349 return PERMISSION_DENIED;
350 }
351
Eric Laurent7504b9e2017-08-15 18:17:26 -0700352 if ((attr->source == AUDIO_SOURCE_HOTWORD) && !captureHotwordAllowed(pid, uid)) {
353 return BAD_VALUE;
354 }
355
356 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700357 {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700358 status_t status;
359 AudioPolicyInterface::input_type_t inputType;
360
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700361 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700362 {
363 AutoCallerClear acc;
364 // the audio_in_acoustics_t parameter is ignored by get_input()
365 status = mAudioPolicyManager->getInputForAttr(attr, input, session, uid,
366 config,
367 flags, selectedDeviceId,
368 &inputType, portId);
369 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700370 audioPolicyEffects = mAudioPolicyEffects;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800371
372 if (status == NO_ERROR) {
373 // enforce permission (if any) required for each type of input
374 switch (inputType) {
375 case AudioPolicyInterface::API_INPUT_LEGACY:
376 break;
Eric Laurent82db2692015-08-07 13:59:42 -0700377 case AudioPolicyInterface::API_INPUT_TELEPHONY_RX:
378 // FIXME: use the same permission as for remote submix for now.
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800379 case AudioPolicyInterface::API_INPUT_MIX_CAPTURE:
Eric Laurentb2379ba2016-05-23 17:42:12 -0700380 if (!captureAudioOutputAllowed(pid, uid)) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800381 ALOGE("getInputForAttr() permission denied: capture not allowed");
382 status = PERMISSION_DENIED;
383 }
384 break;
385 case AudioPolicyInterface::API_INPUT_MIX_EXT_POLICY_REROUTE:
386 if (!modifyAudioRoutingAllowed()) {
387 ALOGE("getInputForAttr() permission denied: modify audio routing not allowed");
388 status = PERMISSION_DENIED;
389 }
390 break;
391 case AudioPolicyInterface::API_INPUT_INVALID:
392 default:
393 LOG_ALWAYS_FATAL("getInputForAttr() encountered an invalid input type %d",
394 (int)inputType);
395 }
396 }
397
398 if (status != NO_ERROR) {
399 if (status == PERMISSION_DENIED) {
Eric Laurent10b71232018-04-13 18:14:44 -0700400 AutoCallerClear acc;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800401 mAudioPolicyManager->releaseInput(*input, session);
402 }
403 return status;
404 }
Eric Laurentfee19762018-01-29 18:44:13 -0800405
406 sp<AudioRecordClient> client =
407 new AudioRecordClient(*attr, *input, uid, pid, opPackageName, session);
408 client->active = false;
409 client->isConcurrent = false;
410 client->isVirtualDevice = false; //TODO : update from APM->getInputForAttr()
Eric Laurent99fcae42018-05-17 16:59:18 -0700411 client->deviceId = *selectedDeviceId;
Eric Laurentfee19762018-01-29 18:44:13 -0800412 mAudioRecordClients.add(*portId, client);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700413 }
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800414
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700415 if (audioPolicyEffects != 0) {
416 // create audio pre processors according to input source
Eric Laurentcaf7f482014-11-25 17:50:47 -0800417 status_t status = audioPolicyEffects->addInputEffects(*input, attr->source, session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700418 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800419 ALOGW("Failed to add effects on input %d", *input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700420 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800421 }
Eric Laurentcaf7f482014-11-25 17:50:47 -0800422 return NO_ERROR;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800423}
424
Ray Essick84e84a52018-05-03 18:45:07 -0700425// this is replicated from frameworks/av/media/libaudioclient/AudioRecord.cpp
426// XXX -- figure out how to put it into a common, shared location
427
428static std::string audioSourceString(audio_source_t value) {
429 std::string source;
430 if (SourceTypeConverter::toString(value, source)) {
431 return source;
432 }
433 char rawbuffer[16]; // room for "%d"
434 snprintf(rawbuffer, sizeof(rawbuffer), "%d", value);
435 return rawbuffer;
436}
437
Eric Laurent99fcae42018-05-17 16:59:18 -0700438static std::string audioConcurrencyString(
439 AudioPolicyInterface::concurrency_type__mask_t concurrency)
Ray Essick84e84a52018-05-03 18:45:07 -0700440{
441 char buffer[64]; // oversized
442 if (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_ALL) {
443 snprintf(buffer, sizeof(buffer), "%s%s%s%s",
444 (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_CALL)? ",call":"",
445 (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_CAPTURE)? ",capture":"",
446 (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_HOTWORD)? ",hotword":"",
447 (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_PREEMPT)? ",preempt":"");
448 } else {
449 snprintf(buffer, sizeof(buffer), ",none");
450 }
451
452 return &buffer[1];
453}
454
Eric Laurent99fcae42018-05-17 16:59:18 -0700455std::string AudioPolicyService::getDeviceTypeStrForPortId(audio_port_handle_t portId) {
456 std::string typeStr;
457 struct audio_port port = {};
458 port.id = portId;
459 status_t status = mAudioPolicyManager->getAudioPort(&port);
460 if (status == NO_ERROR && port.type == AUDIO_PORT_TYPE_DEVICE) {
461 deviceToString(port.ext.device.type, typeStr);
462 }
463 return typeStr;
464}
465
Eric Laurentfee19762018-01-29 18:44:13 -0800466status_t AudioPolicyService::startInput(audio_port_handle_t portId, bool *silenced)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800467{
Eric Laurentdce54a12014-03-10 12:19:46 -0700468 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800469 return NO_INIT;
470 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800471 sp<AudioRecordClient> client;
472 {
473 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800474
Eric Laurent7dca8a82018-01-29 18:44:26 -0800475 ssize_t index = mAudioRecordClients.indexOfKey(portId);
476 if (index < 0) {
477 return INVALID_OPERATION;
478 }
479 client = mAudioRecordClients.valueAt(index);
Eric Laurentfee19762018-01-29 18:44:13 -0800480 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800481
482 // check calling permissions
Svet Ganov6e641372018-03-02 09:21:30 -0800483 if (!startRecording(client->opPackageName, client->pid, client->uid)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800484 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
485 __func__, client->uid, client->pid);
486 return PERMISSION_DENIED;
487 }
Eric Laurentfee19762018-01-29 18:44:13 -0800488
489 // If UID inactive it records silence until becoming active
490 *silenced = !mUidPolicy->isUidActive(client->uid) && !client->isVirtualDevice;
491
Eric Laurent7dca8a82018-01-29 18:44:26 -0800492 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800493 AudioPolicyInterface::concurrency_type__mask_t concurrency =
494 AudioPolicyInterface::API_INPUT_CONCURRENCY_NONE;
Eric Laurentfee19762018-01-29 18:44:13 -0800495
Eric Laurent10b71232018-04-13 18:14:44 -0700496 status_t status;
497 {
498 AutoCallerClear acc;
499 status = mAudioPolicyManager->startInput(
500 client->input, client->session, *silenced, &concurrency);
Ray Essick84e84a52018-05-03 18:45:07 -0700501
502 }
503
Ray Essickf6a57cd2018-05-22 16:20:54 -0700504 // including successes gets very verbose
505 if (status != NO_ERROR) {
Ray Essick84e84a52018-05-03 18:45:07 -0700506
507 static constexpr char kAudioPolicy[] = "audiopolicy";
508
509 static constexpr char kAudioPolicyReason[] = "android.media.audiopolicy.reason";
510 static constexpr char kAudioPolicyStatus[] = "android.media.audiopolicy.status";
511 static constexpr char kAudioPolicyRqstSrc[] = "android.media.audiopolicy.rqst.src";
512 static constexpr char kAudioPolicyRqstPkg[] = "android.media.audiopolicy.rqst.pkg";
513 static constexpr char kAudioPolicyRqstSession[] = "android.media.audiopolicy.rqst.session";
Eric Laurent99fcae42018-05-17 16:59:18 -0700514 static constexpr char kAudioPolicyRqstDevice[] =
515 "android.media.audiopolicy.rqst.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700516 static constexpr char kAudioPolicyActiveSrc[] = "android.media.audiopolicy.active.src";
517 static constexpr char kAudioPolicyActivePkg[] = "android.media.audiopolicy.active.pkg";
Eric Laurent99fcae42018-05-17 16:59:18 -0700518 static constexpr char kAudioPolicyActiveSession[] =
519 "android.media.audiopolicy.active.session";
520 static constexpr char kAudioPolicyActiveDevice[] =
521 "android.media.audiopolicy.active.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700522
523 MediaAnalyticsItem *item = new MediaAnalyticsItem(kAudioPolicy);
524 if (item != NULL) {
525
526 item->setCString(kAudioPolicyReason, audioConcurrencyString(concurrency).c_str());
527 item->setInt32(kAudioPolicyStatus, status);
528
Eric Laurent99fcae42018-05-17 16:59:18 -0700529 item->setCString(kAudioPolicyRqstSrc,
530 audioSourceString(client->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700531 item->setInt32(kAudioPolicyRqstSession, client->session);
Ray Essick51866952018-05-30 11:22:27 -0700532 if (client->opPackageName.size() != 0) {
533 item->setCString(kAudioPolicyRqstPkg,
534 std::string(String8(client->opPackageName).string()).c_str());
535 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700536 item->setCString(kAudioPolicyRqstPkg, std::to_string(client->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700537 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700538 item->setCString(
539 kAudioPolicyRqstDevice, getDeviceTypeStrForPortId(client->deviceId).c_str());
540
Ray Essick84e84a52018-05-03 18:45:07 -0700541 // figure out who is active
542 // NB: might the other party have given up the microphone since then? how sure.
543 // perhaps could have given up on it.
544 // we hold mLock, so perhaps we're safe for this looping
545 if (concurrency != AudioPolicyInterface::API_INPUT_CONCURRENCY_NONE) {
546 int count = mAudioRecordClients.size();
547 for (int i = 0; i<count ; i++) {
548 if (portId == mAudioRecordClients.keyAt(i)) {
549 continue;
550 }
551 sp<AudioRecordClient> other = mAudioRecordClients.valueAt(i);
552 if (other->active) {
553 // keeps the last of the clients marked active
554 item->setCString(kAudioPolicyActiveSrc,
555 audioSourceString(other->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700556 item->setInt32(kAudioPolicyActiveSession, other->session);
Ray Essick51866952018-05-30 11:22:27 -0700557 if (other->opPackageName.size() != 0) {
558 item->setCString(kAudioPolicyActivePkg,
559 std::string(String8(other->opPackageName).string()).c_str());
560 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700561 item->setCString(kAudioPolicyRqstPkg,
562 std::to_string(other->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700563 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700564 item->setCString(kAudioPolicyActiveDevice,
565 getDeviceTypeStrForPortId(other->deviceId).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700566 }
567 }
568 }
569 item->selfrecord();
570 delete item;
571 item = NULL;
572 }
Eric Laurent10b71232018-04-13 18:14:44 -0700573 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800574
Eric Laurentfb66dd92016-01-28 18:32:03 -0800575 if (status == NO_ERROR) {
Eric Laurent43423352016-02-05 11:57:57 -0800576 LOG_ALWAYS_FATAL_IF(concurrency & ~AudioPolicyInterface::API_INPUT_CONCURRENCY_ALL,
577 "startInput(): invalid concurrency type %d", (int)concurrency);
578
Eric Laurentfb66dd92016-01-28 18:32:03 -0800579 // enforce permission (if any) required for each type of concurrency
Eric Laurent43423352016-02-05 11:57:57 -0800580 if (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_CALL) {
Eric Laurentfb66dd92016-01-28 18:32:03 -0800581 //TODO: check incall capture permission
Eric Laurent43423352016-02-05 11:57:57 -0800582 }
583 if (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_CAPTURE) {
Eric Laurentfb66dd92016-01-28 18:32:03 -0800584 //TODO: check concurrent capture permission
Eric Laurentfb66dd92016-01-28 18:32:03 -0800585 }
Ray Essick84e84a52018-05-03 18:45:07 -0700586
587 client->active = true;
Svet Ganov6e641372018-03-02 09:21:30 -0800588 } else {
589 finishRecording(client->opPackageName, client->uid);
Eric Laurentfb66dd92016-01-28 18:32:03 -0800590 }
591
592 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800593}
594
Eric Laurentfee19762018-01-29 18:44:13 -0800595status_t AudioPolicyService::stopInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800596{
Eric Laurentdce54a12014-03-10 12:19:46 -0700597 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800598 return NO_INIT;
599 }
600 Mutex::Autolock _l(mLock);
601
Eric Laurentfee19762018-01-29 18:44:13 -0800602 ssize_t index = mAudioRecordClients.indexOfKey(portId);
603 if (index < 0) {
604 return INVALID_OPERATION;
605 }
606 sp<AudioRecordClient> client = mAudioRecordClients.valueAt(index);
607
Ray Essick84e84a52018-05-03 18:45:07 -0700608 client->active = false;
609
Svet Ganov6e641372018-03-02 09:21:30 -0800610 // finish the recording app op
611 finishRecording(client->opPackageName, client->uid);
Eric Laurent10b71232018-04-13 18:14:44 -0700612 AutoCallerClear acc;
Eric Laurentfee19762018-01-29 18:44:13 -0800613 return mAudioPolicyManager->stopInput(client->input, client->session);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800614}
615
Eric Laurentfee19762018-01-29 18:44:13 -0800616void AudioPolicyService::releaseInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800617{
Eric Laurentdce54a12014-03-10 12:19:46 -0700618 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800619 return;
620 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700621 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800622 sp<AudioRecordClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700623 {
624 Mutex::Autolock _l(mLock);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700625 audioPolicyEffects = mAudioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800626 ssize_t index = mAudioRecordClients.indexOfKey(portId);
627 if (index < 0) {
628 return;
629 }
630 client = mAudioRecordClients.valueAt(index);
631 mAudioRecordClients.removeItem(portId);
632 }
633 if (client == 0) {
634 return;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700635 }
636 if (audioPolicyEffects != 0) {
637 // release audio processors from the input
Eric Laurentfee19762018-01-29 18:44:13 -0800638 status_t status = audioPolicyEffects->releaseInputEffects(client->input, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700639 if(status != NO_ERROR) {
Eric Laurentfee19762018-01-29 18:44:13 -0800640 ALOGW("Failed to release effects on input %d", client->input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700641 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800642 }
Eric Laurentf10c7092016-12-06 17:09:56 -0800643 {
644 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700645 AutoCallerClear acc;
Eric Laurentfee19762018-01-29 18:44:13 -0800646 mAudioPolicyManager->releaseInput(client->input, client->session);
Eric Laurentf10c7092016-12-06 17:09:56 -0800647 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800648}
649
650status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
651 int indexMin,
652 int indexMax)
653{
Eric Laurentdce54a12014-03-10 12:19:46 -0700654 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800655 return NO_INIT;
656 }
657 if (!settingsAllowed()) {
658 return PERMISSION_DENIED;
659 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800660 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800661 return BAD_VALUE;
662 }
663 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700664 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700665 mAudioPolicyManager->initStreamVolume(stream, indexMin, indexMax);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800666 return NO_ERROR;
667}
668
669status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
670 int index,
671 audio_devices_t device)
672{
Eric Laurentdce54a12014-03-10 12:19:46 -0700673 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800674 return NO_INIT;
675 }
676 if (!settingsAllowed()) {
677 return PERMISSION_DENIED;
678 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800679 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800680 return BAD_VALUE;
681 }
682 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700683 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700684 return mAudioPolicyManager->setStreamVolumeIndex(stream,
685 index,
686 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800687}
688
689status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
690 int *index,
691 audio_devices_t device)
692{
Eric Laurentdce54a12014-03-10 12:19:46 -0700693 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800694 return NO_INIT;
695 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800696 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800697 return BAD_VALUE;
698 }
699 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700700 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700701 return mAudioPolicyManager->getStreamVolumeIndex(stream,
702 index,
703 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800704}
705
706uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
707{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800708 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700709 return 0;
Eric Laurentdea15412014-10-28 15:46:45 -0700710 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700711 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800712 return 0;
713 }
Eric Laurent10b71232018-04-13 18:14:44 -0700714 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700715 return mAudioPolicyManager->getStrategyForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800716}
717
718//audio policy: use audio_device_t appropriately
719
720audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
721{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800722 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700723 return AUDIO_DEVICE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700724 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700725 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700726 return AUDIO_DEVICE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800727 }
Haynes Mathew Georgedfb9f3b2015-10-26 18:22:13 -0700728 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700729 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700730 return mAudioPolicyManager->getDevicesForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800731}
732
733audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
734{
735 // FIXME change return type to status_t, and return NO_INIT here
Eric Laurentdce54a12014-03-10 12:19:46 -0700736 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800737 return 0;
738 }
739 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700740 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700741 return mAudioPolicyManager->getOutputForEffect(desc);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800742}
743
744status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
745 audio_io_handle_t io,
746 uint32_t strategy,
Glenn Kastend848eb42016-03-08 13:42:11 -0800747 audio_session_t session,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800748 int id)
749{
Eric Laurentdce54a12014-03-10 12:19:46 -0700750 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800751 return NO_INIT;
752 }
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700753 Mutex::Autolock _l(mEffectsLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700754 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700755 return mAudioPolicyManager->registerEffect(desc, io, strategy, session, id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800756}
757
758status_t AudioPolicyService::unregisterEffect(int id)
759{
Eric Laurentdce54a12014-03-10 12:19:46 -0700760 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800761 return NO_INIT;
762 }
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700763 Mutex::Autolock _l(mEffectsLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700764 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700765 return mAudioPolicyManager->unregisterEffect(id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800766}
767
768status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
769{
Eric Laurentdce54a12014-03-10 12:19:46 -0700770 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800771 return NO_INIT;
772 }
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700773 Mutex::Autolock _l(mEffectsLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700774 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700775 return mAudioPolicyManager->setEffectEnabled(id, enabled);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800776}
777
778bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
779{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800780 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700781 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700782 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700783 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700784 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800785 }
786 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700787 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700788 return mAudioPolicyManager->isStreamActive(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800789}
790
791bool AudioPolicyService::isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs) const
792{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800793 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700794 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700795 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700796 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700797 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800798 }
799 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700800 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700801 return mAudioPolicyManager->isStreamActiveRemotely(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800802}
803
804bool AudioPolicyService::isSourceActive(audio_source_t source) const
805{
Eric Laurentdce54a12014-03-10 12:19:46 -0700806 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800807 return false;
808 }
809 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700810 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700811 return mAudioPolicyManager->isSourceActive(source);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800812}
813
Glenn Kastend848eb42016-03-08 13:42:11 -0800814status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800815 effect_descriptor_t *descriptors,
816 uint32_t *count)
817{
Eric Laurentdce54a12014-03-10 12:19:46 -0700818 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800819 *count = 0;
820 return NO_INIT;
821 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700822 sp<AudioPolicyEffects>audioPolicyEffects;
823 {
824 Mutex::Autolock _l(mLock);
825 audioPolicyEffects = mAudioPolicyEffects;
826 }
827 if (audioPolicyEffects == 0) {
828 *count = 0;
829 return NO_INIT;
830 }
Eric Laurentfb66dd92016-01-28 18:32:03 -0800831 return audioPolicyEffects->queryDefaultInputEffects(
832 (audio_session_t)audioSession, descriptors, count);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800833}
834
835bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
836{
Eric Laurentdce54a12014-03-10 12:19:46 -0700837 if (mAudioPolicyManager == NULL) {
838 ALOGV("mAudioPolicyManager == NULL");
Eric Laurent2d388ec2014-03-07 13:25:54 -0800839 return false;
840 }
Andy Hung2ddee192015-12-18 17:34:44 -0800841 Mutex::Autolock _l(mLock);
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700842 Mutex::Autolock _le(mEffectsLock); // isOffloadSupported queries for
843 // non-offloadable effects
Eric Laurent10b71232018-04-13 18:14:44 -0700844 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700845 return mAudioPolicyManager->isOffloadSupported(info);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800846}
847
Eric Laurent6a94d692014-05-20 11:18:06 -0700848status_t AudioPolicyService::listAudioPorts(audio_port_role_t role,
849 audio_port_type_t type,
Eric Laurent203b1a12014-04-01 10:34:16 -0700850 unsigned int *num_ports,
Eric Laurent6a94d692014-05-20 11:18:06 -0700851 struct audio_port *ports,
852 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -0700853{
Eric Laurent6a94d692014-05-20 11:18:06 -0700854 Mutex::Autolock _l(mLock);
855 if (mAudioPolicyManager == NULL) {
856 return NO_INIT;
857 }
Eric Laurent10b71232018-04-13 18:14:44 -0700858 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700859 return mAudioPolicyManager->listAudioPorts(role, type, num_ports, ports, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -0700860}
861
Eric Laurent6a94d692014-05-20 11:18:06 -0700862status_t AudioPolicyService::getAudioPort(struct audio_port *port)
Eric Laurent203b1a12014-04-01 10:34:16 -0700863{
Eric Laurent6a94d692014-05-20 11:18:06 -0700864 Mutex::Autolock _l(mLock);
865 if (mAudioPolicyManager == NULL) {
866 return NO_INIT;
867 }
Eric Laurent10b71232018-04-13 18:14:44 -0700868 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700869 return mAudioPolicyManager->getAudioPort(port);
Eric Laurent203b1a12014-04-01 10:34:16 -0700870}
871
Eric Laurent6a94d692014-05-20 11:18:06 -0700872status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch,
873 audio_patch_handle_t *handle)
Eric Laurent203b1a12014-04-01 10:34:16 -0700874{
Eric Laurent6a94d692014-05-20 11:18:06 -0700875 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -0700876 if(!modifyAudioRoutingAllowed()) {
877 return PERMISSION_DENIED;
878 }
Eric Laurent6a94d692014-05-20 11:18:06 -0700879 if (mAudioPolicyManager == NULL) {
880 return NO_INIT;
881 }
Eric Laurent10b71232018-04-13 18:14:44 -0700882 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700883 return mAudioPolicyManager->createAudioPatch(patch, handle,
884 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -0700885}
886
Eric Laurent6a94d692014-05-20 11:18:06 -0700887status_t AudioPolicyService::releaseAudioPatch(audio_patch_handle_t handle)
Eric Laurent203b1a12014-04-01 10:34:16 -0700888{
Eric Laurent6a94d692014-05-20 11:18:06 -0700889 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -0700890 if(!modifyAudioRoutingAllowed()) {
891 return PERMISSION_DENIED;
892 }
Eric Laurent6a94d692014-05-20 11:18:06 -0700893 if (mAudioPolicyManager == NULL) {
894 return NO_INIT;
895 }
Eric Laurent10b71232018-04-13 18:14:44 -0700896 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700897 return mAudioPolicyManager->releaseAudioPatch(handle,
898 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -0700899}
900
901status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
Eric Laurent6a94d692014-05-20 11:18:06 -0700902 struct audio_patch *patches,
903 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -0700904{
Eric Laurent6a94d692014-05-20 11:18:06 -0700905 Mutex::Autolock _l(mLock);
906 if (mAudioPolicyManager == NULL) {
907 return NO_INIT;
908 }
Eric Laurent10b71232018-04-13 18:14:44 -0700909 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700910 return mAudioPolicyManager->listAudioPatches(num_patches, patches, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -0700911}
912
Eric Laurent6a94d692014-05-20 11:18:06 -0700913status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config)
Eric Laurent203b1a12014-04-01 10:34:16 -0700914{
Eric Laurent6a94d692014-05-20 11:18:06 -0700915 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -0700916 if(!modifyAudioRoutingAllowed()) {
917 return PERMISSION_DENIED;
918 }
Eric Laurent6a94d692014-05-20 11:18:06 -0700919 if (mAudioPolicyManager == NULL) {
920 return NO_INIT;
921 }
Eric Laurent10b71232018-04-13 18:14:44 -0700922 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700923 return mAudioPolicyManager->setAudioPortConfig(config);
Eric Laurent203b1a12014-04-01 10:34:16 -0700924}
Eric Laurent2d388ec2014-03-07 13:25:54 -0800925
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700926status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session,
927 audio_io_handle_t *ioHandle,
928 audio_devices_t *device)
929{
Andy Hungf759b8c2017-08-15 12:48:54 -0700930 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700931 if (mAudioPolicyManager == NULL) {
932 return NO_INIT;
933 }
Eric Laurent10b71232018-04-13 18:14:44 -0700934 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700935 return mAudioPolicyManager->acquireSoundTriggerSession(session, ioHandle, device);
936}
937
938status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session)
939{
Andy Hungf759b8c2017-08-15 12:48:54 -0700940 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700941 if (mAudioPolicyManager == NULL) {
942 return NO_INIT;
943 }
Eric Laurent10b71232018-04-13 18:14:44 -0700944 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700945 return mAudioPolicyManager->releaseSoundTriggerSession(session);
946}
947
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -0700948status_t AudioPolicyService::registerPolicyMixes(const Vector<AudioMix>& mixes, bool registration)
Eric Laurentbaac1832014-12-01 17:52:59 -0800949{
950 Mutex::Autolock _l(mLock);
951 if(!modifyAudioRoutingAllowed()) {
952 return PERMISSION_DENIED;
953 }
954 if (mAudioPolicyManager == NULL) {
955 return NO_INIT;
956 }
Eric Laurent10b71232018-04-13 18:14:44 -0700957 AutoCallerClear acc;
Eric Laurentbaac1832014-12-01 17:52:59 -0800958 if (registration) {
959 return mAudioPolicyManager->registerPolicyMixes(mixes);
960 } else {
961 return mAudioPolicyManager->unregisterPolicyMixes(mixes);
962 }
963}
964
Eric Laurent554a2772015-04-10 11:29:24 -0700965status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
966 const audio_attributes_t *attributes,
Glenn Kasten559d4392016-03-29 13:42:57 -0700967 audio_patch_handle_t *handle)
Eric Laurent554a2772015-04-10 11:29:24 -0700968{
969 Mutex::Autolock _l(mLock);
970 if (mAudioPolicyManager == NULL) {
971 return NO_INIT;
972 }
Eric Laurent10b71232018-04-13 18:14:44 -0700973 AutoCallerClear acc;
Eric Laurentd60560a2015-04-10 11:31:20 -0700974 return mAudioPolicyManager->startAudioSource(source, attributes, handle,
975 IPCThreadState::self()->getCallingUid());
Eric Laurent554a2772015-04-10 11:29:24 -0700976}
977
Glenn Kasten559d4392016-03-29 13:42:57 -0700978status_t AudioPolicyService::stopAudioSource(audio_patch_handle_t handle)
Eric Laurent554a2772015-04-10 11:29:24 -0700979{
980 Mutex::Autolock _l(mLock);
981 if (mAudioPolicyManager == NULL) {
982 return NO_INIT;
983 }
Eric Laurent10b71232018-04-13 18:14:44 -0700984 AutoCallerClear acc;
Eric Laurent554a2772015-04-10 11:29:24 -0700985 return mAudioPolicyManager->stopAudioSource(handle);
986}
987
Andy Hung2ddee192015-12-18 17:34:44 -0800988status_t AudioPolicyService::setMasterMono(bool mono)
989{
990 if (mAudioPolicyManager == NULL) {
991 return NO_INIT;
992 }
993 if (!settingsAllowed()) {
994 return PERMISSION_DENIED;
995 }
996 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700997 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -0800998 return mAudioPolicyManager->setMasterMono(mono);
999}
1000
1001status_t AudioPolicyService::getMasterMono(bool *mono)
1002{
1003 if (mAudioPolicyManager == NULL) {
1004 return NO_INIT;
1005 }
1006 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001007 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001008 return mAudioPolicyManager->getMasterMono(mono);
1009}
1010
Eric Laurentac9cef52017-06-09 15:46:26 -07001011
1012float AudioPolicyService::getStreamVolumeDB(
1013 audio_stream_type_t stream, int index, audio_devices_t device)
1014{
1015 if (mAudioPolicyManager == NULL) {
1016 return NAN;
1017 }
1018 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001019 AutoCallerClear acc;
Eric Laurentac9cef52017-06-09 15:46:26 -07001020 return mAudioPolicyManager->getStreamVolumeDB(stream, index, device);
1021}
1022
jiabin81772902018-04-02 17:52:27 -07001023status_t AudioPolicyService::getSurroundFormats(unsigned int *numSurroundFormats,
1024 audio_format_t *surroundFormats,
1025 bool *surroundFormatsEnabled,
1026 bool reported)
1027{
1028 if (mAudioPolicyManager == NULL) {
1029 return NO_INIT;
1030 }
1031 Mutex::Autolock _l(mLock);
1032 AutoCallerClear acc;
1033 return mAudioPolicyManager->getSurroundFormats(numSurroundFormats, surroundFormats,
1034 surroundFormatsEnabled, reported);
1035}
1036
1037status_t AudioPolicyService::setSurroundFormatEnabled(audio_format_t audioFormat, bool enabled)
1038{
1039 if (mAudioPolicyManager == NULL) {
1040 return NO_INIT;
1041 }
1042 Mutex::Autolock _l(mLock);
1043 AutoCallerClear acc;
1044 return mAudioPolicyManager->setSurroundFormatEnabled(audioFormat, enabled);
1045}
Eric Laurentac9cef52017-06-09 15:46:26 -07001046
Mikhail Naganov1b2a7942017-12-08 10:18:09 -08001047} // namespace android