blob: 45d87304d255698dad4b8cd7c84067b034366223 [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,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800222 const audio_config_t *config,
Eric Laurente83b55d2014-11-14 10:06:21 -0800223 audio_output_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700224 audio_port_handle_t *selectedDeviceId,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800225 audio_port_handle_t *portId,
226 std::vector<audio_io_handle_t> *secondaryOutputs)
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700227{
228 if (mAudioPolicyManager == NULL) {
Eric Laurente83b55d2014-11-14 10:06:21 -0800229 return NO_INIT;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700230 }
Hayden Gomes524159d2019-12-23 14:41:47 -0800231
232 status_t result = validateUsage(attr->usage, pid, uid);
233 if (result != NO_ERROR) {
234 return result;
235 }
236
Eric Laurent8a1095a2019-11-08 14:44:16 -0800237 ALOGV("%s()", __func__);
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700238 Mutex::Autolock _l(mLock);
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700239
Marco Nelissendcb346b2015-09-09 10:47:29 -0700240 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700241 if (!isAudioServerOrMediaServerUid(callingUid) || uid == (uid_t)-1) {
Marco Nelissendcb346b2015-09-09 10:47:29 -0700242 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Eric Laurent8a1095a2019-11-08 14:44:16 -0800243 "%s uid %d tried to pass itself off as %d", __func__, callingUid, uid);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700244 uid = callingUid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700245 }
Kevin Rocard8be94972019-02-22 13:26:25 -0800246 if (!mPackageManager.allowPlaybackCapture(uid)) {
Mikhail Naganove3b59ac2020-10-01 15:08:13 -0700247 attr->flags = static_cast<audio_flags_mask_t>(attr->flags | AUDIO_FLAG_NO_MEDIA_PROJECTION);
Eric Laurent42984412019-05-09 17:57:03 -0700248 }
Eric Laurent6ede98f2019-06-11 14:50:30 -0700249 if (((attr->flags & (AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE)) != 0)
250 && !bypassInterruptionPolicyAllowed(pid, uid)) {
Mikhail Naganove3b59ac2020-10-01 15:08:13 -0700251 attr->flags = static_cast<audio_flags_mask_t>(
252 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 Correa57a37692020-03-23 17:27:25 -0700269 if (!modifyPhoneStateAllowed(pid, uid)) {
Eric Laurent8a1095a2019-11-08 14:44:16 -0800270 ALOGE("%s() permission denied: modify phone state not allowed for uid %d",
271 __func__, uid);
272 result = PERMISSION_DENIED;
273 }
274 break;
275 case AudioPolicyInterface::API_OUT_MIX_PLAYBACK:
276 if (!modifyAudioRoutingAllowed(pid, uid)) {
277 ALOGE("%s() permission denied: modify audio routing not allowed for uid %d",
278 __func__, uid);
279 result = PERMISSION_DENIED;
280 }
281 break;
282 case AudioPolicyInterface::API_OUTPUT_INVALID:
283 default:
284 LOG_ALWAYS_FATAL("%s() encountered an invalid output type %d",
285 __func__, (int)outputType);
286 }
Nadav Bar766fb022018-01-07 12:18:03 +0200287 }
Eric Laurentd7fe0862018-07-14 16:48:01 -0700288
289 if (result == NO_ERROR) {
290 sp <AudioPlaybackClient> client =
Eric Laurent5ada82e2019-08-29 17:53:54 -0700291 new AudioPlaybackClient(*attr, *output, uid, pid, session, *portId, *selectedDeviceId, *stream);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700292 mAudioPlaybackClients.add(*portId, client);
293 }
Nadav Bar766fb022018-01-07 12:18:03 +0200294 return result;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700295}
296
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700297void AudioPolicyService::getPlaybackClientAndEffects(audio_port_handle_t portId,
298 sp<AudioPlaybackClient>& client,
299 sp<AudioPolicyEffects>& effects,
300 const char *context)
301{
302 Mutex::Autolock _l(mLock);
303 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
304 if (index < 0) {
305 ALOGE("%s AudioTrack client not found for portId %d", context, portId);
306 return;
307 }
308 client = mAudioPlaybackClients.valueAt(index);
309 effects = mAudioPolicyEffects;
310}
311
Eric Laurentd7fe0862018-07-14 16:48:01 -0700312status_t AudioPolicyService::startOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800313{
Eric Laurentdce54a12014-03-10 12:19:46 -0700314 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800315 return NO_INIT;
316 }
317 ALOGV("startOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700318 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700319 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700320
321 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
322
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700323 if (audioPolicyEffects != 0) {
324 // create audio processors according to stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700325 status_t status = audioPolicyEffects->addOutputSessionEffects(
326 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700327 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700328 ALOGW("Failed to add effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700329 }
330 }
331 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700332 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700333 status_t status = mAudioPolicyManager->startOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700334 if (status == NO_ERROR) {
335 client->active = true;
336 }
337 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800338}
339
Eric Laurentd7fe0862018-07-14 16:48:01 -0700340status_t AudioPolicyService::stopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800341{
Eric Laurentdce54a12014-03-10 12:19:46 -0700342 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800343 return NO_INIT;
344 }
345 ALOGV("stopOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700346 mOutputCommandThread->stopOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800347 return NO_ERROR;
348}
349
Eric Laurentd7fe0862018-07-14 16:48:01 -0700350status_t AudioPolicyService::doStopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800351{
Eric Laurentd7fe0862018-07-14 16:48:01 -0700352 ALOGV("doStopOutput");
353 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700354 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentd7fe0862018-07-14 16:48:01 -0700355
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700356 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
357
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700358 if (audioPolicyEffects != 0) {
359 // release audio processors from the stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700360 status_t status = audioPolicyEffects->releaseOutputSessionEffects(
361 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700362 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700363 ALOGW("Failed to release effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700364 }
365 }
366 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700367 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700368 status_t status = mAudioPolicyManager->stopOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700369 if (status == NO_ERROR) {
370 client->active = false;
371 }
372 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800373}
374
Eric Laurentd7fe0862018-07-14 16:48:01 -0700375void AudioPolicyService::releaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800376{
Eric Laurentdce54a12014-03-10 12:19:46 -0700377 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800378 return;
379 }
380 ALOGV("releaseOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700381 mOutputCommandThread->releaseOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800382}
383
Eric Laurentd7fe0862018-07-14 16:48:01 -0700384void AudioPolicyService::doReleaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800385{
386 ALOGV("doReleaseOutput from tid %d", gettid());
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700387 sp<AudioPlaybackClient> client;
388 sp<AudioPolicyEffects> audioPolicyEffects;
389
390 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
391
392 if (audioPolicyEffects != 0 && client->active) {
393 // clean up effects if output was not stopped before being released
394 audioPolicyEffects->releaseOutputSessionEffects(
395 client->io, client->stream, client->session);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700396 }
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700397 Mutex::Autolock _l(mLock);
Eric Laurentd4007242019-03-27 12:42:16 -0700398 mAudioPlaybackClients.removeItem(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700399
Eric Laurent10b71232018-04-13 18:14:44 -0700400 // called from internal thread: no need to clear caller identity
Eric Laurent8fc147b2018-07-22 19:13:55 -0700401 mAudioPolicyManager->releaseOutput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800402}
403
Eric Laurentcaf7f482014-11-25 17:50:47 -0800404status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
405 audio_io_handle_t *input,
Mikhail Naganov2996f672019-04-18 12:29:59 -0700406 audio_unique_id_t riid,
Eric Laurentcaf7f482014-11-25 17:50:47 -0800407 audio_session_t session,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700408 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700409 uid_t uid,
Eric Laurentfee19762018-01-29 18:44:13 -0800410 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800411 const audio_config_base_t *config,
Paul McLean466dc8e2015-04-17 13:15:36 -0600412 audio_input_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700413 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800414 audio_port_handle_t *portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800415{
Eric Laurentdce54a12014-03-10 12:19:46 -0700416 if (mAudioPolicyManager == NULL) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800417 return NO_INIT;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800418 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800419
Hayden Gomes524159d2019-12-23 14:41:47 -0800420 status_t result = validateUsage(attr->usage, pid, uid);
421 if (result != NO_ERROR) {
422 return result;
423 }
424
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900425 audio_source_t inputSource = attr->source;
426 if (inputSource == AUDIO_SOURCE_DEFAULT) {
427 inputSource = AUDIO_SOURCE_MIC;
428 }
429
Eric Laurent2d388ec2014-03-07 13:25:54 -0800430 // already checked by client, but double-check in case the client wrapper is bypassed
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900431 if ((inputSource < AUDIO_SOURCE_DEFAULT)
432 || (inputSource >= AUDIO_SOURCE_CNT
433 && inputSource != AUDIO_SOURCE_HOTWORD
434 && inputSource != AUDIO_SOURCE_FM_TUNER
435 && inputSource != AUDIO_SOURCE_ECHO_REFERENCE)) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800436 return BAD_VALUE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800437 }
438
Eric Laurentb2379ba2016-05-23 17:42:12 -0700439 bool updatePid = (pid == -1);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700440 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700441 if (!isAudioServerOrMediaServerUid(callingUid)) {
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700442 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Marco Nelissendcb346b2015-09-09 10:47:29 -0700443 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
444 uid = callingUid;
Eric Laurentb2379ba2016-05-23 17:42:12 -0700445 updatePid = true;
446 }
447
448 if (updatePid) {
449 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700450 ALOGW_IF(pid != (pid_t)-1 && pid != callingPid,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700451 "%s uid %d pid %d tried to pass itself off as pid %d",
452 __func__, callingUid, callingPid, pid);
453 pid = callingPid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700454 }
455
Eric Laurent58a0dd82019-10-24 12:42:17 -0700456 // check calling permissions.
457 // Capturing from FM_TUNER source is controlled by captureAudioOutputAllowed() only as this
458 // does not affect users privacy as does capturing from an actual microphone.
459 if (!(recordingAllowed(opPackageName, pid, uid) || attr->source == AUDIO_SOURCE_FM_TUNER)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800460 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
461 __func__, uid, pid);
462 return PERMISSION_DENIED;
463 }
464
Eric Laurent1ff16a72019-03-14 18:35:04 -0700465 bool canCaptureOutput = captureAudioOutputAllowed(pid, uid);
Ricardo Correa57a37692020-03-23 17:27:25 -0700466 if ((inputSource == AUDIO_SOURCE_VOICE_UPLINK ||
467 inputSource == AUDIO_SOURCE_VOICE_DOWNLINK ||
468 inputSource == AUDIO_SOURCE_VOICE_CALL ||
469 inputSource == AUDIO_SOURCE_ECHO_REFERENCE||
470 inputSource == AUDIO_SOURCE_FM_TUNER) &&
Eric Laurent1ff16a72019-03-14 18:35:04 -0700471 !canCaptureOutput) {
Nadav Bar744be482018-05-08 13:26:21 +0300472 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.
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800506 case AudioPolicyInterface::API_INPUT_MIX_CAPTURE:
Eric Laurent1ff16a72019-03-14 18:35:04 -0700507 if (!canCaptureOutput) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800508 ALOGE("getInputForAttr() permission denied: capture not allowed");
509 status = PERMISSION_DENIED;
510 }
511 break;
512 case AudioPolicyInterface::API_INPUT_MIX_EXT_POLICY_REROUTE:
Eric Laurent8a1095a2019-11-08 14:44:16 -0800513 if (!modifyAudioRoutingAllowed(pid, uid)) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800514 ALOGE("getInputForAttr() permission denied: modify audio routing not allowed");
515 status = PERMISSION_DENIED;
516 }
517 break;
518 case AudioPolicyInterface::API_INPUT_INVALID:
519 default:
520 LOG_ALWAYS_FATAL("getInputForAttr() encountered an invalid input type %d",
521 (int)inputType);
522 }
523 }
524
525 if (status != NO_ERROR) {
526 if (status == PERMISSION_DENIED) {
Eric Laurent10b71232018-04-13 18:14:44 -0700527 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700528 mAudioPolicyManager->releaseInput(*portId);
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800529 }
530 return status;
531 }
Eric Laurentfee19762018-01-29 18:44:13 -0800532
Eric Laurent5ada82e2019-08-29 17:53:54 -0700533 sp<AudioRecordClient> client = new AudioRecordClient(*attr, *input, uid, pid, session, *portId,
Eric Laurent1ff16a72019-03-14 18:35:04 -0700534 *selectedDeviceId, opPackageName,
Ricardo Correa57a37692020-03-23 17:27:25 -0700535 canCaptureOutput, canCaptureHotword);
Eric Laurentfee19762018-01-29 18:44:13 -0800536 mAudioRecordClients.add(*portId, client);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700537 }
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800538
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700539 if (audioPolicyEffects != 0) {
540 // create audio pre processors according to input source
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900541 status_t status = audioPolicyEffects->addInputEffects(*input, inputSource, session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700542 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800543 ALOGW("Failed to add effects on input %d", *input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700544 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800545 }
Eric Laurentcaf7f482014-11-25 17:50:47 -0800546 return NO_ERROR;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800547}
548
Eric Laurent99fcae42018-05-17 16:59:18 -0700549std::string AudioPolicyService::getDeviceTypeStrForPortId(audio_port_handle_t portId) {
Eric Laurent99fcae42018-05-17 16:59:18 -0700550 struct audio_port port = {};
551 port.id = portId;
552 status_t status = mAudioPolicyManager->getAudioPort(&port);
553 if (status == NO_ERROR && port.type == AUDIO_PORT_TYPE_DEVICE) {
Andy Hung9b181952019-02-25 14:53:36 -0800554 return toString(port.ext.device.type);
Eric Laurent99fcae42018-05-17 16:59:18 -0700555 }
Andy Hung9b181952019-02-25 14:53:36 -0800556 return {};
Eric Laurent99fcae42018-05-17 16:59:18 -0700557}
558
Eric Laurent4eb58f12018-12-07 16:41:02 -0800559status_t AudioPolicyService::startInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800560{
Eric Laurentdce54a12014-03-10 12:19:46 -0700561 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800562 return NO_INIT;
563 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800564 sp<AudioRecordClient> client;
565 {
566 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800567
Eric Laurent7dca8a82018-01-29 18:44:26 -0800568 ssize_t index = mAudioRecordClients.indexOfKey(portId);
569 if (index < 0) {
570 return INVALID_OPERATION;
571 }
572 client = mAudioRecordClients.valueAt(index);
Eric Laurentfee19762018-01-29 18:44:13 -0800573 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800574
575 // check calling permissions
Narayan Kamathd1276442020-08-20 17:19:57 +0100576 if (!(startRecording(client->opPackageName, client->pid, client->uid,
577 client->attributes.source == AUDIO_SOURCE_HOTWORD)
Eric Laurent58a0dd82019-10-24 12:42:17 -0700578 || client->attributes.source == AUDIO_SOURCE_FM_TUNER)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800579 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
580 __func__, client->uid, client->pid);
581 return PERMISSION_DENIED;
582 }
Eric Laurentfee19762018-01-29 18:44:13 -0800583
Eric Laurentdf628922018-12-06 21:45:51 +0000584 Mutex::Autolock _l(mLock);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800585
586 client->active = true;
587 client->startTimeNs = systemTime();
588 updateUidStates_l();
Eric Laurentfee19762018-01-29 18:44:13 -0800589
Eric Laurent10b71232018-04-13 18:14:44 -0700590 status_t status;
591 {
592 AutoCallerClear acc;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800593 status = mAudioPolicyManager->startInput(portId);
Ray Essick84e84a52018-05-03 18:45:07 -0700594
595 }
596
Ray Essickf6a57cd2018-05-22 16:20:54 -0700597 // including successes gets very verbose
Muhammad Qureshi087b37c2020-06-16 16:37:36 -0700598 // but once we cut over to statsd, log them all.
Ray Essickf6a57cd2018-05-22 16:20:54 -0700599 if (status != NO_ERROR) {
Ray Essick84e84a52018-05-03 18:45:07 -0700600
601 static constexpr char kAudioPolicy[] = "audiopolicy";
602
Ray Essick84e84a52018-05-03 18:45:07 -0700603 static constexpr char kAudioPolicyStatus[] = "android.media.audiopolicy.status";
604 static constexpr char kAudioPolicyRqstSrc[] = "android.media.audiopolicy.rqst.src";
605 static constexpr char kAudioPolicyRqstPkg[] = "android.media.audiopolicy.rqst.pkg";
606 static constexpr char kAudioPolicyRqstSession[] = "android.media.audiopolicy.rqst.session";
Eric Laurent99fcae42018-05-17 16:59:18 -0700607 static constexpr char kAudioPolicyRqstDevice[] =
608 "android.media.audiopolicy.rqst.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700609 static constexpr char kAudioPolicyActiveSrc[] = "android.media.audiopolicy.active.src";
610 static constexpr char kAudioPolicyActivePkg[] = "android.media.audiopolicy.active.pkg";
Eric Laurent99fcae42018-05-17 16:59:18 -0700611 static constexpr char kAudioPolicyActiveSession[] =
612 "android.media.audiopolicy.active.session";
613 static constexpr char kAudioPolicyActiveDevice[] =
614 "android.media.audiopolicy.active.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700615
Ray Essickf27e9872019-12-07 06:28:46 -0800616 mediametrics::Item *item = mediametrics::Item::create(kAudioPolicy);
Ray Essick84e84a52018-05-03 18:45:07 -0700617 if (item != NULL) {
618
Ray Essick84e84a52018-05-03 18:45:07 -0700619 item->setInt32(kAudioPolicyStatus, status);
620
Eric Laurent99fcae42018-05-17 16:59:18 -0700621 item->setCString(kAudioPolicyRqstSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800622 toString(client->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700623 item->setInt32(kAudioPolicyRqstSession, client->session);
Ray Essick51866952018-05-30 11:22:27 -0700624 if (client->opPackageName.size() != 0) {
625 item->setCString(kAudioPolicyRqstPkg,
626 std::string(String8(client->opPackageName).string()).c_str());
627 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700628 item->setCString(kAudioPolicyRqstPkg, std::to_string(client->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700629 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700630 item->setCString(
631 kAudioPolicyRqstDevice, getDeviceTypeStrForPortId(client->deviceId).c_str());
632
Eric Laurent4eb58f12018-12-07 16:41:02 -0800633 int count = mAudioRecordClients.size();
634 for (int i = 0; i < count ; i++) {
635 if (portId == mAudioRecordClients.keyAt(i)) {
636 continue;
637 }
638 sp<AudioRecordClient> other = mAudioRecordClients.valueAt(i);
639 if (other->active) {
640 // keeps the last of the clients marked active
641 item->setCString(kAudioPolicyActiveSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800642 toString(other->attributes.source).c_str());
Eric Laurent4eb58f12018-12-07 16:41:02 -0800643 item->setInt32(kAudioPolicyActiveSession, other->session);
644 if (other->opPackageName.size() != 0) {
645 item->setCString(kAudioPolicyActivePkg,
646 std::string(String8(other->opPackageName).string()).c_str());
647 } else {
648 item->setCString(kAudioPolicyRqstPkg,
649 std::to_string(other->uid).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700650 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800651 item->setCString(kAudioPolicyActiveDevice,
652 getDeviceTypeStrForPortId(other->deviceId).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700653 }
654 }
655 item->selfrecord();
656 delete item;
657 item = NULL;
658 }
Ray Essick6ce27e52019-02-15 10:58:05 -0800659 }
660
661 if (status != NO_ERROR) {
Eric Laurent4eb58f12018-12-07 16:41:02 -0800662 client->active = false;
663 client->startTimeNs = 0;
664 updateUidStates_l();
Narayan Kamathd1276442020-08-20 17:19:57 +0100665 finishRecording(client->opPackageName, client->uid,
666 client->attributes.source == AUDIO_SOURCE_HOTWORD);
Eric Laurentfb66dd92016-01-28 18:32:03 -0800667 }
668
669 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800670}
671
Eric Laurentfee19762018-01-29 18:44:13 -0800672status_t AudioPolicyService::stopInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800673{
Eric Laurentdce54a12014-03-10 12:19:46 -0700674 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800675 return NO_INIT;
676 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800677
Eric Laurent2d388ec2014-03-07 13:25:54 -0800678 Mutex::Autolock _l(mLock);
679
Eric Laurentfee19762018-01-29 18:44:13 -0800680 ssize_t index = mAudioRecordClients.indexOfKey(portId);
681 if (index < 0) {
682 return INVALID_OPERATION;
683 }
684 sp<AudioRecordClient> client = mAudioRecordClients.valueAt(index);
685
Ray Essick84e84a52018-05-03 18:45:07 -0700686 client->active = false;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800687 client->startTimeNs = 0;
688
689 updateUidStates_l();
Ray Essick84e84a52018-05-03 18:45:07 -0700690
Svet Ganov6e641372018-03-02 09:21:30 -0800691 // finish the recording app op
Narayan Kamathd1276442020-08-20 17:19:57 +0100692 finishRecording(client->opPackageName, client->uid,
693 client->attributes.source == AUDIO_SOURCE_HOTWORD);
Eric Laurent10b71232018-04-13 18:14:44 -0700694 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700695 return mAudioPolicyManager->stopInput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800696}
697
Eric Laurentfee19762018-01-29 18:44:13 -0800698void AudioPolicyService::releaseInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800699{
Eric Laurentdce54a12014-03-10 12:19:46 -0700700 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800701 return;
702 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700703 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800704 sp<AudioRecordClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700705 {
706 Mutex::Autolock _l(mLock);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700707 audioPolicyEffects = mAudioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800708 ssize_t index = mAudioRecordClients.indexOfKey(portId);
709 if (index < 0) {
710 return;
711 }
712 client = mAudioRecordClients.valueAt(index);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800713
714 if (client->active) {
715 ALOGW("%s releasing active client portId %d", __FUNCTION__, portId);
716 client->active = false;
717 client->startTimeNs = 0;
718 updateUidStates_l();
719 }
720
Eric Laurentfee19762018-01-29 18:44:13 -0800721 mAudioRecordClients.removeItem(portId);
722 }
723 if (client == 0) {
724 return;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700725 }
726 if (audioPolicyEffects != 0) {
727 // release audio processors from the input
Eric Laurentd7fe0862018-07-14 16:48:01 -0700728 status_t status = audioPolicyEffects->releaseInputEffects(client->io, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700729 if(status != NO_ERROR) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700730 ALOGW("Failed to release effects on input %d", client->io);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700731 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800732 }
Eric Laurentf10c7092016-12-06 17:09:56 -0800733 {
734 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700735 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700736 mAudioPolicyManager->releaseInput(portId);
Eric Laurentf10c7092016-12-06 17:09:56 -0800737 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800738}
739
740status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
741 int indexMin,
742 int indexMax)
743{
Eric Laurentdce54a12014-03-10 12:19:46 -0700744 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800745 return NO_INIT;
746 }
747 if (!settingsAllowed()) {
748 return PERMISSION_DENIED;
749 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800750 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800751 return BAD_VALUE;
752 }
753 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700754 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700755 mAudioPolicyManager->initStreamVolume(stream, indexMin, indexMax);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800756 return NO_ERROR;
757}
758
759status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
760 int index,
761 audio_devices_t device)
762{
Eric Laurentdce54a12014-03-10 12:19:46 -0700763 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800764 return NO_INIT;
765 }
766 if (!settingsAllowed()) {
767 return PERMISSION_DENIED;
768 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800769 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800770 return BAD_VALUE;
771 }
772 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700773 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700774 return mAudioPolicyManager->setStreamVolumeIndex(stream,
775 index,
776 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800777}
778
779status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
780 int *index,
781 audio_devices_t device)
782{
Eric Laurentdce54a12014-03-10 12:19:46 -0700783 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800784 return NO_INIT;
785 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800786 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800787 return BAD_VALUE;
788 }
789 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700790 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700791 return mAudioPolicyManager->getStreamVolumeIndex(stream,
792 index,
793 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800794}
795
François Gaffiecfe17322018-11-07 13:41:29 +0100796status_t AudioPolicyService::setVolumeIndexForAttributes(const audio_attributes_t &attributes,
797 int index, audio_devices_t device)
798{
799 if (mAudioPolicyManager == NULL) {
800 return NO_INIT;
801 }
802 if (!settingsAllowed()) {
803 return PERMISSION_DENIED;
804 }
805 Mutex::Autolock _l(mLock);
806 AutoCallerClear acc;
807 return mAudioPolicyManager->setVolumeIndexForAttributes(attributes, index, device);
808}
809
810status_t AudioPolicyService::getVolumeIndexForAttributes(const audio_attributes_t &attributes,
811 int &index, audio_devices_t device)
812{
813 if (mAudioPolicyManager == NULL) {
814 return NO_INIT;
815 }
816 Mutex::Autolock _l(mLock);
817 AutoCallerClear acc;
818 return mAudioPolicyManager->getVolumeIndexForAttributes(attributes, index, device);
819}
820
821status_t AudioPolicyService::getMinVolumeIndexForAttributes(const audio_attributes_t &attributes,
822 int &index)
823{
824 if (mAudioPolicyManager == NULL) {
825 return NO_INIT;
826 }
827 Mutex::Autolock _l(mLock);
828 AutoCallerClear acc;
829 return mAudioPolicyManager->getMinVolumeIndexForAttributes(attributes, index);
830}
831
832status_t AudioPolicyService::getMaxVolumeIndexForAttributes(const audio_attributes_t &attributes,
833 int &index)
834{
835 if (mAudioPolicyManager == NULL) {
836 return NO_INIT;
837 }
838 Mutex::Autolock _l(mLock);
839 AutoCallerClear acc;
840 return mAudioPolicyManager->getMaxVolumeIndexForAttributes(attributes, index);
841}
842
Eric Laurent2d388ec2014-03-07 13:25:54 -0800843uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
844{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800845 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
François Gaffiec005e562018-11-06 15:04:49 +0100846 return PRODUCT_STRATEGY_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700847 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700848 if (mAudioPolicyManager == NULL) {
François Gaffiec005e562018-11-06 15:04:49 +0100849 return PRODUCT_STRATEGY_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800850 }
François Gaffiec005e562018-11-06 15:04:49 +0100851 // DO NOT LOCK, may be called from AudioFlinger with lock held, reaching deadlock
Eric Laurent10b71232018-04-13 18:14:44 -0700852 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700853 return mAudioPolicyManager->getStrategyForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800854}
855
856//audio policy: use audio_device_t appropriately
857
858audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
859{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800860 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700861 return AUDIO_DEVICE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700862 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700863 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700864 return AUDIO_DEVICE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800865 }
Haynes Mathew Georgedfb9f3b2015-10-26 18:22:13 -0700866 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700867 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700868 return mAudioPolicyManager->getDevicesForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800869}
870
Jean-Michel Trivif41599b2020-01-07 14:22:08 -0800871status_t AudioPolicyService::getDevicesForAttributes(const AudioAttributes &aa,
Hayden Gomes524159d2019-12-23 14:41:47 -0800872 AudioDeviceTypeAddrVector *devices) const
Jean-Michel Trivif41599b2020-01-07 14:22:08 -0800873{
874 if (mAudioPolicyManager == NULL) {
875 return NO_INIT;
876 }
877 Mutex::Autolock _l(mLock);
878 AutoCallerClear acc;
879 return mAudioPolicyManager->getDevicesForAttributes(aa.getAttributes(), devices);
880}
881
Eric Laurent2d388ec2014-03-07 13:25:54 -0800882audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
883{
884 // FIXME change return type to status_t, and return NO_INIT here
Eric Laurentdce54a12014-03-10 12:19:46 -0700885 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800886 return 0;
887 }
888 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700889 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700890 return mAudioPolicyManager->getOutputForEffect(desc);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800891}
892
893status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
894 audio_io_handle_t io,
895 uint32_t strategy,
Glenn Kastend848eb42016-03-08 13:42:11 -0800896 audio_session_t session,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800897 int id)
898{
Eric Laurentdce54a12014-03-10 12:19:46 -0700899 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800900 return NO_INIT;
901 }
Eric Laurent6c796322019-04-09 14:13:17 -0700902 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700903 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700904 return mAudioPolicyManager->registerEffect(desc, io, strategy, session, id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800905}
906
907status_t AudioPolicyService::unregisterEffect(int id)
908{
Eric Laurentdce54a12014-03-10 12:19:46 -0700909 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800910 return NO_INIT;
911 }
Eric Laurent6c796322019-04-09 14:13:17 -0700912 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700913 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700914 return mAudioPolicyManager->unregisterEffect(id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800915}
916
917status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
918{
Eric Laurentdce54a12014-03-10 12:19:46 -0700919 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800920 return NO_INIT;
921 }
Eric Laurent6c796322019-04-09 14:13:17 -0700922 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700923 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700924 return mAudioPolicyManager->setEffectEnabled(id, enabled);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800925}
926
Eric Laurent6c796322019-04-09 14:13:17 -0700927status_t AudioPolicyService::moveEffectsToIo(const std::vector<int>& ids, audio_io_handle_t io)
928{
929 if (mAudioPolicyManager == NULL) {
930 return NO_INIT;
931 }
932 Mutex::Autolock _l(mLock);
933 AutoCallerClear acc;
934 return mAudioPolicyManager->moveEffectsToIo(ids, io);
935}
936
Eric Laurent2d388ec2014-03-07 13:25:54 -0800937bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
938{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800939 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700940 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700941 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700942 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700943 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800944 }
945 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700946 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700947 return mAudioPolicyManager->isStreamActive(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800948}
949
950bool AudioPolicyService::isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs) const
951{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800952 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700953 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700954 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700955 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700956 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800957 }
958 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700959 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700960 return mAudioPolicyManager->isStreamActiveRemotely(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800961}
962
963bool AudioPolicyService::isSourceActive(audio_source_t source) const
964{
Eric Laurentdce54a12014-03-10 12:19:46 -0700965 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800966 return false;
967 }
968 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700969 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700970 return mAudioPolicyManager->isSourceActive(source);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800971}
972
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700973status_t AudioPolicyService::getAudioPolicyEffects(sp<AudioPolicyEffects>& audioPolicyEffects)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800974{
Eric Laurentdce54a12014-03-10 12:19:46 -0700975 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800976 return NO_INIT;
977 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700978 {
979 Mutex::Autolock _l(mLock);
980 audioPolicyEffects = mAudioPolicyEffects;
981 }
982 if (audioPolicyEffects == 0) {
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700983 return NO_INIT;
984 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700985
986 return OK;
987}
988
989status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
990 effect_descriptor_t *descriptors,
991 uint32_t *count)
992{
993 sp<AudioPolicyEffects>audioPolicyEffects;
994 status_t status = getAudioPolicyEffects(audioPolicyEffects);
995 if (status != OK) {
996 *count = 0;
997 return status;
998 }
Eric Laurentfb66dd92016-01-28 18:32:03 -0800999 return audioPolicyEffects->queryDefaultInputEffects(
1000 (audio_session_t)audioSession, descriptors, count);
Eric Laurent2d388ec2014-03-07 13:25:54 -08001001}
1002
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001003status_t AudioPolicyService::addSourceDefaultEffect(const effect_uuid_t *type,
1004 const String16& opPackageName,
1005 const effect_uuid_t *uuid,
1006 int32_t priority,
1007 audio_source_t source,
1008 audio_unique_id_t* id)
1009{
1010 sp<AudioPolicyEffects>audioPolicyEffects;
1011 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1012 if (status != OK) {
1013 return status;
1014 }
1015 if (!modifyDefaultAudioEffectsAllowed()) {
1016 return PERMISSION_DENIED;
1017 }
1018 return audioPolicyEffects->addSourceDefaultEffect(
1019 type, opPackageName, uuid, priority, source, id);
1020}
1021
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001022status_t AudioPolicyService::addStreamDefaultEffect(const effect_uuid_t *type,
1023 const String16& opPackageName,
1024 const effect_uuid_t *uuid,
1025 int32_t priority,
1026 audio_usage_t usage,
1027 audio_unique_id_t* id)
1028{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001029 sp<AudioPolicyEffects>audioPolicyEffects;
1030 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1031 if (status != OK) {
1032 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001033 }
1034 if (!modifyDefaultAudioEffectsAllowed()) {
1035 return PERMISSION_DENIED;
1036 }
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001037 return audioPolicyEffects->addStreamDefaultEffect(
1038 type, opPackageName, uuid, priority, usage, id);
1039}
1040
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001041status_t AudioPolicyService::removeSourceDefaultEffect(audio_unique_id_t id)
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001042{
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-Cohen24628312018-08-13 15:01:09 -07001051 return audioPolicyEffects->removeSourceDefaultEffect(id);
1052}
1053
1054status_t AudioPolicyService::removeStreamDefaultEffect(audio_unique_id_t id)
1055{
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001056 sp<AudioPolicyEffects>audioPolicyEffects;
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001057 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1058 if (status != OK) {
1059 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001060 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001061 if (!modifyDefaultAudioEffectsAllowed()) {
1062 return PERMISSION_DENIED;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001063 }
1064 return audioPolicyEffects->removeStreamDefaultEffect(id);
1065}
1066
Hayden Gomes524159d2019-12-23 14:41:47 -08001067status_t AudioPolicyService::setSupportedSystemUsages(const std::vector<audio_usage_t>& systemUsages) {
1068 Mutex::Autolock _l(mLock);
1069 if(!modifyAudioRoutingAllowed()) {
1070 return PERMISSION_DENIED;
1071 }
1072
1073 bool areAllSystemUsages = std::all_of(begin(systemUsages), end(systemUsages),
1074 [](audio_usage_t usage) { return isSystemUsage(usage); });
1075 if (!areAllSystemUsages) {
1076 return BAD_VALUE;
1077 }
1078
1079 mSupportedSystemUsages = systemUsages;
1080 return NO_ERROR;
1081}
1082
Kevin Rocardb99cc752019-03-21 20:52:24 -07001083status_t AudioPolicyService::setAllowedCapturePolicy(uid_t uid, audio_flags_mask_t capturePolicy) {
1084 Mutex::Autolock _l(mLock);
1085 if (mAudioPolicyManager == NULL) {
1086 ALOGV("%s() mAudioPolicyManager == NULL", __func__);
1087 return NO_INIT;
1088 }
Kevin Rocardb99cc752019-03-21 20:52:24 -07001089 return mAudioPolicyManager->setAllowedCapturePolicy(uid, capturePolicy);
1090}
1091
Eric Laurent2d388ec2014-03-07 13:25:54 -08001092bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
1093{
Eric Laurentdce54a12014-03-10 12:19:46 -07001094 if (mAudioPolicyManager == NULL) {
1095 ALOGV("mAudioPolicyManager == NULL");
Eric Laurent2d388ec2014-03-07 13:25:54 -08001096 return false;
1097 }
Andy Hung2ddee192015-12-18 17:34:44 -08001098 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001099 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -07001100 return mAudioPolicyManager->isOffloadSupported(info);
Eric Laurent2d388ec2014-03-07 13:25:54 -08001101}
1102
Michael Chana94fbb22018-04-24 14:31:19 +10001103bool AudioPolicyService::isDirectOutputSupported(const audio_config_base_t& config,
1104 const audio_attributes_t& attributes) {
1105 if (mAudioPolicyManager == NULL) {
1106 ALOGV("mAudioPolicyManager == NULL");
1107 return false;
1108 }
Hayden Gomes524159d2019-12-23 14:41:47 -08001109
1110 status_t result = validateUsage(attributes.usage);
1111 if (result != NO_ERROR) {
1112 return result;
1113 }
1114
Michael Chana94fbb22018-04-24 14:31:19 +10001115 Mutex::Autolock _l(mLock);
1116 return mAudioPolicyManager->isDirectOutputSupported(config, attributes);
1117}
1118
1119
Eric Laurent6a94d692014-05-20 11:18:06 -07001120status_t AudioPolicyService::listAudioPorts(audio_port_role_t role,
1121 audio_port_type_t type,
Eric Laurent203b1a12014-04-01 10:34:16 -07001122 unsigned int *num_ports,
Eric Laurent6a94d692014-05-20 11:18:06 -07001123 struct audio_port *ports,
1124 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001125{
Eric Laurent6a94d692014-05-20 11:18:06 -07001126 Mutex::Autolock _l(mLock);
1127 if (mAudioPolicyManager == NULL) {
1128 return NO_INIT;
1129 }
Eric Laurent10b71232018-04-13 18:14:44 -07001130 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001131 return mAudioPolicyManager->listAudioPorts(role, type, num_ports, ports, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001132}
1133
Eric Laurent6a94d692014-05-20 11:18:06 -07001134status_t AudioPolicyService::getAudioPort(struct audio_port *port)
Eric Laurent203b1a12014-04-01 10:34:16 -07001135{
Eric Laurent6a94d692014-05-20 11:18:06 -07001136 Mutex::Autolock _l(mLock);
1137 if (mAudioPolicyManager == NULL) {
1138 return NO_INIT;
1139 }
Eric Laurent10b71232018-04-13 18:14:44 -07001140 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001141 return mAudioPolicyManager->getAudioPort(port);
Eric Laurent203b1a12014-04-01 10:34:16 -07001142}
1143
Eric Laurent6a94d692014-05-20 11:18:06 -07001144status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch,
1145 audio_patch_handle_t *handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001146{
Eric Laurent6a94d692014-05-20 11:18:06 -07001147 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001148 if(!modifyAudioRoutingAllowed()) {
1149 return PERMISSION_DENIED;
1150 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001151 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->createAudioPatch(patch, handle,
1156 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001157}
1158
Eric Laurent6a94d692014-05-20 11:18:06 -07001159status_t AudioPolicyService::releaseAudioPatch(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->releaseAudioPatch(handle,
1170 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001171}
1172
1173status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
Eric Laurent6a94d692014-05-20 11:18:06 -07001174 struct audio_patch *patches,
1175 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001176{
Eric Laurent6a94d692014-05-20 11:18:06 -07001177 Mutex::Autolock _l(mLock);
1178 if (mAudioPolicyManager == NULL) {
1179 return NO_INIT;
1180 }
Eric Laurent10b71232018-04-13 18:14:44 -07001181 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001182 return mAudioPolicyManager->listAudioPatches(num_patches, patches, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001183}
1184
Eric Laurent6a94d692014-05-20 11:18:06 -07001185status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config)
Eric Laurent203b1a12014-04-01 10:34:16 -07001186{
Eric Laurent6a94d692014-05-20 11:18:06 -07001187 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001188 if(!modifyAudioRoutingAllowed()) {
1189 return PERMISSION_DENIED;
1190 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001191 if (mAudioPolicyManager == NULL) {
1192 return NO_INIT;
1193 }
Eric Laurent10b71232018-04-13 18:14:44 -07001194 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001195 return mAudioPolicyManager->setAudioPortConfig(config);
Eric Laurent203b1a12014-04-01 10:34:16 -07001196}
Eric Laurent2d388ec2014-03-07 13:25:54 -08001197
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001198status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session,
1199 audio_io_handle_t *ioHandle,
1200 audio_devices_t *device)
1201{
Andy Hungf759b8c2017-08-15 12:48:54 -07001202 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001203 if (mAudioPolicyManager == NULL) {
1204 return NO_INIT;
1205 }
Eric Laurent10b71232018-04-13 18:14:44 -07001206 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001207 return mAudioPolicyManager->acquireSoundTriggerSession(session, ioHandle, device);
1208}
1209
1210status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session)
1211{
Andy Hungf759b8c2017-08-15 12:48:54 -07001212 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001213 if (mAudioPolicyManager == NULL) {
1214 return NO_INIT;
1215 }
Eric Laurent10b71232018-04-13 18:14:44 -07001216 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001217 return mAudioPolicyManager->releaseSoundTriggerSession(session);
1218}
1219
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -07001220status_t AudioPolicyService::registerPolicyMixes(const Vector<AudioMix>& mixes, bool registration)
Eric Laurentbaac1832014-12-01 17:52:59 -08001221{
1222 Mutex::Autolock _l(mLock);
Kevin Rocardbe201852019-02-20 22:33:28 -08001223
1224 // loopback|render only need a MediaProjection (checked in caller AudioService.java)
1225 bool needModifyAudioRouting = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
1226 return !is_mix_loopback_render(mix.mRouteFlags); });
1227 if (needModifyAudioRouting && !modifyAudioRoutingAllowed()) {
Eric Laurentbaac1832014-12-01 17:52:59 -08001228 return PERMISSION_DENIED;
1229 }
Kevin Rocardbe201852019-02-20 22:33:28 -08001230
Nadav Bar287d3302020-02-05 14:55:38 +02001231 // If one of the mixes has needCaptureVoiceCommunicationOutput set to true, then we
1232 // need to verify that the caller still has CAPTURE_VOICE_COMMUNICATION_OUTPUT
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001233 bool needCaptureVoiceCommunicationOutput =
1234 std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
Nadav Bar287d3302020-02-05 14:55:38 +02001235 return mix.mVoiceCommunicationCaptureAllowed; });
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001236
Kevin Rocard36b17552019-03-07 18:48:07 -08001237 bool needCaptureMediaOutput = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
Nadav Bar287d3302020-02-05 14:55:38 +02001238 return mix.mAllowPrivilegedPlaybackCapture; });
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001239
Kevin Rocard36b17552019-03-07 18:48:07 -08001240 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
1241 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001242
Kevin Rocard36b17552019-03-07 18:48:07 -08001243 if (needCaptureMediaOutput && !captureMediaOutputAllowed(callingPid, callingUid)) {
1244 return PERMISSION_DENIED;
1245 }
1246
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001247 if (needCaptureVoiceCommunicationOutput &&
1248 !captureVoiceCommunicationOutputAllowed(callingPid, callingUid)) {
1249 return PERMISSION_DENIED;
1250 }
1251
Eric Laurentbaac1832014-12-01 17:52:59 -08001252 if (mAudioPolicyManager == NULL) {
1253 return NO_INIT;
1254 }
Eric Laurent10b71232018-04-13 18:14:44 -07001255 AutoCallerClear acc;
Eric Laurentbaac1832014-12-01 17:52:59 -08001256 if (registration) {
1257 return mAudioPolicyManager->registerPolicyMixes(mixes);
1258 } else {
1259 return mAudioPolicyManager->unregisterPolicyMixes(mixes);
1260 }
1261}
1262
Jean-Michel Trivibda70da2018-12-19 07:30:15 -08001263status_t AudioPolicyService::setUidDeviceAffinities(uid_t uid,
1264 const Vector<AudioDeviceTypeAddr>& devices) {
1265 Mutex::Autolock _l(mLock);
1266 if(!modifyAudioRoutingAllowed()) {
1267 return PERMISSION_DENIED;
1268 }
1269 if (mAudioPolicyManager == NULL) {
1270 return NO_INIT;
1271 }
1272 AutoCallerClear acc;
1273 return mAudioPolicyManager->setUidDeviceAffinities(uid, devices);
1274}
1275
1276status_t AudioPolicyService::removeUidDeviceAffinities(uid_t uid) {
1277 Mutex::Autolock _l(mLock);
1278 if(!modifyAudioRoutingAllowed()) {
1279 return PERMISSION_DENIED;
1280 }
1281 if (mAudioPolicyManager == NULL) {
1282 return NO_INIT;
1283 }
1284 AutoCallerClear acc;
1285 return mAudioPolicyManager->removeUidDeviceAffinities(uid);
1286}
1287
Oscar Azucena90e77632019-11-27 17:12:28 -08001288status_t AudioPolicyService::setUserIdDeviceAffinities(int userId,
1289 const Vector<AudioDeviceTypeAddr>& devices) {
1290 Mutex::Autolock _l(mLock);
1291 if(!modifyAudioRoutingAllowed()) {
1292 return PERMISSION_DENIED;
1293 }
1294 if (mAudioPolicyManager == NULL) {
1295 return NO_INIT;
1296 }
1297 AutoCallerClear acc;
1298 return mAudioPolicyManager->setUserIdDeviceAffinities(userId, devices);
1299}
1300
1301status_t AudioPolicyService::removeUserIdDeviceAffinities(int userId) {
1302 Mutex::Autolock _l(mLock);
1303 if(!modifyAudioRoutingAllowed()) {
1304 return PERMISSION_DENIED;
1305 }
1306 if (mAudioPolicyManager == NULL) {
1307 return NO_INIT;
1308 }
1309 AutoCallerClear acc;
1310 return mAudioPolicyManager->removeUserIdDeviceAffinities(userId);
1311}
1312
Eric Laurent554a2772015-04-10 11:29:24 -07001313status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001314 const audio_attributes_t *attributes,
1315 audio_port_handle_t *portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001316{
1317 Mutex::Autolock _l(mLock);
1318 if (mAudioPolicyManager == NULL) {
1319 return NO_INIT;
1320 }
Hayden Gomes524159d2019-12-23 14:41:47 -08001321
1322 status_t result = validateUsage(attributes->usage);
1323 if (result != NO_ERROR) {
1324 return result;
1325 }
1326
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001327 // startAudioSource should be created as the calling uid
1328 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Eric Laurent10b71232018-04-13 18:14:44 -07001329 AutoCallerClear acc;
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001330 return mAudioPolicyManager->startAudioSource(source, attributes, portId, callingUid);
Eric Laurent554a2772015-04-10 11:29:24 -07001331}
1332
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001333status_t AudioPolicyService::stopAudioSource(audio_port_handle_t portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001334{
1335 Mutex::Autolock _l(mLock);
1336 if (mAudioPolicyManager == NULL) {
1337 return NO_INIT;
1338 }
Eric Laurent10b71232018-04-13 18:14:44 -07001339 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001340 return mAudioPolicyManager->stopAudioSource(portId);
Eric Laurent554a2772015-04-10 11:29:24 -07001341}
1342
Andy Hung2ddee192015-12-18 17:34:44 -08001343status_t AudioPolicyService::setMasterMono(bool mono)
1344{
1345 if (mAudioPolicyManager == NULL) {
1346 return NO_INIT;
1347 }
1348 if (!settingsAllowed()) {
1349 return PERMISSION_DENIED;
1350 }
1351 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001352 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001353 return mAudioPolicyManager->setMasterMono(mono);
1354}
1355
1356status_t AudioPolicyService::getMasterMono(bool *mono)
1357{
1358 if (mAudioPolicyManager == NULL) {
1359 return NO_INIT;
1360 }
1361 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001362 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001363 return mAudioPolicyManager->getMasterMono(mono);
1364}
1365
Eric Laurentac9cef52017-06-09 15:46:26 -07001366
1367float AudioPolicyService::getStreamVolumeDB(
1368 audio_stream_type_t stream, int index, audio_devices_t device)
1369{
1370 if (mAudioPolicyManager == NULL) {
1371 return NAN;
1372 }
1373 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001374 AutoCallerClear acc;
Eric Laurentac9cef52017-06-09 15:46:26 -07001375 return mAudioPolicyManager->getStreamVolumeDB(stream, index, device);
1376}
1377
jiabin81772902018-04-02 17:52:27 -07001378status_t AudioPolicyService::getSurroundFormats(unsigned int *numSurroundFormats,
1379 audio_format_t *surroundFormats,
1380 bool *surroundFormatsEnabled,
1381 bool reported)
1382{
1383 if (mAudioPolicyManager == NULL) {
1384 return NO_INIT;
1385 }
1386 Mutex::Autolock _l(mLock);
1387 AutoCallerClear acc;
1388 return mAudioPolicyManager->getSurroundFormats(numSurroundFormats, surroundFormats,
1389 surroundFormatsEnabled, reported);
1390}
1391
Arun Mirpuri11029ad2018-12-19 20:45:19 -08001392status_t AudioPolicyService::getHwOffloadEncodingFormatsSupportedForA2DP(
1393 std::vector<audio_format_t> *formats)
1394{
1395 if (mAudioPolicyManager == NULL) {
1396 return NO_INIT;
1397 }
1398 Mutex::Autolock _l(mLock);
1399 AutoCallerClear acc;
1400 return mAudioPolicyManager->getHwOffloadEncodingFormatsSupportedForA2DP(formats);
1401}
1402
jiabin81772902018-04-02 17:52:27 -07001403status_t AudioPolicyService::setSurroundFormatEnabled(audio_format_t audioFormat, bool enabled)
1404{
1405 if (mAudioPolicyManager == NULL) {
1406 return NO_INIT;
1407 }
1408 Mutex::Autolock _l(mLock);
1409 AutoCallerClear acc;
1410 return mAudioPolicyManager->setSurroundFormatEnabled(audioFormat, enabled);
1411}
Eric Laurentac9cef52017-06-09 15:46:26 -07001412
Eric Laurentb78763e2018-10-17 10:08:02 -07001413status_t AudioPolicyService::setAssistantUid(uid_t uid)
1414{
1415 Mutex::Autolock _l(mLock);
1416 mUidPolicy->setAssistantUid(uid);
1417 return NO_ERROR;
1418}
1419
1420status_t AudioPolicyService::setA11yServicesUids(const std::vector<uid_t>& uids)
1421{
1422 Mutex::Autolock _l(mLock);
1423 mUidPolicy->setA11yUids(uids);
1424 return NO_ERROR;
1425}
1426
Kohsuke Yatoha623a132020-03-24 20:10:26 -07001427status_t AudioPolicyService::setCurrentImeUid(uid_t uid)
1428{
1429 Mutex::Autolock _l(mLock);
1430 mUidPolicy->setCurrentImeUid(uid);
1431 return NO_ERROR;
1432}
1433
jiabin6012f912018-11-02 17:06:30 -07001434bool AudioPolicyService::isHapticPlaybackSupported()
1435{
1436 if (mAudioPolicyManager == NULL) {
1437 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1438 return false;
1439 }
1440 Mutex::Autolock _l(mLock);
1441 AutoCallerClear acc;
1442 return mAudioPolicyManager->isHapticPlaybackSupported();
1443}
1444
François Gaffied0ba9ed2018-11-05 11:50:42 +01001445status_t AudioPolicyService::listAudioProductStrategies(AudioProductStrategyVector &strategies)
1446{
1447 if (mAudioPolicyManager == NULL) {
1448 return NO_INIT;
1449 }
1450 Mutex::Autolock _l(mLock);
1451 return mAudioPolicyManager->listAudioProductStrategies(strategies);
1452}
1453
François Gaffie4b2018b2018-11-07 11:18:59 +01001454status_t AudioPolicyService::getProductStrategyFromAudioAttributes(
1455 const AudioAttributes &aa, product_strategy_t &productStrategy)
François Gaffied0ba9ed2018-11-05 11:50:42 +01001456{
1457 if (mAudioPolicyManager == NULL) {
François Gaffie4b2018b2018-11-07 11:18:59 +01001458 return NO_INIT;
François Gaffied0ba9ed2018-11-05 11:50:42 +01001459 }
1460 Mutex::Autolock _l(mLock);
François Gaffie4b2018b2018-11-07 11:18:59 +01001461 return mAudioPolicyManager->getProductStrategyFromAudioAttributes(aa, productStrategy);
1462}
1463
1464status_t AudioPolicyService::listAudioVolumeGroups(AudioVolumeGroupVector &groups)
1465{
1466 if (mAudioPolicyManager == NULL) {
1467 return NO_INIT;
1468 }
1469 Mutex::Autolock _l(mLock);
1470 return mAudioPolicyManager->listAudioVolumeGroups(groups);
1471}
1472
1473status_t AudioPolicyService::getVolumeGroupFromAudioAttributes(const AudioAttributes &aa,
1474 volume_group_t &volumeGroup)
1475{
1476 if (mAudioPolicyManager == NULL) {
1477 return NO_INIT;
1478 }
1479 Mutex::Autolock _l(mLock);
1480 return mAudioPolicyManager->getVolumeGroupFromAudioAttributes(aa, volumeGroup);
François Gaffied0ba9ed2018-11-05 11:50:42 +01001481}
Eric Laurent6ede98f2019-06-11 14:50:30 -07001482
1483status_t AudioPolicyService::setRttEnabled(bool enabled)
1484{
1485 Mutex::Autolock _l(mLock);
1486 mUidPolicy->setRttEnabled(enabled);
1487 return NO_ERROR;
1488}
1489
Eric Laurent8340e672019-11-06 11:01:08 -08001490bool AudioPolicyService::isCallScreenModeSupported()
1491{
1492 if (mAudioPolicyManager == NULL) {
1493 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1494 return false;
1495 }
1496 Mutex::Autolock _l(mLock);
1497 AutoCallerClear acc;
1498 return mAudioPolicyManager->isCallScreenModeSupported();
1499}
1500
Jean-Michel Trivi30857152019-11-01 11:04:15 -07001501status_t AudioPolicyService::setPreferredDeviceForStrategy(product_strategy_t strategy,
1502 const AudioDeviceTypeAddr &device)
1503{
1504 if (mAudioPolicyManager == NULL) {
1505 return NO_INIT;
1506 }
1507 Mutex::Autolock _l(mLock);
1508 return mAudioPolicyManager->setPreferredDeviceForStrategy(strategy, device);
1509}
1510
1511status_t AudioPolicyService::removePreferredDeviceForStrategy(product_strategy_t strategy)
1512{
1513 if (mAudioPolicyManager == NULL) {
1514 return NO_INIT;
1515 }
1516 Mutex::Autolock _l(mLock);
1517 return mAudioPolicyManager->removePreferredDeviceForStrategy(strategy);
1518}
1519
1520status_t AudioPolicyService::getPreferredDeviceForStrategy(product_strategy_t strategy,
1521 AudioDeviceTypeAddr &device)
1522{
1523 if (mAudioPolicyManager == NULL) {
1524 return NO_INIT;
1525 }
1526 Mutex::Autolock _l(mLock);
1527 return mAudioPolicyManager->getPreferredDeviceForStrategy(strategy, device);
1528}
1529
Ytai Ben-Tsvi85093d52020-03-26 09:41:15 -07001530status_t AudioPolicyService::registerSoundTriggerCaptureStateListener(
1531 const sp<media::ICaptureStateListener>& listener,
1532 bool* result)
1533{
1534 *result = mCaptureStateNotifier.RegisterListener(listener);
1535 return NO_ERROR;
1536}
1537
Mikhail Naganov1b2a7942017-12-08 10:18:09 -08001538} // namespace android