blob: ee32afe702fa022e3c9a9cd7317095fb1cdb6a8c [file] [log] [blame]
Eric Laurent2d388ec2014-03-07 13:25:54 -08001/*
2 * Copyright (C) 2009 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Eric Laurentdce54a12014-03-10 12:19:46 -070017#define LOG_TAG "AudioPolicyIntefaceImpl"
Eric Laurent2d388ec2014-03-07 13:25:54 -080018//#define LOG_NDEBUG 0
19
Eric Laurent2d388ec2014-03-07 13:25:54 -080020#include "AudioPolicyService.h"
Ray Essick84e84a52018-05-03 18:45:07 -070021#include "TypeConverter.h"
Ray Essickf27e9872019-12-07 06:28:46 -080022#include <media/MediaMetricsItem.h>
Kevin Rocardbe201852019-02-20 22:33:28 -080023#include <media/AudioPolicy.h>
Eric Laurentd7fe0862018-07-14 16:48:01 -070024#include <utils/Log.h>
Eric Laurent2d388ec2014-03-07 13:25:54 -080025
Eric Laurent2d388ec2014-03-07 13:25:54 -080026namespace android {
27
Hayden Gomes524159d2019-12-23 14:41:47 -080028const std::vector<audio_usage_t>& SYSTEM_USAGES = {
29 AUDIO_USAGE_CALL_ASSISTANT,
30 AUDIO_USAGE_EMERGENCY,
31 AUDIO_USAGE_SAFETY,
32 AUDIO_USAGE_VEHICLE_STATUS,
33 AUDIO_USAGE_ANNOUNCEMENT
34};
35
36bool isSystemUsage(audio_usage_t usage) {
37 return std::find(std::begin(SYSTEM_USAGES), std::end(SYSTEM_USAGES), usage)
38 != std::end(SYSTEM_USAGES);
39}
40
41bool AudioPolicyService::isSupportedSystemUsage(audio_usage_t usage) {
42 return std::find(std::begin(mSupportedSystemUsages), std::end(mSupportedSystemUsages), usage)
43 != std::end(mSupportedSystemUsages);
44}
45
46status_t AudioPolicyService::validateUsage(audio_usage_t usage) {
47 return validateUsage(usage, IPCThreadState::self()->getCallingPid(),
48 IPCThreadState::self()->getCallingUid());
49}
50
51status_t AudioPolicyService::validateUsage(audio_usage_t usage, pid_t pid, uid_t uid) {
52 if (isSystemUsage(usage)) {
53 if (isSupportedSystemUsage(usage)) {
54 if (!modifyAudioRoutingAllowed(pid, uid)) {
55 ALOGE("permission denied: modify audio routing not allowed for uid %d", uid);
56 return PERMISSION_DENIED;
57 }
58 } else {
59 return BAD_VALUE;
60 }
61 }
62 return NO_ERROR;
63}
64
65
Eric Laurent2d388ec2014-03-07 13:25:54 -080066
67// ----------------------------------------------------------------------------
68
69status_t AudioPolicyService::setDeviceConnectionState(audio_devices_t device,
70 audio_policy_dev_state_t state,
Paul McLeane743a472015-01-28 11:07:31 -080071 const char *device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080072 const char *device_name,
73 audio_format_t encodedFormat)
Eric Laurent2d388ec2014-03-07 13:25:54 -080074{
Eric Laurentdce54a12014-03-10 12:19:46 -070075 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080076 return NO_INIT;
77 }
78 if (!settingsAllowed()) {
79 return PERMISSION_DENIED;
80 }
Eric Laurent2d388ec2014-03-07 13:25:54 -080081 if (state != AUDIO_POLICY_DEVICE_STATE_AVAILABLE &&
82 state != AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE) {
83 return BAD_VALUE;
84 }
85
86 ALOGV("setDeviceConnectionState()");
87 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -070088 AutoCallerClear acc;
Paul McLeane743a472015-01-28 11:07:31 -080089 return mAudioPolicyManager->setDeviceConnectionState(device, state,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080090 device_address, device_name, encodedFormat);
Eric Laurent2d388ec2014-03-07 13:25:54 -080091}
92
93audio_policy_dev_state_t AudioPolicyService::getDeviceConnectionState(
94 audio_devices_t device,
95 const char *device_address)
96{
Eric Laurentdce54a12014-03-10 12:19:46 -070097 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080098 return AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE;
99 }
Eric Laurent10b71232018-04-13 18:14:44 -0700100 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700101 return mAudioPolicyManager->getDeviceConnectionState(device,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800102 device_address);
103}
104
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800105status_t AudioPolicyService::handleDeviceConfigChange(audio_devices_t device,
106 const char *device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -0800107 const char *device_name,
108 audio_format_t encodedFormat)
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800109{
110 if (mAudioPolicyManager == NULL) {
111 return NO_INIT;
112 }
113 if (!settingsAllowed()) {
114 return PERMISSION_DENIED;
115 }
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800116
117 ALOGV("handleDeviceConfigChange()");
118 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700119 AutoCallerClear acc;
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800120 return mAudioPolicyManager->handleDeviceConfigChange(device, device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -0800121 device_name, encodedFormat);
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -0800122}
123
Eric Laurent2d388ec2014-03-07 13:25:54 -0800124status_t AudioPolicyService::setPhoneState(audio_mode_t state)
125{
Eric Laurentdce54a12014-03-10 12:19:46 -0700126 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800127 return NO_INIT;
128 }
129 if (!settingsAllowed()) {
130 return PERMISSION_DENIED;
131 }
132 if (uint32_t(state) >= AUDIO_MODE_CNT) {
133 return BAD_VALUE;
134 }
135
136 ALOGV("setPhoneState()");
137
Eric Laurentbeb07fe2015-09-16 15:49:30 -0700138 // acquire lock before calling setMode() so that setMode() + setPhoneState() are an atomic
139 // operation from policy manager standpoint (no other operation (e.g track start or stop)
140 // can be interleaved).
141 Mutex::Autolock _l(mLock);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800142 // TODO: check if it is more appropriate to do it in platform specific policy manager
143 AudioSystem::setMode(state);
144
Eric Laurent10b71232018-04-13 18:14:44 -0700145 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700146 mAudioPolicyManager->setPhoneState(state);
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700147 mPhoneState = state;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800148 return NO_ERROR;
149}
150
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700151audio_mode_t AudioPolicyService::getPhoneState()
152{
153 Mutex::Autolock _l(mLock);
154 return mPhoneState;
155}
156
Eric Laurent2d388ec2014-03-07 13:25:54 -0800157status_t AudioPolicyService::setForceUse(audio_policy_force_use_t usage,
158 audio_policy_forced_cfg_t config)
159{
Eric Laurentdce54a12014-03-10 12:19:46 -0700160 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800161 return NO_INIT;
162 }
Eric Laurente17378d2018-05-09 14:43:01 -0700163
164 if (!modifyAudioRoutingAllowed()) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800165 return PERMISSION_DENIED;
166 }
Eric Laurente17378d2018-05-09 14:43:01 -0700167
Eric Laurent2d388ec2014-03-07 13:25:54 -0800168 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
169 return BAD_VALUE;
170 }
171 if (config < 0 || config >= AUDIO_POLICY_FORCE_CFG_CNT) {
172 return BAD_VALUE;
173 }
174 ALOGV("setForceUse()");
175 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700176 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700177 mAudioPolicyManager->setForceUse(usage, config);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800178 return NO_ERROR;
179}
180
181audio_policy_forced_cfg_t AudioPolicyService::getForceUse(audio_policy_force_use_t usage)
182{
Eric Laurentdce54a12014-03-10 12:19:46 -0700183 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800184 return AUDIO_POLICY_FORCE_NONE;
185 }
186 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
187 return AUDIO_POLICY_FORCE_NONE;
188 }
Eric Laurent10b71232018-04-13 18:14:44 -0700189 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700190 return mAudioPolicyManager->getForceUse(usage);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800191}
192
Eric Laurentf4e63452017-11-06 19:31:46 +0000193audio_io_handle_t AudioPolicyService::getOutput(audio_stream_type_t stream)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800194{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800195 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700196 return AUDIO_IO_HANDLE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700197 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700198 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700199 return AUDIO_IO_HANDLE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800200 }
201 ALOGV("getOutput()");
202 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700203 AutoCallerClear acc;
Eric Laurentf4e63452017-11-06 19:31:46 +0000204 return mAudioPolicyManager->getOutput(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800205}
206
Eric Laurent42984412019-05-09 17:57:03 -0700207status_t AudioPolicyService::getOutputForAttr(audio_attributes_t *attr,
Eric Laurente83b55d2014-11-14 10:06:21 -0800208 audio_io_handle_t *output,
209 audio_session_t session,
210 audio_stream_type_t *stream,
Nadav Bar766fb022018-01-07 12:18:03 +0200211 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700212 uid_t uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800213 const audio_config_t *config,
Eric Laurente83b55d2014-11-14 10:06:21 -0800214 audio_output_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700215 audio_port_handle_t *selectedDeviceId,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800216 audio_port_handle_t *portId,
217 std::vector<audio_io_handle_t> *secondaryOutputs)
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700218{
219 if (mAudioPolicyManager == NULL) {
Eric Laurente83b55d2014-11-14 10:06:21 -0800220 return NO_INIT;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700221 }
Hayden Gomes524159d2019-12-23 14:41:47 -0800222
223 status_t result = validateUsage(attr->usage, pid, uid);
224 if (result != NO_ERROR) {
225 return result;
226 }
227
Eric Laurent8a1095a2019-11-08 14:44:16 -0800228 ALOGV("%s()", __func__);
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700229 Mutex::Autolock _l(mLock);
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700230
Marco Nelissendcb346b2015-09-09 10:47:29 -0700231 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700232 if (!isAudioServerOrMediaServerUid(callingUid) || uid == (uid_t)-1) {
Marco Nelissendcb346b2015-09-09 10:47:29 -0700233 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Eric Laurent8a1095a2019-11-08 14:44:16 -0800234 "%s uid %d tried to pass itself off as %d", __func__, callingUid, uid);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700235 uid = callingUid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700236 }
Kevin Rocard8be94972019-02-22 13:26:25 -0800237 if (!mPackageManager.allowPlaybackCapture(uid)) {
Eric Laurent42984412019-05-09 17:57:03 -0700238 attr->flags |= AUDIO_FLAG_NO_MEDIA_PROJECTION;
239 }
Eric Laurent6ede98f2019-06-11 14:50:30 -0700240 if (((attr->flags & (AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE)) != 0)
241 && !bypassInterruptionPolicyAllowed(pid, uid)) {
Eric Laurent42984412019-05-09 17:57:03 -0700242 attr->flags &= ~(AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE);
Kevin Rocard8be94972019-02-22 13:26:25 -0800243 }
Eric Laurent10b71232018-04-13 18:14:44 -0700244 AutoCallerClear acc;
Eric Laurent8a1095a2019-11-08 14:44:16 -0800245 AudioPolicyInterface::output_type_t outputType;
Hayden Gomes3e8bbb92020-01-10 13:37:05 -0800246 result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800247 config,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800248 &flags, selectedDeviceId, portId,
Eric Laurent8a1095a2019-11-08 14:44:16 -0800249 secondaryOutputs,
250 &outputType);
Nadav Bar766fb022018-01-07 12:18:03 +0200251
252 // FIXME: Introduce a way to check for the the telephony device before opening the output
Eric Laurent8a1095a2019-11-08 14:44:16 -0800253 if (result == NO_ERROR) {
254 // enforce permission (if any) required for each type of input
255 switch (outputType) {
256 case AudioPolicyInterface::API_OUTPUT_LEGACY:
257 break;
258 case AudioPolicyInterface::API_OUTPUT_TELEPHONY_TX:
259 if (!modifyPhoneStateAllowed(pid, uid)) {
260 ALOGE("%s() permission denied: modify phone state not allowed for uid %d",
261 __func__, uid);
262 result = PERMISSION_DENIED;
263 }
264 break;
265 case AudioPolicyInterface::API_OUT_MIX_PLAYBACK:
266 if (!modifyAudioRoutingAllowed(pid, uid)) {
267 ALOGE("%s() permission denied: modify audio routing not allowed for uid %d",
268 __func__, uid);
269 result = PERMISSION_DENIED;
270 }
271 break;
272 case AudioPolicyInterface::API_OUTPUT_INVALID:
273 default:
274 LOG_ALWAYS_FATAL("%s() encountered an invalid output type %d",
275 __func__, (int)outputType);
276 }
Nadav Bar766fb022018-01-07 12:18:03 +0200277 }
Eric Laurentd7fe0862018-07-14 16:48:01 -0700278
279 if (result == NO_ERROR) {
280 sp <AudioPlaybackClient> client =
Eric Laurent5ada82e2019-08-29 17:53:54 -0700281 new AudioPlaybackClient(*attr, *output, uid, pid, session, *portId, *selectedDeviceId, *stream);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700282 mAudioPlaybackClients.add(*portId, client);
283 }
Nadav Bar766fb022018-01-07 12:18:03 +0200284 return result;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700285}
286
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700287void AudioPolicyService::getPlaybackClientAndEffects(audio_port_handle_t portId,
288 sp<AudioPlaybackClient>& client,
289 sp<AudioPolicyEffects>& effects,
290 const char *context)
291{
292 Mutex::Autolock _l(mLock);
293 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
294 if (index < 0) {
295 ALOGE("%s AudioTrack client not found for portId %d", context, portId);
296 return;
297 }
298 client = mAudioPlaybackClients.valueAt(index);
299 effects = mAudioPolicyEffects;
300}
301
Eric Laurentd7fe0862018-07-14 16:48:01 -0700302status_t AudioPolicyService::startOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800303{
Eric Laurentdce54a12014-03-10 12:19:46 -0700304 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800305 return NO_INIT;
306 }
307 ALOGV("startOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700308 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700309 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700310
311 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
312
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700313 if (audioPolicyEffects != 0) {
314 // create audio processors according to stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700315 status_t status = audioPolicyEffects->addOutputSessionEffects(
316 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700317 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700318 ALOGW("Failed to add effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700319 }
320 }
321 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700322 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700323 status_t status = mAudioPolicyManager->startOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700324 if (status == NO_ERROR) {
325 client->active = true;
326 }
327 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800328}
329
Eric Laurentd7fe0862018-07-14 16:48:01 -0700330status_t AudioPolicyService::stopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800331{
Eric Laurentdce54a12014-03-10 12:19:46 -0700332 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800333 return NO_INIT;
334 }
335 ALOGV("stopOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700336 mOutputCommandThread->stopOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800337 return NO_ERROR;
338}
339
Eric Laurentd7fe0862018-07-14 16:48:01 -0700340status_t AudioPolicyService::doStopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800341{
Eric Laurentd7fe0862018-07-14 16:48:01 -0700342 ALOGV("doStopOutput");
343 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700344 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentd7fe0862018-07-14 16:48:01 -0700345
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700346 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
347
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700348 if (audioPolicyEffects != 0) {
349 // release audio processors from the stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700350 status_t status = audioPolicyEffects->releaseOutputSessionEffects(
351 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700352 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700353 ALOGW("Failed to release effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700354 }
355 }
356 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700357 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700358 status_t status = mAudioPolicyManager->stopOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700359 if (status == NO_ERROR) {
360 client->active = false;
361 }
362 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800363}
364
Eric Laurentd7fe0862018-07-14 16:48:01 -0700365void AudioPolicyService::releaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800366{
Eric Laurentdce54a12014-03-10 12:19:46 -0700367 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800368 return;
369 }
370 ALOGV("releaseOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700371 mOutputCommandThread->releaseOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800372}
373
Eric Laurentd7fe0862018-07-14 16:48:01 -0700374void AudioPolicyService::doReleaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800375{
376 ALOGV("doReleaseOutput from tid %d", gettid());
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700377 sp<AudioPlaybackClient> client;
378 sp<AudioPolicyEffects> audioPolicyEffects;
379
380 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
381
382 if (audioPolicyEffects != 0 && client->active) {
383 // clean up effects if output was not stopped before being released
384 audioPolicyEffects->releaseOutputSessionEffects(
385 client->io, client->stream, client->session);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700386 }
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700387 Mutex::Autolock _l(mLock);
Eric Laurentd4007242019-03-27 12:42:16 -0700388 mAudioPlaybackClients.removeItem(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700389
Eric Laurent10b71232018-04-13 18:14:44 -0700390 // called from internal thread: no need to clear caller identity
Eric Laurent8fc147b2018-07-22 19:13:55 -0700391 mAudioPolicyManager->releaseOutput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800392}
393
Eric Laurentcaf7f482014-11-25 17:50:47 -0800394status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
395 audio_io_handle_t *input,
Mikhail Naganov2996f672019-04-18 12:29:59 -0700396 audio_unique_id_t riid,
Eric Laurentcaf7f482014-11-25 17:50:47 -0800397 audio_session_t session,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700398 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700399 uid_t uid,
Eric Laurentfee19762018-01-29 18:44:13 -0800400 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800401 const audio_config_base_t *config,
Paul McLean466dc8e2015-04-17 13:15:36 -0600402 audio_input_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700403 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800404 audio_port_handle_t *portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800405{
Eric Laurentdce54a12014-03-10 12:19:46 -0700406 if (mAudioPolicyManager == NULL) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800407 return NO_INIT;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800408 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800409
Hayden Gomes524159d2019-12-23 14:41:47 -0800410 status_t result = validateUsage(attr->usage, pid, uid);
411 if (result != NO_ERROR) {
412 return result;
413 }
414
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900415 audio_source_t inputSource = attr->source;
416 if (inputSource == AUDIO_SOURCE_DEFAULT) {
417 inputSource = AUDIO_SOURCE_MIC;
418 }
419
Eric Laurent2d388ec2014-03-07 13:25:54 -0800420 // already checked by client, but double-check in case the client wrapper is bypassed
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900421 if ((inputSource < AUDIO_SOURCE_DEFAULT)
422 || (inputSource >= AUDIO_SOURCE_CNT
423 && inputSource != AUDIO_SOURCE_HOTWORD
424 && inputSource != AUDIO_SOURCE_FM_TUNER
425 && inputSource != AUDIO_SOURCE_ECHO_REFERENCE)) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800426 return BAD_VALUE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800427 }
428
Eric Laurentb2379ba2016-05-23 17:42:12 -0700429 bool updatePid = (pid == -1);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700430 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700431 if (!isAudioServerOrMediaServerUid(callingUid)) {
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700432 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Marco Nelissendcb346b2015-09-09 10:47:29 -0700433 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
434 uid = callingUid;
Eric Laurentb2379ba2016-05-23 17:42:12 -0700435 updatePid = true;
436 }
437
438 if (updatePid) {
439 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700440 ALOGW_IF(pid != (pid_t)-1 && pid != callingPid,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700441 "%s uid %d pid %d tried to pass itself off as pid %d",
442 __func__, callingUid, callingPid, pid);
443 pid = callingPid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700444 }
445
Eric Laurent58a0dd82019-10-24 12:42:17 -0700446 // check calling permissions.
447 // Capturing from FM_TUNER source is controlled by captureAudioOutputAllowed() only as this
448 // does not affect users privacy as does capturing from an actual microphone.
449 if (!(recordingAllowed(opPackageName, pid, uid) || attr->source == AUDIO_SOURCE_FM_TUNER)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800450 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
451 __func__, uid, pid);
452 return PERMISSION_DENIED;
453 }
454
Eric Laurent1ff16a72019-03-14 18:35:04 -0700455 bool canCaptureOutput = captureAudioOutputAllowed(pid, uid);
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900456 if ((inputSource == AUDIO_SOURCE_VOICE_UPLINK ||
457 inputSource == AUDIO_SOURCE_VOICE_DOWNLINK ||
458 inputSource == AUDIO_SOURCE_VOICE_CALL ||
459 inputSource == AUDIO_SOURCE_ECHO_REFERENCE||
460 inputSource == AUDIO_SOURCE_FM_TUNER) &&
Eric Laurent1ff16a72019-03-14 18:35:04 -0700461 !canCaptureOutput) {
Nadav Bar744be482018-05-08 13:26:21 +0300462 return PERMISSION_DENIED;
463 }
464
jiabin68e0df72019-03-18 17:55:35 -0700465 bool canCaptureHotword = captureHotwordAllowed(opPackageName, pid, uid);
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900466 if ((inputSource == AUDIO_SOURCE_HOTWORD) && !canCaptureHotword) {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700467 return BAD_VALUE;
468 }
469
470 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700471 {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700472 status_t status;
473 AudioPolicyInterface::input_type_t inputType;
474
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700475 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700476 {
477 AutoCallerClear acc;
478 // the audio_in_acoustics_t parameter is ignored by get_input()
Mikhail Naganov2996f672019-04-18 12:29:59 -0700479 status = mAudioPolicyManager->getInputForAttr(attr, input, riid, session, uid,
Eric Laurent10b71232018-04-13 18:14:44 -0700480 config,
481 flags, selectedDeviceId,
482 &inputType, portId);
483 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700484 audioPolicyEffects = mAudioPolicyEffects;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800485
486 if (status == NO_ERROR) {
487 // enforce permission (if any) required for each type of input
488 switch (inputType) {
Kevin Rocard25f9b052019-02-27 15:08:54 -0800489 case AudioPolicyInterface::API_INPUT_MIX_PUBLIC_CAPTURE_PLAYBACK:
490 // this use case has been validated in audio service with a MediaProjection token,
491 // and doesn't rely on regular permissions
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800492 case AudioPolicyInterface::API_INPUT_LEGACY:
493 break;
Eric Laurent82db2692015-08-07 13:59:42 -0700494 case AudioPolicyInterface::API_INPUT_TELEPHONY_RX:
495 // FIXME: use the same permission as for remote submix for now.
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800496 case AudioPolicyInterface::API_INPUT_MIX_CAPTURE:
Eric Laurent1ff16a72019-03-14 18:35:04 -0700497 if (!canCaptureOutput) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800498 ALOGE("getInputForAttr() permission denied: capture not allowed");
499 status = PERMISSION_DENIED;
500 }
501 break;
502 case AudioPolicyInterface::API_INPUT_MIX_EXT_POLICY_REROUTE:
Eric Laurent8a1095a2019-11-08 14:44:16 -0800503 if (!modifyAudioRoutingAllowed(pid, uid)) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800504 ALOGE("getInputForAttr() permission denied: modify audio routing not allowed");
505 status = PERMISSION_DENIED;
506 }
507 break;
508 case AudioPolicyInterface::API_INPUT_INVALID:
509 default:
510 LOG_ALWAYS_FATAL("getInputForAttr() encountered an invalid input type %d",
511 (int)inputType);
512 }
513 }
514
515 if (status != NO_ERROR) {
516 if (status == PERMISSION_DENIED) {
Eric Laurent10b71232018-04-13 18:14:44 -0700517 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700518 mAudioPolicyManager->releaseInput(*portId);
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800519 }
520 return status;
521 }
Eric Laurentfee19762018-01-29 18:44:13 -0800522
Eric Laurent5ada82e2019-08-29 17:53:54 -0700523 sp<AudioRecordClient> client = new AudioRecordClient(*attr, *input, uid, pid, session, *portId,
Eric Laurent1ff16a72019-03-14 18:35:04 -0700524 *selectedDeviceId, opPackageName,
525 canCaptureOutput, canCaptureHotword);
Eric Laurentfee19762018-01-29 18:44:13 -0800526 mAudioRecordClients.add(*portId, client);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700527 }
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800528
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700529 if (audioPolicyEffects != 0) {
530 // create audio pre processors according to input source
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900531 status_t status = audioPolicyEffects->addInputEffects(*input, inputSource, session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700532 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800533 ALOGW("Failed to add effects on input %d", *input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700534 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800535 }
Eric Laurentcaf7f482014-11-25 17:50:47 -0800536 return NO_ERROR;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800537}
538
Eric Laurent99fcae42018-05-17 16:59:18 -0700539std::string AudioPolicyService::getDeviceTypeStrForPortId(audio_port_handle_t portId) {
Eric Laurent99fcae42018-05-17 16:59:18 -0700540 struct audio_port port = {};
541 port.id = portId;
542 status_t status = mAudioPolicyManager->getAudioPort(&port);
543 if (status == NO_ERROR && port.type == AUDIO_PORT_TYPE_DEVICE) {
Andy Hung9b181952019-02-25 14:53:36 -0800544 return toString(port.ext.device.type);
Eric Laurent99fcae42018-05-17 16:59:18 -0700545 }
Andy Hung9b181952019-02-25 14:53:36 -0800546 return {};
Eric Laurent99fcae42018-05-17 16:59:18 -0700547}
548
Eric Laurent4eb58f12018-12-07 16:41:02 -0800549status_t AudioPolicyService::startInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800550{
Eric Laurentdce54a12014-03-10 12:19:46 -0700551 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800552 return NO_INIT;
553 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800554 sp<AudioRecordClient> client;
555 {
556 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800557
Eric Laurent7dca8a82018-01-29 18:44:26 -0800558 ssize_t index = mAudioRecordClients.indexOfKey(portId);
559 if (index < 0) {
560 return INVALID_OPERATION;
561 }
562 client = mAudioRecordClients.valueAt(index);
Eric Laurentfee19762018-01-29 18:44:13 -0800563 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800564
565 // check calling permissions
Eric Laurent58a0dd82019-10-24 12:42:17 -0700566 if (!(startRecording(client->opPackageName, client->pid, client->uid)
567 || client->attributes.source == AUDIO_SOURCE_FM_TUNER)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800568 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
569 __func__, client->uid, client->pid);
570 return PERMISSION_DENIED;
571 }
Eric Laurentfee19762018-01-29 18:44:13 -0800572
Eric Laurentdf628922018-12-06 21:45:51 +0000573 Mutex::Autolock _l(mLock);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800574
575 client->active = true;
576 client->startTimeNs = systemTime();
577 updateUidStates_l();
Eric Laurentfee19762018-01-29 18:44:13 -0800578
Eric Laurent10b71232018-04-13 18:14:44 -0700579 status_t status;
580 {
581 AutoCallerClear acc;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800582 status = mAudioPolicyManager->startInput(portId);
Ray Essick84e84a52018-05-03 18:45:07 -0700583
584 }
585
Ray Essickf6a57cd2018-05-22 16:20:54 -0700586 // including successes gets very verbose
Ray Essick6ce27e52019-02-15 10:58:05 -0800587 // but once we cut over to westworld, log them all.
Ray Essickf6a57cd2018-05-22 16:20:54 -0700588 if (status != NO_ERROR) {
Ray Essick84e84a52018-05-03 18:45:07 -0700589
590 static constexpr char kAudioPolicy[] = "audiopolicy";
591
Ray Essick84e84a52018-05-03 18:45:07 -0700592 static constexpr char kAudioPolicyStatus[] = "android.media.audiopolicy.status";
593 static constexpr char kAudioPolicyRqstSrc[] = "android.media.audiopolicy.rqst.src";
594 static constexpr char kAudioPolicyRqstPkg[] = "android.media.audiopolicy.rqst.pkg";
595 static constexpr char kAudioPolicyRqstSession[] = "android.media.audiopolicy.rqst.session";
Eric Laurent99fcae42018-05-17 16:59:18 -0700596 static constexpr char kAudioPolicyRqstDevice[] =
597 "android.media.audiopolicy.rqst.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700598 static constexpr char kAudioPolicyActiveSrc[] = "android.media.audiopolicy.active.src";
599 static constexpr char kAudioPolicyActivePkg[] = "android.media.audiopolicy.active.pkg";
Eric Laurent99fcae42018-05-17 16:59:18 -0700600 static constexpr char kAudioPolicyActiveSession[] =
601 "android.media.audiopolicy.active.session";
602 static constexpr char kAudioPolicyActiveDevice[] =
603 "android.media.audiopolicy.active.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700604
Ray Essickf27e9872019-12-07 06:28:46 -0800605 mediametrics::Item *item = mediametrics::Item::create(kAudioPolicy);
Ray Essick84e84a52018-05-03 18:45:07 -0700606 if (item != NULL) {
607
Ray Essick84e84a52018-05-03 18:45:07 -0700608 item->setInt32(kAudioPolicyStatus, status);
609
Eric Laurent99fcae42018-05-17 16:59:18 -0700610 item->setCString(kAudioPolicyRqstSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800611 toString(client->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700612 item->setInt32(kAudioPolicyRqstSession, client->session);
Ray Essick51866952018-05-30 11:22:27 -0700613 if (client->opPackageName.size() != 0) {
614 item->setCString(kAudioPolicyRqstPkg,
615 std::string(String8(client->opPackageName).string()).c_str());
616 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700617 item->setCString(kAudioPolicyRqstPkg, std::to_string(client->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700618 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700619 item->setCString(
620 kAudioPolicyRqstDevice, getDeviceTypeStrForPortId(client->deviceId).c_str());
621
Eric Laurent4eb58f12018-12-07 16:41:02 -0800622 int count = mAudioRecordClients.size();
623 for (int i = 0; i < count ; i++) {
624 if (portId == mAudioRecordClients.keyAt(i)) {
625 continue;
626 }
627 sp<AudioRecordClient> other = mAudioRecordClients.valueAt(i);
628 if (other->active) {
629 // keeps the last of the clients marked active
630 item->setCString(kAudioPolicyActiveSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800631 toString(other->attributes.source).c_str());
Eric Laurent4eb58f12018-12-07 16:41:02 -0800632 item->setInt32(kAudioPolicyActiveSession, other->session);
633 if (other->opPackageName.size() != 0) {
634 item->setCString(kAudioPolicyActivePkg,
635 std::string(String8(other->opPackageName).string()).c_str());
636 } else {
637 item->setCString(kAudioPolicyRqstPkg,
638 std::to_string(other->uid).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700639 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800640 item->setCString(kAudioPolicyActiveDevice,
641 getDeviceTypeStrForPortId(other->deviceId).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700642 }
643 }
644 item->selfrecord();
645 delete item;
646 item = NULL;
647 }
Ray Essick6ce27e52019-02-15 10:58:05 -0800648 }
649
650 if (status != NO_ERROR) {
Eric Laurent4eb58f12018-12-07 16:41:02 -0800651 client->active = false;
652 client->startTimeNs = 0;
653 updateUidStates_l();
Svet Ganov6e641372018-03-02 09:21:30 -0800654 finishRecording(client->opPackageName, client->uid);
Eric Laurentfb66dd92016-01-28 18:32:03 -0800655 }
656
657 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800658}
659
Eric Laurentfee19762018-01-29 18:44:13 -0800660status_t AudioPolicyService::stopInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800661{
Eric Laurentdce54a12014-03-10 12:19:46 -0700662 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800663 return NO_INIT;
664 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800665
Eric Laurent2d388ec2014-03-07 13:25:54 -0800666 Mutex::Autolock _l(mLock);
667
Eric Laurentfee19762018-01-29 18:44:13 -0800668 ssize_t index = mAudioRecordClients.indexOfKey(portId);
669 if (index < 0) {
670 return INVALID_OPERATION;
671 }
672 sp<AudioRecordClient> client = mAudioRecordClients.valueAt(index);
673
Ray Essick84e84a52018-05-03 18:45:07 -0700674 client->active = false;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800675 client->startTimeNs = 0;
676
677 updateUidStates_l();
Ray Essick84e84a52018-05-03 18:45:07 -0700678
Svet Ganov6e641372018-03-02 09:21:30 -0800679 // finish the recording app op
680 finishRecording(client->opPackageName, client->uid);
Eric Laurent10b71232018-04-13 18:14:44 -0700681 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700682 return mAudioPolicyManager->stopInput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800683}
684
Eric Laurentfee19762018-01-29 18:44:13 -0800685void AudioPolicyService::releaseInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800686{
Eric Laurentdce54a12014-03-10 12:19:46 -0700687 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800688 return;
689 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700690 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800691 sp<AudioRecordClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700692 {
693 Mutex::Autolock _l(mLock);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700694 audioPolicyEffects = mAudioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800695 ssize_t index = mAudioRecordClients.indexOfKey(portId);
696 if (index < 0) {
697 return;
698 }
699 client = mAudioRecordClients.valueAt(index);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800700
701 if (client->active) {
702 ALOGW("%s releasing active client portId %d", __FUNCTION__, portId);
703 client->active = false;
704 client->startTimeNs = 0;
705 updateUidStates_l();
706 }
707
Eric Laurentfee19762018-01-29 18:44:13 -0800708 mAudioRecordClients.removeItem(portId);
709 }
710 if (client == 0) {
711 return;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700712 }
713 if (audioPolicyEffects != 0) {
714 // release audio processors from the input
Eric Laurentd7fe0862018-07-14 16:48:01 -0700715 status_t status = audioPolicyEffects->releaseInputEffects(client->io, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700716 if(status != NO_ERROR) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700717 ALOGW("Failed to release effects on input %d", client->io);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700718 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800719 }
Eric Laurentf10c7092016-12-06 17:09:56 -0800720 {
721 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700722 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700723 mAudioPolicyManager->releaseInput(portId);
Eric Laurentf10c7092016-12-06 17:09:56 -0800724 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800725}
726
727status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
728 int indexMin,
729 int indexMax)
730{
Eric Laurentdce54a12014-03-10 12:19:46 -0700731 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800732 return NO_INIT;
733 }
734 if (!settingsAllowed()) {
735 return PERMISSION_DENIED;
736 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800737 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800738 return BAD_VALUE;
739 }
740 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700741 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700742 mAudioPolicyManager->initStreamVolume(stream, indexMin, indexMax);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800743 return NO_ERROR;
744}
745
746status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
747 int index,
748 audio_devices_t device)
749{
Eric Laurentdce54a12014-03-10 12:19:46 -0700750 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800751 return NO_INIT;
752 }
753 if (!settingsAllowed()) {
754 return PERMISSION_DENIED;
755 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800756 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800757 return BAD_VALUE;
758 }
759 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700760 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700761 return mAudioPolicyManager->setStreamVolumeIndex(stream,
762 index,
763 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800764}
765
766status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
767 int *index,
768 audio_devices_t device)
769{
Eric Laurentdce54a12014-03-10 12:19:46 -0700770 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800771 return NO_INIT;
772 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800773 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800774 return BAD_VALUE;
775 }
776 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700777 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700778 return mAudioPolicyManager->getStreamVolumeIndex(stream,
779 index,
780 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800781}
782
François Gaffiecfe17322018-11-07 13:41:29 +0100783status_t AudioPolicyService::setVolumeIndexForAttributes(const audio_attributes_t &attributes,
784 int index, audio_devices_t device)
785{
786 if (mAudioPolicyManager == NULL) {
787 return NO_INIT;
788 }
789 if (!settingsAllowed()) {
790 return PERMISSION_DENIED;
791 }
792 Mutex::Autolock _l(mLock);
793 AutoCallerClear acc;
794 return mAudioPolicyManager->setVolumeIndexForAttributes(attributes, index, device);
795}
796
797status_t AudioPolicyService::getVolumeIndexForAttributes(const audio_attributes_t &attributes,
798 int &index, audio_devices_t device)
799{
800 if (mAudioPolicyManager == NULL) {
801 return NO_INIT;
802 }
803 Mutex::Autolock _l(mLock);
804 AutoCallerClear acc;
805 return mAudioPolicyManager->getVolumeIndexForAttributes(attributes, index, device);
806}
807
808status_t AudioPolicyService::getMinVolumeIndexForAttributes(const audio_attributes_t &attributes,
809 int &index)
810{
811 if (mAudioPolicyManager == NULL) {
812 return NO_INIT;
813 }
814 Mutex::Autolock _l(mLock);
815 AutoCallerClear acc;
816 return mAudioPolicyManager->getMinVolumeIndexForAttributes(attributes, index);
817}
818
819status_t AudioPolicyService::getMaxVolumeIndexForAttributes(const audio_attributes_t &attributes,
820 int &index)
821{
822 if (mAudioPolicyManager == NULL) {
823 return NO_INIT;
824 }
825 Mutex::Autolock _l(mLock);
826 AutoCallerClear acc;
827 return mAudioPolicyManager->getMaxVolumeIndexForAttributes(attributes, index);
828}
829
Eric Laurent2d388ec2014-03-07 13:25:54 -0800830uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
831{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800832 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
François Gaffiec005e562018-11-06 15:04:49 +0100833 return PRODUCT_STRATEGY_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700834 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700835 if (mAudioPolicyManager == NULL) {
François Gaffiec005e562018-11-06 15:04:49 +0100836 return PRODUCT_STRATEGY_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800837 }
François Gaffiec005e562018-11-06 15:04:49 +0100838 // DO NOT LOCK, may be called from AudioFlinger with lock held, reaching deadlock
Eric Laurent10b71232018-04-13 18:14:44 -0700839 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700840 return mAudioPolicyManager->getStrategyForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800841}
842
843//audio policy: use audio_device_t appropriately
844
845audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
846{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800847 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700848 return AUDIO_DEVICE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700849 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700850 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700851 return AUDIO_DEVICE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800852 }
Haynes Mathew Georgedfb9f3b2015-10-26 18:22:13 -0700853 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700854 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700855 return mAudioPolicyManager->getDevicesForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800856}
857
Jean-Michel Trivif41599b2020-01-07 14:22:08 -0800858status_t AudioPolicyService::getDevicesForAttributes(const AudioAttributes &aa,
Hayden Gomes524159d2019-12-23 14:41:47 -0800859 AudioDeviceTypeAddrVector *devices) const
Jean-Michel Trivif41599b2020-01-07 14:22:08 -0800860{
861 if (mAudioPolicyManager == NULL) {
862 return NO_INIT;
863 }
864 Mutex::Autolock _l(mLock);
865 AutoCallerClear acc;
866 return mAudioPolicyManager->getDevicesForAttributes(aa.getAttributes(), devices);
867}
868
Eric Laurent2d388ec2014-03-07 13:25:54 -0800869audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
870{
871 // FIXME change return type to status_t, and return NO_INIT here
Eric Laurentdce54a12014-03-10 12:19:46 -0700872 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800873 return 0;
874 }
875 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700876 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700877 return mAudioPolicyManager->getOutputForEffect(desc);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800878}
879
880status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
881 audio_io_handle_t io,
882 uint32_t strategy,
Glenn Kastend848eb42016-03-08 13:42:11 -0800883 audio_session_t session,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800884 int id)
885{
Eric Laurentdce54a12014-03-10 12:19:46 -0700886 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800887 return NO_INIT;
888 }
Eric Laurent6c796322019-04-09 14:13:17 -0700889 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700890 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700891 return mAudioPolicyManager->registerEffect(desc, io, strategy, session, id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800892}
893
894status_t AudioPolicyService::unregisterEffect(int id)
895{
Eric Laurentdce54a12014-03-10 12:19:46 -0700896 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800897 return NO_INIT;
898 }
Eric Laurent6c796322019-04-09 14:13:17 -0700899 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700900 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700901 return mAudioPolicyManager->unregisterEffect(id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800902}
903
904status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
905{
Eric Laurentdce54a12014-03-10 12:19:46 -0700906 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800907 return NO_INIT;
908 }
Eric Laurent6c796322019-04-09 14:13:17 -0700909 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700910 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700911 return mAudioPolicyManager->setEffectEnabled(id, enabled);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800912}
913
Eric Laurent6c796322019-04-09 14:13:17 -0700914status_t AudioPolicyService::moveEffectsToIo(const std::vector<int>& ids, audio_io_handle_t io)
915{
916 if (mAudioPolicyManager == NULL) {
917 return NO_INIT;
918 }
919 Mutex::Autolock _l(mLock);
920 AutoCallerClear acc;
921 return mAudioPolicyManager->moveEffectsToIo(ids, io);
922}
923
Eric Laurent2d388ec2014-03-07 13:25:54 -0800924bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
925{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800926 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700927 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700928 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700929 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700930 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800931 }
932 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700933 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700934 return mAudioPolicyManager->isStreamActive(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800935}
936
937bool AudioPolicyService::isStreamActiveRemotely(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->isStreamActiveRemotely(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800948}
949
950bool AudioPolicyService::isSourceActive(audio_source_t source) const
951{
Eric Laurentdce54a12014-03-10 12:19:46 -0700952 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800953 return false;
954 }
955 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700956 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700957 return mAudioPolicyManager->isSourceActive(source);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800958}
959
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700960status_t AudioPolicyService::getAudioPolicyEffects(sp<AudioPolicyEffects>& audioPolicyEffects)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800961{
Eric Laurentdce54a12014-03-10 12:19:46 -0700962 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800963 return NO_INIT;
964 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700965 {
966 Mutex::Autolock _l(mLock);
967 audioPolicyEffects = mAudioPolicyEffects;
968 }
969 if (audioPolicyEffects == 0) {
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700970 return NO_INIT;
971 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700972
973 return OK;
974}
975
976status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
977 effect_descriptor_t *descriptors,
978 uint32_t *count)
979{
980 sp<AudioPolicyEffects>audioPolicyEffects;
981 status_t status = getAudioPolicyEffects(audioPolicyEffects);
982 if (status != OK) {
983 *count = 0;
984 return status;
985 }
Eric Laurentfb66dd92016-01-28 18:32:03 -0800986 return audioPolicyEffects->queryDefaultInputEffects(
987 (audio_session_t)audioSession, descriptors, count);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800988}
989
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700990status_t AudioPolicyService::addSourceDefaultEffect(const effect_uuid_t *type,
991 const String16& opPackageName,
992 const effect_uuid_t *uuid,
993 int32_t priority,
994 audio_source_t source,
995 audio_unique_id_t* id)
996{
997 sp<AudioPolicyEffects>audioPolicyEffects;
998 status_t status = getAudioPolicyEffects(audioPolicyEffects);
999 if (status != OK) {
1000 return status;
1001 }
1002 if (!modifyDefaultAudioEffectsAllowed()) {
1003 return PERMISSION_DENIED;
1004 }
1005 return audioPolicyEffects->addSourceDefaultEffect(
1006 type, opPackageName, uuid, priority, source, id);
1007}
1008
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001009status_t AudioPolicyService::addStreamDefaultEffect(const effect_uuid_t *type,
1010 const String16& opPackageName,
1011 const effect_uuid_t *uuid,
1012 int32_t priority,
1013 audio_usage_t usage,
1014 audio_unique_id_t* id)
1015{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001016 sp<AudioPolicyEffects>audioPolicyEffects;
1017 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1018 if (status != OK) {
1019 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001020 }
1021 if (!modifyDefaultAudioEffectsAllowed()) {
1022 return PERMISSION_DENIED;
1023 }
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001024 return audioPolicyEffects->addStreamDefaultEffect(
1025 type, opPackageName, uuid, priority, usage, id);
1026}
1027
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001028status_t AudioPolicyService::removeSourceDefaultEffect(audio_unique_id_t id)
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001029{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001030 sp<AudioPolicyEffects>audioPolicyEffects;
1031 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1032 if (status != OK) {
1033 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001034 }
1035 if (!modifyDefaultAudioEffectsAllowed()) {
1036 return PERMISSION_DENIED;
1037 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001038 return audioPolicyEffects->removeSourceDefaultEffect(id);
1039}
1040
1041status_t AudioPolicyService::removeStreamDefaultEffect(audio_unique_id_t id)
1042{
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001043 sp<AudioPolicyEffects>audioPolicyEffects;
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001044 status_t status = getAudioPolicyEffects(audioPolicyEffects);
1045 if (status != OK) {
1046 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001047 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -07001048 if (!modifyDefaultAudioEffectsAllowed()) {
1049 return PERMISSION_DENIED;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001050 }
1051 return audioPolicyEffects->removeStreamDefaultEffect(id);
1052}
1053
Hayden Gomes524159d2019-12-23 14:41:47 -08001054status_t AudioPolicyService::setSupportedSystemUsages(const std::vector<audio_usage_t>& systemUsages) {
1055 Mutex::Autolock _l(mLock);
1056 if(!modifyAudioRoutingAllowed()) {
1057 return PERMISSION_DENIED;
1058 }
1059
1060 bool areAllSystemUsages = std::all_of(begin(systemUsages), end(systemUsages),
1061 [](audio_usage_t usage) { return isSystemUsage(usage); });
1062 if (!areAllSystemUsages) {
1063 return BAD_VALUE;
1064 }
1065
1066 mSupportedSystemUsages = systemUsages;
1067 return NO_ERROR;
1068}
1069
Kevin Rocardb99cc752019-03-21 20:52:24 -07001070status_t AudioPolicyService::setAllowedCapturePolicy(uid_t uid, audio_flags_mask_t capturePolicy) {
1071 Mutex::Autolock _l(mLock);
1072 if (mAudioPolicyManager == NULL) {
1073 ALOGV("%s() mAudioPolicyManager == NULL", __func__);
1074 return NO_INIT;
1075 }
1076 uint_t callingUid = IPCThreadState::self()->getCallingUid();
1077 if (uid != callingUid) {
1078 ALOGD("%s() uid invalid %d != %d", __func__, uid, callingUid);
1079 return PERMISSION_DENIED;
1080 }
1081 return mAudioPolicyManager->setAllowedCapturePolicy(uid, capturePolicy);
1082}
1083
Eric Laurent2d388ec2014-03-07 13:25:54 -08001084bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
1085{
Eric Laurentdce54a12014-03-10 12:19:46 -07001086 if (mAudioPolicyManager == NULL) {
1087 ALOGV("mAudioPolicyManager == NULL");
Eric Laurent2d388ec2014-03-07 13:25:54 -08001088 return false;
1089 }
Andy Hung2ddee192015-12-18 17:34:44 -08001090 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001091 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -07001092 return mAudioPolicyManager->isOffloadSupported(info);
Eric Laurent2d388ec2014-03-07 13:25:54 -08001093}
1094
Michael Chana94fbb22018-04-24 14:31:19 +10001095bool AudioPolicyService::isDirectOutputSupported(const audio_config_base_t& config,
1096 const audio_attributes_t& attributes) {
1097 if (mAudioPolicyManager == NULL) {
1098 ALOGV("mAudioPolicyManager == NULL");
1099 return false;
1100 }
Hayden Gomes524159d2019-12-23 14:41:47 -08001101
1102 status_t result = validateUsage(attributes.usage);
1103 if (result != NO_ERROR) {
1104 return result;
1105 }
1106
Michael Chana94fbb22018-04-24 14:31:19 +10001107 Mutex::Autolock _l(mLock);
1108 return mAudioPolicyManager->isDirectOutputSupported(config, attributes);
1109}
1110
1111
Eric Laurent6a94d692014-05-20 11:18:06 -07001112status_t AudioPolicyService::listAudioPorts(audio_port_role_t role,
1113 audio_port_type_t type,
Eric Laurent203b1a12014-04-01 10:34:16 -07001114 unsigned int *num_ports,
Eric Laurent6a94d692014-05-20 11:18:06 -07001115 struct audio_port *ports,
1116 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001117{
Eric Laurent6a94d692014-05-20 11:18:06 -07001118 Mutex::Autolock _l(mLock);
1119 if (mAudioPolicyManager == NULL) {
1120 return NO_INIT;
1121 }
Eric Laurent10b71232018-04-13 18:14:44 -07001122 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001123 return mAudioPolicyManager->listAudioPorts(role, type, num_ports, ports, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001124}
1125
Eric Laurent6a94d692014-05-20 11:18:06 -07001126status_t AudioPolicyService::getAudioPort(struct audio_port *port)
Eric Laurent203b1a12014-04-01 10:34:16 -07001127{
Eric Laurent6a94d692014-05-20 11:18:06 -07001128 Mutex::Autolock _l(mLock);
1129 if (mAudioPolicyManager == NULL) {
1130 return NO_INIT;
1131 }
Eric Laurent10b71232018-04-13 18:14:44 -07001132 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001133 return mAudioPolicyManager->getAudioPort(port);
Eric Laurent203b1a12014-04-01 10:34:16 -07001134}
1135
Eric Laurent6a94d692014-05-20 11:18:06 -07001136status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch,
1137 audio_patch_handle_t *handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001138{
Eric Laurent6a94d692014-05-20 11:18:06 -07001139 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001140 if(!modifyAudioRoutingAllowed()) {
1141 return PERMISSION_DENIED;
1142 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001143 if (mAudioPolicyManager == NULL) {
1144 return NO_INIT;
1145 }
Eric Laurent10b71232018-04-13 18:14:44 -07001146 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001147 return mAudioPolicyManager->createAudioPatch(patch, handle,
1148 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001149}
1150
Eric Laurent6a94d692014-05-20 11:18:06 -07001151status_t AudioPolicyService::releaseAudioPatch(audio_patch_handle_t handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001152{
Eric Laurent6a94d692014-05-20 11:18:06 -07001153 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001154 if(!modifyAudioRoutingAllowed()) {
1155 return PERMISSION_DENIED;
1156 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001157 if (mAudioPolicyManager == NULL) {
1158 return NO_INIT;
1159 }
Eric Laurent10b71232018-04-13 18:14:44 -07001160 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001161 return mAudioPolicyManager->releaseAudioPatch(handle,
1162 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001163}
1164
1165status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
Eric Laurent6a94d692014-05-20 11:18:06 -07001166 struct audio_patch *patches,
1167 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001168{
Eric Laurent6a94d692014-05-20 11:18:06 -07001169 Mutex::Autolock _l(mLock);
1170 if (mAudioPolicyManager == NULL) {
1171 return NO_INIT;
1172 }
Eric Laurent10b71232018-04-13 18:14:44 -07001173 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001174 return mAudioPolicyManager->listAudioPatches(num_patches, patches, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001175}
1176
Eric Laurent6a94d692014-05-20 11:18:06 -07001177status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config)
Eric Laurent203b1a12014-04-01 10:34:16 -07001178{
Eric Laurent6a94d692014-05-20 11:18:06 -07001179 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001180 if(!modifyAudioRoutingAllowed()) {
1181 return PERMISSION_DENIED;
1182 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001183 if (mAudioPolicyManager == NULL) {
1184 return NO_INIT;
1185 }
Eric Laurent10b71232018-04-13 18:14:44 -07001186 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001187 return mAudioPolicyManager->setAudioPortConfig(config);
Eric Laurent203b1a12014-04-01 10:34:16 -07001188}
Eric Laurent2d388ec2014-03-07 13:25:54 -08001189
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001190status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session,
1191 audio_io_handle_t *ioHandle,
1192 audio_devices_t *device)
1193{
Andy Hungf759b8c2017-08-15 12:48:54 -07001194 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001195 if (mAudioPolicyManager == NULL) {
1196 return NO_INIT;
1197 }
Eric Laurent10b71232018-04-13 18:14:44 -07001198 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001199 return mAudioPolicyManager->acquireSoundTriggerSession(session, ioHandle, device);
1200}
1201
1202status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session)
1203{
Andy Hungf759b8c2017-08-15 12:48:54 -07001204 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001205 if (mAudioPolicyManager == NULL) {
1206 return NO_INIT;
1207 }
Eric Laurent10b71232018-04-13 18:14:44 -07001208 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001209 return mAudioPolicyManager->releaseSoundTriggerSession(session);
1210}
1211
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -07001212status_t AudioPolicyService::registerPolicyMixes(const Vector<AudioMix>& mixes, bool registration)
Eric Laurentbaac1832014-12-01 17:52:59 -08001213{
1214 Mutex::Autolock _l(mLock);
Kevin Rocardbe201852019-02-20 22:33:28 -08001215
1216 // loopback|render only need a MediaProjection (checked in caller AudioService.java)
1217 bool needModifyAudioRouting = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
1218 return !is_mix_loopback_render(mix.mRouteFlags); });
1219 if (needModifyAudioRouting && !modifyAudioRoutingAllowed()) {
Eric Laurentbaac1832014-12-01 17:52:59 -08001220 return PERMISSION_DENIED;
1221 }
Kevin Rocardbe201852019-02-20 22:33:28 -08001222
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001223 // Require CAPTURE_VOICE_COMMUNICATION_OUTPUT if one of the
1224 // mixes is a render|loopback mix that aim to capture audio played with
1225 // USAGE_VOICE_COMMUNICATION.
1226 bool needCaptureVoiceCommunicationOutput =
1227 std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
1228 return is_mix_loopback_render(mix.mRouteFlags) &&
1229 mix.hasMatchingRuleForUsage([] (auto usage) {
1230 return usage == AUDIO_USAGE_VOICE_COMMUNICATION;});
1231 });
1232
1233 // Require CAPTURE_MEDIA_OUTPUT if there is a mix for priveliged capture
1234 // which is trying to capture any usage which is not USAGE_VOICE_COMMUNICATION.
1235 // (If USAGE_VOICE_COMMUNICATION should be captured, then CAPTURE_VOICE_COMMUNICATION_OUTPUT
1236 // is required, even if it is not privileged capture).
Kevin Rocard36b17552019-03-07 18:48:07 -08001237 bool needCaptureMediaOutput = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001238 return mix.mAllowPrivilegedPlaybackCapture &&
1239 mix.hasMatchingRuleForUsage([] (auto usage) {
1240 return usage != AUDIO_USAGE_VOICE_COMMUNICATION;
1241 });
1242 });
1243
Kevin Rocard36b17552019-03-07 18:48:07 -08001244 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
1245 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001246
Kevin Rocard36b17552019-03-07 18:48:07 -08001247 if (needCaptureMediaOutput && !captureMediaOutputAllowed(callingPid, callingUid)) {
1248 return PERMISSION_DENIED;
1249 }
1250
Nadav Bardbf0a2e2020-01-16 23:09:25 +02001251 if (needCaptureVoiceCommunicationOutput &&
1252 !captureVoiceCommunicationOutputAllowed(callingPid, callingUid)) {
1253 return PERMISSION_DENIED;
1254 }
1255
Eric Laurentbaac1832014-12-01 17:52:59 -08001256 if (mAudioPolicyManager == NULL) {
1257 return NO_INIT;
1258 }
Eric Laurent10b71232018-04-13 18:14:44 -07001259 AutoCallerClear acc;
Eric Laurentbaac1832014-12-01 17:52:59 -08001260 if (registration) {
1261 return mAudioPolicyManager->registerPolicyMixes(mixes);
1262 } else {
1263 return mAudioPolicyManager->unregisterPolicyMixes(mixes);
1264 }
1265}
1266
Jean-Michel Trivibda70da2018-12-19 07:30:15 -08001267status_t AudioPolicyService::setUidDeviceAffinities(uid_t uid,
1268 const Vector<AudioDeviceTypeAddr>& devices) {
1269 Mutex::Autolock _l(mLock);
1270 if(!modifyAudioRoutingAllowed()) {
1271 return PERMISSION_DENIED;
1272 }
1273 if (mAudioPolicyManager == NULL) {
1274 return NO_INIT;
1275 }
1276 AutoCallerClear acc;
1277 return mAudioPolicyManager->setUidDeviceAffinities(uid, devices);
1278}
1279
1280status_t AudioPolicyService::removeUidDeviceAffinities(uid_t uid) {
1281 Mutex::Autolock _l(mLock);
1282 if(!modifyAudioRoutingAllowed()) {
1283 return PERMISSION_DENIED;
1284 }
1285 if (mAudioPolicyManager == NULL) {
1286 return NO_INIT;
1287 }
1288 AutoCallerClear acc;
1289 return mAudioPolicyManager->removeUidDeviceAffinities(uid);
1290}
1291
Oscar Azucena90e77632019-11-27 17:12:28 -08001292status_t AudioPolicyService::setUserIdDeviceAffinities(int userId,
1293 const Vector<AudioDeviceTypeAddr>& devices) {
1294 Mutex::Autolock _l(mLock);
1295 if(!modifyAudioRoutingAllowed()) {
1296 return PERMISSION_DENIED;
1297 }
1298 if (mAudioPolicyManager == NULL) {
1299 return NO_INIT;
1300 }
1301 AutoCallerClear acc;
1302 return mAudioPolicyManager->setUserIdDeviceAffinities(userId, devices);
1303}
1304
1305status_t AudioPolicyService::removeUserIdDeviceAffinities(int userId) {
1306 Mutex::Autolock _l(mLock);
1307 if(!modifyAudioRoutingAllowed()) {
1308 return PERMISSION_DENIED;
1309 }
1310 if (mAudioPolicyManager == NULL) {
1311 return NO_INIT;
1312 }
1313 AutoCallerClear acc;
1314 return mAudioPolicyManager->removeUserIdDeviceAffinities(userId);
1315}
1316
Eric Laurent554a2772015-04-10 11:29:24 -07001317status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001318 const audio_attributes_t *attributes,
1319 audio_port_handle_t *portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001320{
1321 Mutex::Autolock _l(mLock);
1322 if (mAudioPolicyManager == NULL) {
1323 return NO_INIT;
1324 }
Hayden Gomes524159d2019-12-23 14:41:47 -08001325
1326 status_t result = validateUsage(attributes->usage);
1327 if (result != NO_ERROR) {
1328 return result;
1329 }
1330
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001331 // startAudioSource should be created as the calling uid
1332 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Eric Laurent10b71232018-04-13 18:14:44 -07001333 AutoCallerClear acc;
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001334 return mAudioPolicyManager->startAudioSource(source, attributes, portId, callingUid);
Eric Laurent554a2772015-04-10 11:29:24 -07001335}
1336
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001337status_t AudioPolicyService::stopAudioSource(audio_port_handle_t portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001338{
1339 Mutex::Autolock _l(mLock);
1340 if (mAudioPolicyManager == NULL) {
1341 return NO_INIT;
1342 }
Eric Laurent10b71232018-04-13 18:14:44 -07001343 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001344 return mAudioPolicyManager->stopAudioSource(portId);
Eric Laurent554a2772015-04-10 11:29:24 -07001345}
1346
Andy Hung2ddee192015-12-18 17:34:44 -08001347status_t AudioPolicyService::setMasterMono(bool mono)
1348{
1349 if (mAudioPolicyManager == NULL) {
1350 return NO_INIT;
1351 }
1352 if (!settingsAllowed()) {
1353 return PERMISSION_DENIED;
1354 }
1355 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001356 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001357 return mAudioPolicyManager->setMasterMono(mono);
1358}
1359
1360status_t AudioPolicyService::getMasterMono(bool *mono)
1361{
1362 if (mAudioPolicyManager == NULL) {
1363 return NO_INIT;
1364 }
1365 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001366 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001367 return mAudioPolicyManager->getMasterMono(mono);
1368}
1369
Eric Laurentac9cef52017-06-09 15:46:26 -07001370
1371float AudioPolicyService::getStreamVolumeDB(
1372 audio_stream_type_t stream, int index, audio_devices_t device)
1373{
1374 if (mAudioPolicyManager == NULL) {
1375 return NAN;
1376 }
1377 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001378 AutoCallerClear acc;
Eric Laurentac9cef52017-06-09 15:46:26 -07001379 return mAudioPolicyManager->getStreamVolumeDB(stream, index, device);
1380}
1381
jiabin81772902018-04-02 17:52:27 -07001382status_t AudioPolicyService::getSurroundFormats(unsigned int *numSurroundFormats,
1383 audio_format_t *surroundFormats,
1384 bool *surroundFormatsEnabled,
1385 bool reported)
1386{
1387 if (mAudioPolicyManager == NULL) {
1388 return NO_INIT;
1389 }
1390 Mutex::Autolock _l(mLock);
1391 AutoCallerClear acc;
1392 return mAudioPolicyManager->getSurroundFormats(numSurroundFormats, surroundFormats,
1393 surroundFormatsEnabled, reported);
1394}
1395
Arun Mirpuri11029ad2018-12-19 20:45:19 -08001396status_t AudioPolicyService::getHwOffloadEncodingFormatsSupportedForA2DP(
1397 std::vector<audio_format_t> *formats)
1398{
1399 if (mAudioPolicyManager == NULL) {
1400 return NO_INIT;
1401 }
1402 Mutex::Autolock _l(mLock);
1403 AutoCallerClear acc;
1404 return mAudioPolicyManager->getHwOffloadEncodingFormatsSupportedForA2DP(formats);
1405}
1406
jiabin81772902018-04-02 17:52:27 -07001407status_t AudioPolicyService::setSurroundFormatEnabled(audio_format_t audioFormat, bool enabled)
1408{
1409 if (mAudioPolicyManager == NULL) {
1410 return NO_INIT;
1411 }
1412 Mutex::Autolock _l(mLock);
1413 AutoCallerClear acc;
1414 return mAudioPolicyManager->setSurroundFormatEnabled(audioFormat, enabled);
1415}
Eric Laurentac9cef52017-06-09 15:46:26 -07001416
Eric Laurentb78763e2018-10-17 10:08:02 -07001417status_t AudioPolicyService::setAssistantUid(uid_t uid)
1418{
1419 Mutex::Autolock _l(mLock);
1420 mUidPolicy->setAssistantUid(uid);
1421 return NO_ERROR;
1422}
1423
1424status_t AudioPolicyService::setA11yServicesUids(const std::vector<uid_t>& uids)
1425{
1426 Mutex::Autolock _l(mLock);
1427 mUidPolicy->setA11yUids(uids);
1428 return NO_ERROR;
1429}
1430
jiabin6012f912018-11-02 17:06:30 -07001431bool AudioPolicyService::isHapticPlaybackSupported()
1432{
1433 if (mAudioPolicyManager == NULL) {
1434 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1435 return false;
1436 }
1437 Mutex::Autolock _l(mLock);
1438 AutoCallerClear acc;
1439 return mAudioPolicyManager->isHapticPlaybackSupported();
1440}
1441
François Gaffied0ba9ed2018-11-05 11:50:42 +01001442status_t AudioPolicyService::listAudioProductStrategies(AudioProductStrategyVector &strategies)
1443{
1444 if (mAudioPolicyManager == NULL) {
1445 return NO_INIT;
1446 }
1447 Mutex::Autolock _l(mLock);
1448 return mAudioPolicyManager->listAudioProductStrategies(strategies);
1449}
1450
François Gaffie4b2018b2018-11-07 11:18:59 +01001451status_t AudioPolicyService::getProductStrategyFromAudioAttributes(
1452 const AudioAttributes &aa, product_strategy_t &productStrategy)
François Gaffied0ba9ed2018-11-05 11:50:42 +01001453{
1454 if (mAudioPolicyManager == NULL) {
François Gaffie4b2018b2018-11-07 11:18:59 +01001455 return NO_INIT;
François Gaffied0ba9ed2018-11-05 11:50:42 +01001456 }
1457 Mutex::Autolock _l(mLock);
François Gaffie4b2018b2018-11-07 11:18:59 +01001458 return mAudioPolicyManager->getProductStrategyFromAudioAttributes(aa, productStrategy);
1459}
1460
1461status_t AudioPolicyService::listAudioVolumeGroups(AudioVolumeGroupVector &groups)
1462{
1463 if (mAudioPolicyManager == NULL) {
1464 return NO_INIT;
1465 }
1466 Mutex::Autolock _l(mLock);
1467 return mAudioPolicyManager->listAudioVolumeGroups(groups);
1468}
1469
1470status_t AudioPolicyService::getVolumeGroupFromAudioAttributes(const AudioAttributes &aa,
1471 volume_group_t &volumeGroup)
1472{
1473 if (mAudioPolicyManager == NULL) {
1474 return NO_INIT;
1475 }
1476 Mutex::Autolock _l(mLock);
1477 return mAudioPolicyManager->getVolumeGroupFromAudioAttributes(aa, volumeGroup);
François Gaffied0ba9ed2018-11-05 11:50:42 +01001478}
Eric Laurent6ede98f2019-06-11 14:50:30 -07001479
1480status_t AudioPolicyService::setRttEnabled(bool enabled)
1481{
1482 Mutex::Autolock _l(mLock);
1483 mUidPolicy->setRttEnabled(enabled);
1484 return NO_ERROR;
1485}
1486
Eric Laurent8340e672019-11-06 11:01:08 -08001487bool AudioPolicyService::isCallScreenModeSupported()
1488{
1489 if (mAudioPolicyManager == NULL) {
1490 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1491 return false;
1492 }
1493 Mutex::Autolock _l(mLock);
1494 AutoCallerClear acc;
1495 return mAudioPolicyManager->isCallScreenModeSupported();
1496}
1497
Jean-Michel Trivi30857152019-11-01 11:04:15 -07001498status_t AudioPolicyService::setPreferredDeviceForStrategy(product_strategy_t strategy,
1499 const AudioDeviceTypeAddr &device)
1500{
1501 if (mAudioPolicyManager == NULL) {
1502 return NO_INIT;
1503 }
1504 Mutex::Autolock _l(mLock);
1505 return mAudioPolicyManager->setPreferredDeviceForStrategy(strategy, device);
1506}
1507
1508status_t AudioPolicyService::removePreferredDeviceForStrategy(product_strategy_t strategy)
1509{
1510 if (mAudioPolicyManager == NULL) {
1511 return NO_INIT;
1512 }
1513 Mutex::Autolock _l(mLock);
1514 return mAudioPolicyManager->removePreferredDeviceForStrategy(strategy);
1515}
1516
1517status_t AudioPolicyService::getPreferredDeviceForStrategy(product_strategy_t strategy,
1518 AudioDeviceTypeAddr &device)
1519{
1520 if (mAudioPolicyManager == NULL) {
1521 return NO_INIT;
1522 }
1523 Mutex::Autolock _l(mLock);
1524 return mAudioPolicyManager->getPreferredDeviceForStrategy(strategy, device);
1525}
1526
Mikhail Naganov1b2a7942017-12-08 10:18:09 -08001527} // namespace android