blob: 38801ec5b2b833f06eb15157259aba635b16121b [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,
Ricardo Correaac26cf72020-01-06 14:43:38 -0800214 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800215 const audio_config_t *config,
Eric Laurente83b55d2014-11-14 10:06:21 -0800216 audio_output_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700217 audio_port_handle_t *selectedDeviceId,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800218 audio_port_handle_t *portId,
219 std::vector<audio_io_handle_t> *secondaryOutputs)
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700220{
221 if (mAudioPolicyManager == NULL) {
Eric Laurente83b55d2014-11-14 10:06:21 -0800222 return NO_INIT;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700223 }
Hayden Gomes524159d2019-12-23 14:41:47 -0800224
225 status_t result = validateUsage(attr->usage, pid, uid);
226 if (result != NO_ERROR) {
227 return result;
228 }
229
Eric Laurent8a1095a2019-11-08 14:44:16 -0800230 ALOGV("%s()", __func__);
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700231 Mutex::Autolock _l(mLock);
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700232
Marco Nelissendcb346b2015-09-09 10:47:29 -0700233 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700234 if (!isAudioServerOrMediaServerUid(callingUid) || uid == (uid_t)-1) {
Marco Nelissendcb346b2015-09-09 10:47:29 -0700235 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Eric Laurent8a1095a2019-11-08 14:44:16 -0800236 "%s uid %d tried to pass itself off as %d", __func__, callingUid, uid);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700237 uid = callingUid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700238 }
Kevin Rocard8be94972019-02-22 13:26:25 -0800239 if (!mPackageManager.allowPlaybackCapture(uid)) {
Eric Laurent42984412019-05-09 17:57:03 -0700240 attr->flags |= AUDIO_FLAG_NO_MEDIA_PROJECTION;
241 }
Eric Laurent6ede98f2019-06-11 14:50:30 -0700242 if (((attr->flags & (AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE)) != 0)
243 && !bypassInterruptionPolicyAllowed(pid, uid)) {
Eric Laurent42984412019-05-09 17:57:03 -0700244 attr->flags &= ~(AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE);
Kevin Rocard8be94972019-02-22 13:26:25 -0800245 }
Eric Laurent10b71232018-04-13 18:14:44 -0700246 AutoCallerClear acc;
Eric Laurent8a1095a2019-11-08 14:44:16 -0800247 AudioPolicyInterface::output_type_t outputType;
Hayden Gomes3e8bbb92020-01-10 13:37:05 -0800248 result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800249 config,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800250 &flags, selectedDeviceId, portId,
Eric Laurent8a1095a2019-11-08 14:44:16 -0800251 secondaryOutputs,
252 &outputType);
Nadav Bar766fb022018-01-07 12:18:03 +0200253
254 // FIXME: Introduce a way to check for the the telephony device before opening the output
Eric Laurent8a1095a2019-11-08 14:44:16 -0800255 if (result == NO_ERROR) {
256 // enforce permission (if any) required for each type of input
257 switch (outputType) {
258 case AudioPolicyInterface::API_OUTPUT_LEGACY:
259 break;
260 case AudioPolicyInterface::API_OUTPUT_TELEPHONY_TX:
Ricardo Correaac26cf72020-01-06 14:43:38 -0800261 if (!modifyPhoneStateAllowed(pid, uid) &&
262 !accessCallAudioAllowed(opPackageName, pid, uid)) {
Eric Laurent8a1095a2019-11-08 14:44:16 -0800263 ALOGE("%s() permission denied: modify phone state not allowed for uid %d",
264 __func__, uid);
265 result = PERMISSION_DENIED;
266 }
267 break;
268 case AudioPolicyInterface::API_OUT_MIX_PLAYBACK:
269 if (!modifyAudioRoutingAllowed(pid, uid)) {
270 ALOGE("%s() permission denied: modify audio routing not allowed for uid %d",
271 __func__, uid);
272 result = PERMISSION_DENIED;
273 }
274 break;
275 case AudioPolicyInterface::API_OUTPUT_INVALID:
276 default:
277 LOG_ALWAYS_FATAL("%s() encountered an invalid output type %d",
278 __func__, (int)outputType);
279 }
Nadav Bar766fb022018-01-07 12:18:03 +0200280 }
Eric Laurentd7fe0862018-07-14 16:48:01 -0700281
282 if (result == NO_ERROR) {
283 sp <AudioPlaybackClient> client =
Eric Laurent5ada82e2019-08-29 17:53:54 -0700284 new AudioPlaybackClient(*attr, *output, uid, pid, session, *portId, *selectedDeviceId, *stream);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700285 mAudioPlaybackClients.add(*portId, client);
286 }
Nadav Bar766fb022018-01-07 12:18:03 +0200287 return result;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700288}
289
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700290void AudioPolicyService::getPlaybackClientAndEffects(audio_port_handle_t portId,
291 sp<AudioPlaybackClient>& client,
292 sp<AudioPolicyEffects>& effects,
293 const char *context)
294{
295 Mutex::Autolock _l(mLock);
296 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
297 if (index < 0) {
298 ALOGE("%s AudioTrack client not found for portId %d", context, portId);
299 return;
300 }
301 client = mAudioPlaybackClients.valueAt(index);
302 effects = mAudioPolicyEffects;
303}
304
Eric Laurentd7fe0862018-07-14 16:48:01 -0700305status_t AudioPolicyService::startOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800306{
Eric Laurentdce54a12014-03-10 12:19:46 -0700307 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800308 return NO_INIT;
309 }
310 ALOGV("startOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700311 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700312 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700313
314 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
315
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700316 if (audioPolicyEffects != 0) {
317 // create audio processors according to stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700318 status_t status = audioPolicyEffects->addOutputSessionEffects(
319 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700320 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700321 ALOGW("Failed to add effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700322 }
323 }
324 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700325 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700326 status_t status = mAudioPolicyManager->startOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700327 if (status == NO_ERROR) {
328 client->active = true;
329 }
330 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800331}
332
Eric Laurentd7fe0862018-07-14 16:48:01 -0700333status_t AudioPolicyService::stopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800334{
Eric Laurentdce54a12014-03-10 12:19:46 -0700335 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800336 return NO_INIT;
337 }
338 ALOGV("stopOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700339 mOutputCommandThread->stopOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800340 return NO_ERROR;
341}
342
Eric Laurentd7fe0862018-07-14 16:48:01 -0700343status_t AudioPolicyService::doStopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800344{
Eric Laurentd7fe0862018-07-14 16:48:01 -0700345 ALOGV("doStopOutput");
346 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700347 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentd7fe0862018-07-14 16:48:01 -0700348
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700349 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
350
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700351 if (audioPolicyEffects != 0) {
352 // release audio processors from the stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700353 status_t status = audioPolicyEffects->releaseOutputSessionEffects(
354 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700355 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700356 ALOGW("Failed to release effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700357 }
358 }
359 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700360 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700361 status_t status = mAudioPolicyManager->stopOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700362 if (status == NO_ERROR) {
363 client->active = false;
364 }
365 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800366}
367
Eric Laurentd7fe0862018-07-14 16:48:01 -0700368void AudioPolicyService::releaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800369{
Eric Laurentdce54a12014-03-10 12:19:46 -0700370 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800371 return;
372 }
373 ALOGV("releaseOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700374 mOutputCommandThread->releaseOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800375}
376
Eric Laurentd7fe0862018-07-14 16:48:01 -0700377void AudioPolicyService::doReleaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800378{
379 ALOGV("doReleaseOutput from tid %d", gettid());
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700380 sp<AudioPlaybackClient> client;
381 sp<AudioPolicyEffects> audioPolicyEffects;
382
383 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
384
385 if (audioPolicyEffects != 0 && client->active) {
386 // clean up effects if output was not stopped before being released
387 audioPolicyEffects->releaseOutputSessionEffects(
388 client->io, client->stream, client->session);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700389 }
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700390 Mutex::Autolock _l(mLock);
Eric Laurentd4007242019-03-27 12:42:16 -0700391 mAudioPlaybackClients.removeItem(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700392
Eric Laurent10b71232018-04-13 18:14:44 -0700393 // called from internal thread: no need to clear caller identity
Eric Laurent8fc147b2018-07-22 19:13:55 -0700394 mAudioPolicyManager->releaseOutput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800395}
396
Eric Laurentcaf7f482014-11-25 17:50:47 -0800397status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
398 audio_io_handle_t *input,
Mikhail Naganov2996f672019-04-18 12:29:59 -0700399 audio_unique_id_t riid,
Eric Laurentcaf7f482014-11-25 17:50:47 -0800400 audio_session_t session,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700401 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700402 uid_t uid,
Eric Laurentfee19762018-01-29 18:44:13 -0800403 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800404 const audio_config_base_t *config,
Paul McLean466dc8e2015-04-17 13:15:36 -0600405 audio_input_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700406 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800407 audio_port_handle_t *portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800408{
Eric Laurentdce54a12014-03-10 12:19:46 -0700409 if (mAudioPolicyManager == NULL) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800410 return NO_INIT;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800411 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800412
Hayden Gomes524159d2019-12-23 14:41:47 -0800413 status_t result = validateUsage(attr->usage, pid, uid);
414 if (result != NO_ERROR) {
415 return result;
416 }
417
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900418 audio_source_t inputSource = attr->source;
419 if (inputSource == AUDIO_SOURCE_DEFAULT) {
420 inputSource = AUDIO_SOURCE_MIC;
421 }
422
Eric Laurent2d388ec2014-03-07 13:25:54 -0800423 // already checked by client, but double-check in case the client wrapper is bypassed
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900424 if ((inputSource < AUDIO_SOURCE_DEFAULT)
425 || (inputSource >= AUDIO_SOURCE_CNT
426 && inputSource != AUDIO_SOURCE_HOTWORD
427 && inputSource != AUDIO_SOURCE_FM_TUNER
428 && inputSource != AUDIO_SOURCE_ECHO_REFERENCE)) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800429 return BAD_VALUE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800430 }
431
Eric Laurentb2379ba2016-05-23 17:42:12 -0700432 bool updatePid = (pid == -1);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700433 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700434 if (!isAudioServerOrMediaServerUid(callingUid)) {
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700435 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Marco Nelissendcb346b2015-09-09 10:47:29 -0700436 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
437 uid = callingUid;
Eric Laurentb2379ba2016-05-23 17:42:12 -0700438 updatePid = true;
439 }
440
441 if (updatePid) {
442 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700443 ALOGW_IF(pid != (pid_t)-1 && pid != callingPid,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700444 "%s uid %d pid %d tried to pass itself off as pid %d",
445 __func__, callingUid, callingPid, pid);
446 pid = callingPid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700447 }
448
Eric Laurent58a0dd82019-10-24 12:42:17 -0700449 // check calling permissions.
450 // Capturing from FM_TUNER source is controlled by captureAudioOutputAllowed() only as this
451 // does not affect users privacy as does capturing from an actual microphone.
452 if (!(recordingAllowed(opPackageName, pid, uid) || attr->source == AUDIO_SOURCE_FM_TUNER)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800453 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
454 __func__, uid, pid);
455 return PERMISSION_DENIED;
456 }
457
Eric Laurent1ff16a72019-03-14 18:35:04 -0700458 bool canCaptureOutput = captureAudioOutputAllowed(pid, uid);
Ricardo Correaac26cf72020-01-06 14:43:38 -0800459 bool canCaptureTelephonyOutput = canCaptureOutput
460 || accessCallAudioAllowed(opPackageName, pid, uid);
461
462 if ((attr->source == AUDIO_SOURCE_ECHO_REFERENCE ||
463 attr->source == AUDIO_SOURCE_FM_TUNER) &&
Eric Laurent1ff16a72019-03-14 18:35:04 -0700464 !canCaptureOutput) {
Nadav Bar744be482018-05-08 13:26:21 +0300465 return PERMISSION_DENIED;
466 }
467
Ricardo Correaac26cf72020-01-06 14:43:38 -0800468 if ((attr->source == AUDIO_SOURCE_VOICE_UPLINK ||
469 attr->source == AUDIO_SOURCE_VOICE_DOWNLINK ||
470 attr->source == AUDIO_SOURCE_VOICE_CALL) &&
471 !canCaptureTelephonyOutput) {
472 return PERMISSION_DENIED;
473 }
474
jiabin68e0df72019-03-18 17:55:35 -0700475 bool canCaptureHotword = captureHotwordAllowed(opPackageName, pid, uid);
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900476 if ((inputSource == AUDIO_SOURCE_HOTWORD) && !canCaptureHotword) {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700477 return BAD_VALUE;
478 }
479
480 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700481 {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700482 status_t status;
483 AudioPolicyInterface::input_type_t inputType;
484
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700485 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700486 {
487 AutoCallerClear acc;
488 // the audio_in_acoustics_t parameter is ignored by get_input()
Mikhail Naganov2996f672019-04-18 12:29:59 -0700489 status = mAudioPolicyManager->getInputForAttr(attr, input, riid, session, uid,
Eric Laurent10b71232018-04-13 18:14:44 -0700490 config,
491 flags, selectedDeviceId,
492 &inputType, portId);
493 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700494 audioPolicyEffects = mAudioPolicyEffects;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800495
496 if (status == NO_ERROR) {
497 // enforce permission (if any) required for each type of input
498 switch (inputType) {
Kevin Rocard25f9b052019-02-27 15:08:54 -0800499 case AudioPolicyInterface::API_INPUT_MIX_PUBLIC_CAPTURE_PLAYBACK:
500 // this use case has been validated in audio service with a MediaProjection token,
501 // and doesn't rely on regular permissions
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800502 case AudioPolicyInterface::API_INPUT_LEGACY:
503 break;
Eric Laurent82db2692015-08-07 13:59:42 -0700504 case AudioPolicyInterface::API_INPUT_TELEPHONY_RX:
505 // FIXME: use the same permission as for remote submix for now.
Ricardo Correaac26cf72020-01-06 14:43:38 -0800506 if (!canCaptureTelephonyOutput) {
507 ALOGE("getInputForAttr() permission denied: call capture not allowed");
508 status = PERMISSION_DENIED;
509 }
510 break;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800511 case AudioPolicyInterface::API_INPUT_MIX_CAPTURE:
Eric Laurent1ff16a72019-03-14 18:35:04 -0700512 if (!canCaptureOutput) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800513 ALOGE("getInputForAttr() permission denied: capture not allowed");
514 status = PERMISSION_DENIED;
515 }
516 break;
517 case AudioPolicyInterface::API_INPUT_MIX_EXT_POLICY_REROUTE:
Eric Laurent8a1095a2019-11-08 14:44:16 -0800518 if (!modifyAudioRoutingAllowed(pid, uid)) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800519 ALOGE("getInputForAttr() permission denied: modify audio routing not allowed");
520 status = PERMISSION_DENIED;
521 }
522 break;
523 case AudioPolicyInterface::API_INPUT_INVALID:
524 default:
525 LOG_ALWAYS_FATAL("getInputForAttr() encountered an invalid input type %d",
526 (int)inputType);
527 }
528 }
529
530 if (status != NO_ERROR) {
531 if (status == PERMISSION_DENIED) {
Eric Laurent10b71232018-04-13 18:14:44 -0700532 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700533 mAudioPolicyManager->releaseInput(*portId);
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800534 }
535 return status;
536 }
Eric Laurentfee19762018-01-29 18:44:13 -0800537
Ricardo Correaac26cf72020-01-06 14:43:38 -0800538 bool allowAudioCapture = canCaptureOutput ||
539 (inputType == AudioPolicyInterface::API_INPUT_TELEPHONY_RX &&
540 canCaptureTelephonyOutput);
541
Eric Laurent5ada82e2019-08-29 17:53:54 -0700542 sp<AudioRecordClient> client = new AudioRecordClient(*attr, *input, uid, pid, session, *portId,
Eric Laurent1ff16a72019-03-14 18:35:04 -0700543 *selectedDeviceId, opPackageName,
Ricardo Correaac26cf72020-01-06 14:43:38 -0800544 allowAudioCapture, canCaptureHotword);
Eric Laurentfee19762018-01-29 18:44:13 -0800545 mAudioRecordClients.add(*portId, client);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700546 }
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800547
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700548 if (audioPolicyEffects != 0) {
549 // create audio pre processors according to input source
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900550 status_t status = audioPolicyEffects->addInputEffects(*input, inputSource, session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700551 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800552 ALOGW("Failed to add effects on input %d", *input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700553 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800554 }
Eric Laurentcaf7f482014-11-25 17:50:47 -0800555 return NO_ERROR;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800556}
557
Eric Laurent99fcae42018-05-17 16:59:18 -0700558std::string AudioPolicyService::getDeviceTypeStrForPortId(audio_port_handle_t portId) {
Eric Laurent99fcae42018-05-17 16:59:18 -0700559 struct audio_port port = {};
560 port.id = portId;
561 status_t status = mAudioPolicyManager->getAudioPort(&port);
562 if (status == NO_ERROR && port.type == AUDIO_PORT_TYPE_DEVICE) {
Andy Hung9b181952019-02-25 14:53:36 -0800563 return toString(port.ext.device.type);
Eric Laurent99fcae42018-05-17 16:59:18 -0700564 }
Andy Hung9b181952019-02-25 14:53:36 -0800565 return {};
Eric Laurent99fcae42018-05-17 16:59:18 -0700566}
567
Eric Laurent4eb58f12018-12-07 16:41:02 -0800568status_t AudioPolicyService::startInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800569{
Eric Laurentdce54a12014-03-10 12:19:46 -0700570 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800571 return NO_INIT;
572 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800573 sp<AudioRecordClient> client;
574 {
575 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800576
Eric Laurent7dca8a82018-01-29 18:44:26 -0800577 ssize_t index = mAudioRecordClients.indexOfKey(portId);
578 if (index < 0) {
579 return INVALID_OPERATION;
580 }
581 client = mAudioRecordClients.valueAt(index);
Eric Laurentfee19762018-01-29 18:44:13 -0800582 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800583
584 // check calling permissions
Eric Laurent58a0dd82019-10-24 12:42:17 -0700585 if (!(startRecording(client->opPackageName, client->pid, client->uid)
586 || client->attributes.source == AUDIO_SOURCE_FM_TUNER)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800587 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
588 __func__, client->uid, client->pid);
589 return PERMISSION_DENIED;
590 }
Eric Laurentfee19762018-01-29 18:44:13 -0800591
Eric Laurentdf628922018-12-06 21:45:51 +0000592 Mutex::Autolock _l(mLock);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800593
594 client->active = true;
595 client->startTimeNs = systemTime();
596 updateUidStates_l();
Eric Laurentfee19762018-01-29 18:44:13 -0800597
Eric Laurent10b71232018-04-13 18:14:44 -0700598 status_t status;
599 {
600 AutoCallerClear acc;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800601 status = mAudioPolicyManager->startInput(portId);
Ray Essick84e84a52018-05-03 18:45:07 -0700602
603 }
604
Ray Essickf6a57cd2018-05-22 16:20:54 -0700605 // including successes gets very verbose
Ray Essick6ce27e52019-02-15 10:58:05 -0800606 // but once we cut over to westworld, log them all.
Ray Essickf6a57cd2018-05-22 16:20:54 -0700607 if (status != NO_ERROR) {
Ray Essick84e84a52018-05-03 18:45:07 -0700608
609 static constexpr char kAudioPolicy[] = "audiopolicy";
610
Ray Essick84e84a52018-05-03 18:45:07 -0700611 static constexpr char kAudioPolicyStatus[] = "android.media.audiopolicy.status";
612 static constexpr char kAudioPolicyRqstSrc[] = "android.media.audiopolicy.rqst.src";
613 static constexpr char kAudioPolicyRqstPkg[] = "android.media.audiopolicy.rqst.pkg";
614 static constexpr char kAudioPolicyRqstSession[] = "android.media.audiopolicy.rqst.session";
Eric Laurent99fcae42018-05-17 16:59:18 -0700615 static constexpr char kAudioPolicyRqstDevice[] =
616 "android.media.audiopolicy.rqst.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700617 static constexpr char kAudioPolicyActiveSrc[] = "android.media.audiopolicy.active.src";
618 static constexpr char kAudioPolicyActivePkg[] = "android.media.audiopolicy.active.pkg";
Eric Laurent99fcae42018-05-17 16:59:18 -0700619 static constexpr char kAudioPolicyActiveSession[] =
620 "android.media.audiopolicy.active.session";
621 static constexpr char kAudioPolicyActiveDevice[] =
622 "android.media.audiopolicy.active.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700623
Ray Essickf27e9872019-12-07 06:28:46 -0800624 mediametrics::Item *item = mediametrics::Item::create(kAudioPolicy);
Ray Essick84e84a52018-05-03 18:45:07 -0700625 if (item != NULL) {
626
Ray Essick84e84a52018-05-03 18:45:07 -0700627 item->setInt32(kAudioPolicyStatus, status);
628
Eric Laurent99fcae42018-05-17 16:59:18 -0700629 item->setCString(kAudioPolicyRqstSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800630 toString(client->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700631 item->setInt32(kAudioPolicyRqstSession, client->session);
Ray Essick51866952018-05-30 11:22:27 -0700632 if (client->opPackageName.size() != 0) {
633 item->setCString(kAudioPolicyRqstPkg,
634 std::string(String8(client->opPackageName).string()).c_str());
635 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700636 item->setCString(kAudioPolicyRqstPkg, std::to_string(client->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700637 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700638 item->setCString(
639 kAudioPolicyRqstDevice, getDeviceTypeStrForPortId(client->deviceId).c_str());
640
Eric Laurent4eb58f12018-12-07 16:41:02 -0800641 int count = mAudioRecordClients.size();
642 for (int i = 0; i < count ; i++) {
643 if (portId == mAudioRecordClients.keyAt(i)) {
644 continue;
645 }
646 sp<AudioRecordClient> other = mAudioRecordClients.valueAt(i);
647 if (other->active) {
648 // keeps the last of the clients marked active
649 item->setCString(kAudioPolicyActiveSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800650 toString(other->attributes.source).c_str());
Eric Laurent4eb58f12018-12-07 16:41:02 -0800651 item->setInt32(kAudioPolicyActiveSession, other->session);
652 if (other->opPackageName.size() != 0) {
653 item->setCString(kAudioPolicyActivePkg,
654 std::string(String8(other->opPackageName).string()).c_str());
655 } else {
656 item->setCString(kAudioPolicyRqstPkg,
657 std::to_string(other->uid).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700658 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800659 item->setCString(kAudioPolicyActiveDevice,
660 getDeviceTypeStrForPortId(other->deviceId).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700661 }
662 }
663 item->selfrecord();
664 delete item;
665 item = NULL;
666 }
Ray Essick6ce27e52019-02-15 10:58:05 -0800667 }
668
669 if (status != NO_ERROR) {
Eric Laurent4eb58f12018-12-07 16:41:02 -0800670 client->active = false;
671 client->startTimeNs = 0;
672 updateUidStates_l();
Svet Ganov6e641372018-03-02 09:21:30 -0800673 finishRecording(client->opPackageName, client->uid);
Eric Laurentfb66dd92016-01-28 18:32:03 -0800674 }
675
676 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800677}
678
Eric Laurentfee19762018-01-29 18:44:13 -0800679status_t AudioPolicyService::stopInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800680{
Eric Laurentdce54a12014-03-10 12:19:46 -0700681 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800682 return NO_INIT;
683 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800684
Eric Laurent2d388ec2014-03-07 13:25:54 -0800685 Mutex::Autolock _l(mLock);
686
Eric Laurentfee19762018-01-29 18:44:13 -0800687 ssize_t index = mAudioRecordClients.indexOfKey(portId);
688 if (index < 0) {
689 return INVALID_OPERATION;
690 }
691 sp<AudioRecordClient> client = mAudioRecordClients.valueAt(index);
692
Ray Essick84e84a52018-05-03 18:45:07 -0700693 client->active = false;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800694 client->startTimeNs = 0;
695
696 updateUidStates_l();
Ray Essick84e84a52018-05-03 18:45:07 -0700697
Svet Ganov6e641372018-03-02 09:21:30 -0800698 // finish the recording app op
699 finishRecording(client->opPackageName, client->uid);
Eric Laurent10b71232018-04-13 18:14:44 -0700700 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700701 return mAudioPolicyManager->stopInput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800702}
703
Eric Laurentfee19762018-01-29 18:44:13 -0800704void AudioPolicyService::releaseInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800705{
Eric Laurentdce54a12014-03-10 12:19:46 -0700706 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800707 return;
708 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700709 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800710 sp<AudioRecordClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700711 {
712 Mutex::Autolock _l(mLock);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700713 audioPolicyEffects = mAudioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800714 ssize_t index = mAudioRecordClients.indexOfKey(portId);
715 if (index < 0) {
716 return;
717 }
718 client = mAudioRecordClients.valueAt(index);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800719
720 if (client->active) {
721 ALOGW("%s releasing active client portId %d", __FUNCTION__, portId);
722 client->active = false;
723 client->startTimeNs = 0;
724 updateUidStates_l();
725 }
726
Eric Laurentfee19762018-01-29 18:44:13 -0800727 mAudioRecordClients.removeItem(portId);
728 }
729 if (client == 0) {
730 return;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700731 }
732 if (audioPolicyEffects != 0) {
733 // release audio processors from the input
Eric Laurentd7fe0862018-07-14 16:48:01 -0700734 status_t status = audioPolicyEffects->releaseInputEffects(client->io, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700735 if(status != NO_ERROR) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700736 ALOGW("Failed to release effects on input %d", client->io);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700737 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800738 }
Eric Laurentf10c7092016-12-06 17:09:56 -0800739 {
740 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700741 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700742 mAudioPolicyManager->releaseInput(portId);
Eric Laurentf10c7092016-12-06 17:09:56 -0800743 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800744}
745
746status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
747 int indexMin,
748 int indexMax)
749{
Eric Laurentdce54a12014-03-10 12:19:46 -0700750 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800751 return NO_INIT;
752 }
753 if (!settingsAllowed()) {
754 return PERMISSION_DENIED;
755 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800756 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800757 return BAD_VALUE;
758 }
759 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700760 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700761 mAudioPolicyManager->initStreamVolume(stream, indexMin, indexMax);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800762 return NO_ERROR;
763}
764
765status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
766 int index,
767 audio_devices_t device)
768{
Eric Laurentdce54a12014-03-10 12:19:46 -0700769 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800770 return NO_INIT;
771 }
772 if (!settingsAllowed()) {
773 return PERMISSION_DENIED;
774 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800775 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800776 return BAD_VALUE;
777 }
778 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700779 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700780 return mAudioPolicyManager->setStreamVolumeIndex(stream,
781 index,
782 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800783}
784
785status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
786 int *index,
787 audio_devices_t device)
788{
Eric Laurentdce54a12014-03-10 12:19:46 -0700789 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800790 return NO_INIT;
791 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800792 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800793 return BAD_VALUE;
794 }
795 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700796 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700797 return mAudioPolicyManager->getStreamVolumeIndex(stream,
798 index,
799 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800800}
801
François Gaffiecfe17322018-11-07 13:41:29 +0100802status_t AudioPolicyService::setVolumeIndexForAttributes(const audio_attributes_t &attributes,
803 int index, audio_devices_t device)
804{
805 if (mAudioPolicyManager == NULL) {
806 return NO_INIT;
807 }
808 if (!settingsAllowed()) {
809 return PERMISSION_DENIED;
810 }
811 Mutex::Autolock _l(mLock);
812 AutoCallerClear acc;
813 return mAudioPolicyManager->setVolumeIndexForAttributes(attributes, index, device);
814}
815
816status_t AudioPolicyService::getVolumeIndexForAttributes(const audio_attributes_t &attributes,
817 int &index, audio_devices_t device)
818{
819 if (mAudioPolicyManager == NULL) {
820 return NO_INIT;
821 }
822 Mutex::Autolock _l(mLock);
823 AutoCallerClear acc;
824 return mAudioPolicyManager->getVolumeIndexForAttributes(attributes, index, device);
825}
826
827status_t AudioPolicyService::getMinVolumeIndexForAttributes(const audio_attributes_t &attributes,
828 int &index)
829{
830 if (mAudioPolicyManager == NULL) {
831 return NO_INIT;
832 }
833 Mutex::Autolock _l(mLock);
834 AutoCallerClear acc;
835 return mAudioPolicyManager->getMinVolumeIndexForAttributes(attributes, index);
836}
837
838status_t AudioPolicyService::getMaxVolumeIndexForAttributes(const audio_attributes_t &attributes,
839 int &index)
840{
841 if (mAudioPolicyManager == NULL) {
842 return NO_INIT;
843 }
844 Mutex::Autolock _l(mLock);
845 AutoCallerClear acc;
846 return mAudioPolicyManager->getMaxVolumeIndexForAttributes(attributes, index);
847}
848
Eric Laurent2d388ec2014-03-07 13:25:54 -0800849uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
850{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800851 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
François Gaffiec005e562018-11-06 15:04:49 +0100852 return PRODUCT_STRATEGY_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700853 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700854 if (mAudioPolicyManager == NULL) {
François Gaffiec005e562018-11-06 15:04:49 +0100855 return PRODUCT_STRATEGY_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800856 }
François Gaffiec005e562018-11-06 15:04:49 +0100857 // DO NOT LOCK, may be called from AudioFlinger with lock held, reaching deadlock
Eric Laurent10b71232018-04-13 18:14:44 -0700858 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700859 return mAudioPolicyManager->getStrategyForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800860}
861
862//audio policy: use audio_device_t appropriately
863
864audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
865{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800866 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700867 return AUDIO_DEVICE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700868 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700869 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700870 return AUDIO_DEVICE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800871 }
Haynes Mathew Georgedfb9f3b2015-10-26 18:22:13 -0700872 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700873 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700874 return mAudioPolicyManager->getDevicesForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800875}
876
Jean-Michel Trivif41599b2020-01-07 14:22:08 -0800877status_t AudioPolicyService::getDevicesForAttributes(const AudioAttributes &aa,
Hayden Gomes524159d2019-12-23 14:41:47 -0800878 AudioDeviceTypeAddrVector *devices) const
Jean-Michel Trivif41599b2020-01-07 14:22:08 -0800879{
880 if (mAudioPolicyManager == NULL) {
881 return NO_INIT;
882 }
883 Mutex::Autolock _l(mLock);
884 AutoCallerClear acc;
885 return mAudioPolicyManager->getDevicesForAttributes(aa.getAttributes(), devices);
886}
887
Eric Laurent2d388ec2014-03-07 13:25:54 -0800888audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
889{
890 // FIXME change return type to status_t, and return NO_INIT here
Eric Laurentdce54a12014-03-10 12:19:46 -0700891 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800892 return 0;
893 }
894 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700895 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700896 return mAudioPolicyManager->getOutputForEffect(desc);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800897}
898
899status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
900 audio_io_handle_t io,
901 uint32_t strategy,
Glenn Kastend848eb42016-03-08 13:42:11 -0800902 audio_session_t session,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800903 int id)
904{
Eric Laurentdce54a12014-03-10 12:19:46 -0700905 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800906 return NO_INIT;
907 }
Eric Laurent6c796322019-04-09 14:13:17 -0700908 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700909 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700910 return mAudioPolicyManager->registerEffect(desc, io, strategy, session, id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800911}
912
913status_t AudioPolicyService::unregisterEffect(int id)
914{
Eric Laurentdce54a12014-03-10 12:19:46 -0700915 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800916 return NO_INIT;
917 }
Eric Laurent6c796322019-04-09 14:13:17 -0700918 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700919 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700920 return mAudioPolicyManager->unregisterEffect(id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800921}
922
923status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
924{
Eric Laurentdce54a12014-03-10 12:19:46 -0700925 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800926 return NO_INIT;
927 }
Eric Laurent6c796322019-04-09 14:13:17 -0700928 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700929 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700930 return mAudioPolicyManager->setEffectEnabled(id, enabled);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800931}
932
Eric Laurent6c796322019-04-09 14:13:17 -0700933status_t AudioPolicyService::moveEffectsToIo(const std::vector<int>& ids, audio_io_handle_t io)
934{
935 if (mAudioPolicyManager == NULL) {
936 return NO_INIT;
937 }
938 Mutex::Autolock _l(mLock);
939 AutoCallerClear acc;
940 return mAudioPolicyManager->moveEffectsToIo(ids, io);
941}
942
Eric Laurent2d388ec2014-03-07 13:25:54 -0800943bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
944{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800945 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700946 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700947 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700948 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700949 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800950 }
951 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700952 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700953 return mAudioPolicyManager->isStreamActive(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800954}
955
956bool AudioPolicyService::isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs) const
957{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800958 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700959 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700960 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700961 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700962 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800963 }
964 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700965 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700966 return mAudioPolicyManager->isStreamActiveRemotely(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800967}
968
969bool AudioPolicyService::isSourceActive(audio_source_t source) const
970{
Eric Laurentdce54a12014-03-10 12:19:46 -0700971 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800972 return false;
973 }
974 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700975 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700976 return mAudioPolicyManager->isSourceActive(source);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800977}
978
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700979status_t AudioPolicyService::getAudioPolicyEffects(sp<AudioPolicyEffects>& audioPolicyEffects)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800980{
Eric Laurentdce54a12014-03-10 12:19:46 -0700981 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800982 return NO_INIT;
983 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700984 {
985 Mutex::Autolock _l(mLock);
986 audioPolicyEffects = mAudioPolicyEffects;
987 }
988 if (audioPolicyEffects == 0) {
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700989 return NO_INIT;
990 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700991
992 return OK;
993}
994
995status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
996 effect_descriptor_t *descriptors,
997 uint32_t *count)
998{
999 sp<AudioPolicyEffects>audioPolicyEffects;
1000 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1001 if (status != OK) {
1002 *count = 0;
1003 return status;
1004 }
Eric Laurentfb66dd92016-01-28 18:32:03 -08001005 return audioPolicyEffects->queryDefaultInputEffects(
1006 (audio_session_t)audioSession, descriptors, count);
Eric Laurent2d388ec2014-03-07 13:25:54 -08001007}
1008
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001009status_t AudioPolicyService::addSourceDefaultEffect(const effect_uuid_t *type,
1010 const String16& opPackageName,
1011 const effect_uuid_t *uuid,
1012 int32_t priority,
1013 audio_source_t source,
1014 audio_unique_id_t* id)
1015{
1016 sp<AudioPolicyEffects>audioPolicyEffects;
1017 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1018 if (status != OK) {
1019 return status;
1020 }
1021 if (!modifyDefaultAudioEffectsAllowed()) {
1022 return PERMISSION_DENIED;
1023 }
1024 return audioPolicyEffects->addSourceDefaultEffect(
1025 type, opPackageName, uuid, priority, source, id);
1026}
1027
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001028status_t AudioPolicyService::addStreamDefaultEffect(const effect_uuid_t *type,
1029 const String16& opPackageName,
1030 const effect_uuid_t *uuid,
1031 int32_t priority,
1032 audio_usage_t usage,
1033 audio_unique_id_t* id)
1034{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001035 sp<AudioPolicyEffects>audioPolicyEffects;
1036 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1037 if (status != OK) {
1038 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001039 }
1040 if (!modifyDefaultAudioEffectsAllowed()) {
1041 return PERMISSION_DENIED;
1042 }
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001043 return audioPolicyEffects->addStreamDefaultEffect(
1044 type, opPackageName, uuid, priority, usage, id);
1045}
1046
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001047status_t AudioPolicyService::removeSourceDefaultEffect(audio_unique_id_t id)
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001048{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001049 sp<AudioPolicyEffects>audioPolicyEffects;
1050 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1051 if (status != OK) {
1052 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001053 }
1054 if (!modifyDefaultAudioEffectsAllowed()) {
1055 return PERMISSION_DENIED;
1056 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001057 return audioPolicyEffects->removeSourceDefaultEffect(id);
1058}
1059
1060status_t AudioPolicyService::removeStreamDefaultEffect(audio_unique_id_t id)
1061{
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001062 sp<AudioPolicyEffects>audioPolicyEffects;
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001063 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1064 if (status != OK) {
1065 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001066 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001067 if (!modifyDefaultAudioEffectsAllowed()) {
1068 return PERMISSION_DENIED;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001069 }
1070 return audioPolicyEffects->removeStreamDefaultEffect(id);
1071}
1072
Hayden Gomes524159d2019-12-23 14:41:47 -08001073status_t AudioPolicyService::setSupportedSystemUsages(const std::vector<audio_usage_t>& systemUsages) {
1074 Mutex::Autolock _l(mLock);
1075 if(!modifyAudioRoutingAllowed()) {
1076 return PERMISSION_DENIED;
1077 }
1078
1079 bool areAllSystemUsages = std::all_of(begin(systemUsages), end(systemUsages),
1080 [](audio_usage_t usage) { return isSystemUsage(usage); });
1081 if (!areAllSystemUsages) {
1082 return BAD_VALUE;
1083 }
1084
1085 mSupportedSystemUsages = systemUsages;
1086 return NO_ERROR;
1087}
1088
Kevin Rocardb99cc752019-03-21 20:52:24 -07001089status_t AudioPolicyService::setAllowedCapturePolicy(uid_t uid, audio_flags_mask_t capturePolicy) {
1090 Mutex::Autolock _l(mLock);
1091 if (mAudioPolicyManager == NULL) {
1092 ALOGV("%s() mAudioPolicyManager == NULL", __func__);
1093 return NO_INIT;
1094 }
Kevin Rocardb99cc752019-03-21 20:52:24 -07001095 return mAudioPolicyManager->setAllowedCapturePolicy(uid, capturePolicy);
1096}
1097
Eric Laurent2d388ec2014-03-07 13:25:54 -08001098bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
1099{
Eric Laurentdce54a12014-03-10 12:19:46 -07001100 if (mAudioPolicyManager == NULL) {
1101 ALOGV("mAudioPolicyManager == NULL");
Eric Laurent2d388ec2014-03-07 13:25:54 -08001102 return false;
1103 }
Andy Hung2ddee192015-12-18 17:34:44 -08001104 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001105 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -07001106 return mAudioPolicyManager->isOffloadSupported(info);
Eric Laurent2d388ec2014-03-07 13:25:54 -08001107}
1108
Michael Chana94fbb22018-04-24 14:31:19 +10001109bool AudioPolicyService::isDirectOutputSupported(const audio_config_base_t& config,
1110 const audio_attributes_t& attributes) {
1111 if (mAudioPolicyManager == NULL) {
1112 ALOGV("mAudioPolicyManager == NULL");
1113 return false;
1114 }
Hayden Gomes524159d2019-12-23 14:41:47 -08001115
1116 status_t result = validateUsage(attributes.usage);
1117 if (result != NO_ERROR) {
1118 return result;
1119 }
1120
Michael Chana94fbb22018-04-24 14:31:19 +10001121 Mutex::Autolock _l(mLock);
1122 return mAudioPolicyManager->isDirectOutputSupported(config, attributes);
1123}
1124
1125
Eric Laurent6a94d692014-05-20 11:18:06 -07001126status_t AudioPolicyService::listAudioPorts(audio_port_role_t role,
1127 audio_port_type_t type,
Eric Laurent203b1a12014-04-01 10:34:16 -07001128 unsigned int *num_ports,
Eric Laurent6a94d692014-05-20 11:18:06 -07001129 struct audio_port *ports,
1130 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001131{
Eric Laurent6a94d692014-05-20 11:18:06 -07001132 Mutex::Autolock _l(mLock);
1133 if (mAudioPolicyManager == NULL) {
1134 return NO_INIT;
1135 }
Eric Laurent10b71232018-04-13 18:14:44 -07001136 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001137 return mAudioPolicyManager->listAudioPorts(role, type, num_ports, ports, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001138}
1139
Eric Laurent6a94d692014-05-20 11:18:06 -07001140status_t AudioPolicyService::getAudioPort(struct audio_port *port)
Eric Laurent203b1a12014-04-01 10:34:16 -07001141{
Eric Laurent6a94d692014-05-20 11:18:06 -07001142 Mutex::Autolock _l(mLock);
1143 if (mAudioPolicyManager == NULL) {
1144 return NO_INIT;
1145 }
Eric Laurent10b71232018-04-13 18:14:44 -07001146 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001147 return mAudioPolicyManager->getAudioPort(port);
Eric Laurent203b1a12014-04-01 10:34:16 -07001148}
1149
Eric Laurent6a94d692014-05-20 11:18:06 -07001150status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch,
1151 audio_patch_handle_t *handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001152{
Eric Laurent6a94d692014-05-20 11:18:06 -07001153 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001154 if(!modifyAudioRoutingAllowed()) {
1155 return PERMISSION_DENIED;
1156 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001157 if (mAudioPolicyManager == NULL) {
1158 return NO_INIT;
1159 }
Eric Laurent10b71232018-04-13 18:14:44 -07001160 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001161 return mAudioPolicyManager->createAudioPatch(patch, handle,
1162 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001163}
1164
Eric Laurent6a94d692014-05-20 11:18:06 -07001165status_t AudioPolicyService::releaseAudioPatch(audio_patch_handle_t handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001166{
Eric Laurent6a94d692014-05-20 11:18:06 -07001167 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001168 if(!modifyAudioRoutingAllowed()) {
1169 return PERMISSION_DENIED;
1170 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001171 if (mAudioPolicyManager == NULL) {
1172 return NO_INIT;
1173 }
Eric Laurent10b71232018-04-13 18:14:44 -07001174 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001175 return mAudioPolicyManager->releaseAudioPatch(handle,
1176 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001177}
1178
1179status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
Eric Laurent6a94d692014-05-20 11:18:06 -07001180 struct audio_patch *patches,
1181 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001182{
Eric Laurent6a94d692014-05-20 11:18:06 -07001183 Mutex::Autolock _l(mLock);
1184 if (mAudioPolicyManager == NULL) {
1185 return NO_INIT;
1186 }
Eric Laurent10b71232018-04-13 18:14:44 -07001187 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001188 return mAudioPolicyManager->listAudioPatches(num_patches, patches, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001189}
1190
Eric Laurent6a94d692014-05-20 11:18:06 -07001191status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config)
Eric Laurent203b1a12014-04-01 10:34:16 -07001192{
Eric Laurent6a94d692014-05-20 11:18:06 -07001193 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001194 if(!modifyAudioRoutingAllowed()) {
1195 return PERMISSION_DENIED;
1196 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001197 if (mAudioPolicyManager == NULL) {
1198 return NO_INIT;
1199 }
Eric Laurent10b71232018-04-13 18:14:44 -07001200 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001201 return mAudioPolicyManager->setAudioPortConfig(config);
Eric Laurent203b1a12014-04-01 10:34:16 -07001202}
Eric Laurent2d388ec2014-03-07 13:25:54 -08001203
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001204status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session,
1205 audio_io_handle_t *ioHandle,
1206 audio_devices_t *device)
1207{
Andy Hungf759b8c2017-08-15 12:48:54 -07001208 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001209 if (mAudioPolicyManager == NULL) {
1210 return NO_INIT;
1211 }
Eric Laurent10b71232018-04-13 18:14:44 -07001212 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001213 return mAudioPolicyManager->acquireSoundTriggerSession(session, ioHandle, device);
1214}
1215
1216status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session)
1217{
Andy Hungf759b8c2017-08-15 12:48:54 -07001218 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001219 if (mAudioPolicyManager == NULL) {
1220 return NO_INIT;
1221 }
Eric Laurent10b71232018-04-13 18:14:44 -07001222 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001223 return mAudioPolicyManager->releaseSoundTriggerSession(session);
1224}
1225
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -07001226status_t AudioPolicyService::registerPolicyMixes(const Vector<AudioMix>& mixes, bool registration)
Eric Laurentbaac1832014-12-01 17:52:59 -08001227{
1228 Mutex::Autolock _l(mLock);
Kevin Rocardbe201852019-02-20 22:33:28 -08001229
1230 // loopback|render only need a MediaProjection (checked in caller AudioService.java)
1231 bool needModifyAudioRouting = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
1232 return !is_mix_loopback_render(mix.mRouteFlags); });
1233 if (needModifyAudioRouting && !modifyAudioRoutingAllowed()) {
Eric Laurentbaac1832014-12-01 17:52:59 -08001234 return PERMISSION_DENIED;
1235 }
Kevin Rocardbe201852019-02-20 22:33:28 -08001236
Nadav Bar287d3302020-02-05 14:55:38 +02001237 // If one of the mixes has needCaptureVoiceCommunicationOutput set to true, then we
1238 // need to verify that the caller still has CAPTURE_VOICE_COMMUNICATION_OUTPUT
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001239 bool needCaptureVoiceCommunicationOutput =
1240 std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
Nadav Bar287d3302020-02-05 14:55:38 +02001241 return mix.mVoiceCommunicationCaptureAllowed; });
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001242
Kevin Rocard36b17552019-03-07 18:48:07 -08001243 bool needCaptureMediaOutput = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
Nadav Bar287d3302020-02-05 14:55:38 +02001244 return mix.mAllowPrivilegedPlaybackCapture; });
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001245
Kevin Rocard36b17552019-03-07 18:48:07 -08001246 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
1247 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001248
Kevin Rocard36b17552019-03-07 18:48:07 -08001249 if (needCaptureMediaOutput && !captureMediaOutputAllowed(callingPid, callingUid)) {
1250 return PERMISSION_DENIED;
1251 }
1252
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001253 if (needCaptureVoiceCommunicationOutput &&
1254 !captureVoiceCommunicationOutputAllowed(callingPid, callingUid)) {
1255 return PERMISSION_DENIED;
1256 }
1257
Eric Laurentbaac1832014-12-01 17:52:59 -08001258 if (mAudioPolicyManager == NULL) {
1259 return NO_INIT;
1260 }
Eric Laurent10b71232018-04-13 18:14:44 -07001261 AutoCallerClear acc;
Eric Laurentbaac1832014-12-01 17:52:59 -08001262 if (registration) {
1263 return mAudioPolicyManager->registerPolicyMixes(mixes);
1264 } else {
1265 return mAudioPolicyManager->unregisterPolicyMixes(mixes);
1266 }
1267}
1268
Jean-Michel Trivibda70da2018-12-19 07:30:15 -08001269status_t AudioPolicyService::setUidDeviceAffinities(uid_t uid,
1270 const Vector<AudioDeviceTypeAddr>& devices) {
1271 Mutex::Autolock _l(mLock);
1272 if(!modifyAudioRoutingAllowed()) {
1273 return PERMISSION_DENIED;
1274 }
1275 if (mAudioPolicyManager == NULL) {
1276 return NO_INIT;
1277 }
1278 AutoCallerClear acc;
1279 return mAudioPolicyManager->setUidDeviceAffinities(uid, devices);
1280}
1281
1282status_t AudioPolicyService::removeUidDeviceAffinities(uid_t uid) {
1283 Mutex::Autolock _l(mLock);
1284 if(!modifyAudioRoutingAllowed()) {
1285 return PERMISSION_DENIED;
1286 }
1287 if (mAudioPolicyManager == NULL) {
1288 return NO_INIT;
1289 }
1290 AutoCallerClear acc;
1291 return mAudioPolicyManager->removeUidDeviceAffinities(uid);
1292}
1293
Oscar Azucena90e77632019-11-27 17:12:28 -08001294status_t AudioPolicyService::setUserIdDeviceAffinities(int userId,
1295 const Vector<AudioDeviceTypeAddr>& devices) {
1296 Mutex::Autolock _l(mLock);
1297 if(!modifyAudioRoutingAllowed()) {
1298 return PERMISSION_DENIED;
1299 }
1300 if (mAudioPolicyManager == NULL) {
1301 return NO_INIT;
1302 }
1303 AutoCallerClear acc;
1304 return mAudioPolicyManager->setUserIdDeviceAffinities(userId, devices);
1305}
1306
1307status_t AudioPolicyService::removeUserIdDeviceAffinities(int userId) {
1308 Mutex::Autolock _l(mLock);
1309 if(!modifyAudioRoutingAllowed()) {
1310 return PERMISSION_DENIED;
1311 }
1312 if (mAudioPolicyManager == NULL) {
1313 return NO_INIT;
1314 }
1315 AutoCallerClear acc;
1316 return mAudioPolicyManager->removeUserIdDeviceAffinities(userId);
1317}
1318
Eric Laurent554a2772015-04-10 11:29:24 -07001319status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001320 const audio_attributes_t *attributes,
1321 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 }
Hayden Gomes524159d2019-12-23 14:41:47 -08001327
1328 status_t result = validateUsage(attributes->usage);
1329 if (result != NO_ERROR) {
1330 return result;
1331 }
1332
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001333 // startAudioSource should be created as the calling uid
1334 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Eric Laurent10b71232018-04-13 18:14:44 -07001335 AutoCallerClear acc;
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001336 return mAudioPolicyManager->startAudioSource(source, attributes, portId, callingUid);
Eric Laurent554a2772015-04-10 11:29:24 -07001337}
1338
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001339status_t AudioPolicyService::stopAudioSource(audio_port_handle_t portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001340{
1341 Mutex::Autolock _l(mLock);
1342 if (mAudioPolicyManager == NULL) {
1343 return NO_INIT;
1344 }
Eric Laurent10b71232018-04-13 18:14:44 -07001345 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001346 return mAudioPolicyManager->stopAudioSource(portId);
Eric Laurent554a2772015-04-10 11:29:24 -07001347}
1348
Andy Hung2ddee192015-12-18 17:34:44 -08001349status_t AudioPolicyService::setMasterMono(bool mono)
1350{
1351 if (mAudioPolicyManager == NULL) {
1352 return NO_INIT;
1353 }
1354 if (!settingsAllowed()) {
1355 return PERMISSION_DENIED;
1356 }
1357 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001358 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001359 return mAudioPolicyManager->setMasterMono(mono);
1360}
1361
1362status_t AudioPolicyService::getMasterMono(bool *mono)
1363{
1364 if (mAudioPolicyManager == NULL) {
1365 return NO_INIT;
1366 }
1367 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001368 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001369 return mAudioPolicyManager->getMasterMono(mono);
1370}
1371
Eric Laurentac9cef52017-06-09 15:46:26 -07001372
1373float AudioPolicyService::getStreamVolumeDB(
1374 audio_stream_type_t stream, int index, audio_devices_t device)
1375{
1376 if (mAudioPolicyManager == NULL) {
1377 return NAN;
1378 }
1379 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001380 AutoCallerClear acc;
Eric Laurentac9cef52017-06-09 15:46:26 -07001381 return mAudioPolicyManager->getStreamVolumeDB(stream, index, device);
1382}
1383
jiabin81772902018-04-02 17:52:27 -07001384status_t AudioPolicyService::getSurroundFormats(unsigned int *numSurroundFormats,
1385 audio_format_t *surroundFormats,
1386 bool *surroundFormatsEnabled,
1387 bool reported)
1388{
1389 if (mAudioPolicyManager == NULL) {
1390 return NO_INIT;
1391 }
1392 Mutex::Autolock _l(mLock);
1393 AutoCallerClear acc;
1394 return mAudioPolicyManager->getSurroundFormats(numSurroundFormats, surroundFormats,
1395 surroundFormatsEnabled, reported);
1396}
1397
Arun Mirpuri11029ad2018-12-19 20:45:19 -08001398status_t AudioPolicyService::getHwOffloadEncodingFormatsSupportedForA2DP(
1399 std::vector<audio_format_t> *formats)
1400{
1401 if (mAudioPolicyManager == NULL) {
1402 return NO_INIT;
1403 }
1404 Mutex::Autolock _l(mLock);
1405 AutoCallerClear acc;
1406 return mAudioPolicyManager->getHwOffloadEncodingFormatsSupportedForA2DP(formats);
1407}
1408
jiabin81772902018-04-02 17:52:27 -07001409status_t AudioPolicyService::setSurroundFormatEnabled(audio_format_t audioFormat, bool enabled)
1410{
1411 if (mAudioPolicyManager == NULL) {
1412 return NO_INIT;
1413 }
1414 Mutex::Autolock _l(mLock);
1415 AutoCallerClear acc;
1416 return mAudioPolicyManager->setSurroundFormatEnabled(audioFormat, enabled);
1417}
Eric Laurentac9cef52017-06-09 15:46:26 -07001418
Eric Laurentb78763e2018-10-17 10:08:02 -07001419status_t AudioPolicyService::setAssistantUid(uid_t uid)
1420{
1421 Mutex::Autolock _l(mLock);
1422 mUidPolicy->setAssistantUid(uid);
1423 return NO_ERROR;
1424}
1425
1426status_t AudioPolicyService::setA11yServicesUids(const std::vector<uid_t>& uids)
1427{
1428 Mutex::Autolock _l(mLock);
1429 mUidPolicy->setA11yUids(uids);
1430 return NO_ERROR;
1431}
1432
jiabin6012f912018-11-02 17:06:30 -07001433bool AudioPolicyService::isHapticPlaybackSupported()
1434{
1435 if (mAudioPolicyManager == NULL) {
1436 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1437 return false;
1438 }
1439 Mutex::Autolock _l(mLock);
1440 AutoCallerClear acc;
1441 return mAudioPolicyManager->isHapticPlaybackSupported();
1442}
1443
François Gaffied0ba9ed2018-11-05 11:50:42 +01001444status_t AudioPolicyService::listAudioProductStrategies(AudioProductStrategyVector &strategies)
1445{
1446 if (mAudioPolicyManager == NULL) {
1447 return NO_INIT;
1448 }
1449 Mutex::Autolock _l(mLock);
1450 return mAudioPolicyManager->listAudioProductStrategies(strategies);
1451}
1452
François Gaffie4b2018b2018-11-07 11:18:59 +01001453status_t AudioPolicyService::getProductStrategyFromAudioAttributes(
1454 const AudioAttributes &aa, product_strategy_t &productStrategy)
François Gaffied0ba9ed2018-11-05 11:50:42 +01001455{
1456 if (mAudioPolicyManager == NULL) {
François Gaffie4b2018b2018-11-07 11:18:59 +01001457 return NO_INIT;
François Gaffied0ba9ed2018-11-05 11:50:42 +01001458 }
1459 Mutex::Autolock _l(mLock);
François Gaffie4b2018b2018-11-07 11:18:59 +01001460 return mAudioPolicyManager->getProductStrategyFromAudioAttributes(aa, productStrategy);
1461}
1462
1463status_t AudioPolicyService::listAudioVolumeGroups(AudioVolumeGroupVector &groups)
1464{
1465 if (mAudioPolicyManager == NULL) {
1466 return NO_INIT;
1467 }
1468 Mutex::Autolock _l(mLock);
1469 return mAudioPolicyManager->listAudioVolumeGroups(groups);
1470}
1471
1472status_t AudioPolicyService::getVolumeGroupFromAudioAttributes(const AudioAttributes &aa,
1473 volume_group_t &volumeGroup)
1474{
1475 if (mAudioPolicyManager == NULL) {
1476 return NO_INIT;
1477 }
1478 Mutex::Autolock _l(mLock);
1479 return mAudioPolicyManager->getVolumeGroupFromAudioAttributes(aa, volumeGroup);
François Gaffied0ba9ed2018-11-05 11:50:42 +01001480}
Eric Laurent6ede98f2019-06-11 14:50:30 -07001481
1482status_t AudioPolicyService::setRttEnabled(bool enabled)
1483{
1484 Mutex::Autolock _l(mLock);
1485 mUidPolicy->setRttEnabled(enabled);
1486 return NO_ERROR;
1487}
1488
Eric Laurent8340e672019-11-06 11:01:08 -08001489bool AudioPolicyService::isCallScreenModeSupported()
1490{
1491 if (mAudioPolicyManager == NULL) {
1492 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1493 return false;
1494 }
1495 Mutex::Autolock _l(mLock);
1496 AutoCallerClear acc;
1497 return mAudioPolicyManager->isCallScreenModeSupported();
1498}
1499
Jean-Michel Trivi30857152019-11-01 11:04:15 -07001500status_t AudioPolicyService::setPreferredDeviceForStrategy(product_strategy_t strategy,
1501 const AudioDeviceTypeAddr &device)
1502{
1503 if (mAudioPolicyManager == NULL) {
1504 return NO_INIT;
1505 }
1506 Mutex::Autolock _l(mLock);
1507 return mAudioPolicyManager->setPreferredDeviceForStrategy(strategy, device);
1508}
1509
1510status_t AudioPolicyService::removePreferredDeviceForStrategy(product_strategy_t strategy)
1511{
1512 if (mAudioPolicyManager == NULL) {
1513 return NO_INIT;
1514 }
1515 Mutex::Autolock _l(mLock);
1516 return mAudioPolicyManager->removePreferredDeviceForStrategy(strategy);
1517}
1518
1519status_t AudioPolicyService::getPreferredDeviceForStrategy(product_strategy_t strategy,
1520 AudioDeviceTypeAddr &device)
1521{
1522 if (mAudioPolicyManager == NULL) {
1523 return NO_INIT;
1524 }
1525 Mutex::Autolock _l(mLock);
1526 return mAudioPolicyManager->getPreferredDeviceForStrategy(strategy, device);
1527}
1528
Mikhail Naganov1b2a7942017-12-08 10:18:09 -08001529} // namespace android