blob: 4d071c89be8ee731bb711b205823771d51175cc7 [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
Eric Laurent2d388ec2014-03-07 13:25:54 -080020#include "AudioPolicyService.h"
Ray Essick84e84a52018-05-03 18:45:07 -070021#include "TypeConverter.h"
Ray Essickf27e9872019-12-07 06:28:46 -080022#include <media/MediaMetricsItem.h>
Kevin Rocardbe201852019-02-20 22:33:28 -080023#include <media/AudioPolicy.h>
Eric Laurentd7fe0862018-07-14 16:48:01 -070024#include <utils/Log.h>
Eric Laurent2d388ec2014-03-07 13:25:54 -080025
Eric Laurent2d388ec2014-03-07 13:25:54 -080026namespace android {
27
Hayden Gomes524159d2019-12-23 14:41:47 -080028const std::vector<audio_usage_t>& SYSTEM_USAGES = {
29 AUDIO_USAGE_CALL_ASSISTANT,
30 AUDIO_USAGE_EMERGENCY,
31 AUDIO_USAGE_SAFETY,
32 AUDIO_USAGE_VEHICLE_STATUS,
33 AUDIO_USAGE_ANNOUNCEMENT
34};
35
36bool isSystemUsage(audio_usage_t usage) {
37 return std::find(std::begin(SYSTEM_USAGES), std::end(SYSTEM_USAGES), usage)
38 != std::end(SYSTEM_USAGES);
39}
40
41bool AudioPolicyService::isSupportedSystemUsage(audio_usage_t usage) {
42 return std::find(std::begin(mSupportedSystemUsages), std::end(mSupportedSystemUsages), usage)
43 != std::end(mSupportedSystemUsages);
44}
45
46status_t AudioPolicyService::validateUsage(audio_usage_t usage) {
47 return validateUsage(usage, IPCThreadState::self()->getCallingPid(),
48 IPCThreadState::self()->getCallingUid());
49}
50
51status_t AudioPolicyService::validateUsage(audio_usage_t usage, pid_t pid, uid_t uid) {
52 if (isSystemUsage(usage)) {
53 if (isSupportedSystemUsage(usage)) {
54 if (!modifyAudioRoutingAllowed(pid, uid)) {
55 ALOGE("permission denied: modify audio routing not allowed for uid %d", uid);
56 return PERMISSION_DENIED;
57 }
58 } else {
59 return BAD_VALUE;
60 }
61 }
62 return NO_ERROR;
63}
64
65
Eric Laurent2d388ec2014-03-07 13:25:54 -080066
67// ----------------------------------------------------------------------------
68
69status_t AudioPolicyService::setDeviceConnectionState(audio_devices_t device,
70 audio_policy_dev_state_t state,
Paul McLeane743a472015-01-28 11:07:31 -080071 const char *device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080072 const char *device_name,
73 audio_format_t encodedFormat)
Eric Laurent2d388ec2014-03-07 13:25:54 -080074{
Eric Laurentdce54a12014-03-10 12:19:46 -070075 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080076 return NO_INIT;
77 }
78 if (!settingsAllowed()) {
79 return PERMISSION_DENIED;
80 }
Eric Laurent2d388ec2014-03-07 13:25:54 -080081 if (state != AUDIO_POLICY_DEVICE_STATE_AVAILABLE &&
82 state != AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE) {
83 return BAD_VALUE;
84 }
85
86 ALOGV("setDeviceConnectionState()");
87 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -070088 AutoCallerClear acc;
Paul McLeane743a472015-01-28 11:07:31 -080089 return mAudioPolicyManager->setDeviceConnectionState(device, state,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080090 device_address, device_name, encodedFormat);
Eric Laurent2d388ec2014-03-07 13:25:54 -080091}
92
93audio_policy_dev_state_t AudioPolicyService::getDeviceConnectionState(
94 audio_devices_t device,
95 const char *device_address)
96{
Eric Laurentdce54a12014-03-10 12:19:46 -070097 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080098 return AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE;
99 }
Eric Laurent10b71232018-04-13 18:14:44 -0700100 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700101 return mAudioPolicyManager->getDeviceConnectionState(device,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800102 device_address);
103}
104
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800105status_t AudioPolicyService::handleDeviceConfigChange(audio_devices_t device,
106 const char *device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -0800107 const char *device_name,
108 audio_format_t encodedFormat)
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800109{
110 if (mAudioPolicyManager == NULL) {
111 return NO_INIT;
112 }
113 if (!settingsAllowed()) {
114 return PERMISSION_DENIED;
115 }
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800116
117 ALOGV("handleDeviceConfigChange()");
118 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700119 AutoCallerClear acc;
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800120 return mAudioPolicyManager->handleDeviceConfigChange(device, device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -0800121 device_name, encodedFormat);
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800122}
123
Eric Laurent00dba062020-02-11 15:52:09 -0800124status_t AudioPolicyService::setPhoneState(audio_mode_t state, uid_t uid)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800125{
Eric Laurentdce54a12014-03-10 12:19:46 -0700126 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800127 return NO_INIT;
128 }
129 if (!settingsAllowed()) {
130 return PERMISSION_DENIED;
131 }
132 if (uint32_t(state) >= AUDIO_MODE_CNT) {
133 return BAD_VALUE;
134 }
135
136 ALOGV("setPhoneState()");
137
Eric Laurentbeb07fe2015-09-16 15:49:30 -0700138 // acquire lock before calling setMode() so that setMode() + setPhoneState() are an atomic
139 // operation from policy manager standpoint (no other operation (e.g track start or stop)
140 // can be interleaved).
141 Mutex::Autolock _l(mLock);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800142 // TODO: check if it is more appropriate to do it in platform specific policy manager
143 AudioSystem::setMode(state);
144
Eric Laurent10b71232018-04-13 18:14:44 -0700145 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700146 mAudioPolicyManager->setPhoneState(state);
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700147 mPhoneState = state;
Eric Laurent00dba062020-02-11 15:52:09 -0800148 mPhoneStateOwnerUid = uid;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800149 return NO_ERROR;
150}
151
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700152audio_mode_t AudioPolicyService::getPhoneState()
153{
154 Mutex::Autolock _l(mLock);
155 return mPhoneState;
156}
157
Eric Laurent2d388ec2014-03-07 13:25:54 -0800158status_t AudioPolicyService::setForceUse(audio_policy_force_use_t usage,
159 audio_policy_forced_cfg_t config)
160{
Eric Laurentdce54a12014-03-10 12:19:46 -0700161 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800162 return NO_INIT;
163 }
Eric Laurente17378d2018-05-09 14:43:01 -0700164
165 if (!modifyAudioRoutingAllowed()) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800166 return PERMISSION_DENIED;
167 }
Eric Laurente17378d2018-05-09 14:43:01 -0700168
Eric Laurent2d388ec2014-03-07 13:25:54 -0800169 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
170 return BAD_VALUE;
171 }
172 if (config < 0 || config >= AUDIO_POLICY_FORCE_CFG_CNT) {
173 return BAD_VALUE;
174 }
175 ALOGV("setForceUse()");
176 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700177 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700178 mAudioPolicyManager->setForceUse(usage, config);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800179 return NO_ERROR;
180}
181
182audio_policy_forced_cfg_t AudioPolicyService::getForceUse(audio_policy_force_use_t usage)
183{
Eric Laurentdce54a12014-03-10 12:19:46 -0700184 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800185 return AUDIO_POLICY_FORCE_NONE;
186 }
187 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
188 return AUDIO_POLICY_FORCE_NONE;
189 }
Eric Laurent10b71232018-04-13 18:14:44 -0700190 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700191 return mAudioPolicyManager->getForceUse(usage);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800192}
193
Eric Laurentf4e63452017-11-06 19:31:46 +0000194audio_io_handle_t AudioPolicyService::getOutput(audio_stream_type_t stream)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800195{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800196 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700197 return AUDIO_IO_HANDLE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700198 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700199 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700200 return AUDIO_IO_HANDLE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800201 }
202 ALOGV("getOutput()");
203 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700204 AutoCallerClear acc;
Eric Laurentf4e63452017-11-06 19:31:46 +0000205 return mAudioPolicyManager->getOutput(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800206}
207
Eric Laurent42984412019-05-09 17:57:03 -0700208status_t AudioPolicyService::getOutputForAttr(audio_attributes_t *attr,
Eric Laurente83b55d2014-11-14 10:06:21 -0800209 audio_io_handle_t *output,
210 audio_session_t session,
211 audio_stream_type_t *stream,
Nadav Bar766fb022018-01-07 12:18:03 +0200212 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700213 uid_t uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800214 const audio_config_t *config,
Eric Laurente83b55d2014-11-14 10:06:21 -0800215 audio_output_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700216 audio_port_handle_t *selectedDeviceId,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800217 audio_port_handle_t *portId,
218 std::vector<audio_io_handle_t> *secondaryOutputs)
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700219{
220 if (mAudioPolicyManager == NULL) {
Eric Laurente83b55d2014-11-14 10:06:21 -0800221 return NO_INIT;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700222 }
Hayden Gomes524159d2019-12-23 14:41:47 -0800223
224 status_t result = validateUsage(attr->usage, pid, uid);
225 if (result != NO_ERROR) {
226 return result;
227 }
228
Eric Laurent8a1095a2019-11-08 14:44:16 -0800229 ALOGV("%s()", __func__);
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700230 Mutex::Autolock _l(mLock);
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700231
Marco Nelissendcb346b2015-09-09 10:47:29 -0700232 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700233 if (!isAudioServerOrMediaServerUid(callingUid) || uid == (uid_t)-1) {
Marco Nelissendcb346b2015-09-09 10:47:29 -0700234 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Eric Laurent8a1095a2019-11-08 14:44:16 -0800235 "%s uid %d tried to pass itself off as %d", __func__, callingUid, uid);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700236 uid = callingUid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700237 }
Kevin Rocard8be94972019-02-22 13:26:25 -0800238 if (!mPackageManager.allowPlaybackCapture(uid)) {
Eric Laurent42984412019-05-09 17:57:03 -0700239 attr->flags |= AUDIO_FLAG_NO_MEDIA_PROJECTION;
240 }
Eric Laurent6ede98f2019-06-11 14:50:30 -0700241 if (((attr->flags & (AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE)) != 0)
242 && !bypassInterruptionPolicyAllowed(pid, uid)) {
Eric Laurent42984412019-05-09 17:57:03 -0700243 attr->flags &= ~(AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE);
Kevin Rocard8be94972019-02-22 13:26:25 -0800244 }
Eric Laurent10b71232018-04-13 18:14:44 -0700245 AutoCallerClear acc;
Eric Laurent8a1095a2019-11-08 14:44:16 -0800246 AudioPolicyInterface::output_type_t outputType;
Hayden Gomes3e8bbb92020-01-10 13:37:05 -0800247 result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800248 config,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800249 &flags, selectedDeviceId, portId,
Eric Laurent8a1095a2019-11-08 14:44:16 -0800250 secondaryOutputs,
251 &outputType);
Nadav Bar766fb022018-01-07 12:18:03 +0200252
253 // FIXME: Introduce a way to check for the the telephony device before opening the output
Eric Laurent8a1095a2019-11-08 14:44:16 -0800254 if (result == NO_ERROR) {
255 // enforce permission (if any) required for each type of input
256 switch (outputType) {
257 case AudioPolicyInterface::API_OUTPUT_LEGACY:
258 break;
259 case AudioPolicyInterface::API_OUTPUT_TELEPHONY_TX:
260 if (!modifyPhoneStateAllowed(pid, uid)) {
261 ALOGE("%s() permission denied: modify phone state not allowed for uid %d",
262 __func__, uid);
263 result = PERMISSION_DENIED;
264 }
265 break;
266 case AudioPolicyInterface::API_OUT_MIX_PLAYBACK:
267 if (!modifyAudioRoutingAllowed(pid, uid)) {
268 ALOGE("%s() permission denied: modify audio routing not allowed for uid %d",
269 __func__, uid);
270 result = PERMISSION_DENIED;
271 }
272 break;
273 case AudioPolicyInterface::API_OUTPUT_INVALID:
274 default:
275 LOG_ALWAYS_FATAL("%s() encountered an invalid output type %d",
276 __func__, (int)outputType);
277 }
Nadav Bar766fb022018-01-07 12:18:03 +0200278 }
Eric Laurentd7fe0862018-07-14 16:48:01 -0700279
280 if (result == NO_ERROR) {
281 sp <AudioPlaybackClient> client =
Eric Laurent5ada82e2019-08-29 17:53:54 -0700282 new AudioPlaybackClient(*attr, *output, uid, pid, session, *portId, *selectedDeviceId, *stream);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700283 mAudioPlaybackClients.add(*portId, client);
284 }
Nadav Bar766fb022018-01-07 12:18:03 +0200285 return result;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700286}
287
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700288void AudioPolicyService::getPlaybackClientAndEffects(audio_port_handle_t portId,
289 sp<AudioPlaybackClient>& client,
290 sp<AudioPolicyEffects>& effects,
291 const char *context)
292{
293 Mutex::Autolock _l(mLock);
294 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
295 if (index < 0) {
296 ALOGE("%s AudioTrack client not found for portId %d", context, portId);
297 return;
298 }
299 client = mAudioPlaybackClients.valueAt(index);
300 effects = mAudioPolicyEffects;
301}
302
Eric Laurentd7fe0862018-07-14 16:48:01 -0700303status_t AudioPolicyService::startOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800304{
Eric Laurentdce54a12014-03-10 12:19:46 -0700305 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800306 return NO_INIT;
307 }
308 ALOGV("startOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700309 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700310 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700311
312 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
313
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700314 if (audioPolicyEffects != 0) {
315 // create audio processors according to stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700316 status_t status = audioPolicyEffects->addOutputSessionEffects(
317 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700318 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700319 ALOGW("Failed to add effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700320 }
321 }
322 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700323 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700324 status_t status = mAudioPolicyManager->startOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700325 if (status == NO_ERROR) {
326 client->active = true;
327 }
328 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800329}
330
Eric Laurentd7fe0862018-07-14 16:48:01 -0700331status_t AudioPolicyService::stopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800332{
Eric Laurentdce54a12014-03-10 12:19:46 -0700333 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800334 return NO_INIT;
335 }
336 ALOGV("stopOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700337 mOutputCommandThread->stopOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800338 return NO_ERROR;
339}
340
Eric Laurentd7fe0862018-07-14 16:48:01 -0700341status_t AudioPolicyService::doStopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800342{
Eric Laurentd7fe0862018-07-14 16:48:01 -0700343 ALOGV("doStopOutput");
344 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700345 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentd7fe0862018-07-14 16:48:01 -0700346
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700347 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
348
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700349 if (audioPolicyEffects != 0) {
350 // release audio processors from the stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700351 status_t status = audioPolicyEffects->releaseOutputSessionEffects(
352 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700353 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700354 ALOGW("Failed to release effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700355 }
356 }
357 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700358 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700359 status_t status = mAudioPolicyManager->stopOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700360 if (status == NO_ERROR) {
361 client->active = false;
362 }
363 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800364}
365
Eric Laurentd7fe0862018-07-14 16:48:01 -0700366void AudioPolicyService::releaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800367{
Eric Laurentdce54a12014-03-10 12:19:46 -0700368 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800369 return;
370 }
371 ALOGV("releaseOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700372 mOutputCommandThread->releaseOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800373}
374
Eric Laurentd7fe0862018-07-14 16:48:01 -0700375void AudioPolicyService::doReleaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800376{
377 ALOGV("doReleaseOutput from tid %d", gettid());
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700378 sp<AudioPlaybackClient> client;
379 sp<AudioPolicyEffects> audioPolicyEffects;
380
381 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
382
383 if (audioPolicyEffects != 0 && client->active) {
384 // clean up effects if output was not stopped before being released
385 audioPolicyEffects->releaseOutputSessionEffects(
386 client->io, client->stream, client->session);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700387 }
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700388 Mutex::Autolock _l(mLock);
Eric Laurentd4007242019-03-27 12:42:16 -0700389 mAudioPlaybackClients.removeItem(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700390
Eric Laurent10b71232018-04-13 18:14:44 -0700391 // called from internal thread: no need to clear caller identity
Eric Laurent8fc147b2018-07-22 19:13:55 -0700392 mAudioPolicyManager->releaseOutput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800393}
394
Eric Laurentcaf7f482014-11-25 17:50:47 -0800395status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
396 audio_io_handle_t *input,
Mikhail Naganov2996f672019-04-18 12:29:59 -0700397 audio_unique_id_t riid,
Eric Laurentcaf7f482014-11-25 17:50:47 -0800398 audio_session_t session,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700399 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700400 uid_t uid,
Eric Laurentfee19762018-01-29 18:44:13 -0800401 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800402 const audio_config_base_t *config,
Paul McLean466dc8e2015-04-17 13:15:36 -0600403 audio_input_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700404 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800405 audio_port_handle_t *portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800406{
Eric Laurentdce54a12014-03-10 12:19:46 -0700407 if (mAudioPolicyManager == NULL) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800408 return NO_INIT;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800409 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800410
Hayden Gomes524159d2019-12-23 14:41:47 -0800411 status_t result = validateUsage(attr->usage, pid, uid);
412 if (result != NO_ERROR) {
413 return result;
414 }
415
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900416 audio_source_t inputSource = attr->source;
417 if (inputSource == AUDIO_SOURCE_DEFAULT) {
418 inputSource = AUDIO_SOURCE_MIC;
419 }
420
Eric Laurent2d388ec2014-03-07 13:25:54 -0800421 // already checked by client, but double-check in case the client wrapper is bypassed
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900422 if ((inputSource < AUDIO_SOURCE_DEFAULT)
423 || (inputSource >= AUDIO_SOURCE_CNT
424 && inputSource != AUDIO_SOURCE_HOTWORD
425 && inputSource != AUDIO_SOURCE_FM_TUNER
426 && inputSource != AUDIO_SOURCE_ECHO_REFERENCE)) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800427 return BAD_VALUE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800428 }
429
Eric Laurentb2379ba2016-05-23 17:42:12 -0700430 bool updatePid = (pid == -1);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700431 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700432 if (!isAudioServerOrMediaServerUid(callingUid)) {
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700433 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Marco Nelissendcb346b2015-09-09 10:47:29 -0700434 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
435 uid = callingUid;
Eric Laurentb2379ba2016-05-23 17:42:12 -0700436 updatePid = true;
437 }
438
439 if (updatePid) {
440 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700441 ALOGW_IF(pid != (pid_t)-1 && pid != callingPid,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700442 "%s uid %d pid %d tried to pass itself off as pid %d",
443 __func__, callingUid, callingPid, pid);
444 pid = callingPid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700445 }
446
Eric Laurent58a0dd82019-10-24 12:42:17 -0700447 // check calling permissions.
448 // Capturing from FM_TUNER source is controlled by captureAudioOutputAllowed() only as this
449 // does not affect users privacy as does capturing from an actual microphone.
450 if (!(recordingAllowed(opPackageName, pid, uid) || attr->source == AUDIO_SOURCE_FM_TUNER)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800451 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
452 __func__, uid, pid);
453 return PERMISSION_DENIED;
454 }
455
Eric Laurent1ff16a72019-03-14 18:35:04 -0700456 bool canCaptureOutput = captureAudioOutputAllowed(pid, uid);
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900457 if ((inputSource == AUDIO_SOURCE_VOICE_UPLINK ||
458 inputSource == AUDIO_SOURCE_VOICE_DOWNLINK ||
459 inputSource == AUDIO_SOURCE_VOICE_CALL ||
460 inputSource == AUDIO_SOURCE_ECHO_REFERENCE||
461 inputSource == AUDIO_SOURCE_FM_TUNER) &&
Eric Laurent1ff16a72019-03-14 18:35:04 -0700462 !canCaptureOutput) {
Nadav Bar744be482018-05-08 13:26:21 +0300463 return PERMISSION_DENIED;
464 }
465
jiabin68e0df72019-03-18 17:55:35 -0700466 bool canCaptureHotword = captureHotwordAllowed(opPackageName, pid, uid);
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900467 if ((inputSource == AUDIO_SOURCE_HOTWORD) && !canCaptureHotword) {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700468 return BAD_VALUE;
469 }
470
471 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700472 {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700473 status_t status;
474 AudioPolicyInterface::input_type_t inputType;
475
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700476 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700477 {
478 AutoCallerClear acc;
479 // the audio_in_acoustics_t parameter is ignored by get_input()
Mikhail Naganov2996f672019-04-18 12:29:59 -0700480 status = mAudioPolicyManager->getInputForAttr(attr, input, riid, session, uid,
Eric Laurent10b71232018-04-13 18:14:44 -0700481 config,
482 flags, selectedDeviceId,
483 &inputType, portId);
484 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700485 audioPolicyEffects = mAudioPolicyEffects;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800486
487 if (status == NO_ERROR) {
488 // enforce permission (if any) required for each type of input
489 switch (inputType) {
Kevin Rocard25f9b052019-02-27 15:08:54 -0800490 case AudioPolicyInterface::API_INPUT_MIX_PUBLIC_CAPTURE_PLAYBACK:
491 // this use case has been validated in audio service with a MediaProjection token,
492 // and doesn't rely on regular permissions
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800493 case AudioPolicyInterface::API_INPUT_LEGACY:
494 break;
Eric Laurent82db2692015-08-07 13:59:42 -0700495 case AudioPolicyInterface::API_INPUT_TELEPHONY_RX:
496 // FIXME: use the same permission as for remote submix for now.
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800497 case AudioPolicyInterface::API_INPUT_MIX_CAPTURE:
Eric Laurent1ff16a72019-03-14 18:35:04 -0700498 if (!canCaptureOutput) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800499 ALOGE("getInputForAttr() permission denied: capture not allowed");
500 status = PERMISSION_DENIED;
501 }
502 break;
503 case AudioPolicyInterface::API_INPUT_MIX_EXT_POLICY_REROUTE:
Eric Laurent8a1095a2019-11-08 14:44:16 -0800504 if (!modifyAudioRoutingAllowed(pid, uid)) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800505 ALOGE("getInputForAttr() permission denied: modify audio routing not allowed");
506 status = PERMISSION_DENIED;
507 }
508 break;
509 case AudioPolicyInterface::API_INPUT_INVALID:
510 default:
511 LOG_ALWAYS_FATAL("getInputForAttr() encountered an invalid input type %d",
512 (int)inputType);
513 }
514 }
515
516 if (status != NO_ERROR) {
517 if (status == PERMISSION_DENIED) {
Eric Laurent10b71232018-04-13 18:14:44 -0700518 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700519 mAudioPolicyManager->releaseInput(*portId);
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800520 }
521 return status;
522 }
Eric Laurentfee19762018-01-29 18:44:13 -0800523
Eric Laurent5ada82e2019-08-29 17:53:54 -0700524 sp<AudioRecordClient> client = new AudioRecordClient(*attr, *input, uid, pid, session, *portId,
Eric Laurent1ff16a72019-03-14 18:35:04 -0700525 *selectedDeviceId, opPackageName,
526 canCaptureOutput, canCaptureHotword);
Eric Laurentfee19762018-01-29 18:44:13 -0800527 mAudioRecordClients.add(*portId, client);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700528 }
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800529
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700530 if (audioPolicyEffects != 0) {
531 // create audio pre processors according to input source
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900532 status_t status = audioPolicyEffects->addInputEffects(*input, inputSource, session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700533 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800534 ALOGW("Failed to add effects on input %d", *input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700535 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800536 }
Eric Laurentcaf7f482014-11-25 17:50:47 -0800537 return NO_ERROR;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800538}
539
Eric Laurent99fcae42018-05-17 16:59:18 -0700540std::string AudioPolicyService::getDeviceTypeStrForPortId(audio_port_handle_t portId) {
Eric Laurent99fcae42018-05-17 16:59:18 -0700541 struct audio_port port = {};
542 port.id = portId;
543 status_t status = mAudioPolicyManager->getAudioPort(&port);
544 if (status == NO_ERROR && port.type == AUDIO_PORT_TYPE_DEVICE) {
Andy Hung9b181952019-02-25 14:53:36 -0800545 return toString(port.ext.device.type);
Eric Laurent99fcae42018-05-17 16:59:18 -0700546 }
Andy Hung9b181952019-02-25 14:53:36 -0800547 return {};
Eric Laurent99fcae42018-05-17 16:59:18 -0700548}
549
Eric Laurent4eb58f12018-12-07 16:41:02 -0800550status_t AudioPolicyService::startInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800551{
Eric Laurentdce54a12014-03-10 12:19:46 -0700552 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800553 return NO_INIT;
554 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800555 sp<AudioRecordClient> client;
556 {
557 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800558
Eric Laurent7dca8a82018-01-29 18:44:26 -0800559 ssize_t index = mAudioRecordClients.indexOfKey(portId);
560 if (index < 0) {
561 return INVALID_OPERATION;
562 }
563 client = mAudioRecordClients.valueAt(index);
Eric Laurentfee19762018-01-29 18:44:13 -0800564 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800565
566 // check calling permissions
Eric Laurent58a0dd82019-10-24 12:42:17 -0700567 if (!(startRecording(client->opPackageName, client->pid, client->uid)
568 || client->attributes.source == AUDIO_SOURCE_FM_TUNER)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800569 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
570 __func__, client->uid, client->pid);
571 return PERMISSION_DENIED;
572 }
Eric Laurentfee19762018-01-29 18:44:13 -0800573
Eric Laurentdf628922018-12-06 21:45:51 +0000574 Mutex::Autolock _l(mLock);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800575
576 client->active = true;
577 client->startTimeNs = systemTime();
578 updateUidStates_l();
Eric Laurentfee19762018-01-29 18:44:13 -0800579
Eric Laurent10b71232018-04-13 18:14:44 -0700580 status_t status;
581 {
582 AutoCallerClear acc;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800583 status = mAudioPolicyManager->startInput(portId);
Ray Essick84e84a52018-05-03 18:45:07 -0700584
585 }
586
Ray Essickf6a57cd2018-05-22 16:20:54 -0700587 // including successes gets very verbose
Ray Essick6ce27e52019-02-15 10:58:05 -0800588 // but once we cut over to westworld, log them all.
Ray Essickf6a57cd2018-05-22 16:20:54 -0700589 if (status != NO_ERROR) {
Ray Essick84e84a52018-05-03 18:45:07 -0700590
591 static constexpr char kAudioPolicy[] = "audiopolicy";
592
Ray Essick84e84a52018-05-03 18:45:07 -0700593 static constexpr char kAudioPolicyStatus[] = "android.media.audiopolicy.status";
594 static constexpr char kAudioPolicyRqstSrc[] = "android.media.audiopolicy.rqst.src";
595 static constexpr char kAudioPolicyRqstPkg[] = "android.media.audiopolicy.rqst.pkg";
596 static constexpr char kAudioPolicyRqstSession[] = "android.media.audiopolicy.rqst.session";
Eric Laurent99fcae42018-05-17 16:59:18 -0700597 static constexpr char kAudioPolicyRqstDevice[] =
598 "android.media.audiopolicy.rqst.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700599 static constexpr char kAudioPolicyActiveSrc[] = "android.media.audiopolicy.active.src";
600 static constexpr char kAudioPolicyActivePkg[] = "android.media.audiopolicy.active.pkg";
Eric Laurent99fcae42018-05-17 16:59:18 -0700601 static constexpr char kAudioPolicyActiveSession[] =
602 "android.media.audiopolicy.active.session";
603 static constexpr char kAudioPolicyActiveDevice[] =
604 "android.media.audiopolicy.active.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700605
Ray Essickf27e9872019-12-07 06:28:46 -0800606 mediametrics::Item *item = mediametrics::Item::create(kAudioPolicy);
Ray Essick84e84a52018-05-03 18:45:07 -0700607 if (item != NULL) {
608
Ray Essick84e84a52018-05-03 18:45:07 -0700609 item->setInt32(kAudioPolicyStatus, status);
610
Eric Laurent99fcae42018-05-17 16:59:18 -0700611 item->setCString(kAudioPolicyRqstSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800612 toString(client->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700613 item->setInt32(kAudioPolicyRqstSession, client->session);
Ray Essick51866952018-05-30 11:22:27 -0700614 if (client->opPackageName.size() != 0) {
615 item->setCString(kAudioPolicyRqstPkg,
616 std::string(String8(client->opPackageName).string()).c_str());
617 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700618 item->setCString(kAudioPolicyRqstPkg, std::to_string(client->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700619 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700620 item->setCString(
621 kAudioPolicyRqstDevice, getDeviceTypeStrForPortId(client->deviceId).c_str());
622
Eric Laurent4eb58f12018-12-07 16:41:02 -0800623 int count = mAudioRecordClients.size();
624 for (int i = 0; i < count ; i++) {
625 if (portId == mAudioRecordClients.keyAt(i)) {
626 continue;
627 }
628 sp<AudioRecordClient> other = mAudioRecordClients.valueAt(i);
629 if (other->active) {
630 // keeps the last of the clients marked active
631 item->setCString(kAudioPolicyActiveSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800632 toString(other->attributes.source).c_str());
Eric Laurent4eb58f12018-12-07 16:41:02 -0800633 item->setInt32(kAudioPolicyActiveSession, other->session);
634 if (other->opPackageName.size() != 0) {
635 item->setCString(kAudioPolicyActivePkg,
636 std::string(String8(other->opPackageName).string()).c_str());
637 } else {
638 item->setCString(kAudioPolicyRqstPkg,
639 std::to_string(other->uid).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700640 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800641 item->setCString(kAudioPolicyActiveDevice,
642 getDeviceTypeStrForPortId(other->deviceId).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700643 }
644 }
645 item->selfrecord();
646 delete item;
647 item = NULL;
648 }
Ray Essick6ce27e52019-02-15 10:58:05 -0800649 }
650
651 if (status != NO_ERROR) {
Eric Laurent4eb58f12018-12-07 16:41:02 -0800652 client->active = false;
653 client->startTimeNs = 0;
654 updateUidStates_l();
Svet Ganov6e641372018-03-02 09:21:30 -0800655 finishRecording(client->opPackageName, client->uid);
Eric Laurentfb66dd92016-01-28 18:32:03 -0800656 }
657
658 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800659}
660
Eric Laurentfee19762018-01-29 18:44:13 -0800661status_t AudioPolicyService::stopInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800662{
Eric Laurentdce54a12014-03-10 12:19:46 -0700663 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800664 return NO_INIT;
665 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800666
Eric Laurent2d388ec2014-03-07 13:25:54 -0800667 Mutex::Autolock _l(mLock);
668
Eric Laurentfee19762018-01-29 18:44:13 -0800669 ssize_t index = mAudioRecordClients.indexOfKey(portId);
670 if (index < 0) {
671 return INVALID_OPERATION;
672 }
673 sp<AudioRecordClient> client = mAudioRecordClients.valueAt(index);
674
Ray Essick84e84a52018-05-03 18:45:07 -0700675 client->active = false;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800676 client->startTimeNs = 0;
677
678 updateUidStates_l();
Ray Essick84e84a52018-05-03 18:45:07 -0700679
Svet Ganov6e641372018-03-02 09:21:30 -0800680 // finish the recording app op
681 finishRecording(client->opPackageName, client->uid);
Eric Laurent10b71232018-04-13 18:14:44 -0700682 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700683 return mAudioPolicyManager->stopInput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800684}
685
Eric Laurentfee19762018-01-29 18:44:13 -0800686void AudioPolicyService::releaseInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800687{
Eric Laurentdce54a12014-03-10 12:19:46 -0700688 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800689 return;
690 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700691 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800692 sp<AudioRecordClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700693 {
694 Mutex::Autolock _l(mLock);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700695 audioPolicyEffects = mAudioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800696 ssize_t index = mAudioRecordClients.indexOfKey(portId);
697 if (index < 0) {
698 return;
699 }
700 client = mAudioRecordClients.valueAt(index);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800701
702 if (client->active) {
703 ALOGW("%s releasing active client portId %d", __FUNCTION__, portId);
704 client->active = false;
705 client->startTimeNs = 0;
706 updateUidStates_l();
707 }
708
Eric Laurentfee19762018-01-29 18:44:13 -0800709 mAudioRecordClients.removeItem(portId);
710 }
711 if (client == 0) {
712 return;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700713 }
714 if (audioPolicyEffects != 0) {
715 // release audio processors from the input
Eric Laurentd7fe0862018-07-14 16:48:01 -0700716 status_t status = audioPolicyEffects->releaseInputEffects(client->io, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700717 if(status != NO_ERROR) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700718 ALOGW("Failed to release effects on input %d", client->io);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700719 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800720 }
Eric Laurentf10c7092016-12-06 17:09:56 -0800721 {
722 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700723 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700724 mAudioPolicyManager->releaseInput(portId);
Eric Laurentf10c7092016-12-06 17:09:56 -0800725 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800726}
727
728status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
729 int indexMin,
730 int indexMax)
731{
Eric Laurentdce54a12014-03-10 12:19:46 -0700732 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800733 return NO_INIT;
734 }
735 if (!settingsAllowed()) {
736 return PERMISSION_DENIED;
737 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800738 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800739 return BAD_VALUE;
740 }
741 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700742 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700743 mAudioPolicyManager->initStreamVolume(stream, indexMin, indexMax);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800744 return NO_ERROR;
745}
746
747status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
748 int index,
749 audio_devices_t device)
750{
Eric Laurentdce54a12014-03-10 12:19:46 -0700751 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800752 return NO_INIT;
753 }
754 if (!settingsAllowed()) {
755 return PERMISSION_DENIED;
756 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800757 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800758 return BAD_VALUE;
759 }
760 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700761 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700762 return mAudioPolicyManager->setStreamVolumeIndex(stream,
763 index,
764 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800765}
766
767status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
768 int *index,
769 audio_devices_t device)
770{
Eric Laurentdce54a12014-03-10 12:19:46 -0700771 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800772 return NO_INIT;
773 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800774 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800775 return BAD_VALUE;
776 }
777 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700778 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700779 return mAudioPolicyManager->getStreamVolumeIndex(stream,
780 index,
781 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800782}
783
François Gaffiecfe17322018-11-07 13:41:29 +0100784status_t AudioPolicyService::setVolumeIndexForAttributes(const audio_attributes_t &attributes,
785 int index, audio_devices_t device)
786{
787 if (mAudioPolicyManager == NULL) {
788 return NO_INIT;
789 }
790 if (!settingsAllowed()) {
791 return PERMISSION_DENIED;
792 }
793 Mutex::Autolock _l(mLock);
794 AutoCallerClear acc;
795 return mAudioPolicyManager->setVolumeIndexForAttributes(attributes, index, device);
796}
797
798status_t AudioPolicyService::getVolumeIndexForAttributes(const audio_attributes_t &attributes,
799 int &index, audio_devices_t device)
800{
801 if (mAudioPolicyManager == NULL) {
802 return NO_INIT;
803 }
804 Mutex::Autolock _l(mLock);
805 AutoCallerClear acc;
806 return mAudioPolicyManager->getVolumeIndexForAttributes(attributes, index, device);
807}
808
809status_t AudioPolicyService::getMinVolumeIndexForAttributes(const audio_attributes_t &attributes,
810 int &index)
811{
812 if (mAudioPolicyManager == NULL) {
813 return NO_INIT;
814 }
815 Mutex::Autolock _l(mLock);
816 AutoCallerClear acc;
817 return mAudioPolicyManager->getMinVolumeIndexForAttributes(attributes, index);
818}
819
820status_t AudioPolicyService::getMaxVolumeIndexForAttributes(const audio_attributes_t &attributes,
821 int &index)
822{
823 if (mAudioPolicyManager == NULL) {
824 return NO_INIT;
825 }
826 Mutex::Autolock _l(mLock);
827 AutoCallerClear acc;
828 return mAudioPolicyManager->getMaxVolumeIndexForAttributes(attributes, index);
829}
830
Eric Laurent2d388ec2014-03-07 13:25:54 -0800831uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
832{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800833 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
François Gaffiec005e562018-11-06 15:04:49 +0100834 return PRODUCT_STRATEGY_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700835 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700836 if (mAudioPolicyManager == NULL) {
François Gaffiec005e562018-11-06 15:04:49 +0100837 return PRODUCT_STRATEGY_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800838 }
François Gaffiec005e562018-11-06 15:04:49 +0100839 // DO NOT LOCK, may be called from AudioFlinger with lock held, reaching deadlock
Eric Laurent10b71232018-04-13 18:14:44 -0700840 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700841 return mAudioPolicyManager->getStrategyForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800842}
843
844//audio policy: use audio_device_t appropriately
845
846audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
847{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800848 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700849 return AUDIO_DEVICE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700850 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700851 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700852 return AUDIO_DEVICE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800853 }
Haynes Mathew Georgedfb9f3b2015-10-26 18:22:13 -0700854 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700855 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700856 return mAudioPolicyManager->getDevicesForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800857}
858
Jean-Michel Trivif41599b2020-01-07 14:22:08 -0800859status_t AudioPolicyService::getDevicesForAttributes(const AudioAttributes &aa,
Hayden Gomes524159d2019-12-23 14:41:47 -0800860 AudioDeviceTypeAddrVector *devices) const
Jean-Michel Trivif41599b2020-01-07 14:22:08 -0800861{
862 if (mAudioPolicyManager == NULL) {
863 return NO_INIT;
864 }
865 Mutex::Autolock _l(mLock);
866 AutoCallerClear acc;
867 return mAudioPolicyManager->getDevicesForAttributes(aa.getAttributes(), devices);
868}
869
Eric Laurent2d388ec2014-03-07 13:25:54 -0800870audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
871{
872 // FIXME change return type to status_t, and return NO_INIT here
Eric Laurentdce54a12014-03-10 12:19:46 -0700873 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800874 return 0;
875 }
876 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700877 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700878 return mAudioPolicyManager->getOutputForEffect(desc);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800879}
880
881status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
882 audio_io_handle_t io,
883 uint32_t strategy,
Glenn Kastend848eb42016-03-08 13:42:11 -0800884 audio_session_t session,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800885 int id)
886{
Eric Laurentdce54a12014-03-10 12:19:46 -0700887 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800888 return NO_INIT;
889 }
Eric Laurent6c796322019-04-09 14:13:17 -0700890 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700891 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700892 return mAudioPolicyManager->registerEffect(desc, io, strategy, session, id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800893}
894
895status_t AudioPolicyService::unregisterEffect(int id)
896{
Eric Laurentdce54a12014-03-10 12:19:46 -0700897 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800898 return NO_INIT;
899 }
Eric Laurent6c796322019-04-09 14:13:17 -0700900 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700901 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700902 return mAudioPolicyManager->unregisterEffect(id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800903}
904
905status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
906{
Eric Laurentdce54a12014-03-10 12:19:46 -0700907 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800908 return NO_INIT;
909 }
Eric Laurent6c796322019-04-09 14:13:17 -0700910 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700911 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700912 return mAudioPolicyManager->setEffectEnabled(id, enabled);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800913}
914
Eric Laurent6c796322019-04-09 14:13:17 -0700915status_t AudioPolicyService::moveEffectsToIo(const std::vector<int>& ids, audio_io_handle_t io)
916{
917 if (mAudioPolicyManager == NULL) {
918 return NO_INIT;
919 }
920 Mutex::Autolock _l(mLock);
921 AutoCallerClear acc;
922 return mAudioPolicyManager->moveEffectsToIo(ids, io);
923}
924
Eric Laurent2d388ec2014-03-07 13:25:54 -0800925bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
926{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800927 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700928 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700929 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700930 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700931 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800932 }
933 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700934 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700935 return mAudioPolicyManager->isStreamActive(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800936}
937
938bool AudioPolicyService::isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs) const
939{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800940 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700941 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700942 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700943 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700944 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800945 }
946 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700947 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700948 return mAudioPolicyManager->isStreamActiveRemotely(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800949}
950
951bool AudioPolicyService::isSourceActive(audio_source_t source) const
952{
Eric Laurentdce54a12014-03-10 12:19:46 -0700953 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800954 return false;
955 }
956 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700957 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700958 return mAudioPolicyManager->isSourceActive(source);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800959}
960
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700961status_t AudioPolicyService::getAudioPolicyEffects(sp<AudioPolicyEffects>& audioPolicyEffects)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800962{
Eric Laurentdce54a12014-03-10 12:19:46 -0700963 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800964 return NO_INIT;
965 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700966 {
967 Mutex::Autolock _l(mLock);
968 audioPolicyEffects = mAudioPolicyEffects;
969 }
970 if (audioPolicyEffects == 0) {
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700971 return NO_INIT;
972 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700973
974 return OK;
975}
976
977status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
978 effect_descriptor_t *descriptors,
979 uint32_t *count)
980{
981 sp<AudioPolicyEffects>audioPolicyEffects;
982 status_t status = getAudioPolicyEffects(audioPolicyEffects);
983 if (status != OK) {
984 *count = 0;
985 return status;
986 }
Eric Laurentfb66dd92016-01-28 18:32:03 -0800987 return audioPolicyEffects->queryDefaultInputEffects(
988 (audio_session_t)audioSession, descriptors, count);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800989}
990
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700991status_t AudioPolicyService::addSourceDefaultEffect(const effect_uuid_t *type,
992 const String16& opPackageName,
993 const effect_uuid_t *uuid,
994 int32_t priority,
995 audio_source_t source,
996 audio_unique_id_t* id)
997{
998 sp<AudioPolicyEffects>audioPolicyEffects;
999 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1000 if (status != OK) {
1001 return status;
1002 }
1003 if (!modifyDefaultAudioEffectsAllowed()) {
1004 return PERMISSION_DENIED;
1005 }
1006 return audioPolicyEffects->addSourceDefaultEffect(
1007 type, opPackageName, uuid, priority, source, id);
1008}
1009
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001010status_t AudioPolicyService::addStreamDefaultEffect(const effect_uuid_t *type,
1011 const String16& opPackageName,
1012 const effect_uuid_t *uuid,
1013 int32_t priority,
1014 audio_usage_t usage,
1015 audio_unique_id_t* id)
1016{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001017 sp<AudioPolicyEffects>audioPolicyEffects;
1018 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1019 if (status != OK) {
1020 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001021 }
1022 if (!modifyDefaultAudioEffectsAllowed()) {
1023 return PERMISSION_DENIED;
1024 }
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001025 return audioPolicyEffects->addStreamDefaultEffect(
1026 type, opPackageName, uuid, priority, usage, id);
1027}
1028
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001029status_t AudioPolicyService::removeSourceDefaultEffect(audio_unique_id_t id)
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001030{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001031 sp<AudioPolicyEffects>audioPolicyEffects;
1032 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1033 if (status != OK) {
1034 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001035 }
1036 if (!modifyDefaultAudioEffectsAllowed()) {
1037 return PERMISSION_DENIED;
1038 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001039 return audioPolicyEffects->removeSourceDefaultEffect(id);
1040}
1041
1042status_t AudioPolicyService::removeStreamDefaultEffect(audio_unique_id_t id)
1043{
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001044 sp<AudioPolicyEffects>audioPolicyEffects;
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001045 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1046 if (status != OK) {
1047 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001048 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001049 if (!modifyDefaultAudioEffectsAllowed()) {
1050 return PERMISSION_DENIED;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001051 }
1052 return audioPolicyEffects->removeStreamDefaultEffect(id);
1053}
1054
Hayden Gomes524159d2019-12-23 14:41:47 -08001055status_t AudioPolicyService::setSupportedSystemUsages(const std::vector<audio_usage_t>& systemUsages) {
1056 Mutex::Autolock _l(mLock);
1057 if(!modifyAudioRoutingAllowed()) {
1058 return PERMISSION_DENIED;
1059 }
1060
1061 bool areAllSystemUsages = std::all_of(begin(systemUsages), end(systemUsages),
1062 [](audio_usage_t usage) { return isSystemUsage(usage); });
1063 if (!areAllSystemUsages) {
1064 return BAD_VALUE;
1065 }
1066
1067 mSupportedSystemUsages = systemUsages;
1068 return NO_ERROR;
1069}
1070
Kevin Rocardb99cc752019-03-21 20:52:24 -07001071status_t AudioPolicyService::setAllowedCapturePolicy(uid_t uid, audio_flags_mask_t capturePolicy) {
1072 Mutex::Autolock _l(mLock);
1073 if (mAudioPolicyManager == NULL) {
1074 ALOGV("%s() mAudioPolicyManager == NULL", __func__);
1075 return NO_INIT;
1076 }
Kevin Rocardb99cc752019-03-21 20:52:24 -07001077 return mAudioPolicyManager->setAllowedCapturePolicy(uid, capturePolicy);
1078}
1079
Eric Laurent2d388ec2014-03-07 13:25:54 -08001080bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
1081{
Eric Laurentdce54a12014-03-10 12:19:46 -07001082 if (mAudioPolicyManager == NULL) {
1083 ALOGV("mAudioPolicyManager == NULL");
Eric Laurent2d388ec2014-03-07 13:25:54 -08001084 return false;
1085 }
Andy Hung2ddee192015-12-18 17:34:44 -08001086 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001087 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -07001088 return mAudioPolicyManager->isOffloadSupported(info);
Eric Laurent2d388ec2014-03-07 13:25:54 -08001089}
1090
Michael Chana94fbb22018-04-24 14:31:19 +10001091bool AudioPolicyService::isDirectOutputSupported(const audio_config_base_t& config,
1092 const audio_attributes_t& attributes) {
1093 if (mAudioPolicyManager == NULL) {
1094 ALOGV("mAudioPolicyManager == NULL");
1095 return false;
1096 }
Hayden Gomes524159d2019-12-23 14:41:47 -08001097
1098 status_t result = validateUsage(attributes.usage);
1099 if (result != NO_ERROR) {
1100 return result;
1101 }
1102
Michael Chana94fbb22018-04-24 14:31:19 +10001103 Mutex::Autolock _l(mLock);
1104 return mAudioPolicyManager->isDirectOutputSupported(config, attributes);
1105}
1106
1107
Eric Laurent6a94d692014-05-20 11:18:06 -07001108status_t AudioPolicyService::listAudioPorts(audio_port_role_t role,
1109 audio_port_type_t type,
Eric Laurent203b1a12014-04-01 10:34:16 -07001110 unsigned int *num_ports,
Eric Laurent6a94d692014-05-20 11:18:06 -07001111 struct audio_port *ports,
1112 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001113{
Eric Laurent6a94d692014-05-20 11:18:06 -07001114 Mutex::Autolock _l(mLock);
1115 if (mAudioPolicyManager == NULL) {
1116 return NO_INIT;
1117 }
Eric Laurent10b71232018-04-13 18:14:44 -07001118 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001119 return mAudioPolicyManager->listAudioPorts(role, type, num_ports, ports, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001120}
1121
Eric Laurent6a94d692014-05-20 11:18:06 -07001122status_t AudioPolicyService::getAudioPort(struct audio_port *port)
Eric Laurent203b1a12014-04-01 10:34:16 -07001123{
Eric Laurent6a94d692014-05-20 11:18:06 -07001124 Mutex::Autolock _l(mLock);
1125 if (mAudioPolicyManager == NULL) {
1126 return NO_INIT;
1127 }
Eric Laurent10b71232018-04-13 18:14:44 -07001128 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001129 return mAudioPolicyManager->getAudioPort(port);
Eric Laurent203b1a12014-04-01 10:34:16 -07001130}
1131
Eric Laurent6a94d692014-05-20 11:18:06 -07001132status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch,
1133 audio_patch_handle_t *handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001134{
Eric Laurent6a94d692014-05-20 11:18:06 -07001135 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001136 if(!modifyAudioRoutingAllowed()) {
1137 return PERMISSION_DENIED;
1138 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001139 if (mAudioPolicyManager == NULL) {
1140 return NO_INIT;
1141 }
Eric Laurent10b71232018-04-13 18:14:44 -07001142 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001143 return mAudioPolicyManager->createAudioPatch(patch, handle,
1144 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001145}
1146
Eric Laurent6a94d692014-05-20 11:18:06 -07001147status_t AudioPolicyService::releaseAudioPatch(audio_patch_handle_t handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001148{
Eric Laurent6a94d692014-05-20 11:18:06 -07001149 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001150 if(!modifyAudioRoutingAllowed()) {
1151 return PERMISSION_DENIED;
1152 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001153 if (mAudioPolicyManager == NULL) {
1154 return NO_INIT;
1155 }
Eric Laurent10b71232018-04-13 18:14:44 -07001156 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001157 return mAudioPolicyManager->releaseAudioPatch(handle,
1158 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001159}
1160
1161status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
Eric Laurent6a94d692014-05-20 11:18:06 -07001162 struct audio_patch *patches,
1163 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001164{
Eric Laurent6a94d692014-05-20 11:18:06 -07001165 Mutex::Autolock _l(mLock);
1166 if (mAudioPolicyManager == NULL) {
1167 return NO_INIT;
1168 }
Eric Laurent10b71232018-04-13 18:14:44 -07001169 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001170 return mAudioPolicyManager->listAudioPatches(num_patches, patches, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001171}
1172
Eric Laurent6a94d692014-05-20 11:18:06 -07001173status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config)
Eric Laurent203b1a12014-04-01 10:34:16 -07001174{
Eric Laurent6a94d692014-05-20 11:18:06 -07001175 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001176 if(!modifyAudioRoutingAllowed()) {
1177 return PERMISSION_DENIED;
1178 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001179 if (mAudioPolicyManager == NULL) {
1180 return NO_INIT;
1181 }
Eric Laurent10b71232018-04-13 18:14:44 -07001182 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001183 return mAudioPolicyManager->setAudioPortConfig(config);
Eric Laurent203b1a12014-04-01 10:34:16 -07001184}
Eric Laurent2d388ec2014-03-07 13:25:54 -08001185
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001186status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session,
1187 audio_io_handle_t *ioHandle,
1188 audio_devices_t *device)
1189{
Andy Hungf759b8c2017-08-15 12:48:54 -07001190 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001191 if (mAudioPolicyManager == NULL) {
1192 return NO_INIT;
1193 }
Eric Laurent10b71232018-04-13 18:14:44 -07001194 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001195 return mAudioPolicyManager->acquireSoundTriggerSession(session, ioHandle, device);
1196}
1197
1198status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session)
1199{
Andy Hungf759b8c2017-08-15 12:48:54 -07001200 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001201 if (mAudioPolicyManager == NULL) {
1202 return NO_INIT;
1203 }
Eric Laurent10b71232018-04-13 18:14:44 -07001204 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001205 return mAudioPolicyManager->releaseSoundTriggerSession(session);
1206}
1207
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -07001208status_t AudioPolicyService::registerPolicyMixes(const Vector<AudioMix>& mixes, bool registration)
Eric Laurentbaac1832014-12-01 17:52:59 -08001209{
1210 Mutex::Autolock _l(mLock);
Kevin Rocardbe201852019-02-20 22:33:28 -08001211
1212 // loopback|render only need a MediaProjection (checked in caller AudioService.java)
1213 bool needModifyAudioRouting = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
1214 return !is_mix_loopback_render(mix.mRouteFlags); });
1215 if (needModifyAudioRouting && !modifyAudioRoutingAllowed()) {
Eric Laurentbaac1832014-12-01 17:52:59 -08001216 return PERMISSION_DENIED;
1217 }
Kevin Rocardbe201852019-02-20 22:33:28 -08001218
Nadav Bar287d3302020-02-05 14:55:38 +02001219 // If one of the mixes has needCaptureVoiceCommunicationOutput set to true, then we
1220 // need to verify that the caller still has CAPTURE_VOICE_COMMUNICATION_OUTPUT
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001221 bool needCaptureVoiceCommunicationOutput =
1222 std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
Nadav Bar287d3302020-02-05 14:55:38 +02001223 return mix.mVoiceCommunicationCaptureAllowed; });
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001224
Kevin Rocard36b17552019-03-07 18:48:07 -08001225 bool needCaptureMediaOutput = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
Nadav Bar287d3302020-02-05 14:55:38 +02001226 return mix.mAllowPrivilegedPlaybackCapture; });
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001227
Kevin Rocard36b17552019-03-07 18:48:07 -08001228 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
1229 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001230
Kevin Rocard36b17552019-03-07 18:48:07 -08001231 if (needCaptureMediaOutput && !captureMediaOutputAllowed(callingPid, callingUid)) {
1232 return PERMISSION_DENIED;
1233 }
1234
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001235 if (needCaptureVoiceCommunicationOutput &&
1236 !captureVoiceCommunicationOutputAllowed(callingPid, callingUid)) {
1237 return PERMISSION_DENIED;
1238 }
1239
Eric Laurentbaac1832014-12-01 17:52:59 -08001240 if (mAudioPolicyManager == NULL) {
1241 return NO_INIT;
1242 }
Eric Laurent10b71232018-04-13 18:14:44 -07001243 AutoCallerClear acc;
Eric Laurentbaac1832014-12-01 17:52:59 -08001244 if (registration) {
1245 return mAudioPolicyManager->registerPolicyMixes(mixes);
1246 } else {
1247 return mAudioPolicyManager->unregisterPolicyMixes(mixes);
1248 }
1249}
1250
Jean-Michel Trivibda70da2018-12-19 07:30:15 -08001251status_t AudioPolicyService::setUidDeviceAffinities(uid_t uid,
1252 const Vector<AudioDeviceTypeAddr>& devices) {
1253 Mutex::Autolock _l(mLock);
1254 if(!modifyAudioRoutingAllowed()) {
1255 return PERMISSION_DENIED;
1256 }
1257 if (mAudioPolicyManager == NULL) {
1258 return NO_INIT;
1259 }
1260 AutoCallerClear acc;
1261 return mAudioPolicyManager->setUidDeviceAffinities(uid, devices);
1262}
1263
1264status_t AudioPolicyService::removeUidDeviceAffinities(uid_t uid) {
1265 Mutex::Autolock _l(mLock);
1266 if(!modifyAudioRoutingAllowed()) {
1267 return PERMISSION_DENIED;
1268 }
1269 if (mAudioPolicyManager == NULL) {
1270 return NO_INIT;
1271 }
1272 AutoCallerClear acc;
1273 return mAudioPolicyManager->removeUidDeviceAffinities(uid);
1274}
1275
Oscar Azucena90e77632019-11-27 17:12:28 -08001276status_t AudioPolicyService::setUserIdDeviceAffinities(int userId,
1277 const Vector<AudioDeviceTypeAddr>& devices) {
1278 Mutex::Autolock _l(mLock);
1279 if(!modifyAudioRoutingAllowed()) {
1280 return PERMISSION_DENIED;
1281 }
1282 if (mAudioPolicyManager == NULL) {
1283 return NO_INIT;
1284 }
1285 AutoCallerClear acc;
1286 return mAudioPolicyManager->setUserIdDeviceAffinities(userId, devices);
1287}
1288
1289status_t AudioPolicyService::removeUserIdDeviceAffinities(int userId) {
1290 Mutex::Autolock _l(mLock);
1291 if(!modifyAudioRoutingAllowed()) {
1292 return PERMISSION_DENIED;
1293 }
1294 if (mAudioPolicyManager == NULL) {
1295 return NO_INIT;
1296 }
1297 AutoCallerClear acc;
1298 return mAudioPolicyManager->removeUserIdDeviceAffinities(userId);
1299}
1300
Eric Laurent554a2772015-04-10 11:29:24 -07001301status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001302 const audio_attributes_t *attributes,
1303 audio_port_handle_t *portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001304{
1305 Mutex::Autolock _l(mLock);
1306 if (mAudioPolicyManager == NULL) {
1307 return NO_INIT;
1308 }
Hayden Gomes524159d2019-12-23 14:41:47 -08001309
1310 status_t result = validateUsage(attributes->usage);
1311 if (result != NO_ERROR) {
1312 return result;
1313 }
1314
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001315 // startAudioSource should be created as the calling uid
1316 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Eric Laurent10b71232018-04-13 18:14:44 -07001317 AutoCallerClear acc;
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001318 return mAudioPolicyManager->startAudioSource(source, attributes, portId, callingUid);
Eric Laurent554a2772015-04-10 11:29:24 -07001319}
1320
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001321status_t AudioPolicyService::stopAudioSource(audio_port_handle_t portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001322{
1323 Mutex::Autolock _l(mLock);
1324 if (mAudioPolicyManager == NULL) {
1325 return NO_INIT;
1326 }
Eric Laurent10b71232018-04-13 18:14:44 -07001327 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001328 return mAudioPolicyManager->stopAudioSource(portId);
Eric Laurent554a2772015-04-10 11:29:24 -07001329}
1330
Andy Hung2ddee192015-12-18 17:34:44 -08001331status_t AudioPolicyService::setMasterMono(bool mono)
1332{
1333 if (mAudioPolicyManager == NULL) {
1334 return NO_INIT;
1335 }
1336 if (!settingsAllowed()) {
1337 return PERMISSION_DENIED;
1338 }
1339 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001340 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001341 return mAudioPolicyManager->setMasterMono(mono);
1342}
1343
1344status_t AudioPolicyService::getMasterMono(bool *mono)
1345{
1346 if (mAudioPolicyManager == NULL) {
1347 return NO_INIT;
1348 }
1349 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001350 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001351 return mAudioPolicyManager->getMasterMono(mono);
1352}
1353
Eric Laurentac9cef52017-06-09 15:46:26 -07001354
1355float AudioPolicyService::getStreamVolumeDB(
1356 audio_stream_type_t stream, int index, audio_devices_t device)
1357{
1358 if (mAudioPolicyManager == NULL) {
1359 return NAN;
1360 }
1361 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001362 AutoCallerClear acc;
Eric Laurentac9cef52017-06-09 15:46:26 -07001363 return mAudioPolicyManager->getStreamVolumeDB(stream, index, device);
1364}
1365
jiabin81772902018-04-02 17:52:27 -07001366status_t AudioPolicyService::getSurroundFormats(unsigned int *numSurroundFormats,
1367 audio_format_t *surroundFormats,
1368 bool *surroundFormatsEnabled,
1369 bool reported)
1370{
1371 if (mAudioPolicyManager == NULL) {
1372 return NO_INIT;
1373 }
1374 Mutex::Autolock _l(mLock);
1375 AutoCallerClear acc;
1376 return mAudioPolicyManager->getSurroundFormats(numSurroundFormats, surroundFormats,
1377 surroundFormatsEnabled, reported);
1378}
1379
Arun Mirpuri11029ad2018-12-19 20:45:19 -08001380status_t AudioPolicyService::getHwOffloadEncodingFormatsSupportedForA2DP(
1381 std::vector<audio_format_t> *formats)
1382{
1383 if (mAudioPolicyManager == NULL) {
1384 return NO_INIT;
1385 }
1386 Mutex::Autolock _l(mLock);
1387 AutoCallerClear acc;
1388 return mAudioPolicyManager->getHwOffloadEncodingFormatsSupportedForA2DP(formats);
1389}
1390
jiabin81772902018-04-02 17:52:27 -07001391status_t AudioPolicyService::setSurroundFormatEnabled(audio_format_t audioFormat, bool enabled)
1392{
1393 if (mAudioPolicyManager == NULL) {
1394 return NO_INIT;
1395 }
1396 Mutex::Autolock _l(mLock);
1397 AutoCallerClear acc;
1398 return mAudioPolicyManager->setSurroundFormatEnabled(audioFormat, enabled);
1399}
Eric Laurentac9cef52017-06-09 15:46:26 -07001400
Eric Laurentb78763e2018-10-17 10:08:02 -07001401status_t AudioPolicyService::setAssistantUid(uid_t uid)
1402{
1403 Mutex::Autolock _l(mLock);
1404 mUidPolicy->setAssistantUid(uid);
1405 return NO_ERROR;
1406}
1407
1408status_t AudioPolicyService::setA11yServicesUids(const std::vector<uid_t>& uids)
1409{
1410 Mutex::Autolock _l(mLock);
1411 mUidPolicy->setA11yUids(uids);
1412 return NO_ERROR;
1413}
1414
jiabin6012f912018-11-02 17:06:30 -07001415bool AudioPolicyService::isHapticPlaybackSupported()
1416{
1417 if (mAudioPolicyManager == NULL) {
1418 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1419 return false;
1420 }
1421 Mutex::Autolock _l(mLock);
1422 AutoCallerClear acc;
1423 return mAudioPolicyManager->isHapticPlaybackSupported();
1424}
1425
François Gaffied0ba9ed2018-11-05 11:50:42 +01001426status_t AudioPolicyService::listAudioProductStrategies(AudioProductStrategyVector &strategies)
1427{
1428 if (mAudioPolicyManager == NULL) {
1429 return NO_INIT;
1430 }
1431 Mutex::Autolock _l(mLock);
1432 return mAudioPolicyManager->listAudioProductStrategies(strategies);
1433}
1434
François Gaffie4b2018b2018-11-07 11:18:59 +01001435status_t AudioPolicyService::getProductStrategyFromAudioAttributes(
1436 const AudioAttributes &aa, product_strategy_t &productStrategy)
François Gaffied0ba9ed2018-11-05 11:50:42 +01001437{
1438 if (mAudioPolicyManager == NULL) {
François Gaffie4b2018b2018-11-07 11:18:59 +01001439 return NO_INIT;
François Gaffied0ba9ed2018-11-05 11:50:42 +01001440 }
1441 Mutex::Autolock _l(mLock);
François Gaffie4b2018b2018-11-07 11:18:59 +01001442 return mAudioPolicyManager->getProductStrategyFromAudioAttributes(aa, productStrategy);
1443}
1444
1445status_t AudioPolicyService::listAudioVolumeGroups(AudioVolumeGroupVector &groups)
1446{
1447 if (mAudioPolicyManager == NULL) {
1448 return NO_INIT;
1449 }
1450 Mutex::Autolock _l(mLock);
1451 return mAudioPolicyManager->listAudioVolumeGroups(groups);
1452}
1453
1454status_t AudioPolicyService::getVolumeGroupFromAudioAttributes(const AudioAttributes &aa,
1455 volume_group_t &volumeGroup)
1456{
1457 if (mAudioPolicyManager == NULL) {
1458 return NO_INIT;
1459 }
1460 Mutex::Autolock _l(mLock);
1461 return mAudioPolicyManager->getVolumeGroupFromAudioAttributes(aa, volumeGroup);
François Gaffied0ba9ed2018-11-05 11:50:42 +01001462}
Eric Laurent6ede98f2019-06-11 14:50:30 -07001463
1464status_t AudioPolicyService::setRttEnabled(bool enabled)
1465{
1466 Mutex::Autolock _l(mLock);
1467 mUidPolicy->setRttEnabled(enabled);
1468 return NO_ERROR;
1469}
1470
Eric Laurent8340e672019-11-06 11:01:08 -08001471bool AudioPolicyService::isCallScreenModeSupported()
1472{
1473 if (mAudioPolicyManager == NULL) {
1474 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1475 return false;
1476 }
1477 Mutex::Autolock _l(mLock);
1478 AutoCallerClear acc;
1479 return mAudioPolicyManager->isCallScreenModeSupported();
1480}
1481
Jean-Michel Trivi30857152019-11-01 11:04:15 -07001482status_t AudioPolicyService::setPreferredDeviceForStrategy(product_strategy_t strategy,
1483 const AudioDeviceTypeAddr &device)
1484{
1485 if (mAudioPolicyManager == NULL) {
1486 return NO_INIT;
1487 }
1488 Mutex::Autolock _l(mLock);
1489 return mAudioPolicyManager->setPreferredDeviceForStrategy(strategy, device);
1490}
1491
1492status_t AudioPolicyService::removePreferredDeviceForStrategy(product_strategy_t strategy)
1493{
1494 if (mAudioPolicyManager == NULL) {
1495 return NO_INIT;
1496 }
1497 Mutex::Autolock _l(mLock);
1498 return mAudioPolicyManager->removePreferredDeviceForStrategy(strategy);
1499}
1500
1501status_t AudioPolicyService::getPreferredDeviceForStrategy(product_strategy_t strategy,
1502 AudioDeviceTypeAddr &device)
1503{
1504 if (mAudioPolicyManager == NULL) {
1505 return NO_INIT;
1506 }
1507 Mutex::Autolock _l(mLock);
1508 return mAudioPolicyManager->getPreferredDeviceForStrategy(strategy, device);
1509}
1510
Mikhail Naganov1b2a7942017-12-08 10:18:09 -08001511} // namespace android