blob: 2c904d9ad710b69e9f29f93c12c2046a139ae0c9 [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"
Eric Laurentd7fe0862018-07-14 16:48:01 -070022#include <media/AudioPolicyHelper.h>
23#include <media/MediaAnalyticsItem.h>
24#include <mediautils/ServiceUtilities.h>
25#include <utils/Log.h>
Eric Laurent2d388ec2014-03-07 13:25:54 -080026
Eric Laurent2d388ec2014-03-07 13:25:54 -080027namespace android {
28
29
30// ----------------------------------------------------------------------------
31
32status_t AudioPolicyService::setDeviceConnectionState(audio_devices_t device,
33 audio_policy_dev_state_t state,
Paul McLeane743a472015-01-28 11:07:31 -080034 const char *device_address,
35 const char *device_name)
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,
52 device_address, device_name);
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,
69 const char *device_name)
70{
71 if (mAudioPolicyManager == NULL) {
72 return NO_INIT;
73 }
74 if (!settingsAllowed()) {
75 return PERMISSION_DENIED;
76 }
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080077
78 ALOGV("handleDeviceConfigChange()");
79 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -070080 AutoCallerClear acc;
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080081 return mAudioPolicyManager->handleDeviceConfigChange(device, device_address,
82 device_name);
83}
84
Eric Laurent2d388ec2014-03-07 13:25:54 -080085status_t AudioPolicyService::setPhoneState(audio_mode_t state)
86{
Eric Laurentdce54a12014-03-10 12:19:46 -070087 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080088 return NO_INIT;
89 }
90 if (!settingsAllowed()) {
91 return PERMISSION_DENIED;
92 }
93 if (uint32_t(state) >= AUDIO_MODE_CNT) {
94 return BAD_VALUE;
95 }
96
97 ALOGV("setPhoneState()");
98
Eric Laurentbeb07fe2015-09-16 15:49:30 -070099 // acquire lock before calling setMode() so that setMode() + setPhoneState() are an atomic
100 // operation from policy manager standpoint (no other operation (e.g track start or stop)
101 // can be interleaved).
102 Mutex::Autolock _l(mLock);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800103 // TODO: check if it is more appropriate to do it in platform specific policy manager
104 AudioSystem::setMode(state);
105
Eric Laurent10b71232018-04-13 18:14:44 -0700106 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700107 mAudioPolicyManager->setPhoneState(state);
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700108 mPhoneState = state;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800109 return NO_ERROR;
110}
111
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700112audio_mode_t AudioPolicyService::getPhoneState()
113{
114 Mutex::Autolock _l(mLock);
115 return mPhoneState;
116}
117
Eric Laurent2d388ec2014-03-07 13:25:54 -0800118status_t AudioPolicyService::setForceUse(audio_policy_force_use_t usage,
119 audio_policy_forced_cfg_t config)
120{
Eric Laurentdce54a12014-03-10 12:19:46 -0700121 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800122 return NO_INIT;
123 }
Eric Laurente17378d2018-05-09 14:43:01 -0700124
125 if (!modifyAudioRoutingAllowed()) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800126 return PERMISSION_DENIED;
127 }
Eric Laurente17378d2018-05-09 14:43:01 -0700128
Eric Laurent2d388ec2014-03-07 13:25:54 -0800129 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
130 return BAD_VALUE;
131 }
132 if (config < 0 || config >= AUDIO_POLICY_FORCE_CFG_CNT) {
133 return BAD_VALUE;
134 }
135 ALOGV("setForceUse()");
136 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700137 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700138 mAudioPolicyManager->setForceUse(usage, config);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800139 return NO_ERROR;
140}
141
142audio_policy_forced_cfg_t AudioPolicyService::getForceUse(audio_policy_force_use_t usage)
143{
Eric Laurentdce54a12014-03-10 12:19:46 -0700144 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800145 return AUDIO_POLICY_FORCE_NONE;
146 }
147 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
148 return AUDIO_POLICY_FORCE_NONE;
149 }
Eric Laurent10b71232018-04-13 18:14:44 -0700150 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700151 return mAudioPolicyManager->getForceUse(usage);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800152}
153
Eric Laurentf4e63452017-11-06 19:31:46 +0000154audio_io_handle_t AudioPolicyService::getOutput(audio_stream_type_t stream)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800155{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800156 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700157 return AUDIO_IO_HANDLE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700158 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700159 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700160 return AUDIO_IO_HANDLE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800161 }
162 ALOGV("getOutput()");
163 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700164 AutoCallerClear acc;
Eric Laurentf4e63452017-11-06 19:31:46 +0000165 return mAudioPolicyManager->getOutput(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800166}
167
Eric Laurente83b55d2014-11-14 10:06:21 -0800168status_t AudioPolicyService::getOutputForAttr(const audio_attributes_t *attr,
169 audio_io_handle_t *output,
170 audio_session_t session,
171 audio_stream_type_t *stream,
Nadav Bar766fb022018-01-07 12:18:03 +0200172 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700173 uid_t uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800174 const audio_config_t *config,
Eric Laurente83b55d2014-11-14 10:06:21 -0800175 audio_output_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700176 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800177 audio_port_handle_t *portId)
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700178{
179 if (mAudioPolicyManager == NULL) {
Eric Laurente83b55d2014-11-14 10:06:21 -0800180 return NO_INIT;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700181 }
Eric Laurentf4e63452017-11-06 19:31:46 +0000182 ALOGV("getOutputForAttr()");
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700183 Mutex::Autolock _l(mLock);
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700184
Marco Nelissendcb346b2015-09-09 10:47:29 -0700185 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700186 if (!isAudioServerOrMediaServerUid(callingUid) || uid == (uid_t)-1) {
Marco Nelissendcb346b2015-09-09 10:47:29 -0700187 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
188 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
189 uid = callingUid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700190 }
Nadav Bar766fb022018-01-07 12:18:03 +0200191 audio_output_flags_t originalFlags = flags;
Eric Laurent10b71232018-04-13 18:14:44 -0700192 AutoCallerClear acc;
Nadav Bar766fb022018-01-07 12:18:03 +0200193 status_t result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800194 config,
Nadav Bar766fb022018-01-07 12:18:03 +0200195 &flags, selectedDeviceId, portId);
196
197 // FIXME: Introduce a way to check for the the telephony device before opening the output
198 if ((result == NO_ERROR) &&
199 (flags & AUDIO_OUTPUT_FLAG_INCALL_MUSIC) &&
200 !modifyPhoneStateAllowed(pid, uid)) {
201 // If the app tries to play music through the telephony device and doesn't have permission
202 // the fallback to the default output device.
Eric Laurent8fc147b2018-07-22 19:13:55 -0700203 mAudioPolicyManager->releaseOutput(*portId);
Nadav Bar766fb022018-01-07 12:18:03 +0200204 flags = originalFlags;
205 *selectedDeviceId = AUDIO_PORT_HANDLE_NONE;
206 *portId = AUDIO_PORT_HANDLE_NONE;
207 result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
208 config,
209 &flags, selectedDeviceId, portId);
210 }
Eric Laurentd7fe0862018-07-14 16:48:01 -0700211
212 if (result == NO_ERROR) {
213 sp <AudioPlaybackClient> client =
214 new AudioPlaybackClient(*attr, *output, uid, pid, session, *selectedDeviceId, *stream);
215 mAudioPlaybackClients.add(*portId, client);
216 }
Nadav Bar766fb022018-01-07 12:18:03 +0200217 return result;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700218}
219
Eric Laurentd7fe0862018-07-14 16:48:01 -0700220status_t AudioPolicyService::startOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800221{
Eric Laurentdce54a12014-03-10 12:19:46 -0700222 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800223 return NO_INIT;
224 }
225 ALOGV("startOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700226 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700227 sp<AudioPolicyEffects>audioPolicyEffects;
228 {
229 Mutex::Autolock _l(mLock);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700230 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
231 if (index < 0) {
232 ALOGE("%s AudioTrack client not found for portId %d", __FUNCTION__, portId);
233 return INVALID_OPERATION;
234 }
235 client = mAudioPlaybackClients.valueAt(index);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700236 audioPolicyEffects = mAudioPolicyEffects;
bryant_liuba2b4392014-06-11 16:49:30 +0800237 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700238 if (audioPolicyEffects != 0) {
239 // create audio processors according to stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700240 status_t status = audioPolicyEffects->addOutputSessionEffects(
241 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700242 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700243 ALOGW("Failed to add effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700244 }
245 }
246 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700247 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700248 status_t status = mAudioPolicyManager->startOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700249 if (status == NO_ERROR) {
250 client->active = true;
251 }
252 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800253}
254
Eric Laurentd7fe0862018-07-14 16:48:01 -0700255status_t AudioPolicyService::stopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800256{
Eric Laurentdce54a12014-03-10 12:19:46 -0700257 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800258 return NO_INIT;
259 }
260 ALOGV("stopOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700261 mOutputCommandThread->stopOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800262 return NO_ERROR;
263}
264
Eric Laurentd7fe0862018-07-14 16:48:01 -0700265status_t AudioPolicyService::doStopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800266{
Eric Laurentd7fe0862018-07-14 16:48:01 -0700267 ALOGV("doStopOutput");
268 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700269 sp<AudioPolicyEffects>audioPolicyEffects;
270 {
271 Mutex::Autolock _l(mLock);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700272
273 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
274 if (index < 0) {
275 ALOGE("%s AudioTrack client not found for portId %d", __FUNCTION__, portId);
276 return INVALID_OPERATION;
277 }
278 client = mAudioPlaybackClients.valueAt(index);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700279 audioPolicyEffects = mAudioPolicyEffects;
bryant_liuba2b4392014-06-11 16:49:30 +0800280 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700281 if (audioPolicyEffects != 0) {
282 // release audio processors from the stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700283 status_t status = audioPolicyEffects->releaseOutputSessionEffects(
284 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700285 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700286 ALOGW("Failed to release effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700287 }
288 }
289 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700290 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700291 status_t status = mAudioPolicyManager->stopOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700292 if (status == NO_ERROR) {
293 client->active = false;
294 }
295 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800296}
297
Eric Laurentd7fe0862018-07-14 16:48:01 -0700298void AudioPolicyService::releaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800299{
Eric Laurentdce54a12014-03-10 12:19:46 -0700300 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800301 return;
302 }
303 ALOGV("releaseOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700304 mOutputCommandThread->releaseOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800305}
306
Eric Laurentd7fe0862018-07-14 16:48:01 -0700307void AudioPolicyService::doReleaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800308{
309 ALOGV("doReleaseOutput from tid %d", gettid());
310 Mutex::Autolock _l(mLock);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700311 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
312 if (index < 0) {
313 ALOGE("%s AudioTrack client not found for portId %d", __FUNCTION__, portId);
314 return;
315 }
316 sp<AudioPlaybackClient> client = mAudioPlaybackClients.valueAt(index);
317 mAudioRecordClients.removeItem(portId);
318
Eric Laurent10b71232018-04-13 18:14:44 -0700319 // called from internal thread: no need to clear caller identity
Eric Laurent8fc147b2018-07-22 19:13:55 -0700320 mAudioPolicyManager->releaseOutput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800321}
322
Eric Laurentcaf7f482014-11-25 17:50:47 -0800323status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
324 audio_io_handle_t *input,
325 audio_session_t session,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700326 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700327 uid_t uid,
Eric Laurentfee19762018-01-29 18:44:13 -0800328 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800329 const audio_config_base_t *config,
Paul McLean466dc8e2015-04-17 13:15:36 -0600330 audio_input_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700331 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800332 audio_port_handle_t *portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800333{
Eric Laurentdce54a12014-03-10 12:19:46 -0700334 if (mAudioPolicyManager == NULL) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800335 return NO_INIT;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800336 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800337
Eric Laurent2d388ec2014-03-07 13:25:54 -0800338 // already checked by client, but double-check in case the client wrapper is bypassed
Eric Laurentae4b6ec2019-01-15 18:34:38 -0800339 if ((attr->source < AUDIO_SOURCE_DEFAULT)
340 || (attr->source >= AUDIO_SOURCE_CNT
341 && attr->source != AUDIO_SOURCE_HOTWORD
342 && attr->source != AUDIO_SOURCE_FM_TUNER
343 && attr->source != AUDIO_SOURCE_ECHO_REFERENCE)) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800344 return BAD_VALUE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800345 }
346
Eric Laurentb2379ba2016-05-23 17:42:12 -0700347 bool updatePid = (pid == -1);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700348 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700349 if (!isAudioServerOrMediaServerUid(callingUid)) {
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700350 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Marco Nelissendcb346b2015-09-09 10:47:29 -0700351 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
352 uid = callingUid;
Eric Laurentb2379ba2016-05-23 17:42:12 -0700353 updatePid = true;
354 }
355
356 if (updatePid) {
357 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700358 ALOGW_IF(pid != (pid_t)-1 && pid != callingPid,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700359 "%s uid %d pid %d tried to pass itself off as pid %d",
360 __func__, callingUid, callingPid, pid);
361 pid = callingPid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700362 }
363
Eric Laurent7dca8a82018-01-29 18:44:26 -0800364 // check calling permissions
365 if (!recordingAllowed(opPackageName, pid, uid)) {
366 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
367 __func__, uid, pid);
368 return PERMISSION_DENIED;
369 }
370
Nadav Bar744be482018-05-08 13:26:21 +0300371 if ((attr->source == AUDIO_SOURCE_VOICE_UPLINK ||
372 attr->source == AUDIO_SOURCE_VOICE_DOWNLINK ||
Eric Laurentae4b6ec2019-01-15 18:34:38 -0800373 attr->source == AUDIO_SOURCE_VOICE_CALL ||
374 attr->source == AUDIO_SOURCE_ECHO_REFERENCE) &&
Nadav Bar744be482018-05-08 13:26:21 +0300375 !captureAudioOutputAllowed(pid, uid)) {
376 return PERMISSION_DENIED;
377 }
378
Eric Laurent7504b9e2017-08-15 18:17:26 -0700379 if ((attr->source == AUDIO_SOURCE_HOTWORD) && !captureHotwordAllowed(pid, uid)) {
380 return BAD_VALUE;
381 }
382
383 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700384 {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700385 status_t status;
386 AudioPolicyInterface::input_type_t inputType;
387
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700388 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700389 {
390 AutoCallerClear acc;
391 // the audio_in_acoustics_t parameter is ignored by get_input()
392 status = mAudioPolicyManager->getInputForAttr(attr, input, session, uid,
393 config,
394 flags, selectedDeviceId,
395 &inputType, portId);
396 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700397 audioPolicyEffects = mAudioPolicyEffects;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800398
399 if (status == NO_ERROR) {
400 // enforce permission (if any) required for each type of input
401 switch (inputType) {
402 case AudioPolicyInterface::API_INPUT_LEGACY:
403 break;
Eric Laurent82db2692015-08-07 13:59:42 -0700404 case AudioPolicyInterface::API_INPUT_TELEPHONY_RX:
405 // FIXME: use the same permission as for remote submix for now.
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800406 case AudioPolicyInterface::API_INPUT_MIX_CAPTURE:
Eric Laurentb2379ba2016-05-23 17:42:12 -0700407 if (!captureAudioOutputAllowed(pid, uid)) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800408 ALOGE("getInputForAttr() permission denied: capture not allowed");
409 status = PERMISSION_DENIED;
410 }
411 break;
412 case AudioPolicyInterface::API_INPUT_MIX_EXT_POLICY_REROUTE:
413 if (!modifyAudioRoutingAllowed()) {
414 ALOGE("getInputForAttr() permission denied: modify audio routing not allowed");
415 status = PERMISSION_DENIED;
416 }
417 break;
418 case AudioPolicyInterface::API_INPUT_INVALID:
419 default:
420 LOG_ALWAYS_FATAL("getInputForAttr() encountered an invalid input type %d",
421 (int)inputType);
422 }
423 }
424
425 if (status != NO_ERROR) {
426 if (status == PERMISSION_DENIED) {
Eric Laurent10b71232018-04-13 18:14:44 -0700427 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700428 mAudioPolicyManager->releaseInput(*portId);
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800429 }
430 return status;
431 }
Eric Laurentfee19762018-01-29 18:44:13 -0800432
Eric Laurentd7fe0862018-07-14 16:48:01 -0700433 sp<AudioRecordClient> client = new AudioRecordClient(*attr, *input, uid, pid, session,
434 *selectedDeviceId, opPackageName);
Eric Laurentfee19762018-01-29 18:44:13 -0800435 mAudioRecordClients.add(*portId, client);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700436 }
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800437
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700438 if (audioPolicyEffects != 0) {
439 // create audio pre processors according to input source
Eric Laurentcaf7f482014-11-25 17:50:47 -0800440 status_t status = audioPolicyEffects->addInputEffects(*input, attr->source, session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700441 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800442 ALOGW("Failed to add effects on input %d", *input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700443 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800444 }
Eric Laurentcaf7f482014-11-25 17:50:47 -0800445 return NO_ERROR;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800446}
447
Ray Essick84e84a52018-05-03 18:45:07 -0700448// this is replicated from frameworks/av/media/libaudioclient/AudioRecord.cpp
449// XXX -- figure out how to put it into a common, shared location
450
451static std::string audioSourceString(audio_source_t value) {
452 std::string source;
453 if (SourceTypeConverter::toString(value, source)) {
454 return source;
455 }
456 char rawbuffer[16]; // room for "%d"
457 snprintf(rawbuffer, sizeof(rawbuffer), "%d", value);
458 return rawbuffer;
459}
460
Eric Laurent99fcae42018-05-17 16:59:18 -0700461std::string AudioPolicyService::getDeviceTypeStrForPortId(audio_port_handle_t portId) {
462 std::string typeStr;
463 struct audio_port port = {};
464 port.id = portId;
465 status_t status = mAudioPolicyManager->getAudioPort(&port);
466 if (status == NO_ERROR && port.type == AUDIO_PORT_TYPE_DEVICE) {
467 deviceToString(port.ext.device.type, typeStr);
468 }
469 return typeStr;
470}
471
Eric Laurent4eb58f12018-12-07 16:41:02 -0800472status_t AudioPolicyService::startInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800473{
Eric Laurentdce54a12014-03-10 12:19:46 -0700474 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800475 return NO_INIT;
476 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800477 sp<AudioRecordClient> client;
478 {
479 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800480
Eric Laurent7dca8a82018-01-29 18:44:26 -0800481 ssize_t index = mAudioRecordClients.indexOfKey(portId);
482 if (index < 0) {
483 return INVALID_OPERATION;
484 }
485 client = mAudioRecordClients.valueAt(index);
Eric Laurentfee19762018-01-29 18:44:13 -0800486 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800487
488 // check calling permissions
Svet Ganov6e641372018-03-02 09:21:30 -0800489 if (!startRecording(client->opPackageName, client->pid, client->uid)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800490 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
491 __func__, client->uid, client->pid);
492 return PERMISSION_DENIED;
493 }
Eric Laurentfee19762018-01-29 18:44:13 -0800494
Eric Laurentdf628922018-12-06 21:45:51 +0000495 Mutex::Autolock _l(mLock);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800496
497 client->active = true;
498 client->startTimeNs = systemTime();
499 updateUidStates_l();
Eric Laurentfee19762018-01-29 18:44:13 -0800500
Eric Laurent10b71232018-04-13 18:14:44 -0700501 status_t status;
502 {
503 AutoCallerClear acc;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800504 status = mAudioPolicyManager->startInput(portId);
Ray Essick84e84a52018-05-03 18:45:07 -0700505
506 }
507
Ray Essickf6a57cd2018-05-22 16:20:54 -0700508 // including successes gets very verbose
509 if (status != NO_ERROR) {
Ray Essick84e84a52018-05-03 18:45:07 -0700510
511 static constexpr char kAudioPolicy[] = "audiopolicy";
512
Ray Essick84e84a52018-05-03 18:45:07 -0700513 static constexpr char kAudioPolicyStatus[] = "android.media.audiopolicy.status";
514 static constexpr char kAudioPolicyRqstSrc[] = "android.media.audiopolicy.rqst.src";
515 static constexpr char kAudioPolicyRqstPkg[] = "android.media.audiopolicy.rqst.pkg";
516 static constexpr char kAudioPolicyRqstSession[] = "android.media.audiopolicy.rqst.session";
Eric Laurent99fcae42018-05-17 16:59:18 -0700517 static constexpr char kAudioPolicyRqstDevice[] =
518 "android.media.audiopolicy.rqst.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700519 static constexpr char kAudioPolicyActiveSrc[] = "android.media.audiopolicy.active.src";
520 static constexpr char kAudioPolicyActivePkg[] = "android.media.audiopolicy.active.pkg";
Eric Laurent99fcae42018-05-17 16:59:18 -0700521 static constexpr char kAudioPolicyActiveSession[] =
522 "android.media.audiopolicy.active.session";
523 static constexpr char kAudioPolicyActiveDevice[] =
524 "android.media.audiopolicy.active.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700525
526 MediaAnalyticsItem *item = new MediaAnalyticsItem(kAudioPolicy);
527 if (item != NULL) {
528
Ray Essick84e84a52018-05-03 18:45:07 -0700529 item->setInt32(kAudioPolicyStatus, status);
530
Eric Laurent99fcae42018-05-17 16:59:18 -0700531 item->setCString(kAudioPolicyRqstSrc,
532 audioSourceString(client->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700533 item->setInt32(kAudioPolicyRqstSession, client->session);
Ray Essick51866952018-05-30 11:22:27 -0700534 if (client->opPackageName.size() != 0) {
535 item->setCString(kAudioPolicyRqstPkg,
536 std::string(String8(client->opPackageName).string()).c_str());
537 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700538 item->setCString(kAudioPolicyRqstPkg, std::to_string(client->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700539 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700540 item->setCString(
541 kAudioPolicyRqstDevice, getDeviceTypeStrForPortId(client->deviceId).c_str());
542
Eric Laurent4eb58f12018-12-07 16:41:02 -0800543 int count = mAudioRecordClients.size();
544 for (int i = 0; i < count ; i++) {
545 if (portId == mAudioRecordClients.keyAt(i)) {
546 continue;
547 }
548 sp<AudioRecordClient> other = mAudioRecordClients.valueAt(i);
549 if (other->active) {
550 // keeps the last of the clients marked active
551 item->setCString(kAudioPolicyActiveSrc,
552 audioSourceString(other->attributes.source).c_str());
553 item->setInt32(kAudioPolicyActiveSession, other->session);
554 if (other->opPackageName.size() != 0) {
555 item->setCString(kAudioPolicyActivePkg,
556 std::string(String8(other->opPackageName).string()).c_str());
557 } else {
558 item->setCString(kAudioPolicyRqstPkg,
559 std::to_string(other->uid).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700560 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800561 item->setCString(kAudioPolicyActiveDevice,
562 getDeviceTypeStrForPortId(other->deviceId).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700563 }
564 }
565 item->selfrecord();
566 delete item;
567 item = NULL;
568 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800569 client->active = false;
570 client->startTimeNs = 0;
571 updateUidStates_l();
Svet Ganov6e641372018-03-02 09:21:30 -0800572 finishRecording(client->opPackageName, client->uid);
Eric Laurentfb66dd92016-01-28 18:32:03 -0800573 }
574
575 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800576}
577
Eric Laurentfee19762018-01-29 18:44:13 -0800578status_t AudioPolicyService::stopInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800579{
Eric Laurentdce54a12014-03-10 12:19:46 -0700580 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800581 return NO_INIT;
582 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800583
Eric Laurent2d388ec2014-03-07 13:25:54 -0800584 Mutex::Autolock _l(mLock);
585
Eric Laurentfee19762018-01-29 18:44:13 -0800586 ssize_t index = mAudioRecordClients.indexOfKey(portId);
587 if (index < 0) {
588 return INVALID_OPERATION;
589 }
590 sp<AudioRecordClient> client = mAudioRecordClients.valueAt(index);
591
Ray Essick84e84a52018-05-03 18:45:07 -0700592 client->active = false;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800593 client->startTimeNs = 0;
594
595 updateUidStates_l();
Ray Essick84e84a52018-05-03 18:45:07 -0700596
Svet Ganov6e641372018-03-02 09:21:30 -0800597 // finish the recording app op
598 finishRecording(client->opPackageName, client->uid);
Eric Laurent10b71232018-04-13 18:14:44 -0700599 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700600 return mAudioPolicyManager->stopInput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800601}
602
Eric Laurentfee19762018-01-29 18:44:13 -0800603void AudioPolicyService::releaseInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800604{
Eric Laurentdce54a12014-03-10 12:19:46 -0700605 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800606 return;
607 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700608 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800609 sp<AudioRecordClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700610 {
611 Mutex::Autolock _l(mLock);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700612 audioPolicyEffects = mAudioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800613 ssize_t index = mAudioRecordClients.indexOfKey(portId);
614 if (index < 0) {
615 return;
616 }
617 client = mAudioRecordClients.valueAt(index);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800618
619 if (client->active) {
620 ALOGW("%s releasing active client portId %d", __FUNCTION__, portId);
621 client->active = false;
622 client->startTimeNs = 0;
623 updateUidStates_l();
624 }
625
Eric Laurentfee19762018-01-29 18:44:13 -0800626 mAudioRecordClients.removeItem(portId);
627 }
628 if (client == 0) {
629 return;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700630 }
631 if (audioPolicyEffects != 0) {
632 // release audio processors from the input
Eric Laurentd7fe0862018-07-14 16:48:01 -0700633 status_t status = audioPolicyEffects->releaseInputEffects(client->io, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700634 if(status != NO_ERROR) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700635 ALOGW("Failed to release effects on input %d", client->io);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700636 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800637 }
Eric Laurentf10c7092016-12-06 17:09:56 -0800638 {
639 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700640 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700641 mAudioPolicyManager->releaseInput(portId);
Eric Laurentf10c7092016-12-06 17:09:56 -0800642 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800643}
644
645status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
646 int indexMin,
647 int indexMax)
648{
Eric Laurentdce54a12014-03-10 12:19:46 -0700649 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800650 return NO_INIT;
651 }
652 if (!settingsAllowed()) {
653 return PERMISSION_DENIED;
654 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800655 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800656 return BAD_VALUE;
657 }
658 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700659 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700660 mAudioPolicyManager->initStreamVolume(stream, indexMin, indexMax);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800661 return NO_ERROR;
662}
663
664status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
665 int index,
666 audio_devices_t device)
667{
Eric Laurentdce54a12014-03-10 12:19:46 -0700668 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800669 return NO_INIT;
670 }
671 if (!settingsAllowed()) {
672 return PERMISSION_DENIED;
673 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800674 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800675 return BAD_VALUE;
676 }
677 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700678 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700679 return mAudioPolicyManager->setStreamVolumeIndex(stream,
680 index,
681 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800682}
683
684status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
685 int *index,
686 audio_devices_t device)
687{
Eric Laurentdce54a12014-03-10 12:19:46 -0700688 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800689 return NO_INIT;
690 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800691 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800692 return BAD_VALUE;
693 }
694 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700695 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700696 return mAudioPolicyManager->getStreamVolumeIndex(stream,
697 index,
698 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800699}
700
701uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
702{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800703 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700704 return 0;
Eric Laurentdea15412014-10-28 15:46:45 -0700705 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700706 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800707 return 0;
708 }
Eric Laurent10b71232018-04-13 18:14:44 -0700709 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700710 return mAudioPolicyManager->getStrategyForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800711}
712
713//audio policy: use audio_device_t appropriately
714
715audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
716{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800717 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700718 return AUDIO_DEVICE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700719 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700720 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700721 return AUDIO_DEVICE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800722 }
Haynes Mathew Georgedfb9f3b2015-10-26 18:22:13 -0700723 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700724 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700725 return mAudioPolicyManager->getDevicesForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800726}
727
728audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
729{
730 // FIXME change return type to status_t, and return NO_INIT here
Eric Laurentdce54a12014-03-10 12:19:46 -0700731 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800732 return 0;
733 }
734 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700735 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700736 return mAudioPolicyManager->getOutputForEffect(desc);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800737}
738
739status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
740 audio_io_handle_t io,
741 uint32_t strategy,
Glenn Kastend848eb42016-03-08 13:42:11 -0800742 audio_session_t session,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800743 int id)
744{
Eric Laurentdce54a12014-03-10 12:19:46 -0700745 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800746 return NO_INIT;
747 }
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700748 Mutex::Autolock _l(mEffectsLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700749 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700750 return mAudioPolicyManager->registerEffect(desc, io, strategy, session, id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800751}
752
753status_t AudioPolicyService::unregisterEffect(int id)
754{
Eric Laurentdce54a12014-03-10 12:19:46 -0700755 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800756 return NO_INIT;
757 }
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700758 Mutex::Autolock _l(mEffectsLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700759 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700760 return mAudioPolicyManager->unregisterEffect(id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800761}
762
763status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
764{
Eric Laurentdce54a12014-03-10 12:19:46 -0700765 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800766 return NO_INIT;
767 }
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700768 Mutex::Autolock _l(mEffectsLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700769 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700770 return mAudioPolicyManager->setEffectEnabled(id, enabled);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800771}
772
773bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
774{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800775 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700776 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700777 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700778 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700779 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800780 }
781 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700782 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700783 return mAudioPolicyManager->isStreamActive(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800784}
785
786bool AudioPolicyService::isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs) const
787{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800788 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700789 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700790 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700791 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700792 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800793 }
794 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700795 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700796 return mAudioPolicyManager->isStreamActiveRemotely(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800797}
798
799bool AudioPolicyService::isSourceActive(audio_source_t source) const
800{
Eric Laurentdce54a12014-03-10 12:19:46 -0700801 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800802 return false;
803 }
804 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700805 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700806 return mAudioPolicyManager->isSourceActive(source);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800807}
808
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700809status_t AudioPolicyService::getAudioPolicyEffects(sp<AudioPolicyEffects>& audioPolicyEffects)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800810{
Eric Laurentdce54a12014-03-10 12:19:46 -0700811 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800812 return NO_INIT;
813 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700814 {
815 Mutex::Autolock _l(mLock);
816 audioPolicyEffects = mAudioPolicyEffects;
817 }
818 if (audioPolicyEffects == 0) {
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700819 return NO_INIT;
820 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700821
822 return OK;
823}
824
825status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
826 effect_descriptor_t *descriptors,
827 uint32_t *count)
828{
829 sp<AudioPolicyEffects>audioPolicyEffects;
830 status_t status = getAudioPolicyEffects(audioPolicyEffects);
831 if (status != OK) {
832 *count = 0;
833 return status;
834 }
Eric Laurentfb66dd92016-01-28 18:32:03 -0800835 return audioPolicyEffects->queryDefaultInputEffects(
836 (audio_session_t)audioSession, descriptors, count);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800837}
838
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700839status_t AudioPolicyService::addSourceDefaultEffect(const effect_uuid_t *type,
840 const String16& opPackageName,
841 const effect_uuid_t *uuid,
842 int32_t priority,
843 audio_source_t source,
844 audio_unique_id_t* id)
845{
846 sp<AudioPolicyEffects>audioPolicyEffects;
847 status_t status = getAudioPolicyEffects(audioPolicyEffects);
848 if (status != OK) {
849 return status;
850 }
851 if (!modifyDefaultAudioEffectsAllowed()) {
852 return PERMISSION_DENIED;
853 }
854 return audioPolicyEffects->addSourceDefaultEffect(
855 type, opPackageName, uuid, priority, source, id);
856}
857
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700858status_t AudioPolicyService::addStreamDefaultEffect(const effect_uuid_t *type,
859 const String16& opPackageName,
860 const effect_uuid_t *uuid,
861 int32_t priority,
862 audio_usage_t usage,
863 audio_unique_id_t* id)
864{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700865 sp<AudioPolicyEffects>audioPolicyEffects;
866 status_t status = getAudioPolicyEffects(audioPolicyEffects);
867 if (status != OK) {
868 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700869 }
870 if (!modifyDefaultAudioEffectsAllowed()) {
871 return PERMISSION_DENIED;
872 }
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700873 return audioPolicyEffects->addStreamDefaultEffect(
874 type, opPackageName, uuid, priority, usage, id);
875}
876
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700877status_t AudioPolicyService::removeSourceDefaultEffect(audio_unique_id_t id)
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700878{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700879 sp<AudioPolicyEffects>audioPolicyEffects;
880 status_t status = getAudioPolicyEffects(audioPolicyEffects);
881 if (status != OK) {
882 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700883 }
884 if (!modifyDefaultAudioEffectsAllowed()) {
885 return PERMISSION_DENIED;
886 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700887 return audioPolicyEffects->removeSourceDefaultEffect(id);
888}
889
890status_t AudioPolicyService::removeStreamDefaultEffect(audio_unique_id_t id)
891{
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700892 sp<AudioPolicyEffects>audioPolicyEffects;
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700893 status_t status = getAudioPolicyEffects(audioPolicyEffects);
894 if (status != OK) {
895 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700896 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700897 if (!modifyDefaultAudioEffectsAllowed()) {
898 return PERMISSION_DENIED;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700899 }
900 return audioPolicyEffects->removeStreamDefaultEffect(id);
901}
902
Eric Laurent2d388ec2014-03-07 13:25:54 -0800903bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
904{
Eric Laurentdce54a12014-03-10 12:19:46 -0700905 if (mAudioPolicyManager == NULL) {
906 ALOGV("mAudioPolicyManager == NULL");
Eric Laurent2d388ec2014-03-07 13:25:54 -0800907 return false;
908 }
Andy Hung2ddee192015-12-18 17:34:44 -0800909 Mutex::Autolock _l(mLock);
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700910 Mutex::Autolock _le(mEffectsLock); // isOffloadSupported queries for
911 // non-offloadable effects
Eric Laurent10b71232018-04-13 18:14:44 -0700912 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700913 return mAudioPolicyManager->isOffloadSupported(info);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800914}
915
Michael Chana94fbb22018-04-24 14:31:19 +1000916bool AudioPolicyService::isDirectOutputSupported(const audio_config_base_t& config,
917 const audio_attributes_t& attributes) {
918 if (mAudioPolicyManager == NULL) {
919 ALOGV("mAudioPolicyManager == NULL");
920 return false;
921 }
922 Mutex::Autolock _l(mLock);
923 return mAudioPolicyManager->isDirectOutputSupported(config, attributes);
924}
925
926
Eric Laurent6a94d692014-05-20 11:18:06 -0700927status_t AudioPolicyService::listAudioPorts(audio_port_role_t role,
928 audio_port_type_t type,
Eric Laurent203b1a12014-04-01 10:34:16 -0700929 unsigned int *num_ports,
Eric Laurent6a94d692014-05-20 11:18:06 -0700930 struct audio_port *ports,
931 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -0700932{
Eric Laurent6a94d692014-05-20 11:18:06 -0700933 Mutex::Autolock _l(mLock);
934 if (mAudioPolicyManager == NULL) {
935 return NO_INIT;
936 }
Eric Laurent10b71232018-04-13 18:14:44 -0700937 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700938 return mAudioPolicyManager->listAudioPorts(role, type, num_ports, ports, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -0700939}
940
Eric Laurent6a94d692014-05-20 11:18:06 -0700941status_t AudioPolicyService::getAudioPort(struct audio_port *port)
Eric Laurent203b1a12014-04-01 10:34:16 -0700942{
Eric Laurent6a94d692014-05-20 11:18:06 -0700943 Mutex::Autolock _l(mLock);
944 if (mAudioPolicyManager == NULL) {
945 return NO_INIT;
946 }
Eric Laurent10b71232018-04-13 18:14:44 -0700947 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700948 return mAudioPolicyManager->getAudioPort(port);
Eric Laurent203b1a12014-04-01 10:34:16 -0700949}
950
Eric Laurent6a94d692014-05-20 11:18:06 -0700951status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch,
952 audio_patch_handle_t *handle)
Eric Laurent203b1a12014-04-01 10:34:16 -0700953{
Eric Laurent6a94d692014-05-20 11:18:06 -0700954 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -0700955 if(!modifyAudioRoutingAllowed()) {
956 return PERMISSION_DENIED;
957 }
Eric Laurent6a94d692014-05-20 11:18:06 -0700958 if (mAudioPolicyManager == NULL) {
959 return NO_INIT;
960 }
Eric Laurent10b71232018-04-13 18:14:44 -0700961 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700962 return mAudioPolicyManager->createAudioPatch(patch, handle,
963 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -0700964}
965
Eric Laurent6a94d692014-05-20 11:18:06 -0700966status_t AudioPolicyService::releaseAudioPatch(audio_patch_handle_t handle)
Eric Laurent203b1a12014-04-01 10:34:16 -0700967{
Eric Laurent6a94d692014-05-20 11:18:06 -0700968 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -0700969 if(!modifyAudioRoutingAllowed()) {
970 return PERMISSION_DENIED;
971 }
Eric Laurent6a94d692014-05-20 11:18:06 -0700972 if (mAudioPolicyManager == NULL) {
973 return NO_INIT;
974 }
Eric Laurent10b71232018-04-13 18:14:44 -0700975 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700976 return mAudioPolicyManager->releaseAudioPatch(handle,
977 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -0700978}
979
980status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
Eric Laurent6a94d692014-05-20 11:18:06 -0700981 struct audio_patch *patches,
982 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -0700983{
Eric Laurent6a94d692014-05-20 11:18:06 -0700984 Mutex::Autolock _l(mLock);
985 if (mAudioPolicyManager == NULL) {
986 return NO_INIT;
987 }
Eric Laurent10b71232018-04-13 18:14:44 -0700988 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700989 return mAudioPolicyManager->listAudioPatches(num_patches, patches, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -0700990}
991
Eric Laurent6a94d692014-05-20 11:18:06 -0700992status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config)
Eric Laurent203b1a12014-04-01 10:34:16 -0700993{
Eric Laurent6a94d692014-05-20 11:18:06 -0700994 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -0700995 if(!modifyAudioRoutingAllowed()) {
996 return PERMISSION_DENIED;
997 }
Eric Laurent6a94d692014-05-20 11:18:06 -0700998 if (mAudioPolicyManager == NULL) {
999 return NO_INIT;
1000 }
Eric Laurent10b71232018-04-13 18:14:44 -07001001 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001002 return mAudioPolicyManager->setAudioPortConfig(config);
Eric Laurent203b1a12014-04-01 10:34:16 -07001003}
Eric Laurent2d388ec2014-03-07 13:25:54 -08001004
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001005status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session,
1006 audio_io_handle_t *ioHandle,
1007 audio_devices_t *device)
1008{
Andy Hungf759b8c2017-08-15 12:48:54 -07001009 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001010 if (mAudioPolicyManager == NULL) {
1011 return NO_INIT;
1012 }
Eric Laurent10b71232018-04-13 18:14:44 -07001013 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001014 return mAudioPolicyManager->acquireSoundTriggerSession(session, ioHandle, device);
1015}
1016
1017status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session)
1018{
Andy Hungf759b8c2017-08-15 12:48:54 -07001019 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001020 if (mAudioPolicyManager == NULL) {
1021 return NO_INIT;
1022 }
Eric Laurent10b71232018-04-13 18:14:44 -07001023 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001024 return mAudioPolicyManager->releaseSoundTriggerSession(session);
1025}
1026
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -07001027status_t AudioPolicyService::registerPolicyMixes(const Vector<AudioMix>& mixes, bool registration)
Eric Laurentbaac1832014-12-01 17:52:59 -08001028{
1029 Mutex::Autolock _l(mLock);
1030 if(!modifyAudioRoutingAllowed()) {
1031 return PERMISSION_DENIED;
1032 }
1033 if (mAudioPolicyManager == NULL) {
1034 return NO_INIT;
1035 }
Eric Laurent10b71232018-04-13 18:14:44 -07001036 AutoCallerClear acc;
Eric Laurentbaac1832014-12-01 17:52:59 -08001037 if (registration) {
1038 return mAudioPolicyManager->registerPolicyMixes(mixes);
1039 } else {
1040 return mAudioPolicyManager->unregisterPolicyMixes(mixes);
1041 }
1042}
1043
Jean-Michel Trivibda70da2018-12-19 07:30:15 -08001044status_t AudioPolicyService::setUidDeviceAffinities(uid_t uid,
1045 const Vector<AudioDeviceTypeAddr>& devices) {
1046 Mutex::Autolock _l(mLock);
1047 if(!modifyAudioRoutingAllowed()) {
1048 return PERMISSION_DENIED;
1049 }
1050 if (mAudioPolicyManager == NULL) {
1051 return NO_INIT;
1052 }
1053 AutoCallerClear acc;
1054 return mAudioPolicyManager->setUidDeviceAffinities(uid, devices);
1055}
1056
1057status_t AudioPolicyService::removeUidDeviceAffinities(uid_t uid) {
1058 Mutex::Autolock _l(mLock);
1059 if(!modifyAudioRoutingAllowed()) {
1060 return PERMISSION_DENIED;
1061 }
1062 if (mAudioPolicyManager == NULL) {
1063 return NO_INIT;
1064 }
1065 AutoCallerClear acc;
1066 return mAudioPolicyManager->removeUidDeviceAffinities(uid);
1067}
1068
Eric Laurent554a2772015-04-10 11:29:24 -07001069status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001070 const audio_attributes_t *attributes,
1071 audio_port_handle_t *portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001072{
1073 Mutex::Autolock _l(mLock);
1074 if (mAudioPolicyManager == NULL) {
1075 return NO_INIT;
1076 }
Eric Laurent10b71232018-04-13 18:14:44 -07001077 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001078 return mAudioPolicyManager->startAudioSource(source, attributes, portId,
Eric Laurentd60560a2015-04-10 11:31:20 -07001079 IPCThreadState::self()->getCallingUid());
Eric Laurent554a2772015-04-10 11:29:24 -07001080}
1081
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001082status_t AudioPolicyService::stopAudioSource(audio_port_handle_t portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001083{
1084 Mutex::Autolock _l(mLock);
1085 if (mAudioPolicyManager == NULL) {
1086 return NO_INIT;
1087 }
Eric Laurent10b71232018-04-13 18:14:44 -07001088 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001089 return mAudioPolicyManager->stopAudioSource(portId);
Eric Laurent554a2772015-04-10 11:29:24 -07001090}
1091
Andy Hung2ddee192015-12-18 17:34:44 -08001092status_t AudioPolicyService::setMasterMono(bool mono)
1093{
1094 if (mAudioPolicyManager == NULL) {
1095 return NO_INIT;
1096 }
1097 if (!settingsAllowed()) {
1098 return PERMISSION_DENIED;
1099 }
1100 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001101 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001102 return mAudioPolicyManager->setMasterMono(mono);
1103}
1104
1105status_t AudioPolicyService::getMasterMono(bool *mono)
1106{
1107 if (mAudioPolicyManager == NULL) {
1108 return NO_INIT;
1109 }
1110 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001111 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001112 return mAudioPolicyManager->getMasterMono(mono);
1113}
1114
Eric Laurentac9cef52017-06-09 15:46:26 -07001115
1116float AudioPolicyService::getStreamVolumeDB(
1117 audio_stream_type_t stream, int index, audio_devices_t device)
1118{
1119 if (mAudioPolicyManager == NULL) {
1120 return NAN;
1121 }
1122 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001123 AutoCallerClear acc;
Eric Laurentac9cef52017-06-09 15:46:26 -07001124 return mAudioPolicyManager->getStreamVolumeDB(stream, index, device);
1125}
1126
jiabin81772902018-04-02 17:52:27 -07001127status_t AudioPolicyService::getSurroundFormats(unsigned int *numSurroundFormats,
1128 audio_format_t *surroundFormats,
1129 bool *surroundFormatsEnabled,
1130 bool reported)
1131{
1132 if (mAudioPolicyManager == NULL) {
1133 return NO_INIT;
1134 }
1135 Mutex::Autolock _l(mLock);
1136 AutoCallerClear acc;
1137 return mAudioPolicyManager->getSurroundFormats(numSurroundFormats, surroundFormats,
1138 surroundFormatsEnabled, reported);
1139}
1140
1141status_t AudioPolicyService::setSurroundFormatEnabled(audio_format_t audioFormat, bool enabled)
1142{
1143 if (mAudioPolicyManager == NULL) {
1144 return NO_INIT;
1145 }
1146 Mutex::Autolock _l(mLock);
1147 AutoCallerClear acc;
1148 return mAudioPolicyManager->setSurroundFormatEnabled(audioFormat, enabled);
1149}
Eric Laurentac9cef52017-06-09 15:46:26 -07001150
Eric Laurentb78763e2018-10-17 10:08:02 -07001151status_t AudioPolicyService::setAssistantUid(uid_t uid)
1152{
1153 Mutex::Autolock _l(mLock);
1154 mUidPolicy->setAssistantUid(uid);
1155 return NO_ERROR;
1156}
1157
1158status_t AudioPolicyService::setA11yServicesUids(const std::vector<uid_t>& uids)
1159{
1160 Mutex::Autolock _l(mLock);
1161 mUidPolicy->setA11yUids(uids);
1162 return NO_ERROR;
1163}
1164
jiabin6012f912018-11-02 17:06:30 -07001165bool AudioPolicyService::isHapticPlaybackSupported()
1166{
1167 if (mAudioPolicyManager == NULL) {
1168 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1169 return false;
1170 }
1171 Mutex::Autolock _l(mLock);
1172 AutoCallerClear acc;
1173 return mAudioPolicyManager->isHapticPlaybackSupported();
1174}
1175
Mikhail Naganov1b2a7942017-12-08 10:18:09 -08001176} // namespace android