blob: 34d07b6d76ff2a9444aa82231b44b9457af748e9 [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)) {
Eric Laurent42984412019-05-09 17:57:03 -0700247 attr->flags |= AUDIO_FLAG_NO_MEDIA_PROJECTION;
248 }
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)) {
Eric Laurent42984412019-05-09 17:57:03 -0700251 attr->flags &= ~(AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE);
Kevin Rocard8be94972019-02-22 13:26:25 -0800252 }
Eric Laurent10b71232018-04-13 18:14:44 -0700253 AutoCallerClear acc;
Eric Laurent8a1095a2019-11-08 14:44:16 -0800254 AudioPolicyInterface::output_type_t outputType;
Hayden Gomes3e8bbb92020-01-10 13:37:05 -0800255 result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800256 config,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800257 &flags, selectedDeviceId, portId,
Eric Laurent8a1095a2019-11-08 14:44:16 -0800258 secondaryOutputs,
259 &outputType);
Nadav Bar766fb022018-01-07 12:18:03 +0200260
261 // FIXME: Introduce a way to check for the the telephony device before opening the output
Eric Laurent8a1095a2019-11-08 14:44:16 -0800262 if (result == NO_ERROR) {
263 // enforce permission (if any) required for each type of input
264 switch (outputType) {
265 case AudioPolicyInterface::API_OUTPUT_LEGACY:
266 break;
267 case AudioPolicyInterface::API_OUTPUT_TELEPHONY_TX:
Ricardo Correa57a37692020-03-23 17:27:25 -0700268 if (!modifyPhoneStateAllowed(pid, uid)) {
Eric Laurent8a1095a2019-11-08 14:44:16 -0800269 ALOGE("%s() permission denied: modify phone state not allowed for uid %d",
270 __func__, uid);
271 result = PERMISSION_DENIED;
272 }
273 break;
274 case AudioPolicyInterface::API_OUT_MIX_PLAYBACK:
275 if (!modifyAudioRoutingAllowed(pid, uid)) {
276 ALOGE("%s() permission denied: modify audio routing not allowed for uid %d",
277 __func__, uid);
278 result = PERMISSION_DENIED;
279 }
280 break;
281 case AudioPolicyInterface::API_OUTPUT_INVALID:
282 default:
283 LOG_ALWAYS_FATAL("%s() encountered an invalid output type %d",
284 __func__, (int)outputType);
285 }
Nadav Bar766fb022018-01-07 12:18:03 +0200286 }
Eric Laurentd7fe0862018-07-14 16:48:01 -0700287
288 if (result == NO_ERROR) {
289 sp <AudioPlaybackClient> client =
Eric Laurent5ada82e2019-08-29 17:53:54 -0700290 new AudioPlaybackClient(*attr, *output, uid, pid, session, *portId, *selectedDeviceId, *stream);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700291 mAudioPlaybackClients.add(*portId, client);
292 }
Nadav Bar766fb022018-01-07 12:18:03 +0200293 return result;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700294}
295
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700296void AudioPolicyService::getPlaybackClientAndEffects(audio_port_handle_t portId,
297 sp<AudioPlaybackClient>& client,
298 sp<AudioPolicyEffects>& effects,
299 const char *context)
300{
301 Mutex::Autolock _l(mLock);
302 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
303 if (index < 0) {
304 ALOGE("%s AudioTrack client not found for portId %d", context, portId);
305 return;
306 }
307 client = mAudioPlaybackClients.valueAt(index);
308 effects = mAudioPolicyEffects;
309}
310
Eric Laurentd7fe0862018-07-14 16:48:01 -0700311status_t AudioPolicyService::startOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800312{
Eric Laurentdce54a12014-03-10 12:19:46 -0700313 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800314 return NO_INIT;
315 }
316 ALOGV("startOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700317 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700318 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700319
320 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
321
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700322 if (audioPolicyEffects != 0) {
323 // create audio processors according to stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700324 status_t status = audioPolicyEffects->addOutputSessionEffects(
325 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700326 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700327 ALOGW("Failed to add effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700328 }
329 }
330 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700331 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700332 status_t status = mAudioPolicyManager->startOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700333 if (status == NO_ERROR) {
334 client->active = true;
335 }
336 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800337}
338
Eric Laurentd7fe0862018-07-14 16:48:01 -0700339status_t AudioPolicyService::stopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800340{
Eric Laurentdce54a12014-03-10 12:19:46 -0700341 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800342 return NO_INIT;
343 }
344 ALOGV("stopOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700345 mOutputCommandThread->stopOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800346 return NO_ERROR;
347}
348
Eric Laurentd7fe0862018-07-14 16:48:01 -0700349status_t AudioPolicyService::doStopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800350{
Eric Laurentd7fe0862018-07-14 16:48:01 -0700351 ALOGV("doStopOutput");
352 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700353 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentd7fe0862018-07-14 16:48:01 -0700354
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700355 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
356
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700357 if (audioPolicyEffects != 0) {
358 // release audio processors from the stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700359 status_t status = audioPolicyEffects->releaseOutputSessionEffects(
360 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700361 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700362 ALOGW("Failed to release effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700363 }
364 }
365 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700366 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700367 status_t status = mAudioPolicyManager->stopOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700368 if (status == NO_ERROR) {
369 client->active = false;
370 }
371 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800372}
373
Eric Laurentd7fe0862018-07-14 16:48:01 -0700374void AudioPolicyService::releaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800375{
Eric Laurentdce54a12014-03-10 12:19:46 -0700376 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800377 return;
378 }
379 ALOGV("releaseOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700380 mOutputCommandThread->releaseOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800381}
382
Eric Laurentd7fe0862018-07-14 16:48:01 -0700383void AudioPolicyService::doReleaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800384{
385 ALOGV("doReleaseOutput from tid %d", gettid());
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700386 sp<AudioPlaybackClient> client;
387 sp<AudioPolicyEffects> audioPolicyEffects;
388
389 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
390
391 if (audioPolicyEffects != 0 && client->active) {
392 // clean up effects if output was not stopped before being released
393 audioPolicyEffects->releaseOutputSessionEffects(
394 client->io, client->stream, client->session);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700395 }
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700396 Mutex::Autolock _l(mLock);
Eric Laurentd4007242019-03-27 12:42:16 -0700397 mAudioPlaybackClients.removeItem(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700398
Eric Laurent10b71232018-04-13 18:14:44 -0700399 // called from internal thread: no need to clear caller identity
Eric Laurent8fc147b2018-07-22 19:13:55 -0700400 mAudioPolicyManager->releaseOutput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800401}
402
Eric Laurentcaf7f482014-11-25 17:50:47 -0800403status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
404 audio_io_handle_t *input,
Mikhail Naganov2996f672019-04-18 12:29:59 -0700405 audio_unique_id_t riid,
Eric Laurentcaf7f482014-11-25 17:50:47 -0800406 audio_session_t session,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700407 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700408 uid_t uid,
Eric Laurentfee19762018-01-29 18:44:13 -0800409 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800410 const audio_config_base_t *config,
Paul McLean466dc8e2015-04-17 13:15:36 -0600411 audio_input_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700412 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800413 audio_port_handle_t *portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800414{
Eric Laurentdce54a12014-03-10 12:19:46 -0700415 if (mAudioPolicyManager == NULL) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800416 return NO_INIT;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800417 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800418
Hayden Gomes524159d2019-12-23 14:41:47 -0800419 status_t result = validateUsage(attr->usage, pid, uid);
420 if (result != NO_ERROR) {
421 return result;
422 }
423
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900424 audio_source_t inputSource = attr->source;
425 if (inputSource == AUDIO_SOURCE_DEFAULT) {
426 inputSource = AUDIO_SOURCE_MIC;
427 }
428
Eric Laurent2d388ec2014-03-07 13:25:54 -0800429 // already checked by client, but double-check in case the client wrapper is bypassed
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900430 if ((inputSource < AUDIO_SOURCE_DEFAULT)
431 || (inputSource >= AUDIO_SOURCE_CNT
432 && inputSource != AUDIO_SOURCE_HOTWORD
433 && inputSource != AUDIO_SOURCE_FM_TUNER
434 && inputSource != AUDIO_SOURCE_ECHO_REFERENCE)) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800435 return BAD_VALUE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800436 }
437
Eric Laurentb2379ba2016-05-23 17:42:12 -0700438 bool updatePid = (pid == -1);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700439 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700440 if (!isAudioServerOrMediaServerUid(callingUid)) {
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700441 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Marco Nelissendcb346b2015-09-09 10:47:29 -0700442 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
443 uid = callingUid;
Eric Laurentb2379ba2016-05-23 17:42:12 -0700444 updatePid = true;
445 }
446
447 if (updatePid) {
448 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700449 ALOGW_IF(pid != (pid_t)-1 && pid != callingPid,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700450 "%s uid %d pid %d tried to pass itself off as pid %d",
451 __func__, callingUid, callingPid, pid);
452 pid = callingPid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700453 }
454
Eric Laurent58a0dd82019-10-24 12:42:17 -0700455 // check calling permissions.
456 // Capturing from FM_TUNER source is controlled by captureAudioOutputAllowed() only as this
457 // does not affect users privacy as does capturing from an actual microphone.
458 if (!(recordingAllowed(opPackageName, pid, uid) || attr->source == AUDIO_SOURCE_FM_TUNER)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800459 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
460 __func__, uid, pid);
461 return PERMISSION_DENIED;
462 }
463
Eric Laurent1ff16a72019-03-14 18:35:04 -0700464 bool canCaptureOutput = captureAudioOutputAllowed(pid, uid);
Ricardo Correa57a37692020-03-23 17:27:25 -0700465 if ((inputSource == AUDIO_SOURCE_VOICE_UPLINK ||
466 inputSource == AUDIO_SOURCE_VOICE_DOWNLINK ||
467 inputSource == AUDIO_SOURCE_VOICE_CALL ||
468 inputSource == AUDIO_SOURCE_ECHO_REFERENCE||
469 inputSource == AUDIO_SOURCE_FM_TUNER) &&
Eric Laurent1ff16a72019-03-14 18:35:04 -0700470 !canCaptureOutput) {
Nadav Bar744be482018-05-08 13:26:21 +0300471 return PERMISSION_DENIED;
472 }
473
jiabin68e0df72019-03-18 17:55:35 -0700474 bool canCaptureHotword = captureHotwordAllowed(opPackageName, pid, uid);
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900475 if ((inputSource == AUDIO_SOURCE_HOTWORD) && !canCaptureHotword) {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700476 return BAD_VALUE;
477 }
478
479 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700480 {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700481 status_t status;
482 AudioPolicyInterface::input_type_t inputType;
483
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700484 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700485 {
486 AutoCallerClear acc;
487 // the audio_in_acoustics_t parameter is ignored by get_input()
Mikhail Naganov2996f672019-04-18 12:29:59 -0700488 status = mAudioPolicyManager->getInputForAttr(attr, input, riid, session, uid,
Eric Laurent10b71232018-04-13 18:14:44 -0700489 config,
490 flags, selectedDeviceId,
491 &inputType, portId);
492 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700493 audioPolicyEffects = mAudioPolicyEffects;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800494
495 if (status == NO_ERROR) {
496 // enforce permission (if any) required for each type of input
497 switch (inputType) {
Kevin Rocard25f9b052019-02-27 15:08:54 -0800498 case AudioPolicyInterface::API_INPUT_MIX_PUBLIC_CAPTURE_PLAYBACK:
499 // this use case has been validated in audio service with a MediaProjection token,
500 // and doesn't rely on regular permissions
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800501 case AudioPolicyInterface::API_INPUT_LEGACY:
502 break;
Eric Laurent82db2692015-08-07 13:59:42 -0700503 case AudioPolicyInterface::API_INPUT_TELEPHONY_RX:
504 // FIXME: use the same permission as for remote submix for now.
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800505 case AudioPolicyInterface::API_INPUT_MIX_CAPTURE:
Eric Laurent1ff16a72019-03-14 18:35:04 -0700506 if (!canCaptureOutput) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800507 ALOGE("getInputForAttr() permission denied: capture not allowed");
508 status = PERMISSION_DENIED;
509 }
510 break;
511 case AudioPolicyInterface::API_INPUT_MIX_EXT_POLICY_REROUTE:
Eric Laurent8a1095a2019-11-08 14:44:16 -0800512 if (!modifyAudioRoutingAllowed(pid, uid)) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800513 ALOGE("getInputForAttr() permission denied: modify audio routing not allowed");
514 status = PERMISSION_DENIED;
515 }
516 break;
517 case AudioPolicyInterface::API_INPUT_INVALID:
518 default:
519 LOG_ALWAYS_FATAL("getInputForAttr() encountered an invalid input type %d",
520 (int)inputType);
521 }
522 }
523
524 if (status != NO_ERROR) {
525 if (status == PERMISSION_DENIED) {
Eric Laurent10b71232018-04-13 18:14:44 -0700526 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700527 mAudioPolicyManager->releaseInput(*portId);
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800528 }
529 return status;
530 }
Eric Laurentfee19762018-01-29 18:44:13 -0800531
Eric Laurent5ada82e2019-08-29 17:53:54 -0700532 sp<AudioRecordClient> client = new AudioRecordClient(*attr, *input, uid, pid, session, *portId,
Eric Laurent1ff16a72019-03-14 18:35:04 -0700533 *selectedDeviceId, opPackageName,
Ricardo Correa57a37692020-03-23 17:27:25 -0700534 canCaptureOutput, canCaptureHotword);
Eric Laurentfee19762018-01-29 18:44:13 -0800535 mAudioRecordClients.add(*portId, client);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700536 }
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800537
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700538 if (audioPolicyEffects != 0) {
539 // create audio pre processors according to input source
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900540 status_t status = audioPolicyEffects->addInputEffects(*input, inputSource, session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700541 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800542 ALOGW("Failed to add effects on input %d", *input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700543 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800544 }
Eric Laurentcaf7f482014-11-25 17:50:47 -0800545 return NO_ERROR;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800546}
547
Eric Laurent99fcae42018-05-17 16:59:18 -0700548std::string AudioPolicyService::getDeviceTypeStrForPortId(audio_port_handle_t portId) {
Eric Laurent99fcae42018-05-17 16:59:18 -0700549 struct audio_port port = {};
550 port.id = portId;
551 status_t status = mAudioPolicyManager->getAudioPort(&port);
552 if (status == NO_ERROR && port.type == AUDIO_PORT_TYPE_DEVICE) {
Andy Hung9b181952019-02-25 14:53:36 -0800553 return toString(port.ext.device.type);
Eric Laurent99fcae42018-05-17 16:59:18 -0700554 }
Andy Hung9b181952019-02-25 14:53:36 -0800555 return {};
Eric Laurent99fcae42018-05-17 16:59:18 -0700556}
557
Eric Laurent4eb58f12018-12-07 16:41:02 -0800558status_t AudioPolicyService::startInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800559{
Eric Laurentdce54a12014-03-10 12:19:46 -0700560 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800561 return NO_INIT;
562 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800563 sp<AudioRecordClient> client;
564 {
565 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800566
Eric Laurent7dca8a82018-01-29 18:44:26 -0800567 ssize_t index = mAudioRecordClients.indexOfKey(portId);
568 if (index < 0) {
569 return INVALID_OPERATION;
570 }
571 client = mAudioRecordClients.valueAt(index);
Eric Laurentfee19762018-01-29 18:44:13 -0800572 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800573
574 // check calling permissions
Eric Laurent58a0dd82019-10-24 12:42:17 -0700575 if (!(startRecording(client->opPackageName, client->pid, client->uid)
576 || client->attributes.source == AUDIO_SOURCE_FM_TUNER)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800577 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
578 __func__, client->uid, client->pid);
579 return PERMISSION_DENIED;
580 }
Eric Laurentfee19762018-01-29 18:44:13 -0800581
Eric Laurentdf628922018-12-06 21:45:51 +0000582 Mutex::Autolock _l(mLock);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800583
584 client->active = true;
585 client->startTimeNs = systemTime();
586 updateUidStates_l();
Eric Laurentfee19762018-01-29 18:44:13 -0800587
Eric Laurent10b71232018-04-13 18:14:44 -0700588 status_t status;
589 {
590 AutoCallerClear acc;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800591 status = mAudioPolicyManager->startInput(portId);
Ray Essick84e84a52018-05-03 18:45:07 -0700592
593 }
594
Ray Essickf6a57cd2018-05-22 16:20:54 -0700595 // including successes gets very verbose
Muhammad Qureshi087b37c2020-06-16 16:37:36 -0700596 // but once we cut over to statsd, log them all.
Ray Essickf6a57cd2018-05-22 16:20:54 -0700597 if (status != NO_ERROR) {
Ray Essick84e84a52018-05-03 18:45:07 -0700598
599 static constexpr char kAudioPolicy[] = "audiopolicy";
600
Ray Essick84e84a52018-05-03 18:45:07 -0700601 static constexpr char kAudioPolicyStatus[] = "android.media.audiopolicy.status";
602 static constexpr char kAudioPolicyRqstSrc[] = "android.media.audiopolicy.rqst.src";
603 static constexpr char kAudioPolicyRqstPkg[] = "android.media.audiopolicy.rqst.pkg";
604 static constexpr char kAudioPolicyRqstSession[] = "android.media.audiopolicy.rqst.session";
Eric Laurent99fcae42018-05-17 16:59:18 -0700605 static constexpr char kAudioPolicyRqstDevice[] =
606 "android.media.audiopolicy.rqst.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700607 static constexpr char kAudioPolicyActiveSrc[] = "android.media.audiopolicy.active.src";
608 static constexpr char kAudioPolicyActivePkg[] = "android.media.audiopolicy.active.pkg";
Eric Laurent99fcae42018-05-17 16:59:18 -0700609 static constexpr char kAudioPolicyActiveSession[] =
610 "android.media.audiopolicy.active.session";
611 static constexpr char kAudioPolicyActiveDevice[] =
612 "android.media.audiopolicy.active.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700613
Ray Essickf27e9872019-12-07 06:28:46 -0800614 mediametrics::Item *item = mediametrics::Item::create(kAudioPolicy);
Ray Essick84e84a52018-05-03 18:45:07 -0700615 if (item != NULL) {
616
Ray Essick84e84a52018-05-03 18:45:07 -0700617 item->setInt32(kAudioPolicyStatus, status);
618
Eric Laurent99fcae42018-05-17 16:59:18 -0700619 item->setCString(kAudioPolicyRqstSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800620 toString(client->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700621 item->setInt32(kAudioPolicyRqstSession, client->session);
Ray Essick51866952018-05-30 11:22:27 -0700622 if (client->opPackageName.size() != 0) {
623 item->setCString(kAudioPolicyRqstPkg,
624 std::string(String8(client->opPackageName).string()).c_str());
625 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700626 item->setCString(kAudioPolicyRqstPkg, std::to_string(client->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700627 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700628 item->setCString(
629 kAudioPolicyRqstDevice, getDeviceTypeStrForPortId(client->deviceId).c_str());
630
Eric Laurent4eb58f12018-12-07 16:41:02 -0800631 int count = mAudioRecordClients.size();
632 for (int i = 0; i < count ; i++) {
633 if (portId == mAudioRecordClients.keyAt(i)) {
634 continue;
635 }
636 sp<AudioRecordClient> other = mAudioRecordClients.valueAt(i);
637 if (other->active) {
638 // keeps the last of the clients marked active
639 item->setCString(kAudioPolicyActiveSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800640 toString(other->attributes.source).c_str());
Eric Laurent4eb58f12018-12-07 16:41:02 -0800641 item->setInt32(kAudioPolicyActiveSession, other->session);
642 if (other->opPackageName.size() != 0) {
643 item->setCString(kAudioPolicyActivePkg,
644 std::string(String8(other->opPackageName).string()).c_str());
645 } else {
646 item->setCString(kAudioPolicyRqstPkg,
647 std::to_string(other->uid).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700648 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800649 item->setCString(kAudioPolicyActiveDevice,
650 getDeviceTypeStrForPortId(other->deviceId).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700651 }
652 }
653 item->selfrecord();
654 delete item;
655 item = NULL;
656 }
Ray Essick6ce27e52019-02-15 10:58:05 -0800657 }
658
659 if (status != NO_ERROR) {
Eric Laurent4eb58f12018-12-07 16:41:02 -0800660 client->active = false;
661 client->startTimeNs = 0;
662 updateUidStates_l();
Svet Ganov6e641372018-03-02 09:21:30 -0800663 finishRecording(client->opPackageName, client->uid);
Eric Laurentfb66dd92016-01-28 18:32:03 -0800664 }
665
666 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800667}
668
Eric Laurentfee19762018-01-29 18:44:13 -0800669status_t AudioPolicyService::stopInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800670{
Eric Laurentdce54a12014-03-10 12:19:46 -0700671 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800672 return NO_INIT;
673 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800674
Eric Laurent2d388ec2014-03-07 13:25:54 -0800675 Mutex::Autolock _l(mLock);
676
Eric Laurentfee19762018-01-29 18:44:13 -0800677 ssize_t index = mAudioRecordClients.indexOfKey(portId);
678 if (index < 0) {
679 return INVALID_OPERATION;
680 }
681 sp<AudioRecordClient> client = mAudioRecordClients.valueAt(index);
682
Ray Essick84e84a52018-05-03 18:45:07 -0700683 client->active = false;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800684 client->startTimeNs = 0;
685
686 updateUidStates_l();
Ray Essick84e84a52018-05-03 18:45:07 -0700687
Svet Ganov6e641372018-03-02 09:21:30 -0800688 // finish the recording app op
689 finishRecording(client->opPackageName, client->uid);
Eric Laurent10b71232018-04-13 18:14:44 -0700690 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700691 return mAudioPolicyManager->stopInput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800692}
693
Eric Laurentfee19762018-01-29 18:44:13 -0800694void AudioPolicyService::releaseInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800695{
Eric Laurentdce54a12014-03-10 12:19:46 -0700696 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800697 return;
698 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700699 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800700 sp<AudioRecordClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700701 {
702 Mutex::Autolock _l(mLock);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700703 audioPolicyEffects = mAudioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800704 ssize_t index = mAudioRecordClients.indexOfKey(portId);
705 if (index < 0) {
706 return;
707 }
708 client = mAudioRecordClients.valueAt(index);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800709
710 if (client->active) {
711 ALOGW("%s releasing active client portId %d", __FUNCTION__, portId);
712 client->active = false;
713 client->startTimeNs = 0;
714 updateUidStates_l();
715 }
716
Eric Laurentfee19762018-01-29 18:44:13 -0800717 mAudioRecordClients.removeItem(portId);
718 }
719 if (client == 0) {
720 return;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700721 }
722 if (audioPolicyEffects != 0) {
723 // release audio processors from the input
Eric Laurentd7fe0862018-07-14 16:48:01 -0700724 status_t status = audioPolicyEffects->releaseInputEffects(client->io, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700725 if(status != NO_ERROR) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700726 ALOGW("Failed to release effects on input %d", client->io);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700727 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800728 }
Eric Laurentf10c7092016-12-06 17:09:56 -0800729 {
730 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700731 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700732 mAudioPolicyManager->releaseInput(portId);
Eric Laurentf10c7092016-12-06 17:09:56 -0800733 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800734}
735
736status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
737 int indexMin,
738 int indexMax)
739{
Eric Laurentdce54a12014-03-10 12:19:46 -0700740 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800741 return NO_INIT;
742 }
743 if (!settingsAllowed()) {
744 return PERMISSION_DENIED;
745 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800746 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800747 return BAD_VALUE;
748 }
749 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700750 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700751 mAudioPolicyManager->initStreamVolume(stream, indexMin, indexMax);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800752 return NO_ERROR;
753}
754
755status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
756 int index,
757 audio_devices_t device)
758{
Eric Laurentdce54a12014-03-10 12:19:46 -0700759 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800760 return NO_INIT;
761 }
762 if (!settingsAllowed()) {
763 return PERMISSION_DENIED;
764 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800765 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800766 return BAD_VALUE;
767 }
768 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700769 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700770 return mAudioPolicyManager->setStreamVolumeIndex(stream,
771 index,
772 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800773}
774
775status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
776 int *index,
777 audio_devices_t device)
778{
Eric Laurentdce54a12014-03-10 12:19:46 -0700779 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800780 return NO_INIT;
781 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800782 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800783 return BAD_VALUE;
784 }
785 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700786 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700787 return mAudioPolicyManager->getStreamVolumeIndex(stream,
788 index,
789 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800790}
791
François Gaffiecfe17322018-11-07 13:41:29 +0100792status_t AudioPolicyService::setVolumeIndexForAttributes(const audio_attributes_t &attributes,
793 int index, audio_devices_t device)
794{
795 if (mAudioPolicyManager == NULL) {
796 return NO_INIT;
797 }
798 if (!settingsAllowed()) {
799 return PERMISSION_DENIED;
800 }
801 Mutex::Autolock _l(mLock);
802 AutoCallerClear acc;
803 return mAudioPolicyManager->setVolumeIndexForAttributes(attributes, index, device);
804}
805
806status_t AudioPolicyService::getVolumeIndexForAttributes(const audio_attributes_t &attributes,
807 int &index, audio_devices_t device)
808{
809 if (mAudioPolicyManager == NULL) {
810 return NO_INIT;
811 }
812 Mutex::Autolock _l(mLock);
813 AutoCallerClear acc;
814 return mAudioPolicyManager->getVolumeIndexForAttributes(attributes, index, device);
815}
816
817status_t AudioPolicyService::getMinVolumeIndexForAttributes(const audio_attributes_t &attributes,
818 int &index)
819{
820 if (mAudioPolicyManager == NULL) {
821 return NO_INIT;
822 }
823 Mutex::Autolock _l(mLock);
824 AutoCallerClear acc;
825 return mAudioPolicyManager->getMinVolumeIndexForAttributes(attributes, index);
826}
827
828status_t AudioPolicyService::getMaxVolumeIndexForAttributes(const audio_attributes_t &attributes,
829 int &index)
830{
831 if (mAudioPolicyManager == NULL) {
832 return NO_INIT;
833 }
834 Mutex::Autolock _l(mLock);
835 AutoCallerClear acc;
836 return mAudioPolicyManager->getMaxVolumeIndexForAttributes(attributes, index);
837}
838
Eric Laurent2d388ec2014-03-07 13:25:54 -0800839uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
840{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800841 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
François Gaffiec005e562018-11-06 15:04:49 +0100842 return PRODUCT_STRATEGY_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700843 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700844 if (mAudioPolicyManager == NULL) {
François Gaffiec005e562018-11-06 15:04:49 +0100845 return PRODUCT_STRATEGY_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800846 }
François Gaffiec005e562018-11-06 15:04:49 +0100847 // DO NOT LOCK, may be called from AudioFlinger with lock held, reaching deadlock
Eric Laurent10b71232018-04-13 18:14:44 -0700848 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700849 return mAudioPolicyManager->getStrategyForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800850}
851
852//audio policy: use audio_device_t appropriately
853
854audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
855{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800856 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700857 return AUDIO_DEVICE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700858 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700859 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700860 return AUDIO_DEVICE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800861 }
Haynes Mathew Georgedfb9f3b2015-10-26 18:22:13 -0700862 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700863 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700864 return mAudioPolicyManager->getDevicesForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800865}
866
Jean-Michel Trivif41599b2020-01-07 14:22:08 -0800867status_t AudioPolicyService::getDevicesForAttributes(const AudioAttributes &aa,
Hayden Gomes524159d2019-12-23 14:41:47 -0800868 AudioDeviceTypeAddrVector *devices) const
Jean-Michel Trivif41599b2020-01-07 14:22:08 -0800869{
870 if (mAudioPolicyManager == NULL) {
871 return NO_INIT;
872 }
873 Mutex::Autolock _l(mLock);
874 AutoCallerClear acc;
875 return mAudioPolicyManager->getDevicesForAttributes(aa.getAttributes(), devices);
876}
877
Eric Laurent2d388ec2014-03-07 13:25:54 -0800878audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
879{
880 // FIXME change return type to status_t, and return NO_INIT here
Eric Laurentdce54a12014-03-10 12:19:46 -0700881 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800882 return 0;
883 }
884 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700885 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700886 return mAudioPolicyManager->getOutputForEffect(desc);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800887}
888
889status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
890 audio_io_handle_t io,
891 uint32_t strategy,
Glenn Kastend848eb42016-03-08 13:42:11 -0800892 audio_session_t session,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800893 int id)
894{
Eric Laurentdce54a12014-03-10 12:19:46 -0700895 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800896 return NO_INIT;
897 }
Eric Laurent6c796322019-04-09 14:13:17 -0700898 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700899 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700900 return mAudioPolicyManager->registerEffect(desc, io, strategy, session, id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800901}
902
903status_t AudioPolicyService::unregisterEffect(int id)
904{
Eric Laurentdce54a12014-03-10 12:19:46 -0700905 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800906 return NO_INIT;
907 }
Eric Laurent6c796322019-04-09 14:13:17 -0700908 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700909 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700910 return mAudioPolicyManager->unregisterEffect(id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800911}
912
913status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
914{
Eric Laurentdce54a12014-03-10 12:19:46 -0700915 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800916 return NO_INIT;
917 }
Eric Laurent6c796322019-04-09 14:13:17 -0700918 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700919 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700920 return mAudioPolicyManager->setEffectEnabled(id, enabled);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800921}
922
Eric Laurent6c796322019-04-09 14:13:17 -0700923status_t AudioPolicyService::moveEffectsToIo(const std::vector<int>& ids, audio_io_handle_t io)
924{
925 if (mAudioPolicyManager == NULL) {
926 return NO_INIT;
927 }
928 Mutex::Autolock _l(mLock);
929 AutoCallerClear acc;
930 return mAudioPolicyManager->moveEffectsToIo(ids, io);
931}
932
Eric Laurent2d388ec2014-03-07 13:25:54 -0800933bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
934{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800935 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700936 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700937 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700938 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700939 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800940 }
941 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700942 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700943 return mAudioPolicyManager->isStreamActive(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800944}
945
946bool AudioPolicyService::isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs) const
947{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800948 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700949 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700950 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700951 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700952 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800953 }
954 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700955 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700956 return mAudioPolicyManager->isStreamActiveRemotely(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800957}
958
959bool AudioPolicyService::isSourceActive(audio_source_t source) const
960{
Eric Laurentdce54a12014-03-10 12:19:46 -0700961 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800962 return false;
963 }
964 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700965 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700966 return mAudioPolicyManager->isSourceActive(source);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800967}
968
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700969status_t AudioPolicyService::getAudioPolicyEffects(sp<AudioPolicyEffects>& audioPolicyEffects)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800970{
Eric Laurentdce54a12014-03-10 12:19:46 -0700971 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800972 return NO_INIT;
973 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700974 {
975 Mutex::Autolock _l(mLock);
976 audioPolicyEffects = mAudioPolicyEffects;
977 }
978 if (audioPolicyEffects == 0) {
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700979 return NO_INIT;
980 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700981
982 return OK;
983}
984
985status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
986 effect_descriptor_t *descriptors,
987 uint32_t *count)
988{
989 sp<AudioPolicyEffects>audioPolicyEffects;
990 status_t status = getAudioPolicyEffects(audioPolicyEffects);
991 if (status != OK) {
992 *count = 0;
993 return status;
994 }
Eric Laurentfb66dd92016-01-28 18:32:03 -0800995 return audioPolicyEffects->queryDefaultInputEffects(
996 (audio_session_t)audioSession, descriptors, count);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800997}
998
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700999status_t AudioPolicyService::addSourceDefaultEffect(const effect_uuid_t *type,
1000 const String16& opPackageName,
1001 const effect_uuid_t *uuid,
1002 int32_t priority,
1003 audio_source_t source,
1004 audio_unique_id_t* id)
1005{
1006 sp<AudioPolicyEffects>audioPolicyEffects;
1007 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1008 if (status != OK) {
1009 return status;
1010 }
1011 if (!modifyDefaultAudioEffectsAllowed()) {
1012 return PERMISSION_DENIED;
1013 }
1014 return audioPolicyEffects->addSourceDefaultEffect(
1015 type, opPackageName, uuid, priority, source, id);
1016}
1017
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001018status_t AudioPolicyService::addStreamDefaultEffect(const effect_uuid_t *type,
1019 const String16& opPackageName,
1020 const effect_uuid_t *uuid,
1021 int32_t priority,
1022 audio_usage_t usage,
1023 audio_unique_id_t* id)
1024{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001025 sp<AudioPolicyEffects>audioPolicyEffects;
1026 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1027 if (status != OK) {
1028 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001029 }
1030 if (!modifyDefaultAudioEffectsAllowed()) {
1031 return PERMISSION_DENIED;
1032 }
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001033 return audioPolicyEffects->addStreamDefaultEffect(
1034 type, opPackageName, uuid, priority, usage, id);
1035}
1036
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001037status_t AudioPolicyService::removeSourceDefaultEffect(audio_unique_id_t id)
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001038{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001039 sp<AudioPolicyEffects>audioPolicyEffects;
1040 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1041 if (status != OK) {
1042 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001043 }
1044 if (!modifyDefaultAudioEffectsAllowed()) {
1045 return PERMISSION_DENIED;
1046 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001047 return audioPolicyEffects->removeSourceDefaultEffect(id);
1048}
1049
1050status_t AudioPolicyService::removeStreamDefaultEffect(audio_unique_id_t id)
1051{
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001052 sp<AudioPolicyEffects>audioPolicyEffects;
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001053 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1054 if (status != OK) {
1055 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001056 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001057 if (!modifyDefaultAudioEffectsAllowed()) {
1058 return PERMISSION_DENIED;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001059 }
1060 return audioPolicyEffects->removeStreamDefaultEffect(id);
1061}
1062
Hayden Gomes524159d2019-12-23 14:41:47 -08001063status_t AudioPolicyService::setSupportedSystemUsages(const std::vector<audio_usage_t>& systemUsages) {
1064 Mutex::Autolock _l(mLock);
1065 if(!modifyAudioRoutingAllowed()) {
1066 return PERMISSION_DENIED;
1067 }
1068
1069 bool areAllSystemUsages = std::all_of(begin(systemUsages), end(systemUsages),
1070 [](audio_usage_t usage) { return isSystemUsage(usage); });
1071 if (!areAllSystemUsages) {
1072 return BAD_VALUE;
1073 }
1074
1075 mSupportedSystemUsages = systemUsages;
1076 return NO_ERROR;
1077}
1078
Kevin Rocardb99cc752019-03-21 20:52:24 -07001079status_t AudioPolicyService::setAllowedCapturePolicy(uid_t uid, audio_flags_mask_t capturePolicy) {
1080 Mutex::Autolock _l(mLock);
1081 if (mAudioPolicyManager == NULL) {
1082 ALOGV("%s() mAudioPolicyManager == NULL", __func__);
1083 return NO_INIT;
1084 }
Kevin Rocardb99cc752019-03-21 20:52:24 -07001085 return mAudioPolicyManager->setAllowedCapturePolicy(uid, capturePolicy);
1086}
1087
Eric Laurent2d388ec2014-03-07 13:25:54 -08001088bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
1089{
Eric Laurentdce54a12014-03-10 12:19:46 -07001090 if (mAudioPolicyManager == NULL) {
1091 ALOGV("mAudioPolicyManager == NULL");
Eric Laurent2d388ec2014-03-07 13:25:54 -08001092 return false;
1093 }
Andy Hung2ddee192015-12-18 17:34:44 -08001094 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001095 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -07001096 return mAudioPolicyManager->isOffloadSupported(info);
Eric Laurent2d388ec2014-03-07 13:25:54 -08001097}
1098
Michael Chana94fbb22018-04-24 14:31:19 +10001099bool AudioPolicyService::isDirectOutputSupported(const audio_config_base_t& config,
1100 const audio_attributes_t& attributes) {
1101 if (mAudioPolicyManager == NULL) {
1102 ALOGV("mAudioPolicyManager == NULL");
1103 return false;
1104 }
Hayden Gomes524159d2019-12-23 14:41:47 -08001105
1106 status_t result = validateUsage(attributes.usage);
1107 if (result != NO_ERROR) {
1108 return result;
1109 }
1110
Michael Chana94fbb22018-04-24 14:31:19 +10001111 Mutex::Autolock _l(mLock);
1112 return mAudioPolicyManager->isDirectOutputSupported(config, attributes);
1113}
1114
1115
Eric Laurent6a94d692014-05-20 11:18:06 -07001116status_t AudioPolicyService::listAudioPorts(audio_port_role_t role,
1117 audio_port_type_t type,
Eric Laurent203b1a12014-04-01 10:34:16 -07001118 unsigned int *num_ports,
Eric Laurent6a94d692014-05-20 11:18:06 -07001119 struct audio_port *ports,
1120 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001121{
Eric Laurent6a94d692014-05-20 11:18:06 -07001122 Mutex::Autolock _l(mLock);
1123 if (mAudioPolicyManager == NULL) {
1124 return NO_INIT;
1125 }
Eric Laurent10b71232018-04-13 18:14:44 -07001126 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001127 return mAudioPolicyManager->listAudioPorts(role, type, num_ports, ports, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001128}
1129
Eric Laurent6a94d692014-05-20 11:18:06 -07001130status_t AudioPolicyService::getAudioPort(struct audio_port *port)
Eric Laurent203b1a12014-04-01 10:34:16 -07001131{
Eric Laurent6a94d692014-05-20 11:18:06 -07001132 Mutex::Autolock _l(mLock);
1133 if (mAudioPolicyManager == NULL) {
1134 return NO_INIT;
1135 }
Eric Laurent10b71232018-04-13 18:14:44 -07001136 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001137 return mAudioPolicyManager->getAudioPort(port);
Eric Laurent203b1a12014-04-01 10:34:16 -07001138}
1139
Eric Laurent6a94d692014-05-20 11:18:06 -07001140status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch,
1141 audio_patch_handle_t *handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001142{
Eric Laurent6a94d692014-05-20 11:18:06 -07001143 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001144 if(!modifyAudioRoutingAllowed()) {
1145 return PERMISSION_DENIED;
1146 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001147 if (mAudioPolicyManager == NULL) {
1148 return NO_INIT;
1149 }
Eric Laurent10b71232018-04-13 18:14:44 -07001150 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001151 return mAudioPolicyManager->createAudioPatch(patch, handle,
1152 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001153}
1154
Eric Laurent6a94d692014-05-20 11:18:06 -07001155status_t AudioPolicyService::releaseAudioPatch(audio_patch_handle_t handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001156{
Eric Laurent6a94d692014-05-20 11:18:06 -07001157 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001158 if(!modifyAudioRoutingAllowed()) {
1159 return PERMISSION_DENIED;
1160 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001161 if (mAudioPolicyManager == NULL) {
1162 return NO_INIT;
1163 }
Eric Laurent10b71232018-04-13 18:14:44 -07001164 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001165 return mAudioPolicyManager->releaseAudioPatch(handle,
1166 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001167}
1168
1169status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
Eric Laurent6a94d692014-05-20 11:18:06 -07001170 struct audio_patch *patches,
1171 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001172{
Eric Laurent6a94d692014-05-20 11:18:06 -07001173 Mutex::Autolock _l(mLock);
1174 if (mAudioPolicyManager == NULL) {
1175 return NO_INIT;
1176 }
Eric Laurent10b71232018-04-13 18:14:44 -07001177 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001178 return mAudioPolicyManager->listAudioPatches(num_patches, patches, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001179}
1180
Eric Laurent6a94d692014-05-20 11:18:06 -07001181status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config)
Eric Laurent203b1a12014-04-01 10:34:16 -07001182{
Eric Laurent6a94d692014-05-20 11:18:06 -07001183 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001184 if(!modifyAudioRoutingAllowed()) {
1185 return PERMISSION_DENIED;
1186 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001187 if (mAudioPolicyManager == NULL) {
1188 return NO_INIT;
1189 }
Eric Laurent10b71232018-04-13 18:14:44 -07001190 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001191 return mAudioPolicyManager->setAudioPortConfig(config);
Eric Laurent203b1a12014-04-01 10:34:16 -07001192}
Eric Laurent2d388ec2014-03-07 13:25:54 -08001193
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001194status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session,
1195 audio_io_handle_t *ioHandle,
1196 audio_devices_t *device)
1197{
Andy Hungf759b8c2017-08-15 12:48:54 -07001198 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001199 if (mAudioPolicyManager == NULL) {
1200 return NO_INIT;
1201 }
Eric Laurent10b71232018-04-13 18:14:44 -07001202 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001203 return mAudioPolicyManager->acquireSoundTriggerSession(session, ioHandle, device);
1204}
1205
1206status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session)
1207{
Andy Hungf759b8c2017-08-15 12:48:54 -07001208 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001209 if (mAudioPolicyManager == NULL) {
1210 return NO_INIT;
1211 }
Eric Laurent10b71232018-04-13 18:14:44 -07001212 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001213 return mAudioPolicyManager->releaseSoundTriggerSession(session);
1214}
1215
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -07001216status_t AudioPolicyService::registerPolicyMixes(const Vector<AudioMix>& mixes, bool registration)
Eric Laurentbaac1832014-12-01 17:52:59 -08001217{
1218 Mutex::Autolock _l(mLock);
Kevin Rocardbe201852019-02-20 22:33:28 -08001219
1220 // loopback|render only need a MediaProjection (checked in caller AudioService.java)
1221 bool needModifyAudioRouting = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
1222 return !is_mix_loopback_render(mix.mRouteFlags); });
1223 if (needModifyAudioRouting && !modifyAudioRoutingAllowed()) {
Eric Laurentbaac1832014-12-01 17:52:59 -08001224 return PERMISSION_DENIED;
1225 }
Kevin Rocardbe201852019-02-20 22:33:28 -08001226
Nadav Bar287d3302020-02-05 14:55:38 +02001227 // If one of the mixes has needCaptureVoiceCommunicationOutput set to true, then we
1228 // need to verify that the caller still has CAPTURE_VOICE_COMMUNICATION_OUTPUT
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001229 bool needCaptureVoiceCommunicationOutput =
1230 std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
Nadav Bar287d3302020-02-05 14:55:38 +02001231 return mix.mVoiceCommunicationCaptureAllowed; });
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001232
Kevin Rocard36b17552019-03-07 18:48:07 -08001233 bool needCaptureMediaOutput = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
Nadav Bar287d3302020-02-05 14:55:38 +02001234 return mix.mAllowPrivilegedPlaybackCapture; });
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001235
Kevin Rocard36b17552019-03-07 18:48:07 -08001236 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
1237 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001238
Kevin Rocard36b17552019-03-07 18:48:07 -08001239 if (needCaptureMediaOutput && !captureMediaOutputAllowed(callingPid, callingUid)) {
1240 return PERMISSION_DENIED;
1241 }
1242
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001243 if (needCaptureVoiceCommunicationOutput &&
1244 !captureVoiceCommunicationOutputAllowed(callingPid, callingUid)) {
1245 return PERMISSION_DENIED;
1246 }
1247
Eric Laurentbaac1832014-12-01 17:52:59 -08001248 if (mAudioPolicyManager == NULL) {
1249 return NO_INIT;
1250 }
Eric Laurent10b71232018-04-13 18:14:44 -07001251 AutoCallerClear acc;
Eric Laurentbaac1832014-12-01 17:52:59 -08001252 if (registration) {
1253 return mAudioPolicyManager->registerPolicyMixes(mixes);
1254 } else {
1255 return mAudioPolicyManager->unregisterPolicyMixes(mixes);
1256 }
1257}
1258
Jean-Michel Trivibda70da2018-12-19 07:30:15 -08001259status_t AudioPolicyService::setUidDeviceAffinities(uid_t uid,
1260 const Vector<AudioDeviceTypeAddr>& devices) {
1261 Mutex::Autolock _l(mLock);
1262 if(!modifyAudioRoutingAllowed()) {
1263 return PERMISSION_DENIED;
1264 }
1265 if (mAudioPolicyManager == NULL) {
1266 return NO_INIT;
1267 }
1268 AutoCallerClear acc;
1269 return mAudioPolicyManager->setUidDeviceAffinities(uid, devices);
1270}
1271
1272status_t AudioPolicyService::removeUidDeviceAffinities(uid_t uid) {
1273 Mutex::Autolock _l(mLock);
1274 if(!modifyAudioRoutingAllowed()) {
1275 return PERMISSION_DENIED;
1276 }
1277 if (mAudioPolicyManager == NULL) {
1278 return NO_INIT;
1279 }
1280 AutoCallerClear acc;
1281 return mAudioPolicyManager->removeUidDeviceAffinities(uid);
1282}
1283
Oscar Azucena90e77632019-11-27 17:12:28 -08001284status_t AudioPolicyService::setUserIdDeviceAffinities(int userId,
1285 const Vector<AudioDeviceTypeAddr>& devices) {
1286 Mutex::Autolock _l(mLock);
1287 if(!modifyAudioRoutingAllowed()) {
1288 return PERMISSION_DENIED;
1289 }
1290 if (mAudioPolicyManager == NULL) {
1291 return NO_INIT;
1292 }
1293 AutoCallerClear acc;
1294 return mAudioPolicyManager->setUserIdDeviceAffinities(userId, devices);
1295}
1296
1297status_t AudioPolicyService::removeUserIdDeviceAffinities(int userId) {
1298 Mutex::Autolock _l(mLock);
1299 if(!modifyAudioRoutingAllowed()) {
1300 return PERMISSION_DENIED;
1301 }
1302 if (mAudioPolicyManager == NULL) {
1303 return NO_INIT;
1304 }
1305 AutoCallerClear acc;
1306 return mAudioPolicyManager->removeUserIdDeviceAffinities(userId);
1307}
1308
Eric Laurent554a2772015-04-10 11:29:24 -07001309status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001310 const audio_attributes_t *attributes,
1311 audio_port_handle_t *portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001312{
1313 Mutex::Autolock _l(mLock);
1314 if (mAudioPolicyManager == NULL) {
1315 return NO_INIT;
1316 }
Hayden Gomes524159d2019-12-23 14:41:47 -08001317
1318 status_t result = validateUsage(attributes->usage);
1319 if (result != NO_ERROR) {
1320 return result;
1321 }
1322
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001323 // startAudioSource should be created as the calling uid
1324 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Eric Laurent10b71232018-04-13 18:14:44 -07001325 AutoCallerClear acc;
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001326 return mAudioPolicyManager->startAudioSource(source, attributes, portId, callingUid);
Eric Laurent554a2772015-04-10 11:29:24 -07001327}
1328
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001329status_t AudioPolicyService::stopAudioSource(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 }
Eric Laurent10b71232018-04-13 18:14:44 -07001335 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001336 return mAudioPolicyManager->stopAudioSource(portId);
Eric Laurent554a2772015-04-10 11:29:24 -07001337}
1338
Andy Hung2ddee192015-12-18 17:34:44 -08001339status_t AudioPolicyService::setMasterMono(bool mono)
1340{
1341 if (mAudioPolicyManager == NULL) {
1342 return NO_INIT;
1343 }
1344 if (!settingsAllowed()) {
1345 return PERMISSION_DENIED;
1346 }
1347 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001348 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001349 return mAudioPolicyManager->setMasterMono(mono);
1350}
1351
1352status_t AudioPolicyService::getMasterMono(bool *mono)
1353{
1354 if (mAudioPolicyManager == NULL) {
1355 return NO_INIT;
1356 }
1357 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001358 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001359 return mAudioPolicyManager->getMasterMono(mono);
1360}
1361
Eric Laurentac9cef52017-06-09 15:46:26 -07001362
1363float AudioPolicyService::getStreamVolumeDB(
1364 audio_stream_type_t stream, int index, audio_devices_t device)
1365{
1366 if (mAudioPolicyManager == NULL) {
1367 return NAN;
1368 }
1369 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001370 AutoCallerClear acc;
Eric Laurentac9cef52017-06-09 15:46:26 -07001371 return mAudioPolicyManager->getStreamVolumeDB(stream, index, device);
1372}
1373
jiabin81772902018-04-02 17:52:27 -07001374status_t AudioPolicyService::getSurroundFormats(unsigned int *numSurroundFormats,
1375 audio_format_t *surroundFormats,
1376 bool *surroundFormatsEnabled,
1377 bool reported)
1378{
1379 if (mAudioPolicyManager == NULL) {
1380 return NO_INIT;
1381 }
1382 Mutex::Autolock _l(mLock);
1383 AutoCallerClear acc;
1384 return mAudioPolicyManager->getSurroundFormats(numSurroundFormats, surroundFormats,
1385 surroundFormatsEnabled, reported);
1386}
1387
Arun Mirpuri11029ad2018-12-19 20:45:19 -08001388status_t AudioPolicyService::getHwOffloadEncodingFormatsSupportedForA2DP(
1389 std::vector<audio_format_t> *formats)
1390{
1391 if (mAudioPolicyManager == NULL) {
1392 return NO_INIT;
1393 }
1394 Mutex::Autolock _l(mLock);
1395 AutoCallerClear acc;
1396 return mAudioPolicyManager->getHwOffloadEncodingFormatsSupportedForA2DP(formats);
1397}
1398
jiabin81772902018-04-02 17:52:27 -07001399status_t AudioPolicyService::setSurroundFormatEnabled(audio_format_t audioFormat, bool enabled)
1400{
1401 if (mAudioPolicyManager == NULL) {
1402 return NO_INIT;
1403 }
1404 Mutex::Autolock _l(mLock);
1405 AutoCallerClear acc;
1406 return mAudioPolicyManager->setSurroundFormatEnabled(audioFormat, enabled);
1407}
Eric Laurentac9cef52017-06-09 15:46:26 -07001408
Eric Laurentb78763e2018-10-17 10:08:02 -07001409status_t AudioPolicyService::setAssistantUid(uid_t uid)
1410{
1411 Mutex::Autolock _l(mLock);
1412 mUidPolicy->setAssistantUid(uid);
1413 return NO_ERROR;
1414}
1415
1416status_t AudioPolicyService::setA11yServicesUids(const std::vector<uid_t>& uids)
1417{
1418 Mutex::Autolock _l(mLock);
1419 mUidPolicy->setA11yUids(uids);
1420 return NO_ERROR;
1421}
1422
Kohsuke Yatoha623a132020-03-24 20:10:26 -07001423status_t AudioPolicyService::setCurrentImeUid(uid_t uid)
1424{
1425 Mutex::Autolock _l(mLock);
1426 mUidPolicy->setCurrentImeUid(uid);
1427 return NO_ERROR;
1428}
1429
jiabin6012f912018-11-02 17:06:30 -07001430bool AudioPolicyService::isHapticPlaybackSupported()
1431{
1432 if (mAudioPolicyManager == NULL) {
1433 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1434 return false;
1435 }
1436 Mutex::Autolock _l(mLock);
1437 AutoCallerClear acc;
1438 return mAudioPolicyManager->isHapticPlaybackSupported();
1439}
1440
François Gaffied0ba9ed2018-11-05 11:50:42 +01001441status_t AudioPolicyService::listAudioProductStrategies(AudioProductStrategyVector &strategies)
1442{
1443 if (mAudioPolicyManager == NULL) {
1444 return NO_INIT;
1445 }
1446 Mutex::Autolock _l(mLock);
1447 return mAudioPolicyManager->listAudioProductStrategies(strategies);
1448}
1449
François Gaffie4b2018b2018-11-07 11:18:59 +01001450status_t AudioPolicyService::getProductStrategyFromAudioAttributes(
1451 const AudioAttributes &aa, product_strategy_t &productStrategy)
François Gaffied0ba9ed2018-11-05 11:50:42 +01001452{
1453 if (mAudioPolicyManager == NULL) {
François Gaffie4b2018b2018-11-07 11:18:59 +01001454 return NO_INIT;
François Gaffied0ba9ed2018-11-05 11:50:42 +01001455 }
1456 Mutex::Autolock _l(mLock);
François Gaffie4b2018b2018-11-07 11:18:59 +01001457 return mAudioPolicyManager->getProductStrategyFromAudioAttributes(aa, productStrategy);
1458}
1459
1460status_t AudioPolicyService::listAudioVolumeGroups(AudioVolumeGroupVector &groups)
1461{
1462 if (mAudioPolicyManager == NULL) {
1463 return NO_INIT;
1464 }
1465 Mutex::Autolock _l(mLock);
1466 return mAudioPolicyManager->listAudioVolumeGroups(groups);
1467}
1468
1469status_t AudioPolicyService::getVolumeGroupFromAudioAttributes(const AudioAttributes &aa,
1470 volume_group_t &volumeGroup)
1471{
1472 if (mAudioPolicyManager == NULL) {
1473 return NO_INIT;
1474 }
1475 Mutex::Autolock _l(mLock);
1476 return mAudioPolicyManager->getVolumeGroupFromAudioAttributes(aa, volumeGroup);
François Gaffied0ba9ed2018-11-05 11:50:42 +01001477}
Eric Laurent6ede98f2019-06-11 14:50:30 -07001478
1479status_t AudioPolicyService::setRttEnabled(bool enabled)
1480{
1481 Mutex::Autolock _l(mLock);
1482 mUidPolicy->setRttEnabled(enabled);
1483 return NO_ERROR;
1484}
1485
Eric Laurent8340e672019-11-06 11:01:08 -08001486bool AudioPolicyService::isCallScreenModeSupported()
1487{
1488 if (mAudioPolicyManager == NULL) {
1489 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1490 return false;
1491 }
1492 Mutex::Autolock _l(mLock);
1493 AutoCallerClear acc;
1494 return mAudioPolicyManager->isCallScreenModeSupported();
1495}
1496
Jean-Michel Trivi30857152019-11-01 11:04:15 -07001497status_t AudioPolicyService::setPreferredDeviceForStrategy(product_strategy_t strategy,
1498 const AudioDeviceTypeAddr &device)
1499{
1500 if (mAudioPolicyManager == NULL) {
1501 return NO_INIT;
1502 }
1503 Mutex::Autolock _l(mLock);
1504 return mAudioPolicyManager->setPreferredDeviceForStrategy(strategy, device);
1505}
1506
1507status_t AudioPolicyService::removePreferredDeviceForStrategy(product_strategy_t strategy)
1508{
1509 if (mAudioPolicyManager == NULL) {
1510 return NO_INIT;
1511 }
1512 Mutex::Autolock _l(mLock);
1513 return mAudioPolicyManager->removePreferredDeviceForStrategy(strategy);
1514}
1515
1516status_t AudioPolicyService::getPreferredDeviceForStrategy(product_strategy_t strategy,
1517 AudioDeviceTypeAddr &device)
1518{
1519 if (mAudioPolicyManager == NULL) {
1520 return NO_INIT;
1521 }
1522 Mutex::Autolock _l(mLock);
1523 return mAudioPolicyManager->getPreferredDeviceForStrategy(strategy, device);
1524}
1525
Ytai Ben-Tsvi85093d52020-03-26 09:41:15 -07001526status_t AudioPolicyService::registerSoundTriggerCaptureStateListener(
1527 const sp<media::ICaptureStateListener>& listener,
1528 bool* result)
1529{
1530 *result = mCaptureStateNotifier.RegisterListener(listener);
1531 return NO_ERROR;
1532}
1533
Mikhail Naganov1b2a7942017-12-08 10:18:09 -08001534} // namespace android