blob: 68a2a8cf193d6ca2a889b3f3774a662a62baada9 [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
28
29// ----------------------------------------------------------------------------
30
31status_t AudioPolicyService::setDeviceConnectionState(audio_devices_t device,
32 audio_policy_dev_state_t state,
Paul McLeane743a472015-01-28 11:07:31 -080033 const char *device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080034 const char *device_name,
35 audio_format_t encodedFormat)
Eric Laurent2d388ec2014-03-07 13:25:54 -080036{
Eric Laurentdce54a12014-03-10 12:19:46 -070037 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080038 return NO_INIT;
39 }
40 if (!settingsAllowed()) {
41 return PERMISSION_DENIED;
42 }
Eric Laurent2d388ec2014-03-07 13:25:54 -080043 if (state != AUDIO_POLICY_DEVICE_STATE_AVAILABLE &&
44 state != AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE) {
45 return BAD_VALUE;
46 }
47
48 ALOGV("setDeviceConnectionState()");
49 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -070050 AutoCallerClear acc;
Paul McLeane743a472015-01-28 11:07:31 -080051 return mAudioPolicyManager->setDeviceConnectionState(device, state,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080052 device_address, device_name, encodedFormat);
Eric Laurent2d388ec2014-03-07 13:25:54 -080053}
54
55audio_policy_dev_state_t AudioPolicyService::getDeviceConnectionState(
56 audio_devices_t device,
57 const char *device_address)
58{
Eric Laurentdce54a12014-03-10 12:19:46 -070059 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080060 return AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE;
61 }
Eric Laurent10b71232018-04-13 18:14:44 -070062 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -070063 return mAudioPolicyManager->getDeviceConnectionState(device,
Eric Laurent2d388ec2014-03-07 13:25:54 -080064 device_address);
65}
66
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080067status_t AudioPolicyService::handleDeviceConfigChange(audio_devices_t device,
68 const char *device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080069 const char *device_name,
70 audio_format_t encodedFormat)
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080071{
72 if (mAudioPolicyManager == NULL) {
73 return NO_INIT;
74 }
75 if (!settingsAllowed()) {
76 return PERMISSION_DENIED;
77 }
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080078
79 ALOGV("handleDeviceConfigChange()");
80 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -070081 AutoCallerClear acc;
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080082 return mAudioPolicyManager->handleDeviceConfigChange(device, device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080083 device_name, encodedFormat);
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080084}
85
Eric Laurent2d388ec2014-03-07 13:25:54 -080086status_t AudioPolicyService::setPhoneState(audio_mode_t state)
87{
Eric Laurentdce54a12014-03-10 12:19:46 -070088 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080089 return NO_INIT;
90 }
91 if (!settingsAllowed()) {
92 return PERMISSION_DENIED;
93 }
94 if (uint32_t(state) >= AUDIO_MODE_CNT) {
95 return BAD_VALUE;
96 }
97
98 ALOGV("setPhoneState()");
99
Eric Laurentbeb07fe2015-09-16 15:49:30 -0700100 // acquire lock before calling setMode() so that setMode() + setPhoneState() are an atomic
101 // operation from policy manager standpoint (no other operation (e.g track start or stop)
102 // can be interleaved).
103 Mutex::Autolock _l(mLock);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800104 // TODO: check if it is more appropriate to do it in platform specific policy manager
105 AudioSystem::setMode(state);
106
Eric Laurent10b71232018-04-13 18:14:44 -0700107 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700108 mAudioPolicyManager->setPhoneState(state);
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700109 mPhoneState = state;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800110 return NO_ERROR;
111}
112
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700113audio_mode_t AudioPolicyService::getPhoneState()
114{
115 Mutex::Autolock _l(mLock);
116 return mPhoneState;
117}
118
Eric Laurent2d388ec2014-03-07 13:25:54 -0800119status_t AudioPolicyService::setForceUse(audio_policy_force_use_t usage,
120 audio_policy_forced_cfg_t config)
121{
Eric Laurentdce54a12014-03-10 12:19:46 -0700122 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800123 return NO_INIT;
124 }
Eric Laurente17378d2018-05-09 14:43:01 -0700125
126 if (!modifyAudioRoutingAllowed()) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800127 return PERMISSION_DENIED;
128 }
Eric Laurente17378d2018-05-09 14:43:01 -0700129
Eric Laurent2d388ec2014-03-07 13:25:54 -0800130 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
131 return BAD_VALUE;
132 }
133 if (config < 0 || config >= AUDIO_POLICY_FORCE_CFG_CNT) {
134 return BAD_VALUE;
135 }
136 ALOGV("setForceUse()");
137 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700138 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700139 mAudioPolicyManager->setForceUse(usage, config);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800140 return NO_ERROR;
141}
142
143audio_policy_forced_cfg_t AudioPolicyService::getForceUse(audio_policy_force_use_t usage)
144{
Eric Laurentdce54a12014-03-10 12:19:46 -0700145 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800146 return AUDIO_POLICY_FORCE_NONE;
147 }
148 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
149 return AUDIO_POLICY_FORCE_NONE;
150 }
Eric Laurent10b71232018-04-13 18:14:44 -0700151 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700152 return mAudioPolicyManager->getForceUse(usage);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800153}
154
Eric Laurentf4e63452017-11-06 19:31:46 +0000155audio_io_handle_t AudioPolicyService::getOutput(audio_stream_type_t stream)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800156{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800157 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700158 return AUDIO_IO_HANDLE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700159 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700160 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700161 return AUDIO_IO_HANDLE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800162 }
163 ALOGV("getOutput()");
164 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700165 AutoCallerClear acc;
Eric Laurentf4e63452017-11-06 19:31:46 +0000166 return mAudioPolicyManager->getOutput(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800167}
168
Eric Laurent42984412019-05-09 17:57:03 -0700169status_t AudioPolicyService::getOutputForAttr(audio_attributes_t *attr,
Eric Laurente83b55d2014-11-14 10:06:21 -0800170 audio_io_handle_t *output,
171 audio_session_t session,
172 audio_stream_type_t *stream,
Nadav Bar766fb022018-01-07 12:18:03 +0200173 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700174 uid_t uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800175 const audio_config_t *config,
Eric Laurente83b55d2014-11-14 10:06:21 -0800176 audio_output_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700177 audio_port_handle_t *selectedDeviceId,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800178 audio_port_handle_t *portId,
179 std::vector<audio_io_handle_t> *secondaryOutputs)
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700180{
181 if (mAudioPolicyManager == NULL) {
Eric Laurente83b55d2014-11-14 10:06:21 -0800182 return NO_INIT;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700183 }
Eric Laurent8a1095a2019-11-08 14:44:16 -0800184 ALOGV("%s()", __func__);
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700185 Mutex::Autolock _l(mLock);
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700186
Marco Nelissendcb346b2015-09-09 10:47:29 -0700187 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700188 if (!isAudioServerOrMediaServerUid(callingUid) || uid == (uid_t)-1) {
Marco Nelissendcb346b2015-09-09 10:47:29 -0700189 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Eric Laurent8a1095a2019-11-08 14:44:16 -0800190 "%s uid %d tried to pass itself off as %d", __func__, callingUid, uid);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700191 uid = callingUid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700192 }
Kevin Rocard8be94972019-02-22 13:26:25 -0800193 if (!mPackageManager.allowPlaybackCapture(uid)) {
Eric Laurent42984412019-05-09 17:57:03 -0700194 attr->flags |= AUDIO_FLAG_NO_MEDIA_PROJECTION;
195 }
Eric Laurent6ede98f2019-06-11 14:50:30 -0700196 if (((attr->flags & (AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE)) != 0)
197 && !bypassInterruptionPolicyAllowed(pid, uid)) {
Eric Laurent42984412019-05-09 17:57:03 -0700198 attr->flags &= ~(AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE);
Kevin Rocard8be94972019-02-22 13:26:25 -0800199 }
Eric Laurent10b71232018-04-13 18:14:44 -0700200 AutoCallerClear acc;
Eric Laurent8a1095a2019-11-08 14:44:16 -0800201 AudioPolicyInterface::output_type_t outputType;
Eric Laurent42984412019-05-09 17:57:03 -0700202 status_t result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800203 config,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800204 &flags, selectedDeviceId, portId,
Eric Laurent8a1095a2019-11-08 14:44:16 -0800205 secondaryOutputs,
206 &outputType);
Nadav Bar766fb022018-01-07 12:18:03 +0200207
208 // FIXME: Introduce a way to check for the the telephony device before opening the output
Eric Laurent8a1095a2019-11-08 14:44:16 -0800209 if (result == NO_ERROR) {
210 // enforce permission (if any) required for each type of input
211 switch (outputType) {
212 case AudioPolicyInterface::API_OUTPUT_LEGACY:
213 break;
214 case AudioPolicyInterface::API_OUTPUT_TELEPHONY_TX:
215 if (!modifyPhoneStateAllowed(pid, uid)) {
216 ALOGE("%s() permission denied: modify phone state not allowed for uid %d",
217 __func__, uid);
218 result = PERMISSION_DENIED;
219 }
220 break;
221 case AudioPolicyInterface::API_OUT_MIX_PLAYBACK:
222 if (!modifyAudioRoutingAllowed(pid, uid)) {
223 ALOGE("%s() permission denied: modify audio routing not allowed for uid %d",
224 __func__, uid);
225 result = PERMISSION_DENIED;
226 }
227 break;
228 case AudioPolicyInterface::API_OUTPUT_INVALID:
229 default:
230 LOG_ALWAYS_FATAL("%s() encountered an invalid output type %d",
231 __func__, (int)outputType);
232 }
Nadav Bar766fb022018-01-07 12:18:03 +0200233 }
Eric Laurentd7fe0862018-07-14 16:48:01 -0700234
235 if (result == NO_ERROR) {
236 sp <AudioPlaybackClient> client =
Eric Laurent5ada82e2019-08-29 17:53:54 -0700237 new AudioPlaybackClient(*attr, *output, uid, pid, session, *portId, *selectedDeviceId, *stream);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700238 mAudioPlaybackClients.add(*portId, client);
239 }
Nadav Bar766fb022018-01-07 12:18:03 +0200240 return result;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700241}
242
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700243void AudioPolicyService::getPlaybackClientAndEffects(audio_port_handle_t portId,
244 sp<AudioPlaybackClient>& client,
245 sp<AudioPolicyEffects>& effects,
246 const char *context)
247{
248 Mutex::Autolock _l(mLock);
249 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
250 if (index < 0) {
251 ALOGE("%s AudioTrack client not found for portId %d", context, portId);
252 return;
253 }
254 client = mAudioPlaybackClients.valueAt(index);
255 effects = mAudioPolicyEffects;
256}
257
Eric Laurentd7fe0862018-07-14 16:48:01 -0700258status_t AudioPolicyService::startOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800259{
Eric Laurentdce54a12014-03-10 12:19:46 -0700260 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800261 return NO_INIT;
262 }
263 ALOGV("startOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700264 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700265 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700266
267 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
268
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700269 if (audioPolicyEffects != 0) {
270 // create audio processors according to stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700271 status_t status = audioPolicyEffects->addOutputSessionEffects(
272 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700273 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700274 ALOGW("Failed to add effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700275 }
276 }
277 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700278 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700279 status_t status = mAudioPolicyManager->startOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700280 if (status == NO_ERROR) {
281 client->active = true;
282 }
283 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800284}
285
Eric Laurentd7fe0862018-07-14 16:48:01 -0700286status_t AudioPolicyService::stopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800287{
Eric Laurentdce54a12014-03-10 12:19:46 -0700288 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800289 return NO_INIT;
290 }
291 ALOGV("stopOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700292 mOutputCommandThread->stopOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800293 return NO_ERROR;
294}
295
Eric Laurentd7fe0862018-07-14 16:48:01 -0700296status_t AudioPolicyService::doStopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800297{
Eric Laurentd7fe0862018-07-14 16:48:01 -0700298 ALOGV("doStopOutput");
299 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700300 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentd7fe0862018-07-14 16:48:01 -0700301
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700302 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
303
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700304 if (audioPolicyEffects != 0) {
305 // release audio processors from the stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700306 status_t status = audioPolicyEffects->releaseOutputSessionEffects(
307 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700308 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700309 ALOGW("Failed to release effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700310 }
311 }
312 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700313 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700314 status_t status = mAudioPolicyManager->stopOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700315 if (status == NO_ERROR) {
316 client->active = false;
317 }
318 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800319}
320
Eric Laurentd7fe0862018-07-14 16:48:01 -0700321void AudioPolicyService::releaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800322{
Eric Laurentdce54a12014-03-10 12:19:46 -0700323 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800324 return;
325 }
326 ALOGV("releaseOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700327 mOutputCommandThread->releaseOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800328}
329
Eric Laurentd7fe0862018-07-14 16:48:01 -0700330void AudioPolicyService::doReleaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800331{
332 ALOGV("doReleaseOutput from tid %d", gettid());
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700333 sp<AudioPlaybackClient> client;
334 sp<AudioPolicyEffects> audioPolicyEffects;
335
336 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
337
338 if (audioPolicyEffects != 0 && client->active) {
339 // clean up effects if output was not stopped before being released
340 audioPolicyEffects->releaseOutputSessionEffects(
341 client->io, client->stream, client->session);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700342 }
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700343 Mutex::Autolock _l(mLock);
Eric Laurentd4007242019-03-27 12:42:16 -0700344 mAudioPlaybackClients.removeItem(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700345
Eric Laurent10b71232018-04-13 18:14:44 -0700346 // called from internal thread: no need to clear caller identity
Eric Laurent8fc147b2018-07-22 19:13:55 -0700347 mAudioPolicyManager->releaseOutput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800348}
349
Eric Laurentcaf7f482014-11-25 17:50:47 -0800350status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
351 audio_io_handle_t *input,
Mikhail Naganov2996f672019-04-18 12:29:59 -0700352 audio_unique_id_t riid,
Eric Laurentcaf7f482014-11-25 17:50:47 -0800353 audio_session_t session,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700354 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700355 uid_t uid,
Eric Laurentfee19762018-01-29 18:44:13 -0800356 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800357 const audio_config_base_t *config,
Paul McLean466dc8e2015-04-17 13:15:36 -0600358 audio_input_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700359 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800360 audio_port_handle_t *portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800361{
Eric Laurentdce54a12014-03-10 12:19:46 -0700362 if (mAudioPolicyManager == NULL) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800363 return NO_INIT;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800364 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800365
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900366 audio_source_t inputSource = attr->source;
367 if (inputSource == AUDIO_SOURCE_DEFAULT) {
368 inputSource = AUDIO_SOURCE_MIC;
369 }
370
Eric Laurent2d388ec2014-03-07 13:25:54 -0800371 // already checked by client, but double-check in case the client wrapper is bypassed
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900372 if ((inputSource < AUDIO_SOURCE_DEFAULT)
373 || (inputSource >= AUDIO_SOURCE_CNT
374 && inputSource != AUDIO_SOURCE_HOTWORD
375 && inputSource != AUDIO_SOURCE_FM_TUNER
376 && inputSource != AUDIO_SOURCE_ECHO_REFERENCE)) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800377 return BAD_VALUE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800378 }
379
Eric Laurentb2379ba2016-05-23 17:42:12 -0700380 bool updatePid = (pid == -1);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700381 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700382 if (!isAudioServerOrMediaServerUid(callingUid)) {
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700383 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Marco Nelissendcb346b2015-09-09 10:47:29 -0700384 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
385 uid = callingUid;
Eric Laurentb2379ba2016-05-23 17:42:12 -0700386 updatePid = true;
387 }
388
389 if (updatePid) {
390 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700391 ALOGW_IF(pid != (pid_t)-1 && pid != callingPid,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700392 "%s uid %d pid %d tried to pass itself off as pid %d",
393 __func__, callingUid, callingPid, pid);
394 pid = callingPid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700395 }
396
Eric Laurent58a0dd82019-10-24 12:42:17 -0700397 // check calling permissions.
398 // Capturing from FM_TUNER source is controlled by captureAudioOutputAllowed() only as this
399 // does not affect users privacy as does capturing from an actual microphone.
400 if (!(recordingAllowed(opPackageName, pid, uid) || attr->source == AUDIO_SOURCE_FM_TUNER)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800401 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
402 __func__, uid, pid);
403 return PERMISSION_DENIED;
404 }
405
Eric Laurent1ff16a72019-03-14 18:35:04 -0700406 bool canCaptureOutput = captureAudioOutputAllowed(pid, uid);
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900407 if ((inputSource == AUDIO_SOURCE_VOICE_UPLINK ||
408 inputSource == AUDIO_SOURCE_VOICE_DOWNLINK ||
409 inputSource == AUDIO_SOURCE_VOICE_CALL ||
410 inputSource == AUDIO_SOURCE_ECHO_REFERENCE||
411 inputSource == AUDIO_SOURCE_FM_TUNER) &&
Eric Laurent1ff16a72019-03-14 18:35:04 -0700412 !canCaptureOutput) {
Nadav Bar744be482018-05-08 13:26:21 +0300413 return PERMISSION_DENIED;
414 }
415
jiabin68e0df72019-03-18 17:55:35 -0700416 bool canCaptureHotword = captureHotwordAllowed(opPackageName, pid, uid);
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900417 if ((inputSource == AUDIO_SOURCE_HOTWORD) && !canCaptureHotword) {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700418 return BAD_VALUE;
419 }
420
421 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700422 {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700423 status_t status;
424 AudioPolicyInterface::input_type_t inputType;
425
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700426 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700427 {
428 AutoCallerClear acc;
429 // the audio_in_acoustics_t parameter is ignored by get_input()
Mikhail Naganov2996f672019-04-18 12:29:59 -0700430 status = mAudioPolicyManager->getInputForAttr(attr, input, riid, session, uid,
Eric Laurent10b71232018-04-13 18:14:44 -0700431 config,
432 flags, selectedDeviceId,
433 &inputType, portId);
434 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700435 audioPolicyEffects = mAudioPolicyEffects;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800436
437 if (status == NO_ERROR) {
438 // enforce permission (if any) required for each type of input
439 switch (inputType) {
Kevin Rocard25f9b052019-02-27 15:08:54 -0800440 case AudioPolicyInterface::API_INPUT_MIX_PUBLIC_CAPTURE_PLAYBACK:
441 // this use case has been validated in audio service with a MediaProjection token,
442 // and doesn't rely on regular permissions
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800443 case AudioPolicyInterface::API_INPUT_LEGACY:
444 break;
Eric Laurent82db2692015-08-07 13:59:42 -0700445 case AudioPolicyInterface::API_INPUT_TELEPHONY_RX:
446 // FIXME: use the same permission as for remote submix for now.
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800447 case AudioPolicyInterface::API_INPUT_MIX_CAPTURE:
Eric Laurent1ff16a72019-03-14 18:35:04 -0700448 if (!canCaptureOutput) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800449 ALOGE("getInputForAttr() permission denied: capture not allowed");
450 status = PERMISSION_DENIED;
451 }
452 break;
453 case AudioPolicyInterface::API_INPUT_MIX_EXT_POLICY_REROUTE:
Eric Laurent8a1095a2019-11-08 14:44:16 -0800454 if (!modifyAudioRoutingAllowed(pid, uid)) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800455 ALOGE("getInputForAttr() permission denied: modify audio routing not allowed");
456 status = PERMISSION_DENIED;
457 }
458 break;
459 case AudioPolicyInterface::API_INPUT_INVALID:
460 default:
461 LOG_ALWAYS_FATAL("getInputForAttr() encountered an invalid input type %d",
462 (int)inputType);
463 }
464 }
465
466 if (status != NO_ERROR) {
467 if (status == PERMISSION_DENIED) {
Eric Laurent10b71232018-04-13 18:14:44 -0700468 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700469 mAudioPolicyManager->releaseInput(*portId);
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800470 }
471 return status;
472 }
Eric Laurentfee19762018-01-29 18:44:13 -0800473
Eric Laurent5ada82e2019-08-29 17:53:54 -0700474 sp<AudioRecordClient> client = new AudioRecordClient(*attr, *input, uid, pid, session, *portId,
Eric Laurent1ff16a72019-03-14 18:35:04 -0700475 *selectedDeviceId, opPackageName,
476 canCaptureOutput, canCaptureHotword);
Eric Laurentfee19762018-01-29 18:44:13 -0800477 mAudioRecordClients.add(*portId, client);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700478 }
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800479
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700480 if (audioPolicyEffects != 0) {
481 // create audio pre processors according to input source
Hiroaki Hayashi4de0b452019-07-18 19:50:47 +0900482 status_t status = audioPolicyEffects->addInputEffects(*input, inputSource, session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700483 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800484 ALOGW("Failed to add effects on input %d", *input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700485 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800486 }
Eric Laurentcaf7f482014-11-25 17:50:47 -0800487 return NO_ERROR;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800488}
489
Eric Laurent99fcae42018-05-17 16:59:18 -0700490std::string AudioPolicyService::getDeviceTypeStrForPortId(audio_port_handle_t portId) {
Eric Laurent99fcae42018-05-17 16:59:18 -0700491 struct audio_port port = {};
492 port.id = portId;
493 status_t status = mAudioPolicyManager->getAudioPort(&port);
494 if (status == NO_ERROR && port.type == AUDIO_PORT_TYPE_DEVICE) {
Andy Hung9b181952019-02-25 14:53:36 -0800495 return toString(port.ext.device.type);
Eric Laurent99fcae42018-05-17 16:59:18 -0700496 }
Andy Hung9b181952019-02-25 14:53:36 -0800497 return {};
Eric Laurent99fcae42018-05-17 16:59:18 -0700498}
499
Eric Laurent4eb58f12018-12-07 16:41:02 -0800500status_t AudioPolicyService::startInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800501{
Eric Laurentdce54a12014-03-10 12:19:46 -0700502 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800503 return NO_INIT;
504 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800505 sp<AudioRecordClient> client;
506 {
507 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800508
Eric Laurent7dca8a82018-01-29 18:44:26 -0800509 ssize_t index = mAudioRecordClients.indexOfKey(portId);
510 if (index < 0) {
511 return INVALID_OPERATION;
512 }
513 client = mAudioRecordClients.valueAt(index);
Eric Laurentfee19762018-01-29 18:44:13 -0800514 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800515
516 // check calling permissions
Eric Laurent58a0dd82019-10-24 12:42:17 -0700517 if (!(startRecording(client->opPackageName, client->pid, client->uid)
518 || client->attributes.source == AUDIO_SOURCE_FM_TUNER)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800519 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
520 __func__, client->uid, client->pid);
521 return PERMISSION_DENIED;
522 }
Eric Laurentfee19762018-01-29 18:44:13 -0800523
Eric Laurentdf628922018-12-06 21:45:51 +0000524 Mutex::Autolock _l(mLock);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800525
526 client->active = true;
527 client->startTimeNs = systemTime();
528 updateUidStates_l();
Eric Laurentfee19762018-01-29 18:44:13 -0800529
Eric Laurent10b71232018-04-13 18:14:44 -0700530 status_t status;
531 {
532 AutoCallerClear acc;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800533 status = mAudioPolicyManager->startInput(portId);
Ray Essick84e84a52018-05-03 18:45:07 -0700534
535 }
536
Ray Essickf6a57cd2018-05-22 16:20:54 -0700537 // including successes gets very verbose
Ray Essick6ce27e52019-02-15 10:58:05 -0800538 // but once we cut over to westworld, log them all.
Ray Essickf6a57cd2018-05-22 16:20:54 -0700539 if (status != NO_ERROR) {
Ray Essick84e84a52018-05-03 18:45:07 -0700540
541 static constexpr char kAudioPolicy[] = "audiopolicy";
542
Ray Essick84e84a52018-05-03 18:45:07 -0700543 static constexpr char kAudioPolicyStatus[] = "android.media.audiopolicy.status";
544 static constexpr char kAudioPolicyRqstSrc[] = "android.media.audiopolicy.rqst.src";
545 static constexpr char kAudioPolicyRqstPkg[] = "android.media.audiopolicy.rqst.pkg";
546 static constexpr char kAudioPolicyRqstSession[] = "android.media.audiopolicy.rqst.session";
Eric Laurent99fcae42018-05-17 16:59:18 -0700547 static constexpr char kAudioPolicyRqstDevice[] =
548 "android.media.audiopolicy.rqst.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700549 static constexpr char kAudioPolicyActiveSrc[] = "android.media.audiopolicy.active.src";
550 static constexpr char kAudioPolicyActivePkg[] = "android.media.audiopolicy.active.pkg";
Eric Laurent99fcae42018-05-17 16:59:18 -0700551 static constexpr char kAudioPolicyActiveSession[] =
552 "android.media.audiopolicy.active.session";
553 static constexpr char kAudioPolicyActiveDevice[] =
554 "android.media.audiopolicy.active.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700555
Ray Essickf27e9872019-12-07 06:28:46 -0800556 mediametrics::Item *item = mediametrics::Item::create(kAudioPolicy);
Ray Essick84e84a52018-05-03 18:45:07 -0700557 if (item != NULL) {
558
Ray Essick84e84a52018-05-03 18:45:07 -0700559 item->setInt32(kAudioPolicyStatus, status);
560
Eric Laurent99fcae42018-05-17 16:59:18 -0700561 item->setCString(kAudioPolicyRqstSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800562 toString(client->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700563 item->setInt32(kAudioPolicyRqstSession, client->session);
Ray Essick51866952018-05-30 11:22:27 -0700564 if (client->opPackageName.size() != 0) {
565 item->setCString(kAudioPolicyRqstPkg,
566 std::string(String8(client->opPackageName).string()).c_str());
567 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700568 item->setCString(kAudioPolicyRqstPkg, std::to_string(client->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700569 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700570 item->setCString(
571 kAudioPolicyRqstDevice, getDeviceTypeStrForPortId(client->deviceId).c_str());
572
Eric Laurent4eb58f12018-12-07 16:41:02 -0800573 int count = mAudioRecordClients.size();
574 for (int i = 0; i < count ; i++) {
575 if (portId == mAudioRecordClients.keyAt(i)) {
576 continue;
577 }
578 sp<AudioRecordClient> other = mAudioRecordClients.valueAt(i);
579 if (other->active) {
580 // keeps the last of the clients marked active
581 item->setCString(kAudioPolicyActiveSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800582 toString(other->attributes.source).c_str());
Eric Laurent4eb58f12018-12-07 16:41:02 -0800583 item->setInt32(kAudioPolicyActiveSession, other->session);
584 if (other->opPackageName.size() != 0) {
585 item->setCString(kAudioPolicyActivePkg,
586 std::string(String8(other->opPackageName).string()).c_str());
587 } else {
588 item->setCString(kAudioPolicyRqstPkg,
589 std::to_string(other->uid).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700590 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800591 item->setCString(kAudioPolicyActiveDevice,
592 getDeviceTypeStrForPortId(other->deviceId).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700593 }
594 }
595 item->selfrecord();
596 delete item;
597 item = NULL;
598 }
Ray Essick6ce27e52019-02-15 10:58:05 -0800599 }
600
601 if (status != NO_ERROR) {
Eric Laurent4eb58f12018-12-07 16:41:02 -0800602 client->active = false;
603 client->startTimeNs = 0;
604 updateUidStates_l();
Svet Ganov6e641372018-03-02 09:21:30 -0800605 finishRecording(client->opPackageName, client->uid);
Eric Laurentfb66dd92016-01-28 18:32:03 -0800606 }
607
608 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800609}
610
Eric Laurentfee19762018-01-29 18:44:13 -0800611status_t AudioPolicyService::stopInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800612{
Eric Laurentdce54a12014-03-10 12:19:46 -0700613 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800614 return NO_INIT;
615 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800616
Eric Laurent2d388ec2014-03-07 13:25:54 -0800617 Mutex::Autolock _l(mLock);
618
Eric Laurentfee19762018-01-29 18:44:13 -0800619 ssize_t index = mAudioRecordClients.indexOfKey(portId);
620 if (index < 0) {
621 return INVALID_OPERATION;
622 }
623 sp<AudioRecordClient> client = mAudioRecordClients.valueAt(index);
624
Ray Essick84e84a52018-05-03 18:45:07 -0700625 client->active = false;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800626 client->startTimeNs = 0;
627
628 updateUidStates_l();
Ray Essick84e84a52018-05-03 18:45:07 -0700629
Svet Ganov6e641372018-03-02 09:21:30 -0800630 // finish the recording app op
631 finishRecording(client->opPackageName, client->uid);
Eric Laurent10b71232018-04-13 18:14:44 -0700632 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700633 return mAudioPolicyManager->stopInput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800634}
635
Eric Laurentfee19762018-01-29 18:44:13 -0800636void AudioPolicyService::releaseInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800637{
Eric Laurentdce54a12014-03-10 12:19:46 -0700638 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800639 return;
640 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700641 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800642 sp<AudioRecordClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700643 {
644 Mutex::Autolock _l(mLock);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700645 audioPolicyEffects = mAudioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800646 ssize_t index = mAudioRecordClients.indexOfKey(portId);
647 if (index < 0) {
648 return;
649 }
650 client = mAudioRecordClients.valueAt(index);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800651
652 if (client->active) {
653 ALOGW("%s releasing active client portId %d", __FUNCTION__, portId);
654 client->active = false;
655 client->startTimeNs = 0;
656 updateUidStates_l();
657 }
658
Eric Laurentfee19762018-01-29 18:44:13 -0800659 mAudioRecordClients.removeItem(portId);
660 }
661 if (client == 0) {
662 return;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700663 }
664 if (audioPolicyEffects != 0) {
665 // release audio processors from the input
Eric Laurentd7fe0862018-07-14 16:48:01 -0700666 status_t status = audioPolicyEffects->releaseInputEffects(client->io, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700667 if(status != NO_ERROR) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700668 ALOGW("Failed to release effects on input %d", client->io);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700669 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800670 }
Eric Laurentf10c7092016-12-06 17:09:56 -0800671 {
672 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700673 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700674 mAudioPolicyManager->releaseInput(portId);
Eric Laurentf10c7092016-12-06 17:09:56 -0800675 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800676}
677
678status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
679 int indexMin,
680 int indexMax)
681{
Eric Laurentdce54a12014-03-10 12:19:46 -0700682 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800683 return NO_INIT;
684 }
685 if (!settingsAllowed()) {
686 return PERMISSION_DENIED;
687 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800688 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800689 return BAD_VALUE;
690 }
691 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700692 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700693 mAudioPolicyManager->initStreamVolume(stream, indexMin, indexMax);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800694 return NO_ERROR;
695}
696
697status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
698 int index,
699 audio_devices_t device)
700{
Eric Laurentdce54a12014-03-10 12:19:46 -0700701 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800702 return NO_INIT;
703 }
704 if (!settingsAllowed()) {
705 return PERMISSION_DENIED;
706 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800707 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800708 return BAD_VALUE;
709 }
710 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700711 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700712 return mAudioPolicyManager->setStreamVolumeIndex(stream,
713 index,
714 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800715}
716
717status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
718 int *index,
719 audio_devices_t device)
720{
Eric Laurentdce54a12014-03-10 12:19:46 -0700721 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800722 return NO_INIT;
723 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800724 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800725 return BAD_VALUE;
726 }
727 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700728 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700729 return mAudioPolicyManager->getStreamVolumeIndex(stream,
730 index,
731 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800732}
733
François Gaffiecfe17322018-11-07 13:41:29 +0100734status_t AudioPolicyService::setVolumeIndexForAttributes(const audio_attributes_t &attributes,
735 int index, audio_devices_t device)
736{
737 if (mAudioPolicyManager == NULL) {
738 return NO_INIT;
739 }
740 if (!settingsAllowed()) {
741 return PERMISSION_DENIED;
742 }
743 Mutex::Autolock _l(mLock);
744 AutoCallerClear acc;
745 return mAudioPolicyManager->setVolumeIndexForAttributes(attributes, index, device);
746}
747
748status_t AudioPolicyService::getVolumeIndexForAttributes(const audio_attributes_t &attributes,
749 int &index, audio_devices_t device)
750{
751 if (mAudioPolicyManager == NULL) {
752 return NO_INIT;
753 }
754 Mutex::Autolock _l(mLock);
755 AutoCallerClear acc;
756 return mAudioPolicyManager->getVolumeIndexForAttributes(attributes, index, device);
757}
758
759status_t AudioPolicyService::getMinVolumeIndexForAttributes(const audio_attributes_t &attributes,
760 int &index)
761{
762 if (mAudioPolicyManager == NULL) {
763 return NO_INIT;
764 }
765 Mutex::Autolock _l(mLock);
766 AutoCallerClear acc;
767 return mAudioPolicyManager->getMinVolumeIndexForAttributes(attributes, index);
768}
769
770status_t AudioPolicyService::getMaxVolumeIndexForAttributes(const audio_attributes_t &attributes,
771 int &index)
772{
773 if (mAudioPolicyManager == NULL) {
774 return NO_INIT;
775 }
776 Mutex::Autolock _l(mLock);
777 AutoCallerClear acc;
778 return mAudioPolicyManager->getMaxVolumeIndexForAttributes(attributes, index);
779}
780
Eric Laurent2d388ec2014-03-07 13:25:54 -0800781uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
782{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800783 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
François Gaffiec005e562018-11-06 15:04:49 +0100784 return PRODUCT_STRATEGY_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700785 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700786 if (mAudioPolicyManager == NULL) {
François Gaffiec005e562018-11-06 15:04:49 +0100787 return PRODUCT_STRATEGY_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800788 }
François Gaffiec005e562018-11-06 15:04:49 +0100789 // DO NOT LOCK, may be called from AudioFlinger with lock held, reaching deadlock
Eric Laurent10b71232018-04-13 18:14:44 -0700790 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700791 return mAudioPolicyManager->getStrategyForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800792}
793
794//audio policy: use audio_device_t appropriately
795
796audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
797{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800798 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700799 return AUDIO_DEVICE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700800 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700801 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700802 return AUDIO_DEVICE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800803 }
Haynes Mathew Georgedfb9f3b2015-10-26 18:22:13 -0700804 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700805 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700806 return mAudioPolicyManager->getDevicesForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800807}
808
Jean-Michel Trivif41599b2020-01-07 14:22:08 -0800809status_t AudioPolicyService::getDevicesForAttributes(const AudioAttributes &aa,
810 AudioDeviceTypeAddrVector *devices) const
811{
812 if (mAudioPolicyManager == NULL) {
813 return NO_INIT;
814 }
815 Mutex::Autolock _l(mLock);
816 AutoCallerClear acc;
817 return mAudioPolicyManager->getDevicesForAttributes(aa.getAttributes(), devices);
818}
819
Eric Laurent2d388ec2014-03-07 13:25:54 -0800820audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
821{
822 // FIXME change return type to status_t, and return NO_INIT here
Eric Laurentdce54a12014-03-10 12:19:46 -0700823 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800824 return 0;
825 }
826 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700827 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700828 return mAudioPolicyManager->getOutputForEffect(desc);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800829}
830
831status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
832 audio_io_handle_t io,
833 uint32_t strategy,
Glenn Kastend848eb42016-03-08 13:42:11 -0800834 audio_session_t session,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800835 int id)
836{
Eric Laurentdce54a12014-03-10 12:19:46 -0700837 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800838 return NO_INIT;
839 }
Eric Laurent6c796322019-04-09 14:13:17 -0700840 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700841 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700842 return mAudioPolicyManager->registerEffect(desc, io, strategy, session, id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800843}
844
845status_t AudioPolicyService::unregisterEffect(int id)
846{
Eric Laurentdce54a12014-03-10 12:19:46 -0700847 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800848 return NO_INIT;
849 }
Eric Laurent6c796322019-04-09 14:13:17 -0700850 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700851 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700852 return mAudioPolicyManager->unregisterEffect(id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800853}
854
855status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
856{
Eric Laurentdce54a12014-03-10 12:19:46 -0700857 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800858 return NO_INIT;
859 }
Eric Laurent6c796322019-04-09 14:13:17 -0700860 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700861 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700862 return mAudioPolicyManager->setEffectEnabled(id, enabled);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800863}
864
Eric Laurent6c796322019-04-09 14:13:17 -0700865status_t AudioPolicyService::moveEffectsToIo(const std::vector<int>& ids, audio_io_handle_t io)
866{
867 if (mAudioPolicyManager == NULL) {
868 return NO_INIT;
869 }
870 Mutex::Autolock _l(mLock);
871 AutoCallerClear acc;
872 return mAudioPolicyManager->moveEffectsToIo(ids, io);
873}
874
Eric Laurent2d388ec2014-03-07 13:25:54 -0800875bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
876{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800877 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700878 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700879 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700880 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700881 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800882 }
883 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700884 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700885 return mAudioPolicyManager->isStreamActive(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800886}
887
888bool AudioPolicyService::isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs) const
889{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800890 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700891 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700892 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700893 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700894 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800895 }
896 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700897 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700898 return mAudioPolicyManager->isStreamActiveRemotely(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800899}
900
901bool AudioPolicyService::isSourceActive(audio_source_t source) const
902{
Eric Laurentdce54a12014-03-10 12:19:46 -0700903 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800904 return false;
905 }
906 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700907 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700908 return mAudioPolicyManager->isSourceActive(source);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800909}
910
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700911status_t AudioPolicyService::getAudioPolicyEffects(sp<AudioPolicyEffects>& audioPolicyEffects)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800912{
Eric Laurentdce54a12014-03-10 12:19:46 -0700913 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800914 return NO_INIT;
915 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700916 {
917 Mutex::Autolock _l(mLock);
918 audioPolicyEffects = mAudioPolicyEffects;
919 }
920 if (audioPolicyEffects == 0) {
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700921 return NO_INIT;
922 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700923
924 return OK;
925}
926
927status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
928 effect_descriptor_t *descriptors,
929 uint32_t *count)
930{
931 sp<AudioPolicyEffects>audioPolicyEffects;
932 status_t status = getAudioPolicyEffects(audioPolicyEffects);
933 if (status != OK) {
934 *count = 0;
935 return status;
936 }
Eric Laurentfb66dd92016-01-28 18:32:03 -0800937 return audioPolicyEffects->queryDefaultInputEffects(
938 (audio_session_t)audioSession, descriptors, count);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800939}
940
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700941status_t AudioPolicyService::addSourceDefaultEffect(const effect_uuid_t *type,
942 const String16& opPackageName,
943 const effect_uuid_t *uuid,
944 int32_t priority,
945 audio_source_t source,
946 audio_unique_id_t* id)
947{
948 sp<AudioPolicyEffects>audioPolicyEffects;
949 status_t status = getAudioPolicyEffects(audioPolicyEffects);
950 if (status != OK) {
951 return status;
952 }
953 if (!modifyDefaultAudioEffectsAllowed()) {
954 return PERMISSION_DENIED;
955 }
956 return audioPolicyEffects->addSourceDefaultEffect(
957 type, opPackageName, uuid, priority, source, id);
958}
959
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700960status_t AudioPolicyService::addStreamDefaultEffect(const effect_uuid_t *type,
961 const String16& opPackageName,
962 const effect_uuid_t *uuid,
963 int32_t priority,
964 audio_usage_t usage,
965 audio_unique_id_t* id)
966{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700967 sp<AudioPolicyEffects>audioPolicyEffects;
968 status_t status = getAudioPolicyEffects(audioPolicyEffects);
969 if (status != OK) {
970 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700971 }
972 if (!modifyDefaultAudioEffectsAllowed()) {
973 return PERMISSION_DENIED;
974 }
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700975 return audioPolicyEffects->addStreamDefaultEffect(
976 type, opPackageName, uuid, priority, usage, id);
977}
978
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700979status_t AudioPolicyService::removeSourceDefaultEffect(audio_unique_id_t id)
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700980{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700981 sp<AudioPolicyEffects>audioPolicyEffects;
982 status_t status = getAudioPolicyEffects(audioPolicyEffects);
983 if (status != OK) {
984 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700985 }
986 if (!modifyDefaultAudioEffectsAllowed()) {
987 return PERMISSION_DENIED;
988 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700989 return audioPolicyEffects->removeSourceDefaultEffect(id);
990}
991
992status_t AudioPolicyService::removeStreamDefaultEffect(audio_unique_id_t id)
993{
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700994 sp<AudioPolicyEffects>audioPolicyEffects;
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700995 status_t status = getAudioPolicyEffects(audioPolicyEffects);
996 if (status != OK) {
997 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700998 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700999 if (!modifyDefaultAudioEffectsAllowed()) {
1000 return PERMISSION_DENIED;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -07001001 }
1002 return audioPolicyEffects->removeStreamDefaultEffect(id);
1003}
1004
Kevin Rocardb99cc752019-03-21 20:52:24 -07001005status_t AudioPolicyService::setAllowedCapturePolicy(uid_t uid, audio_flags_mask_t capturePolicy) {
1006 Mutex::Autolock _l(mLock);
1007 if (mAudioPolicyManager == NULL) {
1008 ALOGV("%s() mAudioPolicyManager == NULL", __func__);
1009 return NO_INIT;
1010 }
1011 uint_t callingUid = IPCThreadState::self()->getCallingUid();
1012 if (uid != callingUid) {
1013 ALOGD("%s() uid invalid %d != %d", __func__, uid, callingUid);
1014 return PERMISSION_DENIED;
1015 }
1016 return mAudioPolicyManager->setAllowedCapturePolicy(uid, capturePolicy);
1017}
1018
Eric Laurent2d388ec2014-03-07 13:25:54 -08001019bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
1020{
Eric Laurentdce54a12014-03-10 12:19:46 -07001021 if (mAudioPolicyManager == NULL) {
1022 ALOGV("mAudioPolicyManager == NULL");
Eric Laurent2d388ec2014-03-07 13:25:54 -08001023 return false;
1024 }
Andy Hung2ddee192015-12-18 17:34:44 -08001025 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001026 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -07001027 return mAudioPolicyManager->isOffloadSupported(info);
Eric Laurent2d388ec2014-03-07 13:25:54 -08001028}
1029
Michael Chana94fbb22018-04-24 14:31:19 +10001030bool AudioPolicyService::isDirectOutputSupported(const audio_config_base_t& config,
1031 const audio_attributes_t& attributes) {
1032 if (mAudioPolicyManager == NULL) {
1033 ALOGV("mAudioPolicyManager == NULL");
1034 return false;
1035 }
1036 Mutex::Autolock _l(mLock);
1037 return mAudioPolicyManager->isDirectOutputSupported(config, attributes);
1038}
1039
1040
Eric Laurent6a94d692014-05-20 11:18:06 -07001041status_t AudioPolicyService::listAudioPorts(audio_port_role_t role,
1042 audio_port_type_t type,
Eric Laurent203b1a12014-04-01 10:34:16 -07001043 unsigned int *num_ports,
Eric Laurent6a94d692014-05-20 11:18:06 -07001044 struct audio_port *ports,
1045 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001046{
Eric Laurent6a94d692014-05-20 11:18:06 -07001047 Mutex::Autolock _l(mLock);
1048 if (mAudioPolicyManager == NULL) {
1049 return NO_INIT;
1050 }
Eric Laurent10b71232018-04-13 18:14:44 -07001051 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001052 return mAudioPolicyManager->listAudioPorts(role, type, num_ports, ports, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001053}
1054
Eric Laurent6a94d692014-05-20 11:18:06 -07001055status_t AudioPolicyService::getAudioPort(struct audio_port *port)
Eric Laurent203b1a12014-04-01 10:34:16 -07001056{
Eric Laurent6a94d692014-05-20 11:18:06 -07001057 Mutex::Autolock _l(mLock);
1058 if (mAudioPolicyManager == NULL) {
1059 return NO_INIT;
1060 }
Eric Laurent10b71232018-04-13 18:14:44 -07001061 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001062 return mAudioPolicyManager->getAudioPort(port);
Eric Laurent203b1a12014-04-01 10:34:16 -07001063}
1064
Eric Laurent6a94d692014-05-20 11:18:06 -07001065status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch,
1066 audio_patch_handle_t *handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001067{
Eric Laurent6a94d692014-05-20 11:18:06 -07001068 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001069 if(!modifyAudioRoutingAllowed()) {
1070 return PERMISSION_DENIED;
1071 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001072 if (mAudioPolicyManager == NULL) {
1073 return NO_INIT;
1074 }
Eric Laurent10b71232018-04-13 18:14:44 -07001075 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001076 return mAudioPolicyManager->createAudioPatch(patch, handle,
1077 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001078}
1079
Eric Laurent6a94d692014-05-20 11:18:06 -07001080status_t AudioPolicyService::releaseAudioPatch(audio_patch_handle_t handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001081{
Eric Laurent6a94d692014-05-20 11:18:06 -07001082 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001083 if(!modifyAudioRoutingAllowed()) {
1084 return PERMISSION_DENIED;
1085 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001086 if (mAudioPolicyManager == NULL) {
1087 return NO_INIT;
1088 }
Eric Laurent10b71232018-04-13 18:14:44 -07001089 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001090 return mAudioPolicyManager->releaseAudioPatch(handle,
1091 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001092}
1093
1094status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
Eric Laurent6a94d692014-05-20 11:18:06 -07001095 struct audio_patch *patches,
1096 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001097{
Eric Laurent6a94d692014-05-20 11:18:06 -07001098 Mutex::Autolock _l(mLock);
1099 if (mAudioPolicyManager == NULL) {
1100 return NO_INIT;
1101 }
Eric Laurent10b71232018-04-13 18:14:44 -07001102 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001103 return mAudioPolicyManager->listAudioPatches(num_patches, patches, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001104}
1105
Eric Laurent6a94d692014-05-20 11:18:06 -07001106status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config)
Eric Laurent203b1a12014-04-01 10:34:16 -07001107{
Eric Laurent6a94d692014-05-20 11:18:06 -07001108 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001109 if(!modifyAudioRoutingAllowed()) {
1110 return PERMISSION_DENIED;
1111 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001112 if (mAudioPolicyManager == NULL) {
1113 return NO_INIT;
1114 }
Eric Laurent10b71232018-04-13 18:14:44 -07001115 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001116 return mAudioPolicyManager->setAudioPortConfig(config);
Eric Laurent203b1a12014-04-01 10:34:16 -07001117}
Eric Laurent2d388ec2014-03-07 13:25:54 -08001118
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001119status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session,
1120 audio_io_handle_t *ioHandle,
1121 audio_devices_t *device)
1122{
Andy Hungf759b8c2017-08-15 12:48:54 -07001123 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001124 if (mAudioPolicyManager == NULL) {
1125 return NO_INIT;
1126 }
Eric Laurent10b71232018-04-13 18:14:44 -07001127 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001128 return mAudioPolicyManager->acquireSoundTriggerSession(session, ioHandle, device);
1129}
1130
1131status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session)
1132{
Andy Hungf759b8c2017-08-15 12:48:54 -07001133 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001134 if (mAudioPolicyManager == NULL) {
1135 return NO_INIT;
1136 }
Eric Laurent10b71232018-04-13 18:14:44 -07001137 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001138 return mAudioPolicyManager->releaseSoundTriggerSession(session);
1139}
1140
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -07001141status_t AudioPolicyService::registerPolicyMixes(const Vector<AudioMix>& mixes, bool registration)
Eric Laurentbaac1832014-12-01 17:52:59 -08001142{
1143 Mutex::Autolock _l(mLock);
Kevin Rocardbe201852019-02-20 22:33:28 -08001144
1145 // loopback|render only need a MediaProjection (checked in caller AudioService.java)
1146 bool needModifyAudioRouting = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
1147 return !is_mix_loopback_render(mix.mRouteFlags); });
1148 if (needModifyAudioRouting && !modifyAudioRoutingAllowed()) {
Eric Laurentbaac1832014-12-01 17:52:59 -08001149 return PERMISSION_DENIED;
1150 }
Kevin Rocardbe201852019-02-20 22:33:28 -08001151
Kevin Rocard36b17552019-03-07 18:48:07 -08001152 bool needCaptureMediaOutput = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
1153 return mix.mAllowPrivilegedPlaybackCapture; });
1154 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
1155 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
1156 if (needCaptureMediaOutput && !captureMediaOutputAllowed(callingPid, callingUid)) {
1157 return PERMISSION_DENIED;
1158 }
1159
Eric Laurentbaac1832014-12-01 17:52:59 -08001160 if (mAudioPolicyManager == NULL) {
1161 return NO_INIT;
1162 }
Eric Laurent10b71232018-04-13 18:14:44 -07001163 AutoCallerClear acc;
Eric Laurentbaac1832014-12-01 17:52:59 -08001164 if (registration) {
1165 return mAudioPolicyManager->registerPolicyMixes(mixes);
1166 } else {
1167 return mAudioPolicyManager->unregisterPolicyMixes(mixes);
1168 }
1169}
1170
Jean-Michel Trivibda70da2018-12-19 07:30:15 -08001171status_t AudioPolicyService::setUidDeviceAffinities(uid_t uid,
1172 const Vector<AudioDeviceTypeAddr>& devices) {
1173 Mutex::Autolock _l(mLock);
1174 if(!modifyAudioRoutingAllowed()) {
1175 return PERMISSION_DENIED;
1176 }
1177 if (mAudioPolicyManager == NULL) {
1178 return NO_INIT;
1179 }
1180 AutoCallerClear acc;
1181 return mAudioPolicyManager->setUidDeviceAffinities(uid, devices);
1182}
1183
1184status_t AudioPolicyService::removeUidDeviceAffinities(uid_t uid) {
1185 Mutex::Autolock _l(mLock);
1186 if(!modifyAudioRoutingAllowed()) {
1187 return PERMISSION_DENIED;
1188 }
1189 if (mAudioPolicyManager == NULL) {
1190 return NO_INIT;
1191 }
1192 AutoCallerClear acc;
1193 return mAudioPolicyManager->removeUidDeviceAffinities(uid);
1194}
1195
Eric Laurent554a2772015-04-10 11:29:24 -07001196status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001197 const audio_attributes_t *attributes,
1198 audio_port_handle_t *portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001199{
1200 Mutex::Autolock _l(mLock);
1201 if (mAudioPolicyManager == NULL) {
1202 return NO_INIT;
1203 }
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001204 // startAudioSource should be created as the calling uid
1205 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Eric Laurent10b71232018-04-13 18:14:44 -07001206 AutoCallerClear acc;
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001207 return mAudioPolicyManager->startAudioSource(source, attributes, portId, callingUid);
Eric Laurent554a2772015-04-10 11:29:24 -07001208}
1209
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001210status_t AudioPolicyService::stopAudioSource(audio_port_handle_t portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001211{
1212 Mutex::Autolock _l(mLock);
1213 if (mAudioPolicyManager == NULL) {
1214 return NO_INIT;
1215 }
Eric Laurent10b71232018-04-13 18:14:44 -07001216 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001217 return mAudioPolicyManager->stopAudioSource(portId);
Eric Laurent554a2772015-04-10 11:29:24 -07001218}
1219
Andy Hung2ddee192015-12-18 17:34:44 -08001220status_t AudioPolicyService::setMasterMono(bool mono)
1221{
1222 if (mAudioPolicyManager == NULL) {
1223 return NO_INIT;
1224 }
1225 if (!settingsAllowed()) {
1226 return PERMISSION_DENIED;
1227 }
1228 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001229 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001230 return mAudioPolicyManager->setMasterMono(mono);
1231}
1232
1233status_t AudioPolicyService::getMasterMono(bool *mono)
1234{
1235 if (mAudioPolicyManager == NULL) {
1236 return NO_INIT;
1237 }
1238 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001239 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001240 return mAudioPolicyManager->getMasterMono(mono);
1241}
1242
Eric Laurentac9cef52017-06-09 15:46:26 -07001243
1244float AudioPolicyService::getStreamVolumeDB(
1245 audio_stream_type_t stream, int index, audio_devices_t device)
1246{
1247 if (mAudioPolicyManager == NULL) {
1248 return NAN;
1249 }
1250 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001251 AutoCallerClear acc;
Eric Laurentac9cef52017-06-09 15:46:26 -07001252 return mAudioPolicyManager->getStreamVolumeDB(stream, index, device);
1253}
1254
jiabin81772902018-04-02 17:52:27 -07001255status_t AudioPolicyService::getSurroundFormats(unsigned int *numSurroundFormats,
1256 audio_format_t *surroundFormats,
1257 bool *surroundFormatsEnabled,
1258 bool reported)
1259{
1260 if (mAudioPolicyManager == NULL) {
1261 return NO_INIT;
1262 }
1263 Mutex::Autolock _l(mLock);
1264 AutoCallerClear acc;
1265 return mAudioPolicyManager->getSurroundFormats(numSurroundFormats, surroundFormats,
1266 surroundFormatsEnabled, reported);
1267}
1268
Arun Mirpuri11029ad2018-12-19 20:45:19 -08001269status_t AudioPolicyService::getHwOffloadEncodingFormatsSupportedForA2DP(
1270 std::vector<audio_format_t> *formats)
1271{
1272 if (mAudioPolicyManager == NULL) {
1273 return NO_INIT;
1274 }
1275 Mutex::Autolock _l(mLock);
1276 AutoCallerClear acc;
1277 return mAudioPolicyManager->getHwOffloadEncodingFormatsSupportedForA2DP(formats);
1278}
1279
jiabin81772902018-04-02 17:52:27 -07001280status_t AudioPolicyService::setSurroundFormatEnabled(audio_format_t audioFormat, bool enabled)
1281{
1282 if (mAudioPolicyManager == NULL) {
1283 return NO_INIT;
1284 }
1285 Mutex::Autolock _l(mLock);
1286 AutoCallerClear acc;
1287 return mAudioPolicyManager->setSurroundFormatEnabled(audioFormat, enabled);
1288}
Eric Laurentac9cef52017-06-09 15:46:26 -07001289
Eric Laurentb78763e2018-10-17 10:08:02 -07001290status_t AudioPolicyService::setAssistantUid(uid_t uid)
1291{
1292 Mutex::Autolock _l(mLock);
1293 mUidPolicy->setAssistantUid(uid);
1294 return NO_ERROR;
1295}
1296
1297status_t AudioPolicyService::setA11yServicesUids(const std::vector<uid_t>& uids)
1298{
1299 Mutex::Autolock _l(mLock);
1300 mUidPolicy->setA11yUids(uids);
1301 return NO_ERROR;
1302}
1303
jiabin6012f912018-11-02 17:06:30 -07001304bool AudioPolicyService::isHapticPlaybackSupported()
1305{
1306 if (mAudioPolicyManager == NULL) {
1307 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1308 return false;
1309 }
1310 Mutex::Autolock _l(mLock);
1311 AutoCallerClear acc;
1312 return mAudioPolicyManager->isHapticPlaybackSupported();
1313}
1314
François Gaffied0ba9ed2018-11-05 11:50:42 +01001315status_t AudioPolicyService::listAudioProductStrategies(AudioProductStrategyVector &strategies)
1316{
1317 if (mAudioPolicyManager == NULL) {
1318 return NO_INIT;
1319 }
1320 Mutex::Autolock _l(mLock);
1321 return mAudioPolicyManager->listAudioProductStrategies(strategies);
1322}
1323
François Gaffie4b2018b2018-11-07 11:18:59 +01001324status_t AudioPolicyService::getProductStrategyFromAudioAttributes(
1325 const AudioAttributes &aa, product_strategy_t &productStrategy)
François Gaffied0ba9ed2018-11-05 11:50:42 +01001326{
1327 if (mAudioPolicyManager == NULL) {
François Gaffie4b2018b2018-11-07 11:18:59 +01001328 return NO_INIT;
François Gaffied0ba9ed2018-11-05 11:50:42 +01001329 }
1330 Mutex::Autolock _l(mLock);
François Gaffie4b2018b2018-11-07 11:18:59 +01001331 return mAudioPolicyManager->getProductStrategyFromAudioAttributes(aa, productStrategy);
1332}
1333
1334status_t AudioPolicyService::listAudioVolumeGroups(AudioVolumeGroupVector &groups)
1335{
1336 if (mAudioPolicyManager == NULL) {
1337 return NO_INIT;
1338 }
1339 Mutex::Autolock _l(mLock);
1340 return mAudioPolicyManager->listAudioVolumeGroups(groups);
1341}
1342
1343status_t AudioPolicyService::getVolumeGroupFromAudioAttributes(const AudioAttributes &aa,
1344 volume_group_t &volumeGroup)
1345{
1346 if (mAudioPolicyManager == NULL) {
1347 return NO_INIT;
1348 }
1349 Mutex::Autolock _l(mLock);
1350 return mAudioPolicyManager->getVolumeGroupFromAudioAttributes(aa, volumeGroup);
François Gaffied0ba9ed2018-11-05 11:50:42 +01001351}
Eric Laurent6ede98f2019-06-11 14:50:30 -07001352
1353status_t AudioPolicyService::setRttEnabled(bool enabled)
1354{
1355 Mutex::Autolock _l(mLock);
1356 mUidPolicy->setRttEnabled(enabled);
1357 return NO_ERROR;
1358}
1359
Eric Laurent8340e672019-11-06 11:01:08 -08001360bool AudioPolicyService::isCallScreenModeSupported()
1361{
1362 if (mAudioPolicyManager == NULL) {
1363 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1364 return false;
1365 }
1366 Mutex::Autolock _l(mLock);
1367 AutoCallerClear acc;
1368 return mAudioPolicyManager->isCallScreenModeSupported();
1369}
1370
Jean-Michel Trivi30857152019-11-01 11:04:15 -07001371status_t AudioPolicyService::setPreferredDeviceForStrategy(product_strategy_t strategy,
1372 const AudioDeviceTypeAddr &device)
1373{
1374 if (mAudioPolicyManager == NULL) {
1375 return NO_INIT;
1376 }
1377 Mutex::Autolock _l(mLock);
1378 return mAudioPolicyManager->setPreferredDeviceForStrategy(strategy, device);
1379}
1380
1381status_t AudioPolicyService::removePreferredDeviceForStrategy(product_strategy_t strategy)
1382{
1383 if (mAudioPolicyManager == NULL) {
1384 return NO_INIT;
1385 }
1386 Mutex::Autolock _l(mLock);
1387 return mAudioPolicyManager->removePreferredDeviceForStrategy(strategy);
1388}
1389
1390status_t AudioPolicyService::getPreferredDeviceForStrategy(product_strategy_t strategy,
1391 AudioDeviceTypeAddr &device)
1392{
1393 if (mAudioPolicyManager == NULL) {
1394 return NO_INIT;
1395 }
1396 Mutex::Autolock _l(mLock);
1397 return mAudioPolicyManager->getPreferredDeviceForStrategy(strategy, device);
1398}
1399
Mikhail Naganov1b2a7942017-12-08 10:18:09 -08001400} // namespace android