blob: 68eade152cef6b49b19a3eedba30665d4e173e25 [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/MediaAnalyticsItem.h>
23#include <mediautils/ServiceUtilities.h>
Kevin Rocardbe201852019-02-20 22:33:28 -080024#include <media/AudioPolicy.h>
Eric Laurentd7fe0862018-07-14 16:48:01 -070025#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,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080035 const char *device_name,
36 audio_format_t encodedFormat)
Eric Laurent2d388ec2014-03-07 13:25:54 -080037{
Eric Laurentdce54a12014-03-10 12:19:46 -070038 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080039 return NO_INIT;
40 }
41 if (!settingsAllowed()) {
42 return PERMISSION_DENIED;
43 }
Eric Laurent2d388ec2014-03-07 13:25:54 -080044 if (state != AUDIO_POLICY_DEVICE_STATE_AVAILABLE &&
45 state != AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE) {
46 return BAD_VALUE;
47 }
48
49 ALOGV("setDeviceConnectionState()");
50 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -070051 AutoCallerClear acc;
Paul McLeane743a472015-01-28 11:07:31 -080052 return mAudioPolicyManager->setDeviceConnectionState(device, state,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080053 device_address, device_name, encodedFormat);
Eric Laurent2d388ec2014-03-07 13:25:54 -080054}
55
56audio_policy_dev_state_t AudioPolicyService::getDeviceConnectionState(
57 audio_devices_t device,
58 const char *device_address)
59{
Eric Laurentdce54a12014-03-10 12:19:46 -070060 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080061 return AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE;
62 }
Eric Laurent10b71232018-04-13 18:14:44 -070063 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -070064 return mAudioPolicyManager->getDeviceConnectionState(device,
Eric Laurent2d388ec2014-03-07 13:25:54 -080065 device_address);
66}
67
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080068status_t AudioPolicyService::handleDeviceConfigChange(audio_devices_t device,
69 const char *device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080070 const char *device_name,
71 audio_format_t encodedFormat)
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080072{
73 if (mAudioPolicyManager == NULL) {
74 return NO_INIT;
75 }
76 if (!settingsAllowed()) {
77 return PERMISSION_DENIED;
78 }
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080079
80 ALOGV("handleDeviceConfigChange()");
81 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -070082 AutoCallerClear acc;
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080083 return mAudioPolicyManager->handleDeviceConfigChange(device, device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080084 device_name, encodedFormat);
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080085}
86
Eric Laurent2d388ec2014-03-07 13:25:54 -080087status_t AudioPolicyService::setPhoneState(audio_mode_t state)
88{
Eric Laurentdce54a12014-03-10 12:19:46 -070089 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080090 return NO_INIT;
91 }
92 if (!settingsAllowed()) {
93 return PERMISSION_DENIED;
94 }
95 if (uint32_t(state) >= AUDIO_MODE_CNT) {
96 return BAD_VALUE;
97 }
98
99 ALOGV("setPhoneState()");
100
Eric Laurentbeb07fe2015-09-16 15:49:30 -0700101 // acquire lock before calling setMode() so that setMode() + setPhoneState() are an atomic
102 // operation from policy manager standpoint (no other operation (e.g track start or stop)
103 // can be interleaved).
104 Mutex::Autolock _l(mLock);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800105 // TODO: check if it is more appropriate to do it in platform specific policy manager
106 AudioSystem::setMode(state);
107
Eric Laurent10b71232018-04-13 18:14:44 -0700108 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700109 mAudioPolicyManager->setPhoneState(state);
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700110 mPhoneState = state;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800111 return NO_ERROR;
112}
113
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700114audio_mode_t AudioPolicyService::getPhoneState()
115{
116 Mutex::Autolock _l(mLock);
117 return mPhoneState;
118}
119
Eric Laurent2d388ec2014-03-07 13:25:54 -0800120status_t AudioPolicyService::setForceUse(audio_policy_force_use_t usage,
121 audio_policy_forced_cfg_t config)
122{
Eric Laurentdce54a12014-03-10 12:19:46 -0700123 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800124 return NO_INIT;
125 }
Eric Laurente17378d2018-05-09 14:43:01 -0700126
127 if (!modifyAudioRoutingAllowed()) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800128 return PERMISSION_DENIED;
129 }
Eric Laurente17378d2018-05-09 14:43:01 -0700130
Eric Laurent2d388ec2014-03-07 13:25:54 -0800131 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
132 return BAD_VALUE;
133 }
134 if (config < 0 || config >= AUDIO_POLICY_FORCE_CFG_CNT) {
135 return BAD_VALUE;
136 }
137 ALOGV("setForceUse()");
138 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700139 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700140 mAudioPolicyManager->setForceUse(usage, config);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800141 return NO_ERROR;
142}
143
144audio_policy_forced_cfg_t AudioPolicyService::getForceUse(audio_policy_force_use_t usage)
145{
Eric Laurentdce54a12014-03-10 12:19:46 -0700146 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800147 return AUDIO_POLICY_FORCE_NONE;
148 }
149 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
150 return AUDIO_POLICY_FORCE_NONE;
151 }
Eric Laurent10b71232018-04-13 18:14:44 -0700152 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700153 return mAudioPolicyManager->getForceUse(usage);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800154}
155
Eric Laurentf4e63452017-11-06 19:31:46 +0000156audio_io_handle_t AudioPolicyService::getOutput(audio_stream_type_t stream)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800157{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800158 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700159 return AUDIO_IO_HANDLE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700160 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700161 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700162 return AUDIO_IO_HANDLE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800163 }
164 ALOGV("getOutput()");
165 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700166 AutoCallerClear acc;
Eric Laurentf4e63452017-11-06 19:31:46 +0000167 return mAudioPolicyManager->getOutput(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800168}
169
Eric Laurente83b55d2014-11-14 10:06:21 -0800170status_t AudioPolicyService::getOutputForAttr(const audio_attributes_t *attr,
171 audio_io_handle_t *output,
172 audio_session_t session,
173 audio_stream_type_t *stream,
Nadav Bar766fb022018-01-07 12:18:03 +0200174 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700175 uid_t uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800176 const audio_config_t *config,
Eric Laurente83b55d2014-11-14 10:06:21 -0800177 audio_output_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700178 audio_port_handle_t *selectedDeviceId,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800179 audio_port_handle_t *portId,
180 std::vector<audio_io_handle_t> *secondaryOutputs)
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700181{
182 if (mAudioPolicyManager == NULL) {
Eric Laurente83b55d2014-11-14 10:06:21 -0800183 return NO_INIT;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700184 }
Eric Laurentf4e63452017-11-06 19:31:46 +0000185 ALOGV("getOutputForAttr()");
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700186 Mutex::Autolock _l(mLock);
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700187
Marco Nelissendcb346b2015-09-09 10:47:29 -0700188 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700189 if (!isAudioServerOrMediaServerUid(callingUid) || uid == (uid_t)-1) {
Marco Nelissendcb346b2015-09-09 10:47:29 -0700190 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
191 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
192 uid = callingUid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700193 }
Nadav Bar766fb022018-01-07 12:18:03 +0200194 audio_output_flags_t originalFlags = flags;
Eric Laurent10b71232018-04-13 18:14:44 -0700195 AutoCallerClear acc;
Nadav Bar766fb022018-01-07 12:18:03 +0200196 status_t result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800197 config,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800198 &flags, selectedDeviceId, portId,
199 secondaryOutputs);
Nadav Bar766fb022018-01-07 12:18:03 +0200200
201 // FIXME: Introduce a way to check for the the telephony device before opening the output
202 if ((result == NO_ERROR) &&
203 (flags & AUDIO_OUTPUT_FLAG_INCALL_MUSIC) &&
204 !modifyPhoneStateAllowed(pid, uid)) {
205 // If the app tries to play music through the telephony device and doesn't have permission
206 // the fallback to the default output device.
Eric Laurent8fc147b2018-07-22 19:13:55 -0700207 mAudioPolicyManager->releaseOutput(*portId);
Nadav Bar766fb022018-01-07 12:18:03 +0200208 flags = originalFlags;
209 *selectedDeviceId = AUDIO_PORT_HANDLE_NONE;
210 *portId = AUDIO_PORT_HANDLE_NONE;
Kevin Rocard153f92d2018-12-18 18:33:28 -0800211 secondaryOutputs->clear();
212 result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid, config,
213 &flags, selectedDeviceId, portId,
214 secondaryOutputs);
Nadav Bar766fb022018-01-07 12:18:03 +0200215 }
Eric Laurentd7fe0862018-07-14 16:48:01 -0700216
217 if (result == NO_ERROR) {
218 sp <AudioPlaybackClient> client =
219 new AudioPlaybackClient(*attr, *output, uid, pid, session, *selectedDeviceId, *stream);
220 mAudioPlaybackClients.add(*portId, client);
221 }
Nadav Bar766fb022018-01-07 12:18:03 +0200222 return result;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700223}
224
Eric Laurentd7fe0862018-07-14 16:48:01 -0700225status_t AudioPolicyService::startOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800226{
Eric Laurentdce54a12014-03-10 12:19:46 -0700227 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800228 return NO_INIT;
229 }
230 ALOGV("startOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700231 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700232 sp<AudioPolicyEffects>audioPolicyEffects;
233 {
234 Mutex::Autolock _l(mLock);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700235 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
236 if (index < 0) {
237 ALOGE("%s AudioTrack client not found for portId %d", __FUNCTION__, portId);
238 return INVALID_OPERATION;
239 }
240 client = mAudioPlaybackClients.valueAt(index);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700241 audioPolicyEffects = mAudioPolicyEffects;
bryant_liuba2b4392014-06-11 16:49:30 +0800242 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700243 if (audioPolicyEffects != 0) {
244 // create audio processors according to stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700245 status_t status = audioPolicyEffects->addOutputSessionEffects(
246 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700247 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700248 ALOGW("Failed to add effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700249 }
250 }
251 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700252 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700253 status_t status = mAudioPolicyManager->startOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700254 if (status == NO_ERROR) {
255 client->active = true;
256 }
257 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800258}
259
Eric Laurentd7fe0862018-07-14 16:48:01 -0700260status_t AudioPolicyService::stopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800261{
Eric Laurentdce54a12014-03-10 12:19:46 -0700262 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800263 return NO_INIT;
264 }
265 ALOGV("stopOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700266 mOutputCommandThread->stopOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800267 return NO_ERROR;
268}
269
Eric Laurentd7fe0862018-07-14 16:48:01 -0700270status_t AudioPolicyService::doStopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800271{
Eric Laurentd7fe0862018-07-14 16:48:01 -0700272 ALOGV("doStopOutput");
273 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700274 sp<AudioPolicyEffects>audioPolicyEffects;
275 {
276 Mutex::Autolock _l(mLock);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700277
278 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
279 if (index < 0) {
280 ALOGE("%s AudioTrack client not found for portId %d", __FUNCTION__, portId);
281 return INVALID_OPERATION;
282 }
283 client = mAudioPlaybackClients.valueAt(index);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700284 audioPolicyEffects = mAudioPolicyEffects;
bryant_liuba2b4392014-06-11 16:49:30 +0800285 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700286 if (audioPolicyEffects != 0) {
287 // release audio processors from the stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700288 status_t status = audioPolicyEffects->releaseOutputSessionEffects(
289 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700290 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700291 ALOGW("Failed to release effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700292 }
293 }
294 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700295 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700296 status_t status = mAudioPolicyManager->stopOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700297 if (status == NO_ERROR) {
298 client->active = false;
299 }
300 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800301}
302
Eric Laurentd7fe0862018-07-14 16:48:01 -0700303void AudioPolicyService::releaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800304{
Eric Laurentdce54a12014-03-10 12:19:46 -0700305 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800306 return;
307 }
308 ALOGV("releaseOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700309 mOutputCommandThread->releaseOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800310}
311
Eric Laurentd7fe0862018-07-14 16:48:01 -0700312void AudioPolicyService::doReleaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800313{
314 ALOGV("doReleaseOutput from tid %d", gettid());
315 Mutex::Autolock _l(mLock);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700316 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
317 if (index < 0) {
318 ALOGE("%s AudioTrack client not found for portId %d", __FUNCTION__, portId);
319 return;
320 }
321 sp<AudioPlaybackClient> client = mAudioPlaybackClients.valueAt(index);
322 mAudioRecordClients.removeItem(portId);
323
Eric Laurent10b71232018-04-13 18:14:44 -0700324 // called from internal thread: no need to clear caller identity
Eric Laurent8fc147b2018-07-22 19:13:55 -0700325 mAudioPolicyManager->releaseOutput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800326}
327
Eric Laurentcaf7f482014-11-25 17:50:47 -0800328status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
329 audio_io_handle_t *input,
330 audio_session_t session,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700331 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700332 uid_t uid,
Eric Laurentfee19762018-01-29 18:44:13 -0800333 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800334 const audio_config_base_t *config,
Paul McLean466dc8e2015-04-17 13:15:36 -0600335 audio_input_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700336 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800337 audio_port_handle_t *portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800338{
Eric Laurentdce54a12014-03-10 12:19:46 -0700339 if (mAudioPolicyManager == NULL) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800340 return NO_INIT;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800341 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800342
Eric Laurent2d388ec2014-03-07 13:25:54 -0800343 // already checked by client, but double-check in case the client wrapper is bypassed
Eric Laurentae4b6ec2019-01-15 18:34:38 -0800344 if ((attr->source < AUDIO_SOURCE_DEFAULT)
345 || (attr->source >= AUDIO_SOURCE_CNT
346 && attr->source != AUDIO_SOURCE_HOTWORD
347 && attr->source != AUDIO_SOURCE_FM_TUNER
348 && attr->source != AUDIO_SOURCE_ECHO_REFERENCE)) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800349 return BAD_VALUE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800350 }
351
Eric Laurentb2379ba2016-05-23 17:42:12 -0700352 bool updatePid = (pid == -1);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700353 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700354 if (!isAudioServerOrMediaServerUid(callingUid)) {
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700355 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Marco Nelissendcb346b2015-09-09 10:47:29 -0700356 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
357 uid = callingUid;
Eric Laurentb2379ba2016-05-23 17:42:12 -0700358 updatePid = true;
359 }
360
361 if (updatePid) {
362 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700363 ALOGW_IF(pid != (pid_t)-1 && pid != callingPid,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700364 "%s uid %d pid %d tried to pass itself off as pid %d",
365 __func__, callingUid, callingPid, pid);
366 pid = callingPid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700367 }
368
Eric Laurent7dca8a82018-01-29 18:44:26 -0800369 // check calling permissions
370 if (!recordingAllowed(opPackageName, pid, uid)) {
371 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
372 __func__, uid, pid);
373 return PERMISSION_DENIED;
374 }
375
Nadav Bar744be482018-05-08 13:26:21 +0300376 if ((attr->source == AUDIO_SOURCE_VOICE_UPLINK ||
377 attr->source == AUDIO_SOURCE_VOICE_DOWNLINK ||
Eric Laurentae4b6ec2019-01-15 18:34:38 -0800378 attr->source == AUDIO_SOURCE_VOICE_CALL ||
379 attr->source == AUDIO_SOURCE_ECHO_REFERENCE) &&
Nadav Bar744be482018-05-08 13:26:21 +0300380 !captureAudioOutputAllowed(pid, uid)) {
381 return PERMISSION_DENIED;
382 }
383
Eric Laurent7504b9e2017-08-15 18:17:26 -0700384 if ((attr->source == AUDIO_SOURCE_HOTWORD) && !captureHotwordAllowed(pid, uid)) {
385 return BAD_VALUE;
386 }
387
388 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700389 {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700390 status_t status;
391 AudioPolicyInterface::input_type_t inputType;
392
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700393 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700394 {
395 AutoCallerClear acc;
396 // the audio_in_acoustics_t parameter is ignored by get_input()
397 status = mAudioPolicyManager->getInputForAttr(attr, input, session, uid,
398 config,
399 flags, selectedDeviceId,
400 &inputType, portId);
401 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700402 audioPolicyEffects = mAudioPolicyEffects;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800403
404 if (status == NO_ERROR) {
405 // enforce permission (if any) required for each type of input
406 switch (inputType) {
Kevin Rocard25f9b052019-02-27 15:08:54 -0800407 case AudioPolicyInterface::API_INPUT_MIX_PUBLIC_CAPTURE_PLAYBACK:
408 // this use case has been validated in audio service with a MediaProjection token,
409 // and doesn't rely on regular permissions
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800410 case AudioPolicyInterface::API_INPUT_LEGACY:
411 break;
Eric Laurent82db2692015-08-07 13:59:42 -0700412 case AudioPolicyInterface::API_INPUT_TELEPHONY_RX:
413 // FIXME: use the same permission as for remote submix for now.
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800414 case AudioPolicyInterface::API_INPUT_MIX_CAPTURE:
Eric Laurentb2379ba2016-05-23 17:42:12 -0700415 if (!captureAudioOutputAllowed(pid, uid)) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800416 ALOGE("getInputForAttr() permission denied: capture not allowed");
417 status = PERMISSION_DENIED;
418 }
419 break;
420 case AudioPolicyInterface::API_INPUT_MIX_EXT_POLICY_REROUTE:
421 if (!modifyAudioRoutingAllowed()) {
422 ALOGE("getInputForAttr() permission denied: modify audio routing not allowed");
423 status = PERMISSION_DENIED;
424 }
425 break;
426 case AudioPolicyInterface::API_INPUT_INVALID:
427 default:
428 LOG_ALWAYS_FATAL("getInputForAttr() encountered an invalid input type %d",
429 (int)inputType);
430 }
431 }
432
433 if (status != NO_ERROR) {
434 if (status == PERMISSION_DENIED) {
Eric Laurent10b71232018-04-13 18:14:44 -0700435 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700436 mAudioPolicyManager->releaseInput(*portId);
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800437 }
438 return status;
439 }
Eric Laurentfee19762018-01-29 18:44:13 -0800440
Eric Laurentd7fe0862018-07-14 16:48:01 -0700441 sp<AudioRecordClient> client = new AudioRecordClient(*attr, *input, uid, pid, session,
442 *selectedDeviceId, opPackageName);
Eric Laurentfee19762018-01-29 18:44:13 -0800443 mAudioRecordClients.add(*portId, client);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700444 }
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800445
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700446 if (audioPolicyEffects != 0) {
447 // create audio pre processors according to input source
Eric Laurentcaf7f482014-11-25 17:50:47 -0800448 status_t status = audioPolicyEffects->addInputEffects(*input, attr->source, session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700449 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800450 ALOGW("Failed to add effects on input %d", *input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700451 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800452 }
Eric Laurentcaf7f482014-11-25 17:50:47 -0800453 return NO_ERROR;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800454}
455
Eric Laurent99fcae42018-05-17 16:59:18 -0700456std::string AudioPolicyService::getDeviceTypeStrForPortId(audio_port_handle_t portId) {
Eric Laurent99fcae42018-05-17 16:59:18 -0700457 struct audio_port port = {};
458 port.id = portId;
459 status_t status = mAudioPolicyManager->getAudioPort(&port);
460 if (status == NO_ERROR && port.type == AUDIO_PORT_TYPE_DEVICE) {
Andy Hung9b181952019-02-25 14:53:36 -0800461 return toString(port.ext.device.type);
Eric Laurent99fcae42018-05-17 16:59:18 -0700462 }
Andy Hung9b181952019-02-25 14:53:36 -0800463 return {};
Eric Laurent99fcae42018-05-17 16:59:18 -0700464}
465
Eric Laurent4eb58f12018-12-07 16:41:02 -0800466status_t AudioPolicyService::startInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800467{
Eric Laurentdce54a12014-03-10 12:19:46 -0700468 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800469 return NO_INIT;
470 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800471 sp<AudioRecordClient> client;
472 {
473 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800474
Eric Laurent7dca8a82018-01-29 18:44:26 -0800475 ssize_t index = mAudioRecordClients.indexOfKey(portId);
476 if (index < 0) {
477 return INVALID_OPERATION;
478 }
479 client = mAudioRecordClients.valueAt(index);
Eric Laurentfee19762018-01-29 18:44:13 -0800480 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800481
482 // check calling permissions
Svet Ganov6e641372018-03-02 09:21:30 -0800483 if (!startRecording(client->opPackageName, client->pid, client->uid)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800484 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
485 __func__, client->uid, client->pid);
486 return PERMISSION_DENIED;
487 }
Eric Laurentfee19762018-01-29 18:44:13 -0800488
Eric Laurentdf628922018-12-06 21:45:51 +0000489 Mutex::Autolock _l(mLock);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800490
491 client->active = true;
492 client->startTimeNs = systemTime();
493 updateUidStates_l();
Eric Laurentfee19762018-01-29 18:44:13 -0800494
Eric Laurent10b71232018-04-13 18:14:44 -0700495 status_t status;
496 {
497 AutoCallerClear acc;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800498 status = mAudioPolicyManager->startInput(portId);
Ray Essick84e84a52018-05-03 18:45:07 -0700499
500 }
501
Ray Essickf6a57cd2018-05-22 16:20:54 -0700502 // including successes gets very verbose
503 if (status != NO_ERROR) {
Ray Essick84e84a52018-05-03 18:45:07 -0700504
505 static constexpr char kAudioPolicy[] = "audiopolicy";
506
Ray Essick84e84a52018-05-03 18:45:07 -0700507 static constexpr char kAudioPolicyStatus[] = "android.media.audiopolicy.status";
508 static constexpr char kAudioPolicyRqstSrc[] = "android.media.audiopolicy.rqst.src";
509 static constexpr char kAudioPolicyRqstPkg[] = "android.media.audiopolicy.rqst.pkg";
510 static constexpr char kAudioPolicyRqstSession[] = "android.media.audiopolicy.rqst.session";
Eric Laurent99fcae42018-05-17 16:59:18 -0700511 static constexpr char kAudioPolicyRqstDevice[] =
512 "android.media.audiopolicy.rqst.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700513 static constexpr char kAudioPolicyActiveSrc[] = "android.media.audiopolicy.active.src";
514 static constexpr char kAudioPolicyActivePkg[] = "android.media.audiopolicy.active.pkg";
Eric Laurent99fcae42018-05-17 16:59:18 -0700515 static constexpr char kAudioPolicyActiveSession[] =
516 "android.media.audiopolicy.active.session";
517 static constexpr char kAudioPolicyActiveDevice[] =
518 "android.media.audiopolicy.active.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700519
Ray Essick6a305222019-01-28 20:33:18 -0800520 MediaAnalyticsItem *item = MediaAnalyticsItem::create(kAudioPolicy);
Ray Essick84e84a52018-05-03 18:45:07 -0700521 if (item != NULL) {
522
Ray Essick84e84a52018-05-03 18:45:07 -0700523 item->setInt32(kAudioPolicyStatus, status);
524
Eric Laurent99fcae42018-05-17 16:59:18 -0700525 item->setCString(kAudioPolicyRqstSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800526 toString(client->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700527 item->setInt32(kAudioPolicyRqstSession, client->session);
Ray Essick51866952018-05-30 11:22:27 -0700528 if (client->opPackageName.size() != 0) {
529 item->setCString(kAudioPolicyRqstPkg,
530 std::string(String8(client->opPackageName).string()).c_str());
531 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700532 item->setCString(kAudioPolicyRqstPkg, std::to_string(client->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700533 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700534 item->setCString(
535 kAudioPolicyRqstDevice, getDeviceTypeStrForPortId(client->deviceId).c_str());
536
Eric Laurent4eb58f12018-12-07 16:41:02 -0800537 int count = mAudioRecordClients.size();
538 for (int i = 0; i < count ; i++) {
539 if (portId == mAudioRecordClients.keyAt(i)) {
540 continue;
541 }
542 sp<AudioRecordClient> other = mAudioRecordClients.valueAt(i);
543 if (other->active) {
544 // keeps the last of the clients marked active
545 item->setCString(kAudioPolicyActiveSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800546 toString(other->attributes.source).c_str());
Eric Laurent4eb58f12018-12-07 16:41:02 -0800547 item->setInt32(kAudioPolicyActiveSession, other->session);
548 if (other->opPackageName.size() != 0) {
549 item->setCString(kAudioPolicyActivePkg,
550 std::string(String8(other->opPackageName).string()).c_str());
551 } else {
552 item->setCString(kAudioPolicyRqstPkg,
553 std::to_string(other->uid).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700554 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800555 item->setCString(kAudioPolicyActiveDevice,
556 getDeviceTypeStrForPortId(other->deviceId).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700557 }
558 }
559 item->selfrecord();
560 delete item;
561 item = NULL;
562 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800563 client->active = false;
564 client->startTimeNs = 0;
565 updateUidStates_l();
Svet Ganov6e641372018-03-02 09:21:30 -0800566 finishRecording(client->opPackageName, client->uid);
Eric Laurentfb66dd92016-01-28 18:32:03 -0800567 }
568
569 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800570}
571
Eric Laurentfee19762018-01-29 18:44:13 -0800572status_t AudioPolicyService::stopInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800573{
Eric Laurentdce54a12014-03-10 12:19:46 -0700574 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800575 return NO_INIT;
576 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800577
Eric Laurent2d388ec2014-03-07 13:25:54 -0800578 Mutex::Autolock _l(mLock);
579
Eric Laurentfee19762018-01-29 18:44:13 -0800580 ssize_t index = mAudioRecordClients.indexOfKey(portId);
581 if (index < 0) {
582 return INVALID_OPERATION;
583 }
584 sp<AudioRecordClient> client = mAudioRecordClients.valueAt(index);
585
Ray Essick84e84a52018-05-03 18:45:07 -0700586 client->active = false;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800587 client->startTimeNs = 0;
588
589 updateUidStates_l();
Ray Essick84e84a52018-05-03 18:45:07 -0700590
Svet Ganov6e641372018-03-02 09:21:30 -0800591 // finish the recording app op
592 finishRecording(client->opPackageName, client->uid);
Eric Laurent10b71232018-04-13 18:14:44 -0700593 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700594 return mAudioPolicyManager->stopInput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800595}
596
Eric Laurentfee19762018-01-29 18:44:13 -0800597void AudioPolicyService::releaseInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800598{
Eric Laurentdce54a12014-03-10 12:19:46 -0700599 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800600 return;
601 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700602 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800603 sp<AudioRecordClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700604 {
605 Mutex::Autolock _l(mLock);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700606 audioPolicyEffects = mAudioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800607 ssize_t index = mAudioRecordClients.indexOfKey(portId);
608 if (index < 0) {
609 return;
610 }
611 client = mAudioRecordClients.valueAt(index);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800612
613 if (client->active) {
614 ALOGW("%s releasing active client portId %d", __FUNCTION__, portId);
615 client->active = false;
616 client->startTimeNs = 0;
617 updateUidStates_l();
618 }
619
Eric Laurentfee19762018-01-29 18:44:13 -0800620 mAudioRecordClients.removeItem(portId);
621 }
622 if (client == 0) {
623 return;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700624 }
625 if (audioPolicyEffects != 0) {
626 // release audio processors from the input
Eric Laurentd7fe0862018-07-14 16:48:01 -0700627 status_t status = audioPolicyEffects->releaseInputEffects(client->io, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700628 if(status != NO_ERROR) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700629 ALOGW("Failed to release effects on input %d", client->io);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700630 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800631 }
Eric Laurentf10c7092016-12-06 17:09:56 -0800632 {
633 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700634 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700635 mAudioPolicyManager->releaseInput(portId);
Eric Laurentf10c7092016-12-06 17:09:56 -0800636 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800637}
638
639status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
640 int indexMin,
641 int indexMax)
642{
Eric Laurentdce54a12014-03-10 12:19:46 -0700643 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800644 return NO_INIT;
645 }
646 if (!settingsAllowed()) {
647 return PERMISSION_DENIED;
648 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800649 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800650 return BAD_VALUE;
651 }
652 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700653 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700654 mAudioPolicyManager->initStreamVolume(stream, indexMin, indexMax);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800655 return NO_ERROR;
656}
657
658status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
659 int index,
660 audio_devices_t device)
661{
Eric Laurentdce54a12014-03-10 12:19:46 -0700662 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800663 return NO_INIT;
664 }
665 if (!settingsAllowed()) {
666 return PERMISSION_DENIED;
667 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800668 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800669 return BAD_VALUE;
670 }
671 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700672 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700673 return mAudioPolicyManager->setStreamVolumeIndex(stream,
674 index,
675 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800676}
677
678status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
679 int *index,
680 audio_devices_t device)
681{
Eric Laurentdce54a12014-03-10 12:19:46 -0700682 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800683 return NO_INIT;
684 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800685 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800686 return BAD_VALUE;
687 }
688 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700689 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700690 return mAudioPolicyManager->getStreamVolumeIndex(stream,
691 index,
692 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800693}
694
François Gaffiecfe17322018-11-07 13:41:29 +0100695status_t AudioPolicyService::setVolumeIndexForAttributes(const audio_attributes_t &attributes,
696 int index, audio_devices_t device)
697{
698 if (mAudioPolicyManager == NULL) {
699 return NO_INIT;
700 }
701 if (!settingsAllowed()) {
702 return PERMISSION_DENIED;
703 }
704 Mutex::Autolock _l(mLock);
705 AutoCallerClear acc;
706 return mAudioPolicyManager->setVolumeIndexForAttributes(attributes, index, device);
707}
708
709status_t AudioPolicyService::getVolumeIndexForAttributes(const audio_attributes_t &attributes,
710 int &index, audio_devices_t device)
711{
712 if (mAudioPolicyManager == NULL) {
713 return NO_INIT;
714 }
715 Mutex::Autolock _l(mLock);
716 AutoCallerClear acc;
717 return mAudioPolicyManager->getVolumeIndexForAttributes(attributes, index, device);
718}
719
720status_t AudioPolicyService::getMinVolumeIndexForAttributes(const audio_attributes_t &attributes,
721 int &index)
722{
723 if (mAudioPolicyManager == NULL) {
724 return NO_INIT;
725 }
726 Mutex::Autolock _l(mLock);
727 AutoCallerClear acc;
728 return mAudioPolicyManager->getMinVolumeIndexForAttributes(attributes, index);
729}
730
731status_t AudioPolicyService::getMaxVolumeIndexForAttributes(const audio_attributes_t &attributes,
732 int &index)
733{
734 if (mAudioPolicyManager == NULL) {
735 return NO_INIT;
736 }
737 Mutex::Autolock _l(mLock);
738 AutoCallerClear acc;
739 return mAudioPolicyManager->getMaxVolumeIndexForAttributes(attributes, index);
740}
741
Eric Laurent2d388ec2014-03-07 13:25:54 -0800742uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
743{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800744 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
François Gaffiec005e562018-11-06 15:04:49 +0100745 return PRODUCT_STRATEGY_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700746 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700747 if (mAudioPolicyManager == NULL) {
François Gaffiec005e562018-11-06 15:04:49 +0100748 return PRODUCT_STRATEGY_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800749 }
François Gaffiec005e562018-11-06 15:04:49 +0100750 // DO NOT LOCK, may be called from AudioFlinger with lock held, reaching deadlock
Eric Laurent10b71232018-04-13 18:14:44 -0700751 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700752 return mAudioPolicyManager->getStrategyForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800753}
754
755//audio policy: use audio_device_t appropriately
756
757audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
758{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800759 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700760 return AUDIO_DEVICE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700761 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700762 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700763 return AUDIO_DEVICE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800764 }
Haynes Mathew Georgedfb9f3b2015-10-26 18:22:13 -0700765 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700766 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700767 return mAudioPolicyManager->getDevicesForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800768}
769
770audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
771{
772 // FIXME change return type to status_t, and return NO_INIT here
Eric Laurentdce54a12014-03-10 12:19:46 -0700773 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800774 return 0;
775 }
776 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700777 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700778 return mAudioPolicyManager->getOutputForEffect(desc);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800779}
780
781status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
782 audio_io_handle_t io,
783 uint32_t strategy,
Glenn Kastend848eb42016-03-08 13:42:11 -0800784 audio_session_t session,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800785 int id)
786{
Eric Laurentdce54a12014-03-10 12:19:46 -0700787 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800788 return NO_INIT;
789 }
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700790 Mutex::Autolock _l(mEffectsLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700791 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700792 return mAudioPolicyManager->registerEffect(desc, io, strategy, session, id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800793}
794
795status_t AudioPolicyService::unregisterEffect(int id)
796{
Eric Laurentdce54a12014-03-10 12:19:46 -0700797 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800798 return NO_INIT;
799 }
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700800 Mutex::Autolock _l(mEffectsLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700801 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700802 return mAudioPolicyManager->unregisterEffect(id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800803}
804
805status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
806{
Eric Laurentdce54a12014-03-10 12:19:46 -0700807 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800808 return NO_INIT;
809 }
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700810 Mutex::Autolock _l(mEffectsLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700811 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700812 return mAudioPolicyManager->setEffectEnabled(id, enabled);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800813}
814
815bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
816{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800817 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700818 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700819 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700820 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700821 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800822 }
823 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700824 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700825 return mAudioPolicyManager->isStreamActive(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800826}
827
828bool AudioPolicyService::isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs) const
829{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800830 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700831 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700832 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700833 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700834 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800835 }
836 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700837 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700838 return mAudioPolicyManager->isStreamActiveRemotely(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800839}
840
841bool AudioPolicyService::isSourceActive(audio_source_t source) const
842{
Eric Laurentdce54a12014-03-10 12:19:46 -0700843 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800844 return false;
845 }
846 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700847 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700848 return mAudioPolicyManager->isSourceActive(source);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800849}
850
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700851status_t AudioPolicyService::getAudioPolicyEffects(sp<AudioPolicyEffects>& audioPolicyEffects)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800852{
Eric Laurentdce54a12014-03-10 12:19:46 -0700853 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800854 return NO_INIT;
855 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700856 {
857 Mutex::Autolock _l(mLock);
858 audioPolicyEffects = mAudioPolicyEffects;
859 }
860 if (audioPolicyEffects == 0) {
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700861 return NO_INIT;
862 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700863
864 return OK;
865}
866
867status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
868 effect_descriptor_t *descriptors,
869 uint32_t *count)
870{
871 sp<AudioPolicyEffects>audioPolicyEffects;
872 status_t status = getAudioPolicyEffects(audioPolicyEffects);
873 if (status != OK) {
874 *count = 0;
875 return status;
876 }
Eric Laurentfb66dd92016-01-28 18:32:03 -0800877 return audioPolicyEffects->queryDefaultInputEffects(
878 (audio_session_t)audioSession, descriptors, count);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800879}
880
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700881status_t AudioPolicyService::addSourceDefaultEffect(const effect_uuid_t *type,
882 const String16& opPackageName,
883 const effect_uuid_t *uuid,
884 int32_t priority,
885 audio_source_t source,
886 audio_unique_id_t* id)
887{
888 sp<AudioPolicyEffects>audioPolicyEffects;
889 status_t status = getAudioPolicyEffects(audioPolicyEffects);
890 if (status != OK) {
891 return status;
892 }
893 if (!modifyDefaultAudioEffectsAllowed()) {
894 return PERMISSION_DENIED;
895 }
896 return audioPolicyEffects->addSourceDefaultEffect(
897 type, opPackageName, uuid, priority, source, id);
898}
899
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700900status_t AudioPolicyService::addStreamDefaultEffect(const effect_uuid_t *type,
901 const String16& opPackageName,
902 const effect_uuid_t *uuid,
903 int32_t priority,
904 audio_usage_t usage,
905 audio_unique_id_t* id)
906{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700907 sp<AudioPolicyEffects>audioPolicyEffects;
908 status_t status = getAudioPolicyEffects(audioPolicyEffects);
909 if (status != OK) {
910 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700911 }
912 if (!modifyDefaultAudioEffectsAllowed()) {
913 return PERMISSION_DENIED;
914 }
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700915 return audioPolicyEffects->addStreamDefaultEffect(
916 type, opPackageName, uuid, priority, usage, id);
917}
918
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700919status_t AudioPolicyService::removeSourceDefaultEffect(audio_unique_id_t id)
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700920{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700921 sp<AudioPolicyEffects>audioPolicyEffects;
922 status_t status = getAudioPolicyEffects(audioPolicyEffects);
923 if (status != OK) {
924 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700925 }
926 if (!modifyDefaultAudioEffectsAllowed()) {
927 return PERMISSION_DENIED;
928 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700929 return audioPolicyEffects->removeSourceDefaultEffect(id);
930}
931
932status_t AudioPolicyService::removeStreamDefaultEffect(audio_unique_id_t id)
933{
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700934 sp<AudioPolicyEffects>audioPolicyEffects;
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700935 status_t status = getAudioPolicyEffects(audioPolicyEffects);
936 if (status != OK) {
937 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700938 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700939 if (!modifyDefaultAudioEffectsAllowed()) {
940 return PERMISSION_DENIED;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700941 }
942 return audioPolicyEffects->removeStreamDefaultEffect(id);
943}
944
Eric Laurent2d388ec2014-03-07 13:25:54 -0800945bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
946{
Eric Laurentdce54a12014-03-10 12:19:46 -0700947 if (mAudioPolicyManager == NULL) {
948 ALOGV("mAudioPolicyManager == NULL");
Eric Laurent2d388ec2014-03-07 13:25:54 -0800949 return false;
950 }
Andy Hung2ddee192015-12-18 17:34:44 -0800951 Mutex::Autolock _l(mLock);
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700952 Mutex::Autolock _le(mEffectsLock); // isOffloadSupported queries for
953 // non-offloadable effects
Eric Laurent10b71232018-04-13 18:14:44 -0700954 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700955 return mAudioPolicyManager->isOffloadSupported(info);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800956}
957
Michael Chana94fbb22018-04-24 14:31:19 +1000958bool AudioPolicyService::isDirectOutputSupported(const audio_config_base_t& config,
959 const audio_attributes_t& attributes) {
960 if (mAudioPolicyManager == NULL) {
961 ALOGV("mAudioPolicyManager == NULL");
962 return false;
963 }
964 Mutex::Autolock _l(mLock);
965 return mAudioPolicyManager->isDirectOutputSupported(config, attributes);
966}
967
968
Eric Laurent6a94d692014-05-20 11:18:06 -0700969status_t AudioPolicyService::listAudioPorts(audio_port_role_t role,
970 audio_port_type_t type,
Eric Laurent203b1a12014-04-01 10:34:16 -0700971 unsigned int *num_ports,
Eric Laurent6a94d692014-05-20 11:18:06 -0700972 struct audio_port *ports,
973 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -0700974{
Eric Laurent6a94d692014-05-20 11:18:06 -0700975 Mutex::Autolock _l(mLock);
976 if (mAudioPolicyManager == NULL) {
977 return NO_INIT;
978 }
Eric Laurent10b71232018-04-13 18:14:44 -0700979 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700980 return mAudioPolicyManager->listAudioPorts(role, type, num_ports, ports, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -0700981}
982
Eric Laurent6a94d692014-05-20 11:18:06 -0700983status_t AudioPolicyService::getAudioPort(struct audio_port *port)
Eric Laurent203b1a12014-04-01 10:34:16 -0700984{
Eric Laurent6a94d692014-05-20 11:18:06 -0700985 Mutex::Autolock _l(mLock);
986 if (mAudioPolicyManager == NULL) {
987 return NO_INIT;
988 }
Eric Laurent10b71232018-04-13 18:14:44 -0700989 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700990 return mAudioPolicyManager->getAudioPort(port);
Eric Laurent203b1a12014-04-01 10:34:16 -0700991}
992
Eric Laurent6a94d692014-05-20 11:18:06 -0700993status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch,
994 audio_patch_handle_t *handle)
Eric Laurent203b1a12014-04-01 10:34:16 -0700995{
Eric Laurent6a94d692014-05-20 11:18:06 -0700996 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -0700997 if(!modifyAudioRoutingAllowed()) {
998 return PERMISSION_DENIED;
999 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001000 if (mAudioPolicyManager == NULL) {
1001 return NO_INIT;
1002 }
Eric Laurent10b71232018-04-13 18:14:44 -07001003 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001004 return mAudioPolicyManager->createAudioPatch(patch, handle,
1005 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001006}
1007
Eric Laurent6a94d692014-05-20 11:18:06 -07001008status_t AudioPolicyService::releaseAudioPatch(audio_patch_handle_t handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001009{
Eric Laurent6a94d692014-05-20 11:18:06 -07001010 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001011 if(!modifyAudioRoutingAllowed()) {
1012 return PERMISSION_DENIED;
1013 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001014 if (mAudioPolicyManager == NULL) {
1015 return NO_INIT;
1016 }
Eric Laurent10b71232018-04-13 18:14:44 -07001017 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001018 return mAudioPolicyManager->releaseAudioPatch(handle,
1019 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001020}
1021
1022status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
Eric Laurent6a94d692014-05-20 11:18:06 -07001023 struct audio_patch *patches,
1024 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001025{
Eric Laurent6a94d692014-05-20 11:18:06 -07001026 Mutex::Autolock _l(mLock);
1027 if (mAudioPolicyManager == NULL) {
1028 return NO_INIT;
1029 }
Eric Laurent10b71232018-04-13 18:14:44 -07001030 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001031 return mAudioPolicyManager->listAudioPatches(num_patches, patches, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001032}
1033
Eric Laurent6a94d692014-05-20 11:18:06 -07001034status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config)
Eric Laurent203b1a12014-04-01 10:34:16 -07001035{
Eric Laurent6a94d692014-05-20 11:18:06 -07001036 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001037 if(!modifyAudioRoutingAllowed()) {
1038 return PERMISSION_DENIED;
1039 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001040 if (mAudioPolicyManager == NULL) {
1041 return NO_INIT;
1042 }
Eric Laurent10b71232018-04-13 18:14:44 -07001043 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001044 return mAudioPolicyManager->setAudioPortConfig(config);
Eric Laurent203b1a12014-04-01 10:34:16 -07001045}
Eric Laurent2d388ec2014-03-07 13:25:54 -08001046
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001047status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session,
1048 audio_io_handle_t *ioHandle,
1049 audio_devices_t *device)
1050{
Andy Hungf759b8c2017-08-15 12:48:54 -07001051 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001052 if (mAudioPolicyManager == NULL) {
1053 return NO_INIT;
1054 }
Eric Laurent10b71232018-04-13 18:14:44 -07001055 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001056 return mAudioPolicyManager->acquireSoundTriggerSession(session, ioHandle, device);
1057}
1058
1059status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session)
1060{
Andy Hungf759b8c2017-08-15 12:48:54 -07001061 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001062 if (mAudioPolicyManager == NULL) {
1063 return NO_INIT;
1064 }
Eric Laurent10b71232018-04-13 18:14:44 -07001065 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001066 return mAudioPolicyManager->releaseSoundTriggerSession(session);
1067}
1068
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -07001069status_t AudioPolicyService::registerPolicyMixes(const Vector<AudioMix>& mixes, bool registration)
Eric Laurentbaac1832014-12-01 17:52:59 -08001070{
1071 Mutex::Autolock _l(mLock);
Kevin Rocardbe201852019-02-20 22:33:28 -08001072
1073 // loopback|render only need a MediaProjection (checked in caller AudioService.java)
1074 bool needModifyAudioRouting = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
1075 return !is_mix_loopback_render(mix.mRouteFlags); });
1076 if (needModifyAudioRouting && !modifyAudioRoutingAllowed()) {
Eric Laurentbaac1832014-12-01 17:52:59 -08001077 return PERMISSION_DENIED;
1078 }
Kevin Rocardbe201852019-02-20 22:33:28 -08001079
Eric Laurentbaac1832014-12-01 17:52:59 -08001080 if (mAudioPolicyManager == NULL) {
1081 return NO_INIT;
1082 }
Eric Laurent10b71232018-04-13 18:14:44 -07001083 AutoCallerClear acc;
Eric Laurentbaac1832014-12-01 17:52:59 -08001084 if (registration) {
1085 return mAudioPolicyManager->registerPolicyMixes(mixes);
1086 } else {
1087 return mAudioPolicyManager->unregisterPolicyMixes(mixes);
1088 }
1089}
1090
Jean-Michel Trivibda70da2018-12-19 07:30:15 -08001091status_t AudioPolicyService::setUidDeviceAffinities(uid_t uid,
1092 const Vector<AudioDeviceTypeAddr>& devices) {
1093 Mutex::Autolock _l(mLock);
1094 if(!modifyAudioRoutingAllowed()) {
1095 return PERMISSION_DENIED;
1096 }
1097 if (mAudioPolicyManager == NULL) {
1098 return NO_INIT;
1099 }
1100 AutoCallerClear acc;
1101 return mAudioPolicyManager->setUidDeviceAffinities(uid, devices);
1102}
1103
1104status_t AudioPolicyService::removeUidDeviceAffinities(uid_t uid) {
1105 Mutex::Autolock _l(mLock);
1106 if(!modifyAudioRoutingAllowed()) {
1107 return PERMISSION_DENIED;
1108 }
1109 if (mAudioPolicyManager == NULL) {
1110 return NO_INIT;
1111 }
1112 AutoCallerClear acc;
1113 return mAudioPolicyManager->removeUidDeviceAffinities(uid);
1114}
1115
Eric Laurent554a2772015-04-10 11:29:24 -07001116status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001117 const audio_attributes_t *attributes,
1118 audio_port_handle_t *portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001119{
1120 Mutex::Autolock _l(mLock);
1121 if (mAudioPolicyManager == NULL) {
1122 return NO_INIT;
1123 }
Eric Laurent10b71232018-04-13 18:14:44 -07001124 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001125 return mAudioPolicyManager->startAudioSource(source, attributes, portId,
Eric Laurentd60560a2015-04-10 11:31:20 -07001126 IPCThreadState::self()->getCallingUid());
Eric Laurent554a2772015-04-10 11:29:24 -07001127}
1128
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001129status_t AudioPolicyService::stopAudioSource(audio_port_handle_t portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001130{
1131 Mutex::Autolock _l(mLock);
1132 if (mAudioPolicyManager == NULL) {
1133 return NO_INIT;
1134 }
Eric Laurent10b71232018-04-13 18:14:44 -07001135 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001136 return mAudioPolicyManager->stopAudioSource(portId);
Eric Laurent554a2772015-04-10 11:29:24 -07001137}
1138
Andy Hung2ddee192015-12-18 17:34:44 -08001139status_t AudioPolicyService::setMasterMono(bool mono)
1140{
1141 if (mAudioPolicyManager == NULL) {
1142 return NO_INIT;
1143 }
1144 if (!settingsAllowed()) {
1145 return PERMISSION_DENIED;
1146 }
1147 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001148 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001149 return mAudioPolicyManager->setMasterMono(mono);
1150}
1151
1152status_t AudioPolicyService::getMasterMono(bool *mono)
1153{
1154 if (mAudioPolicyManager == NULL) {
1155 return NO_INIT;
1156 }
1157 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001158 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001159 return mAudioPolicyManager->getMasterMono(mono);
1160}
1161
Eric Laurentac9cef52017-06-09 15:46:26 -07001162
1163float AudioPolicyService::getStreamVolumeDB(
1164 audio_stream_type_t stream, int index, audio_devices_t device)
1165{
1166 if (mAudioPolicyManager == NULL) {
1167 return NAN;
1168 }
1169 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001170 AutoCallerClear acc;
Eric Laurentac9cef52017-06-09 15:46:26 -07001171 return mAudioPolicyManager->getStreamVolumeDB(stream, index, device);
1172}
1173
jiabin81772902018-04-02 17:52:27 -07001174status_t AudioPolicyService::getSurroundFormats(unsigned int *numSurroundFormats,
1175 audio_format_t *surroundFormats,
1176 bool *surroundFormatsEnabled,
1177 bool reported)
1178{
1179 if (mAudioPolicyManager == NULL) {
1180 return NO_INIT;
1181 }
1182 Mutex::Autolock _l(mLock);
1183 AutoCallerClear acc;
1184 return mAudioPolicyManager->getSurroundFormats(numSurroundFormats, surroundFormats,
1185 surroundFormatsEnabled, reported);
1186}
1187
Arun Mirpuri11029ad2018-12-19 20:45:19 -08001188status_t AudioPolicyService::getHwOffloadEncodingFormatsSupportedForA2DP(
1189 std::vector<audio_format_t> *formats)
1190{
1191 if (mAudioPolicyManager == NULL) {
1192 return NO_INIT;
1193 }
1194 Mutex::Autolock _l(mLock);
1195 AutoCallerClear acc;
1196 return mAudioPolicyManager->getHwOffloadEncodingFormatsSupportedForA2DP(formats);
1197}
1198
jiabin81772902018-04-02 17:52:27 -07001199status_t AudioPolicyService::setSurroundFormatEnabled(audio_format_t audioFormat, bool enabled)
1200{
1201 if (mAudioPolicyManager == NULL) {
1202 return NO_INIT;
1203 }
1204 Mutex::Autolock _l(mLock);
1205 AutoCallerClear acc;
1206 return mAudioPolicyManager->setSurroundFormatEnabled(audioFormat, enabled);
1207}
Eric Laurentac9cef52017-06-09 15:46:26 -07001208
Eric Laurentb78763e2018-10-17 10:08:02 -07001209status_t AudioPolicyService::setAssistantUid(uid_t uid)
1210{
1211 Mutex::Autolock _l(mLock);
1212 mUidPolicy->setAssistantUid(uid);
1213 return NO_ERROR;
1214}
1215
1216status_t AudioPolicyService::setA11yServicesUids(const std::vector<uid_t>& uids)
1217{
1218 Mutex::Autolock _l(mLock);
1219 mUidPolicy->setA11yUids(uids);
1220 return NO_ERROR;
1221}
1222
jiabin6012f912018-11-02 17:06:30 -07001223bool AudioPolicyService::isHapticPlaybackSupported()
1224{
1225 if (mAudioPolicyManager == NULL) {
1226 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1227 return false;
1228 }
1229 Mutex::Autolock _l(mLock);
1230 AutoCallerClear acc;
1231 return mAudioPolicyManager->isHapticPlaybackSupported();
1232}
1233
François Gaffied0ba9ed2018-11-05 11:50:42 +01001234status_t AudioPolicyService::listAudioProductStrategies(AudioProductStrategyVector &strategies)
1235{
1236 if (mAudioPolicyManager == NULL) {
1237 return NO_INIT;
1238 }
1239 Mutex::Autolock _l(mLock);
1240 return mAudioPolicyManager->listAudioProductStrategies(strategies);
1241}
1242
François Gaffie4b2018b2018-11-07 11:18:59 +01001243status_t AudioPolicyService::getProductStrategyFromAudioAttributes(
1244 const AudioAttributes &aa, product_strategy_t &productStrategy)
François Gaffied0ba9ed2018-11-05 11:50:42 +01001245{
1246 if (mAudioPolicyManager == NULL) {
François Gaffie4b2018b2018-11-07 11:18:59 +01001247 return NO_INIT;
François Gaffied0ba9ed2018-11-05 11:50:42 +01001248 }
1249 Mutex::Autolock _l(mLock);
François Gaffie4b2018b2018-11-07 11:18:59 +01001250 return mAudioPolicyManager->getProductStrategyFromAudioAttributes(aa, productStrategy);
1251}
1252
1253status_t AudioPolicyService::listAudioVolumeGroups(AudioVolumeGroupVector &groups)
1254{
1255 if (mAudioPolicyManager == NULL) {
1256 return NO_INIT;
1257 }
1258 Mutex::Autolock _l(mLock);
1259 return mAudioPolicyManager->listAudioVolumeGroups(groups);
1260}
1261
1262status_t AudioPolicyService::getVolumeGroupFromAudioAttributes(const AudioAttributes &aa,
1263 volume_group_t &volumeGroup)
1264{
1265 if (mAudioPolicyManager == NULL) {
1266 return NO_INIT;
1267 }
1268 Mutex::Autolock _l(mLock);
1269 return mAudioPolicyManager->getVolumeGroupFromAudioAttributes(aa, volumeGroup);
François Gaffied0ba9ed2018-11-05 11:50:42 +01001270}
Mikhail Naganov1b2a7942017-12-08 10:18:09 -08001271} // namespace android