blob: 0da3b9cb01955f44769de8231d5387b47b466db8 [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
Mikhail Naganov88b30d22020-03-09 19:43:13 +000069void AudioPolicyService::doOnNewAudioModulesAvailable()
70{
71 if (mAudioPolicyManager == NULL) return;
72 Mutex::Autolock _l(mLock);
73 AutoCallerClear acc;
74 mAudioPolicyManager->onNewAudioModulesAvailable();
75}
76
Eric Laurent2d388ec2014-03-07 13:25:54 -080077status_t AudioPolicyService::setDeviceConnectionState(audio_devices_t device,
78 audio_policy_dev_state_t state,
Paul McLeane743a472015-01-28 11:07:31 -080079 const char *device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080080 const char *device_name,
81 audio_format_t encodedFormat)
Eric Laurent2d388ec2014-03-07 13:25:54 -080082{
Eric Laurentdce54a12014-03-10 12:19:46 -070083 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080084 return NO_INIT;
85 }
86 if (!settingsAllowed()) {
87 return PERMISSION_DENIED;
88 }
Eric Laurent2d388ec2014-03-07 13:25:54 -080089 if (state != AUDIO_POLICY_DEVICE_STATE_AVAILABLE &&
90 state != AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE) {
91 return BAD_VALUE;
92 }
93
94 ALOGV("setDeviceConnectionState()");
95 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -070096 AutoCallerClear acc;
Paul McLeane743a472015-01-28 11:07:31 -080097 return mAudioPolicyManager->setDeviceConnectionState(device, state,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080098 device_address, device_name, encodedFormat);
Eric Laurent2d388ec2014-03-07 13:25:54 -080099}
100
101audio_policy_dev_state_t AudioPolicyService::getDeviceConnectionState(
102 audio_devices_t device,
103 const char *device_address)
104{
Eric Laurentdce54a12014-03-10 12:19:46 -0700105 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800106 return AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE;
107 }
Eric Laurent10b71232018-04-13 18:14:44 -0700108 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700109 return mAudioPolicyManager->getDeviceConnectionState(device,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800110 device_address);
111}
112
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800113status_t AudioPolicyService::handleDeviceConfigChange(audio_devices_t device,
114 const char *device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -0800115 const char *device_name,
116 audio_format_t encodedFormat)
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800117{
118 if (mAudioPolicyManager == NULL) {
119 return NO_INIT;
120 }
121 if (!settingsAllowed()) {
122 return PERMISSION_DENIED;
123 }
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800124
125 ALOGV("handleDeviceConfigChange()");
126 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700127 AutoCallerClear acc;
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800128 return mAudioPolicyManager->handleDeviceConfigChange(device, device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -0800129 device_name, encodedFormat);
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800130}
131
Eric Laurent00dba062020-02-11 15:52:09 -0800132status_t AudioPolicyService::setPhoneState(audio_mode_t state, uid_t uid)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800133{
Eric Laurentdce54a12014-03-10 12:19:46 -0700134 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800135 return NO_INIT;
136 }
137 if (!settingsAllowed()) {
138 return PERMISSION_DENIED;
139 }
140 if (uint32_t(state) >= AUDIO_MODE_CNT) {
141 return BAD_VALUE;
142 }
143
144 ALOGV("setPhoneState()");
145
Eric Laurentbeb07fe2015-09-16 15:49:30 -0700146 // acquire lock before calling setMode() so that setMode() + setPhoneState() are an atomic
147 // operation from policy manager standpoint (no other operation (e.g track start or stop)
148 // can be interleaved).
149 Mutex::Autolock _l(mLock);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800150 // TODO: check if it is more appropriate to do it in platform specific policy manager
151 AudioSystem::setMode(state);
152
Eric Laurent10b71232018-04-13 18:14:44 -0700153 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700154 mAudioPolicyManager->setPhoneState(state);
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700155 mPhoneState = state;
Eric Laurent00dba062020-02-11 15:52:09 -0800156 mPhoneStateOwnerUid = uid;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800157 return NO_ERROR;
158}
159
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700160audio_mode_t AudioPolicyService::getPhoneState()
161{
162 Mutex::Autolock _l(mLock);
163 return mPhoneState;
164}
165
Eric Laurent2d388ec2014-03-07 13:25:54 -0800166status_t AudioPolicyService::setForceUse(audio_policy_force_use_t usage,
167 audio_policy_forced_cfg_t config)
168{
Eric Laurentdce54a12014-03-10 12:19:46 -0700169 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800170 return NO_INIT;
171 }
Eric Laurente17378d2018-05-09 14:43:01 -0700172
173 if (!modifyAudioRoutingAllowed()) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800174 return PERMISSION_DENIED;
175 }
Eric Laurente17378d2018-05-09 14:43:01 -0700176
Eric Laurent2d388ec2014-03-07 13:25:54 -0800177 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
178 return BAD_VALUE;
179 }
180 if (config < 0 || config >= AUDIO_POLICY_FORCE_CFG_CNT) {
181 return BAD_VALUE;
182 }
183 ALOGV("setForceUse()");
184 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700185 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700186 mAudioPolicyManager->setForceUse(usage, config);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800187 return NO_ERROR;
188}
189
190audio_policy_forced_cfg_t AudioPolicyService::getForceUse(audio_policy_force_use_t usage)
191{
Eric Laurentdce54a12014-03-10 12:19:46 -0700192 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800193 return AUDIO_POLICY_FORCE_NONE;
194 }
195 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
196 return AUDIO_POLICY_FORCE_NONE;
197 }
Eric Laurent10b71232018-04-13 18:14:44 -0700198 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700199 return mAudioPolicyManager->getForceUse(usage);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800200}
201
Eric Laurentf4e63452017-11-06 19:31:46 +0000202audio_io_handle_t AudioPolicyService::getOutput(audio_stream_type_t stream)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800203{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800204 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700205 return AUDIO_IO_HANDLE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700206 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700207 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700208 return AUDIO_IO_HANDLE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800209 }
210 ALOGV("getOutput()");
211 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700212 AutoCallerClear acc;
Eric Laurentf4e63452017-11-06 19:31:46 +0000213 return mAudioPolicyManager->getOutput(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800214}
215
Eric Laurent42984412019-05-09 17:57:03 -0700216status_t AudioPolicyService::getOutputForAttr(audio_attributes_t *attr,
Eric Laurente83b55d2014-11-14 10:06:21 -0800217 audio_io_handle_t *output,
218 audio_session_t session,
219 audio_stream_type_t *stream,
Nadav Bar766fb022018-01-07 12:18:03 +0200220 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700221 uid_t uid,
Ricardo Correaac26cf72020-01-06 14:43:38 -0800222 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800223 const audio_config_t *config,
Eric Laurente83b55d2014-11-14 10:06:21 -0800224 audio_output_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700225 audio_port_handle_t *selectedDeviceId,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800226 audio_port_handle_t *portId,
227 std::vector<audio_io_handle_t> *secondaryOutputs)
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700228{
229 if (mAudioPolicyManager == NULL) {
Eric Laurente83b55d2014-11-14 10:06:21 -0800230 return NO_INIT;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700231 }
Hayden Gomes524159d2019-12-23 14:41:47 -0800232
233 status_t result = validateUsage(attr->usage, pid, uid);
234 if (result != NO_ERROR) {
235 return result;
236 }
237
Eric Laurent8a1095a2019-11-08 14:44:16 -0800238 ALOGV("%s()", __func__);
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700239 Mutex::Autolock _l(mLock);
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700240
Marco Nelissendcb346b2015-09-09 10:47:29 -0700241 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700242 if (!isAudioServerOrMediaServerUid(callingUid) || uid == (uid_t)-1) {
Marco Nelissendcb346b2015-09-09 10:47:29 -0700243 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Eric Laurent8a1095a2019-11-08 14:44:16 -0800244 "%s uid %d tried to pass itself off as %d", __func__, callingUid, uid);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700245 uid = callingUid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700246 }
Kevin Rocard8be94972019-02-22 13:26:25 -0800247 if (!mPackageManager.allowPlaybackCapture(uid)) {
Eric Laurent42984412019-05-09 17:57:03 -0700248 attr->flags |= AUDIO_FLAG_NO_MEDIA_PROJECTION;
249 }
Eric Laurent6ede98f2019-06-11 14:50:30 -0700250 if (((attr->flags & (AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE)) != 0)
251 && !bypassInterruptionPolicyAllowed(pid, uid)) {
Eric Laurent42984412019-05-09 17:57:03 -0700252 attr->flags &= ~(AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE);
Kevin Rocard8be94972019-02-22 13:26:25 -0800253 }
Eric Laurent10b71232018-04-13 18:14:44 -0700254 AutoCallerClear acc;
Eric Laurent8a1095a2019-11-08 14:44:16 -0800255 AudioPolicyInterface::output_type_t outputType;
Hayden Gomes3e8bbb92020-01-10 13:37:05 -0800256 result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800257 config,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800258 &flags, selectedDeviceId, portId,
Eric Laurent8a1095a2019-11-08 14:44:16 -0800259 secondaryOutputs,
260 &outputType);
Nadav Bar766fb022018-01-07 12:18:03 +0200261
262 // FIXME: Introduce a way to check for the the telephony device before opening the output
Eric Laurent8a1095a2019-11-08 14:44:16 -0800263 if (result == NO_ERROR) {
264 // enforce permission (if any) required for each type of input
265 switch (outputType) {
266 case AudioPolicyInterface::API_OUTPUT_LEGACY:
267 break;
268 case AudioPolicyInterface::API_OUTPUT_TELEPHONY_TX:
Ricardo Correaac26cf72020-01-06 14:43:38 -0800269 if (!modifyPhoneStateAllowed(pid, uid) &&
270 !accessCallAudioAllowed(opPackageName, pid, uid)) {
Eric Laurent8a1095a2019-11-08 14:44:16 -0800271 ALOGE("%s() permission denied: modify phone state not allowed for uid %d",
272 __func__, uid);
273 result = PERMISSION_DENIED;
274 }
275 break;
276 case AudioPolicyInterface::API_OUT_MIX_PLAYBACK:
277 if (!modifyAudioRoutingAllowed(pid, uid)) {
278 ALOGE("%s() permission denied: modify audio routing not allowed for uid %d",
279 __func__, uid);
280 result = PERMISSION_DENIED;
281 }
282 break;
283 case AudioPolicyInterface::API_OUTPUT_INVALID:
284 default:
285 LOG_ALWAYS_FATAL("%s() encountered an invalid output type %d",
286 __func__, (int)outputType);
287 }
Nadav Bar766fb022018-01-07 12:18:03 +0200288 }
Eric Laurentd7fe0862018-07-14 16:48:01 -0700289
290 if (result == NO_ERROR) {
291 sp <AudioPlaybackClient> client =
Eric Laurent5ada82e2019-08-29 17:53:54 -0700292 new AudioPlaybackClient(*attr, *output, uid, pid, session, *portId, *selectedDeviceId, *stream);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700293 mAudioPlaybackClients.add(*portId, client);
294 }
Nadav Bar766fb022018-01-07 12:18:03 +0200295 return result;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700296}
297
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700298void AudioPolicyService::getPlaybackClientAndEffects(audio_port_handle_t portId,
299 sp<AudioPlaybackClient>& client,
300 sp<AudioPolicyEffects>& effects,
301 const char *context)
302{
303 Mutex::Autolock _l(mLock);
304 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
305 if (index < 0) {
306 ALOGE("%s AudioTrack client not found for portId %d", context, portId);
307 return;
308 }
309 client = mAudioPlaybackClients.valueAt(index);
310 effects = mAudioPolicyEffects;
311}
312
Eric Laurentd7fe0862018-07-14 16:48:01 -0700313status_t AudioPolicyService::startOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800314{
Eric Laurentdce54a12014-03-10 12:19:46 -0700315 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800316 return NO_INIT;
317 }
318 ALOGV("startOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700319 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700320 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700321
322 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
323
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700324 if (audioPolicyEffects != 0) {
325 // create audio processors according to stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700326 status_t status = audioPolicyEffects->addOutputSessionEffects(
327 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700328 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700329 ALOGW("Failed to add effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700330 }
331 }
332 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700333 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700334 status_t status = mAudioPolicyManager->startOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700335 if (status == NO_ERROR) {
336 client->active = true;
337 }
338 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800339}
340
Eric Laurentd7fe0862018-07-14 16:48:01 -0700341status_t AudioPolicyService::stopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800342{
Eric Laurentdce54a12014-03-10 12:19:46 -0700343 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800344 return NO_INIT;
345 }
346 ALOGV("stopOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700347 mOutputCommandThread->stopOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800348 return NO_ERROR;
349}
350
Eric Laurentd7fe0862018-07-14 16:48:01 -0700351status_t AudioPolicyService::doStopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800352{
Eric Laurentd7fe0862018-07-14 16:48:01 -0700353 ALOGV("doStopOutput");
354 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700355 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentd7fe0862018-07-14 16:48:01 -0700356
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700357 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
358
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700359 if (audioPolicyEffects != 0) {
360 // release audio processors from the stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700361 status_t status = audioPolicyEffects->releaseOutputSessionEffects(
362 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700363 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700364 ALOGW("Failed to release effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700365 }
366 }
367 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700368 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700369 status_t status = mAudioPolicyManager->stopOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700370 if (status == NO_ERROR) {
371 client->active = false;
372 }
373 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800374}
375
Eric Laurentd7fe0862018-07-14 16:48:01 -0700376void AudioPolicyService::releaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800377{
Eric Laurentdce54a12014-03-10 12:19:46 -0700378 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800379 return;
380 }
381 ALOGV("releaseOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700382 mOutputCommandThread->releaseOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800383}
384
Eric Laurentd7fe0862018-07-14 16:48:01 -0700385void AudioPolicyService::doReleaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800386{
387 ALOGV("doReleaseOutput from tid %d", gettid());
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700388 sp<AudioPlaybackClient> client;
389 sp<AudioPolicyEffects> audioPolicyEffects;
390
391 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
392
393 if (audioPolicyEffects != 0 && client->active) {
394 // clean up effects if output was not stopped before being released
395 audioPolicyEffects->releaseOutputSessionEffects(
396 client->io, client->stream, client->session);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700397 }
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700398 Mutex::Autolock _l(mLock);
Eric Laurentd4007242019-03-27 12:42:16 -0700399 mAudioPlaybackClients.removeItem(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700400
Eric Laurent10b71232018-04-13 18:14:44 -0700401 // called from internal thread: no need to clear caller identity
Eric Laurent8fc147b2018-07-22 19:13:55 -0700402 mAudioPolicyManager->releaseOutput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800403}
404
Eric Laurentcaf7f482014-11-25 17:50:47 -0800405status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
406 audio_io_handle_t *input,
Mikhail Naganov2996f672019-04-18 12:29:59 -0700407 audio_unique_id_t riid,
Eric Laurentcaf7f482014-11-25 17:50:47 -0800408 audio_session_t session,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700409 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700410 uid_t uid,
Eric Laurentfee19762018-01-29 18:44:13 -0800411 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800412 const audio_config_base_t *config,
Paul McLean466dc8e2015-04-17 13:15:36 -0600413 audio_input_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700414 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800415 audio_port_handle_t *portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800416{
Eric Laurentdce54a12014-03-10 12:19:46 -0700417 if (mAudioPolicyManager == NULL) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800418 return NO_INIT;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800419 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800420
Hayden Gomes524159d2019-12-23 14:41:47 -0800421 status_t result = validateUsage(attr->usage, pid, uid);
422 if (result != NO_ERROR) {
423 return result;
424 }
425
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900426 audio_source_t inputSource = attr->source;
427 if (inputSource == AUDIO_SOURCE_DEFAULT) {
428 inputSource = AUDIO_SOURCE_MIC;
429 }
430
Eric Laurent2d388ec2014-03-07 13:25:54 -0800431 // already checked by client, but double-check in case the client wrapper is bypassed
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900432 if ((inputSource < AUDIO_SOURCE_DEFAULT)
433 || (inputSource >= AUDIO_SOURCE_CNT
434 && inputSource != AUDIO_SOURCE_HOTWORD
435 && inputSource != AUDIO_SOURCE_FM_TUNER
436 && inputSource != AUDIO_SOURCE_ECHO_REFERENCE)) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800437 return BAD_VALUE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800438 }
439
Eric Laurentb2379ba2016-05-23 17:42:12 -0700440 bool updatePid = (pid == -1);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700441 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700442 if (!isAudioServerOrMediaServerUid(callingUid)) {
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700443 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Marco Nelissendcb346b2015-09-09 10:47:29 -0700444 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
445 uid = callingUid;
Eric Laurentb2379ba2016-05-23 17:42:12 -0700446 updatePid = true;
447 }
448
449 if (updatePid) {
450 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700451 ALOGW_IF(pid != (pid_t)-1 && pid != callingPid,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700452 "%s uid %d pid %d tried to pass itself off as pid %d",
453 __func__, callingUid, callingPid, pid);
454 pid = callingPid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700455 }
456
Eric Laurent58a0dd82019-10-24 12:42:17 -0700457 // check calling permissions.
458 // Capturing from FM_TUNER source is controlled by captureAudioOutputAllowed() only as this
459 // does not affect users privacy as does capturing from an actual microphone.
460 if (!(recordingAllowed(opPackageName, pid, uid) || attr->source == AUDIO_SOURCE_FM_TUNER)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800461 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
462 __func__, uid, pid);
463 return PERMISSION_DENIED;
464 }
465
Eric Laurent1ff16a72019-03-14 18:35:04 -0700466 bool canCaptureOutput = captureAudioOutputAllowed(pid, uid);
Ricardo Correaac26cf72020-01-06 14:43:38 -0800467 bool canCaptureTelephonyOutput = canCaptureOutput
468 || accessCallAudioAllowed(opPackageName, pid, uid);
469
470 if ((attr->source == AUDIO_SOURCE_ECHO_REFERENCE ||
471 attr->source == AUDIO_SOURCE_FM_TUNER) &&
Eric Laurent1ff16a72019-03-14 18:35:04 -0700472 !canCaptureOutput) {
Nadav Bar744be482018-05-08 13:26:21 +0300473 return PERMISSION_DENIED;
474 }
475
Ricardo Correaac26cf72020-01-06 14:43:38 -0800476 if ((attr->source == AUDIO_SOURCE_VOICE_UPLINK ||
477 attr->source == AUDIO_SOURCE_VOICE_DOWNLINK ||
478 attr->source == AUDIO_SOURCE_VOICE_CALL) &&
479 !canCaptureTelephonyOutput) {
480 return PERMISSION_DENIED;
481 }
482
jiabin68e0df72019-03-18 17:55:35 -0700483 bool canCaptureHotword = captureHotwordAllowed(opPackageName, pid, uid);
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900484 if ((inputSource == AUDIO_SOURCE_HOTWORD) && !canCaptureHotword) {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700485 return BAD_VALUE;
486 }
487
488 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700489 {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700490 status_t status;
491 AudioPolicyInterface::input_type_t inputType;
492
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700493 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700494 {
495 AutoCallerClear acc;
496 // the audio_in_acoustics_t parameter is ignored by get_input()
Mikhail Naganov2996f672019-04-18 12:29:59 -0700497 status = mAudioPolicyManager->getInputForAttr(attr, input, riid, session, uid,
Eric Laurent10b71232018-04-13 18:14:44 -0700498 config,
499 flags, selectedDeviceId,
500 &inputType, portId);
501 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700502 audioPolicyEffects = mAudioPolicyEffects;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800503
504 if (status == NO_ERROR) {
505 // enforce permission (if any) required for each type of input
506 switch (inputType) {
Kevin Rocard25f9b052019-02-27 15:08:54 -0800507 case AudioPolicyInterface::API_INPUT_MIX_PUBLIC_CAPTURE_PLAYBACK:
508 // this use case has been validated in audio service with a MediaProjection token,
509 // and doesn't rely on regular permissions
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800510 case AudioPolicyInterface::API_INPUT_LEGACY:
511 break;
Eric Laurent82db2692015-08-07 13:59:42 -0700512 case AudioPolicyInterface::API_INPUT_TELEPHONY_RX:
513 // FIXME: use the same permission as for remote submix for now.
Ricardo Correaac26cf72020-01-06 14:43:38 -0800514 if (!canCaptureTelephonyOutput) {
515 ALOGE("getInputForAttr() permission denied: call capture not allowed");
516 status = PERMISSION_DENIED;
517 }
518 break;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800519 case AudioPolicyInterface::API_INPUT_MIX_CAPTURE:
Eric Laurent1ff16a72019-03-14 18:35:04 -0700520 if (!canCaptureOutput) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800521 ALOGE("getInputForAttr() permission denied: capture not allowed");
522 status = PERMISSION_DENIED;
523 }
524 break;
525 case AudioPolicyInterface::API_INPUT_MIX_EXT_POLICY_REROUTE:
Eric Laurent8a1095a2019-11-08 14:44:16 -0800526 if (!modifyAudioRoutingAllowed(pid, uid)) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800527 ALOGE("getInputForAttr() permission denied: modify audio routing not allowed");
528 status = PERMISSION_DENIED;
529 }
530 break;
531 case AudioPolicyInterface::API_INPUT_INVALID:
532 default:
533 LOG_ALWAYS_FATAL("getInputForAttr() encountered an invalid input type %d",
534 (int)inputType);
535 }
536 }
537
538 if (status != NO_ERROR) {
539 if (status == PERMISSION_DENIED) {
Eric Laurent10b71232018-04-13 18:14:44 -0700540 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700541 mAudioPolicyManager->releaseInput(*portId);
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800542 }
543 return status;
544 }
Eric Laurentfee19762018-01-29 18:44:13 -0800545
Ricardo Correaac26cf72020-01-06 14:43:38 -0800546 bool allowAudioCapture = canCaptureOutput ||
547 (inputType == AudioPolicyInterface::API_INPUT_TELEPHONY_RX &&
548 canCaptureTelephonyOutput);
549
Eric Laurent5ada82e2019-08-29 17:53:54 -0700550 sp<AudioRecordClient> client = new AudioRecordClient(*attr, *input, uid, pid, session, *portId,
Eric Laurent1ff16a72019-03-14 18:35:04 -0700551 *selectedDeviceId, opPackageName,
Ricardo Correaac26cf72020-01-06 14:43:38 -0800552 allowAudioCapture, canCaptureHotword);
Eric Laurentfee19762018-01-29 18:44:13 -0800553 mAudioRecordClients.add(*portId, client);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700554 }
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800555
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700556 if (audioPolicyEffects != 0) {
557 // create audio pre processors according to input source
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900558 status_t status = audioPolicyEffects->addInputEffects(*input, inputSource, session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700559 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800560 ALOGW("Failed to add effects on input %d", *input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700561 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800562 }
Eric Laurentcaf7f482014-11-25 17:50:47 -0800563 return NO_ERROR;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800564}
565
Eric Laurent99fcae42018-05-17 16:59:18 -0700566std::string AudioPolicyService::getDeviceTypeStrForPortId(audio_port_handle_t portId) {
Eric Laurent99fcae42018-05-17 16:59:18 -0700567 struct audio_port port = {};
568 port.id = portId;
569 status_t status = mAudioPolicyManager->getAudioPort(&port);
570 if (status == NO_ERROR && port.type == AUDIO_PORT_TYPE_DEVICE) {
Andy Hung9b181952019-02-25 14:53:36 -0800571 return toString(port.ext.device.type);
Eric Laurent99fcae42018-05-17 16:59:18 -0700572 }
Andy Hung9b181952019-02-25 14:53:36 -0800573 return {};
Eric Laurent99fcae42018-05-17 16:59:18 -0700574}
575
Eric Laurent4eb58f12018-12-07 16:41:02 -0800576status_t AudioPolicyService::startInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800577{
Eric Laurentdce54a12014-03-10 12:19:46 -0700578 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800579 return NO_INIT;
580 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800581 sp<AudioRecordClient> client;
582 {
583 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800584
Eric Laurent7dca8a82018-01-29 18:44:26 -0800585 ssize_t index = mAudioRecordClients.indexOfKey(portId);
586 if (index < 0) {
587 return INVALID_OPERATION;
588 }
589 client = mAudioRecordClients.valueAt(index);
Eric Laurentfee19762018-01-29 18:44:13 -0800590 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800591
592 // check calling permissions
Eric Laurent58a0dd82019-10-24 12:42:17 -0700593 if (!(startRecording(client->opPackageName, client->pid, client->uid)
594 || client->attributes.source == AUDIO_SOURCE_FM_TUNER)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800595 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
596 __func__, client->uid, client->pid);
597 return PERMISSION_DENIED;
598 }
Eric Laurentfee19762018-01-29 18:44:13 -0800599
Eric Laurentdf628922018-12-06 21:45:51 +0000600 Mutex::Autolock _l(mLock);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800601
602 client->active = true;
603 client->startTimeNs = systemTime();
604 updateUidStates_l();
Eric Laurentfee19762018-01-29 18:44:13 -0800605
Eric Laurent10b71232018-04-13 18:14:44 -0700606 status_t status;
607 {
608 AutoCallerClear acc;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800609 status = mAudioPolicyManager->startInput(portId);
Ray Essick84e84a52018-05-03 18:45:07 -0700610
611 }
612
Ray Essickf6a57cd2018-05-22 16:20:54 -0700613 // including successes gets very verbose
Ray Essick6ce27e52019-02-15 10:58:05 -0800614 // but once we cut over to westworld, log them all.
Ray Essickf6a57cd2018-05-22 16:20:54 -0700615 if (status != NO_ERROR) {
Ray Essick84e84a52018-05-03 18:45:07 -0700616
617 static constexpr char kAudioPolicy[] = "audiopolicy";
618
Ray Essick84e84a52018-05-03 18:45:07 -0700619 static constexpr char kAudioPolicyStatus[] = "android.media.audiopolicy.status";
620 static constexpr char kAudioPolicyRqstSrc[] = "android.media.audiopolicy.rqst.src";
621 static constexpr char kAudioPolicyRqstPkg[] = "android.media.audiopolicy.rqst.pkg";
622 static constexpr char kAudioPolicyRqstSession[] = "android.media.audiopolicy.rqst.session";
Eric Laurent99fcae42018-05-17 16:59:18 -0700623 static constexpr char kAudioPolicyRqstDevice[] =
624 "android.media.audiopolicy.rqst.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700625 static constexpr char kAudioPolicyActiveSrc[] = "android.media.audiopolicy.active.src";
626 static constexpr char kAudioPolicyActivePkg[] = "android.media.audiopolicy.active.pkg";
Eric Laurent99fcae42018-05-17 16:59:18 -0700627 static constexpr char kAudioPolicyActiveSession[] =
628 "android.media.audiopolicy.active.session";
629 static constexpr char kAudioPolicyActiveDevice[] =
630 "android.media.audiopolicy.active.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700631
Ray Essickf27e9872019-12-07 06:28:46 -0800632 mediametrics::Item *item = mediametrics::Item::create(kAudioPolicy);
Ray Essick84e84a52018-05-03 18:45:07 -0700633 if (item != NULL) {
634
Ray Essick84e84a52018-05-03 18:45:07 -0700635 item->setInt32(kAudioPolicyStatus, status);
636
Eric Laurent99fcae42018-05-17 16:59:18 -0700637 item->setCString(kAudioPolicyRqstSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800638 toString(client->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700639 item->setInt32(kAudioPolicyRqstSession, client->session);
Ray Essick51866952018-05-30 11:22:27 -0700640 if (client->opPackageName.size() != 0) {
641 item->setCString(kAudioPolicyRqstPkg,
642 std::string(String8(client->opPackageName).string()).c_str());
643 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700644 item->setCString(kAudioPolicyRqstPkg, std::to_string(client->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700645 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700646 item->setCString(
647 kAudioPolicyRqstDevice, getDeviceTypeStrForPortId(client->deviceId).c_str());
648
Eric Laurent4eb58f12018-12-07 16:41:02 -0800649 int count = mAudioRecordClients.size();
650 for (int i = 0; i < count ; i++) {
651 if (portId == mAudioRecordClients.keyAt(i)) {
652 continue;
653 }
654 sp<AudioRecordClient> other = mAudioRecordClients.valueAt(i);
655 if (other->active) {
656 // keeps the last of the clients marked active
657 item->setCString(kAudioPolicyActiveSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800658 toString(other->attributes.source).c_str());
Eric Laurent4eb58f12018-12-07 16:41:02 -0800659 item->setInt32(kAudioPolicyActiveSession, other->session);
660 if (other->opPackageName.size() != 0) {
661 item->setCString(kAudioPolicyActivePkg,
662 std::string(String8(other->opPackageName).string()).c_str());
663 } else {
664 item->setCString(kAudioPolicyRqstPkg,
665 std::to_string(other->uid).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700666 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800667 item->setCString(kAudioPolicyActiveDevice,
668 getDeviceTypeStrForPortId(other->deviceId).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700669 }
670 }
671 item->selfrecord();
672 delete item;
673 item = NULL;
674 }
Ray Essick6ce27e52019-02-15 10:58:05 -0800675 }
676
677 if (status != NO_ERROR) {
Eric Laurent4eb58f12018-12-07 16:41:02 -0800678 client->active = false;
679 client->startTimeNs = 0;
680 updateUidStates_l();
Svet Ganov6e641372018-03-02 09:21:30 -0800681 finishRecording(client->opPackageName, client->uid);
Eric Laurentfb66dd92016-01-28 18:32:03 -0800682 }
683
684 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800685}
686
Eric Laurentfee19762018-01-29 18:44:13 -0800687status_t AudioPolicyService::stopInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800688{
Eric Laurentdce54a12014-03-10 12:19:46 -0700689 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800690 return NO_INIT;
691 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800692
Eric Laurent2d388ec2014-03-07 13:25:54 -0800693 Mutex::Autolock _l(mLock);
694
Eric Laurentfee19762018-01-29 18:44:13 -0800695 ssize_t index = mAudioRecordClients.indexOfKey(portId);
696 if (index < 0) {
697 return INVALID_OPERATION;
698 }
699 sp<AudioRecordClient> client = mAudioRecordClients.valueAt(index);
700
Ray Essick84e84a52018-05-03 18:45:07 -0700701 client->active = false;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800702 client->startTimeNs = 0;
703
704 updateUidStates_l();
Ray Essick84e84a52018-05-03 18:45:07 -0700705
Svet Ganov6e641372018-03-02 09:21:30 -0800706 // finish the recording app op
707 finishRecording(client->opPackageName, client->uid);
Eric Laurent10b71232018-04-13 18:14:44 -0700708 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700709 return mAudioPolicyManager->stopInput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800710}
711
Eric Laurentfee19762018-01-29 18:44:13 -0800712void AudioPolicyService::releaseInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800713{
Eric Laurentdce54a12014-03-10 12:19:46 -0700714 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800715 return;
716 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700717 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800718 sp<AudioRecordClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700719 {
720 Mutex::Autolock _l(mLock);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700721 audioPolicyEffects = mAudioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800722 ssize_t index = mAudioRecordClients.indexOfKey(portId);
723 if (index < 0) {
724 return;
725 }
726 client = mAudioRecordClients.valueAt(index);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800727
728 if (client->active) {
729 ALOGW("%s releasing active client portId %d", __FUNCTION__, portId);
730 client->active = false;
731 client->startTimeNs = 0;
732 updateUidStates_l();
733 }
734
Eric Laurentfee19762018-01-29 18:44:13 -0800735 mAudioRecordClients.removeItem(portId);
736 }
737 if (client == 0) {
738 return;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700739 }
740 if (audioPolicyEffects != 0) {
741 // release audio processors from the input
Eric Laurentd7fe0862018-07-14 16:48:01 -0700742 status_t status = audioPolicyEffects->releaseInputEffects(client->io, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700743 if(status != NO_ERROR) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700744 ALOGW("Failed to release effects on input %d", client->io);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700745 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800746 }
Eric Laurentf10c7092016-12-06 17:09:56 -0800747 {
748 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700749 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700750 mAudioPolicyManager->releaseInput(portId);
Eric Laurentf10c7092016-12-06 17:09:56 -0800751 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800752}
753
754status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
755 int indexMin,
756 int indexMax)
757{
Eric Laurentdce54a12014-03-10 12:19:46 -0700758 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800759 return NO_INIT;
760 }
761 if (!settingsAllowed()) {
762 return PERMISSION_DENIED;
763 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800764 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800765 return BAD_VALUE;
766 }
767 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700768 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700769 mAudioPolicyManager->initStreamVolume(stream, indexMin, indexMax);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800770 return NO_ERROR;
771}
772
773status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
774 int index,
775 audio_devices_t device)
776{
Eric Laurentdce54a12014-03-10 12:19:46 -0700777 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800778 return NO_INIT;
779 }
780 if (!settingsAllowed()) {
781 return PERMISSION_DENIED;
782 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800783 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800784 return BAD_VALUE;
785 }
786 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700787 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700788 return mAudioPolicyManager->setStreamVolumeIndex(stream,
789 index,
790 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800791}
792
793status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
794 int *index,
795 audio_devices_t device)
796{
Eric Laurentdce54a12014-03-10 12:19:46 -0700797 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800798 return NO_INIT;
799 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800800 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800801 return BAD_VALUE;
802 }
803 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700804 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700805 return mAudioPolicyManager->getStreamVolumeIndex(stream,
806 index,
807 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800808}
809
François Gaffiecfe17322018-11-07 13:41:29 +0100810status_t AudioPolicyService::setVolumeIndexForAttributes(const audio_attributes_t &attributes,
811 int index, audio_devices_t device)
812{
813 if (mAudioPolicyManager == NULL) {
814 return NO_INIT;
815 }
816 if (!settingsAllowed()) {
817 return PERMISSION_DENIED;
818 }
819 Mutex::Autolock _l(mLock);
820 AutoCallerClear acc;
821 return mAudioPolicyManager->setVolumeIndexForAttributes(attributes, index, device);
822}
823
824status_t AudioPolicyService::getVolumeIndexForAttributes(const audio_attributes_t &attributes,
825 int &index, audio_devices_t device)
826{
827 if (mAudioPolicyManager == NULL) {
828 return NO_INIT;
829 }
830 Mutex::Autolock _l(mLock);
831 AutoCallerClear acc;
832 return mAudioPolicyManager->getVolumeIndexForAttributes(attributes, index, device);
833}
834
835status_t AudioPolicyService::getMinVolumeIndexForAttributes(const audio_attributes_t &attributes,
836 int &index)
837{
838 if (mAudioPolicyManager == NULL) {
839 return NO_INIT;
840 }
841 Mutex::Autolock _l(mLock);
842 AutoCallerClear acc;
843 return mAudioPolicyManager->getMinVolumeIndexForAttributes(attributes, index);
844}
845
846status_t AudioPolicyService::getMaxVolumeIndexForAttributes(const audio_attributes_t &attributes,
847 int &index)
848{
849 if (mAudioPolicyManager == NULL) {
850 return NO_INIT;
851 }
852 Mutex::Autolock _l(mLock);
853 AutoCallerClear acc;
854 return mAudioPolicyManager->getMaxVolumeIndexForAttributes(attributes, index);
855}
856
Eric Laurent2d388ec2014-03-07 13:25:54 -0800857uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
858{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800859 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
François Gaffiec005e562018-11-06 15:04:49 +0100860 return PRODUCT_STRATEGY_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700861 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700862 if (mAudioPolicyManager == NULL) {
François Gaffiec005e562018-11-06 15:04:49 +0100863 return PRODUCT_STRATEGY_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800864 }
François Gaffiec005e562018-11-06 15:04:49 +0100865 // DO NOT LOCK, may be called from AudioFlinger with lock held, reaching deadlock
Eric Laurent10b71232018-04-13 18:14:44 -0700866 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700867 return mAudioPolicyManager->getStrategyForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800868}
869
870//audio policy: use audio_device_t appropriately
871
872audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
873{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800874 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700875 return AUDIO_DEVICE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700876 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700877 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700878 return AUDIO_DEVICE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800879 }
Haynes Mathew Georgedfb9f3b2015-10-26 18:22:13 -0700880 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700881 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700882 return mAudioPolicyManager->getDevicesForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800883}
884
Jean-Michel Trivif41599b2020-01-07 14:22:08 -0800885status_t AudioPolicyService::getDevicesForAttributes(const AudioAttributes &aa,
Hayden Gomes524159d2019-12-23 14:41:47 -0800886 AudioDeviceTypeAddrVector *devices) const
Jean-Michel Trivif41599b2020-01-07 14:22:08 -0800887{
888 if (mAudioPolicyManager == NULL) {
889 return NO_INIT;
890 }
891 Mutex::Autolock _l(mLock);
892 AutoCallerClear acc;
893 return mAudioPolicyManager->getDevicesForAttributes(aa.getAttributes(), devices);
894}
895
Eric Laurent2d388ec2014-03-07 13:25:54 -0800896audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
897{
898 // FIXME change return type to status_t, and return NO_INIT here
Eric Laurentdce54a12014-03-10 12:19:46 -0700899 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800900 return 0;
901 }
902 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700903 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700904 return mAudioPolicyManager->getOutputForEffect(desc);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800905}
906
907status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
908 audio_io_handle_t io,
909 uint32_t strategy,
Glenn Kastend848eb42016-03-08 13:42:11 -0800910 audio_session_t session,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800911 int id)
912{
Eric Laurentdce54a12014-03-10 12:19:46 -0700913 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800914 return NO_INIT;
915 }
Eric Laurent6c796322019-04-09 14:13:17 -0700916 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700917 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700918 return mAudioPolicyManager->registerEffect(desc, io, strategy, session, id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800919}
920
921status_t AudioPolicyService::unregisterEffect(int id)
922{
Eric Laurentdce54a12014-03-10 12:19:46 -0700923 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800924 return NO_INIT;
925 }
Eric Laurent6c796322019-04-09 14:13:17 -0700926 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700927 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700928 return mAudioPolicyManager->unregisterEffect(id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800929}
930
931status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
932{
Eric Laurentdce54a12014-03-10 12:19:46 -0700933 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800934 return NO_INIT;
935 }
Eric Laurent6c796322019-04-09 14:13:17 -0700936 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700937 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700938 return mAudioPolicyManager->setEffectEnabled(id, enabled);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800939}
940
Eric Laurent6c796322019-04-09 14:13:17 -0700941status_t AudioPolicyService::moveEffectsToIo(const std::vector<int>& ids, audio_io_handle_t io)
942{
943 if (mAudioPolicyManager == NULL) {
944 return NO_INIT;
945 }
946 Mutex::Autolock _l(mLock);
947 AutoCallerClear acc;
948 return mAudioPolicyManager->moveEffectsToIo(ids, io);
949}
950
Eric Laurent2d388ec2014-03-07 13:25:54 -0800951bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
952{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800953 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700954 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700955 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700956 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700957 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800958 }
959 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700960 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700961 return mAudioPolicyManager->isStreamActive(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800962}
963
964bool AudioPolicyService::isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs) const
965{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800966 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700967 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700968 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700969 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700970 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800971 }
972 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700973 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700974 return mAudioPolicyManager->isStreamActiveRemotely(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800975}
976
977bool AudioPolicyService::isSourceActive(audio_source_t source) const
978{
Eric Laurentdce54a12014-03-10 12:19:46 -0700979 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800980 return false;
981 }
982 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700983 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700984 return mAudioPolicyManager->isSourceActive(source);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800985}
986
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700987status_t AudioPolicyService::getAudioPolicyEffects(sp<AudioPolicyEffects>& audioPolicyEffects)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800988{
Eric Laurentdce54a12014-03-10 12:19:46 -0700989 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800990 return NO_INIT;
991 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700992 {
993 Mutex::Autolock _l(mLock);
994 audioPolicyEffects = mAudioPolicyEffects;
995 }
996 if (audioPolicyEffects == 0) {
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700997 return NO_INIT;
998 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700999
1000 return OK;
1001}
1002
1003status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
1004 effect_descriptor_t *descriptors,
1005 uint32_t *count)
1006{
1007 sp<AudioPolicyEffects>audioPolicyEffects;
1008 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1009 if (status != OK) {
1010 *count = 0;
1011 return status;
1012 }
Eric Laurentfb66dd92016-01-28 18:32:03 -08001013 return audioPolicyEffects->queryDefaultInputEffects(
1014 (audio_session_t)audioSession, descriptors, count);
Eric Laurent2d388ec2014-03-07 13:25:54 -08001015}
1016
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001017status_t AudioPolicyService::addSourceDefaultEffect(const effect_uuid_t *type,
1018 const String16& opPackageName,
1019 const effect_uuid_t *uuid,
1020 int32_t priority,
1021 audio_source_t source,
1022 audio_unique_id_t* id)
1023{
1024 sp<AudioPolicyEffects>audioPolicyEffects;
1025 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1026 if (status != OK) {
1027 return status;
1028 }
1029 if (!modifyDefaultAudioEffectsAllowed()) {
1030 return PERMISSION_DENIED;
1031 }
1032 return audioPolicyEffects->addSourceDefaultEffect(
1033 type, opPackageName, uuid, priority, source, id);
1034}
1035
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001036status_t AudioPolicyService::addStreamDefaultEffect(const effect_uuid_t *type,
1037 const String16& opPackageName,
1038 const effect_uuid_t *uuid,
1039 int32_t priority,
1040 audio_usage_t usage,
1041 audio_unique_id_t* id)
1042{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001043 sp<AudioPolicyEffects>audioPolicyEffects;
1044 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1045 if (status != OK) {
1046 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001047 }
1048 if (!modifyDefaultAudioEffectsAllowed()) {
1049 return PERMISSION_DENIED;
1050 }
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001051 return audioPolicyEffects->addStreamDefaultEffect(
1052 type, opPackageName, uuid, priority, usage, id);
1053}
1054
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001055status_t AudioPolicyService::removeSourceDefaultEffect(audio_unique_id_t id)
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001056{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001057 sp<AudioPolicyEffects>audioPolicyEffects;
1058 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1059 if (status != OK) {
1060 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001061 }
1062 if (!modifyDefaultAudioEffectsAllowed()) {
1063 return PERMISSION_DENIED;
1064 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001065 return audioPolicyEffects->removeSourceDefaultEffect(id);
1066}
1067
1068status_t AudioPolicyService::removeStreamDefaultEffect(audio_unique_id_t id)
1069{
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001070 sp<AudioPolicyEffects>audioPolicyEffects;
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001071 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1072 if (status != OK) {
1073 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001074 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001075 if (!modifyDefaultAudioEffectsAllowed()) {
1076 return PERMISSION_DENIED;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001077 }
1078 return audioPolicyEffects->removeStreamDefaultEffect(id);
1079}
1080
Hayden Gomes524159d2019-12-23 14:41:47 -08001081status_t AudioPolicyService::setSupportedSystemUsages(const std::vector<audio_usage_t>& systemUsages) {
1082 Mutex::Autolock _l(mLock);
1083 if(!modifyAudioRoutingAllowed()) {
1084 return PERMISSION_DENIED;
1085 }
1086
1087 bool areAllSystemUsages = std::all_of(begin(systemUsages), end(systemUsages),
1088 [](audio_usage_t usage) { return isSystemUsage(usage); });
1089 if (!areAllSystemUsages) {
1090 return BAD_VALUE;
1091 }
1092
1093 mSupportedSystemUsages = systemUsages;
1094 return NO_ERROR;
1095}
1096
Kevin Rocardb99cc752019-03-21 20:52:24 -07001097status_t AudioPolicyService::setAllowedCapturePolicy(uid_t uid, audio_flags_mask_t capturePolicy) {
1098 Mutex::Autolock _l(mLock);
1099 if (mAudioPolicyManager == NULL) {
1100 ALOGV("%s() mAudioPolicyManager == NULL", __func__);
1101 return NO_INIT;
1102 }
Kevin Rocardb99cc752019-03-21 20:52:24 -07001103 return mAudioPolicyManager->setAllowedCapturePolicy(uid, capturePolicy);
1104}
1105
Eric Laurent2d388ec2014-03-07 13:25:54 -08001106bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
1107{
Eric Laurentdce54a12014-03-10 12:19:46 -07001108 if (mAudioPolicyManager == NULL) {
1109 ALOGV("mAudioPolicyManager == NULL");
Eric Laurent2d388ec2014-03-07 13:25:54 -08001110 return false;
1111 }
Andy Hung2ddee192015-12-18 17:34:44 -08001112 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001113 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -07001114 return mAudioPolicyManager->isOffloadSupported(info);
Eric Laurent2d388ec2014-03-07 13:25:54 -08001115}
1116
Michael Chana94fbb22018-04-24 14:31:19 +10001117bool AudioPolicyService::isDirectOutputSupported(const audio_config_base_t& config,
1118 const audio_attributes_t& attributes) {
1119 if (mAudioPolicyManager == NULL) {
1120 ALOGV("mAudioPolicyManager == NULL");
1121 return false;
1122 }
Hayden Gomes524159d2019-12-23 14:41:47 -08001123
1124 status_t result = validateUsage(attributes.usage);
1125 if (result != NO_ERROR) {
1126 return result;
1127 }
1128
Michael Chana94fbb22018-04-24 14:31:19 +10001129 Mutex::Autolock _l(mLock);
1130 return mAudioPolicyManager->isDirectOutputSupported(config, attributes);
1131}
1132
1133
Eric Laurent6a94d692014-05-20 11:18:06 -07001134status_t AudioPolicyService::listAudioPorts(audio_port_role_t role,
1135 audio_port_type_t type,
Eric Laurent203b1a12014-04-01 10:34:16 -07001136 unsigned int *num_ports,
Eric Laurent6a94d692014-05-20 11:18:06 -07001137 struct audio_port *ports,
1138 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001139{
Eric Laurent6a94d692014-05-20 11:18:06 -07001140 Mutex::Autolock _l(mLock);
1141 if (mAudioPolicyManager == NULL) {
1142 return NO_INIT;
1143 }
Eric Laurent10b71232018-04-13 18:14:44 -07001144 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001145 return mAudioPolicyManager->listAudioPorts(role, type, num_ports, ports, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001146}
1147
Eric Laurent6a94d692014-05-20 11:18:06 -07001148status_t AudioPolicyService::getAudioPort(struct audio_port *port)
Eric Laurent203b1a12014-04-01 10:34:16 -07001149{
Eric Laurent6a94d692014-05-20 11:18:06 -07001150 Mutex::Autolock _l(mLock);
1151 if (mAudioPolicyManager == NULL) {
1152 return NO_INIT;
1153 }
Eric Laurent10b71232018-04-13 18:14:44 -07001154 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001155 return mAudioPolicyManager->getAudioPort(port);
Eric Laurent203b1a12014-04-01 10:34:16 -07001156}
1157
Eric Laurent6a94d692014-05-20 11:18:06 -07001158status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch,
1159 audio_patch_handle_t *handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001160{
Eric Laurent6a94d692014-05-20 11:18:06 -07001161 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001162 if(!modifyAudioRoutingAllowed()) {
1163 return PERMISSION_DENIED;
1164 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001165 if (mAudioPolicyManager == NULL) {
1166 return NO_INIT;
1167 }
Eric Laurent10b71232018-04-13 18:14:44 -07001168 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001169 return mAudioPolicyManager->createAudioPatch(patch, handle,
1170 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001171}
1172
Eric Laurent6a94d692014-05-20 11:18:06 -07001173status_t AudioPolicyService::releaseAudioPatch(audio_patch_handle_t handle)
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->releaseAudioPatch(handle,
1184 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001185}
1186
1187status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
Eric Laurent6a94d692014-05-20 11:18:06 -07001188 struct audio_patch *patches,
1189 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001190{
Eric Laurent6a94d692014-05-20 11:18:06 -07001191 Mutex::Autolock _l(mLock);
1192 if (mAudioPolicyManager == NULL) {
1193 return NO_INIT;
1194 }
Eric Laurent10b71232018-04-13 18:14:44 -07001195 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001196 return mAudioPolicyManager->listAudioPatches(num_patches, patches, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001197}
1198
Eric Laurent6a94d692014-05-20 11:18:06 -07001199status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config)
Eric Laurent203b1a12014-04-01 10:34:16 -07001200{
Eric Laurent6a94d692014-05-20 11:18:06 -07001201 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001202 if(!modifyAudioRoutingAllowed()) {
1203 return PERMISSION_DENIED;
1204 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001205 if (mAudioPolicyManager == NULL) {
1206 return NO_INIT;
1207 }
Eric Laurent10b71232018-04-13 18:14:44 -07001208 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001209 return mAudioPolicyManager->setAudioPortConfig(config);
Eric Laurent203b1a12014-04-01 10:34:16 -07001210}
Eric Laurent2d388ec2014-03-07 13:25:54 -08001211
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001212status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session,
1213 audio_io_handle_t *ioHandle,
1214 audio_devices_t *device)
1215{
Andy Hungf759b8c2017-08-15 12:48:54 -07001216 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001217 if (mAudioPolicyManager == NULL) {
1218 return NO_INIT;
1219 }
Eric Laurent10b71232018-04-13 18:14:44 -07001220 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001221 return mAudioPolicyManager->acquireSoundTriggerSession(session, ioHandle, device);
1222}
1223
1224status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session)
1225{
Andy Hungf759b8c2017-08-15 12:48:54 -07001226 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001227 if (mAudioPolicyManager == NULL) {
1228 return NO_INIT;
1229 }
Eric Laurent10b71232018-04-13 18:14:44 -07001230 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001231 return mAudioPolicyManager->releaseSoundTriggerSession(session);
1232}
1233
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -07001234status_t AudioPolicyService::registerPolicyMixes(const Vector<AudioMix>& mixes, bool registration)
Eric Laurentbaac1832014-12-01 17:52:59 -08001235{
1236 Mutex::Autolock _l(mLock);
Kevin Rocardbe201852019-02-20 22:33:28 -08001237
1238 // loopback|render only need a MediaProjection (checked in caller AudioService.java)
1239 bool needModifyAudioRouting = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
1240 return !is_mix_loopback_render(mix.mRouteFlags); });
1241 if (needModifyAudioRouting && !modifyAudioRoutingAllowed()) {
Eric Laurentbaac1832014-12-01 17:52:59 -08001242 return PERMISSION_DENIED;
1243 }
Kevin Rocardbe201852019-02-20 22:33:28 -08001244
Nadav Bar287d3302020-02-05 14:55:38 +02001245 // If one of the mixes has needCaptureVoiceCommunicationOutput set to true, then we
1246 // need to verify that the caller still has CAPTURE_VOICE_COMMUNICATION_OUTPUT
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001247 bool needCaptureVoiceCommunicationOutput =
1248 std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
Nadav Bar287d3302020-02-05 14:55:38 +02001249 return mix.mVoiceCommunicationCaptureAllowed; });
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001250
Kevin Rocard36b17552019-03-07 18:48:07 -08001251 bool needCaptureMediaOutput = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
Nadav Bar287d3302020-02-05 14:55:38 +02001252 return mix.mAllowPrivilegedPlaybackCapture; });
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001253
Kevin Rocard36b17552019-03-07 18:48:07 -08001254 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
1255 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001256
Kevin Rocard36b17552019-03-07 18:48:07 -08001257 if (needCaptureMediaOutput && !captureMediaOutputAllowed(callingPid, callingUid)) {
1258 return PERMISSION_DENIED;
1259 }
1260
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001261 if (needCaptureVoiceCommunicationOutput &&
1262 !captureVoiceCommunicationOutputAllowed(callingPid, callingUid)) {
1263 return PERMISSION_DENIED;
1264 }
1265
Eric Laurentbaac1832014-12-01 17:52:59 -08001266 if (mAudioPolicyManager == NULL) {
1267 return NO_INIT;
1268 }
Eric Laurent10b71232018-04-13 18:14:44 -07001269 AutoCallerClear acc;
Eric Laurentbaac1832014-12-01 17:52:59 -08001270 if (registration) {
1271 return mAudioPolicyManager->registerPolicyMixes(mixes);
1272 } else {
1273 return mAudioPolicyManager->unregisterPolicyMixes(mixes);
1274 }
1275}
1276
Jean-Michel Trivibda70da2018-12-19 07:30:15 -08001277status_t AudioPolicyService::setUidDeviceAffinities(uid_t uid,
1278 const Vector<AudioDeviceTypeAddr>& devices) {
1279 Mutex::Autolock _l(mLock);
1280 if(!modifyAudioRoutingAllowed()) {
1281 return PERMISSION_DENIED;
1282 }
1283 if (mAudioPolicyManager == NULL) {
1284 return NO_INIT;
1285 }
1286 AutoCallerClear acc;
1287 return mAudioPolicyManager->setUidDeviceAffinities(uid, devices);
1288}
1289
1290status_t AudioPolicyService::removeUidDeviceAffinities(uid_t uid) {
1291 Mutex::Autolock _l(mLock);
1292 if(!modifyAudioRoutingAllowed()) {
1293 return PERMISSION_DENIED;
1294 }
1295 if (mAudioPolicyManager == NULL) {
1296 return NO_INIT;
1297 }
1298 AutoCallerClear acc;
1299 return mAudioPolicyManager->removeUidDeviceAffinities(uid);
1300}
1301
Oscar Azucena90e77632019-11-27 17:12:28 -08001302status_t AudioPolicyService::setUserIdDeviceAffinities(int userId,
1303 const Vector<AudioDeviceTypeAddr>& devices) {
1304 Mutex::Autolock _l(mLock);
1305 if(!modifyAudioRoutingAllowed()) {
1306 return PERMISSION_DENIED;
1307 }
1308 if (mAudioPolicyManager == NULL) {
1309 return NO_INIT;
1310 }
1311 AutoCallerClear acc;
1312 return mAudioPolicyManager->setUserIdDeviceAffinities(userId, devices);
1313}
1314
1315status_t AudioPolicyService::removeUserIdDeviceAffinities(int userId) {
1316 Mutex::Autolock _l(mLock);
1317 if(!modifyAudioRoutingAllowed()) {
1318 return PERMISSION_DENIED;
1319 }
1320 if (mAudioPolicyManager == NULL) {
1321 return NO_INIT;
1322 }
1323 AutoCallerClear acc;
1324 return mAudioPolicyManager->removeUserIdDeviceAffinities(userId);
1325}
1326
Eric Laurent554a2772015-04-10 11:29:24 -07001327status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001328 const audio_attributes_t *attributes,
1329 audio_port_handle_t *portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001330{
1331 Mutex::Autolock _l(mLock);
1332 if (mAudioPolicyManager == NULL) {
1333 return NO_INIT;
1334 }
Hayden Gomes524159d2019-12-23 14:41:47 -08001335
1336 status_t result = validateUsage(attributes->usage);
1337 if (result != NO_ERROR) {
1338 return result;
1339 }
1340
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001341 // startAudioSource should be created as the calling uid
1342 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Eric Laurent10b71232018-04-13 18:14:44 -07001343 AutoCallerClear acc;
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001344 return mAudioPolicyManager->startAudioSource(source, attributes, portId, callingUid);
Eric Laurent554a2772015-04-10 11:29:24 -07001345}
1346
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001347status_t AudioPolicyService::stopAudioSource(audio_port_handle_t portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001348{
1349 Mutex::Autolock _l(mLock);
1350 if (mAudioPolicyManager == NULL) {
1351 return NO_INIT;
1352 }
Eric Laurent10b71232018-04-13 18:14:44 -07001353 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001354 return mAudioPolicyManager->stopAudioSource(portId);
Eric Laurent554a2772015-04-10 11:29:24 -07001355}
1356
Andy Hung2ddee192015-12-18 17:34:44 -08001357status_t AudioPolicyService::setMasterMono(bool mono)
1358{
1359 if (mAudioPolicyManager == NULL) {
1360 return NO_INIT;
1361 }
1362 if (!settingsAllowed()) {
1363 return PERMISSION_DENIED;
1364 }
1365 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001366 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001367 return mAudioPolicyManager->setMasterMono(mono);
1368}
1369
1370status_t AudioPolicyService::getMasterMono(bool *mono)
1371{
1372 if (mAudioPolicyManager == NULL) {
1373 return NO_INIT;
1374 }
1375 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001376 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001377 return mAudioPolicyManager->getMasterMono(mono);
1378}
1379
Eric Laurentac9cef52017-06-09 15:46:26 -07001380
1381float AudioPolicyService::getStreamVolumeDB(
1382 audio_stream_type_t stream, int index, audio_devices_t device)
1383{
1384 if (mAudioPolicyManager == NULL) {
1385 return NAN;
1386 }
1387 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001388 AutoCallerClear acc;
Eric Laurentac9cef52017-06-09 15:46:26 -07001389 return mAudioPolicyManager->getStreamVolumeDB(stream, index, device);
1390}
1391
jiabin81772902018-04-02 17:52:27 -07001392status_t AudioPolicyService::getSurroundFormats(unsigned int *numSurroundFormats,
1393 audio_format_t *surroundFormats,
1394 bool *surroundFormatsEnabled,
1395 bool reported)
1396{
1397 if (mAudioPolicyManager == NULL) {
1398 return NO_INIT;
1399 }
1400 Mutex::Autolock _l(mLock);
1401 AutoCallerClear acc;
1402 return mAudioPolicyManager->getSurroundFormats(numSurroundFormats, surroundFormats,
1403 surroundFormatsEnabled, reported);
1404}
1405
Arun Mirpuri11029ad2018-12-19 20:45:19 -08001406status_t AudioPolicyService::getHwOffloadEncodingFormatsSupportedForA2DP(
1407 std::vector<audio_format_t> *formats)
1408{
1409 if (mAudioPolicyManager == NULL) {
1410 return NO_INIT;
1411 }
1412 Mutex::Autolock _l(mLock);
1413 AutoCallerClear acc;
1414 return mAudioPolicyManager->getHwOffloadEncodingFormatsSupportedForA2DP(formats);
1415}
1416
jiabin81772902018-04-02 17:52:27 -07001417status_t AudioPolicyService::setSurroundFormatEnabled(audio_format_t audioFormat, bool enabled)
1418{
1419 if (mAudioPolicyManager == NULL) {
1420 return NO_INIT;
1421 }
1422 Mutex::Autolock _l(mLock);
1423 AutoCallerClear acc;
1424 return mAudioPolicyManager->setSurroundFormatEnabled(audioFormat, enabled);
1425}
Eric Laurentac9cef52017-06-09 15:46:26 -07001426
Eric Laurentb78763e2018-10-17 10:08:02 -07001427status_t AudioPolicyService::setAssistantUid(uid_t uid)
1428{
1429 Mutex::Autolock _l(mLock);
1430 mUidPolicy->setAssistantUid(uid);
1431 return NO_ERROR;
1432}
1433
1434status_t AudioPolicyService::setA11yServicesUids(const std::vector<uid_t>& uids)
1435{
1436 Mutex::Autolock _l(mLock);
1437 mUidPolicy->setA11yUids(uids);
1438 return NO_ERROR;
1439}
1440
jiabin6012f912018-11-02 17:06:30 -07001441bool AudioPolicyService::isHapticPlaybackSupported()
1442{
1443 if (mAudioPolicyManager == NULL) {
1444 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1445 return false;
1446 }
1447 Mutex::Autolock _l(mLock);
1448 AutoCallerClear acc;
1449 return mAudioPolicyManager->isHapticPlaybackSupported();
1450}
1451
François Gaffied0ba9ed2018-11-05 11:50:42 +01001452status_t AudioPolicyService::listAudioProductStrategies(AudioProductStrategyVector &strategies)
1453{
1454 if (mAudioPolicyManager == NULL) {
1455 return NO_INIT;
1456 }
1457 Mutex::Autolock _l(mLock);
1458 return mAudioPolicyManager->listAudioProductStrategies(strategies);
1459}
1460
François Gaffie4b2018b2018-11-07 11:18:59 +01001461status_t AudioPolicyService::getProductStrategyFromAudioAttributes(
1462 const AudioAttributes &aa, product_strategy_t &productStrategy)
François Gaffied0ba9ed2018-11-05 11:50:42 +01001463{
1464 if (mAudioPolicyManager == NULL) {
François Gaffie4b2018b2018-11-07 11:18:59 +01001465 return NO_INIT;
François Gaffied0ba9ed2018-11-05 11:50:42 +01001466 }
1467 Mutex::Autolock _l(mLock);
François Gaffie4b2018b2018-11-07 11:18:59 +01001468 return mAudioPolicyManager->getProductStrategyFromAudioAttributes(aa, productStrategy);
1469}
1470
1471status_t AudioPolicyService::listAudioVolumeGroups(AudioVolumeGroupVector &groups)
1472{
1473 if (mAudioPolicyManager == NULL) {
1474 return NO_INIT;
1475 }
1476 Mutex::Autolock _l(mLock);
1477 return mAudioPolicyManager->listAudioVolumeGroups(groups);
1478}
1479
1480status_t AudioPolicyService::getVolumeGroupFromAudioAttributes(const AudioAttributes &aa,
1481 volume_group_t &volumeGroup)
1482{
1483 if (mAudioPolicyManager == NULL) {
1484 return NO_INIT;
1485 }
1486 Mutex::Autolock _l(mLock);
1487 return mAudioPolicyManager->getVolumeGroupFromAudioAttributes(aa, volumeGroup);
François Gaffied0ba9ed2018-11-05 11:50:42 +01001488}
Eric Laurent6ede98f2019-06-11 14:50:30 -07001489
1490status_t AudioPolicyService::setRttEnabled(bool enabled)
1491{
1492 Mutex::Autolock _l(mLock);
1493 mUidPolicy->setRttEnabled(enabled);
1494 return NO_ERROR;
1495}
1496
Eric Laurent8340e672019-11-06 11:01:08 -08001497bool AudioPolicyService::isCallScreenModeSupported()
1498{
1499 if (mAudioPolicyManager == NULL) {
1500 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1501 return false;
1502 }
1503 Mutex::Autolock _l(mLock);
1504 AutoCallerClear acc;
1505 return mAudioPolicyManager->isCallScreenModeSupported();
1506}
1507
Jean-Michel Trivi30857152019-11-01 11:04:15 -07001508status_t AudioPolicyService::setPreferredDeviceForStrategy(product_strategy_t strategy,
1509 const AudioDeviceTypeAddr &device)
1510{
1511 if (mAudioPolicyManager == NULL) {
1512 return NO_INIT;
1513 }
1514 Mutex::Autolock _l(mLock);
1515 return mAudioPolicyManager->setPreferredDeviceForStrategy(strategy, device);
1516}
1517
1518status_t AudioPolicyService::removePreferredDeviceForStrategy(product_strategy_t strategy)
1519{
1520 if (mAudioPolicyManager == NULL) {
1521 return NO_INIT;
1522 }
1523 Mutex::Autolock _l(mLock);
1524 return mAudioPolicyManager->removePreferredDeviceForStrategy(strategy);
1525}
1526
1527status_t AudioPolicyService::getPreferredDeviceForStrategy(product_strategy_t strategy,
1528 AudioDeviceTypeAddr &device)
1529{
1530 if (mAudioPolicyManager == NULL) {
1531 return NO_INIT;
1532 }
1533 Mutex::Autolock _l(mLock);
1534 return mAudioPolicyManager->getPreferredDeviceForStrategy(strategy, device);
1535}
1536
Mikhail Naganov1b2a7942017-12-08 10:18:09 -08001537} // namespace android