blob: dbfda44e5ef8687ae1c85f59635372d68b0ade1a [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 Laurentd7fe0862018-07-14 16:48:01 -0700257 {
258 Mutex::Autolock _l(mLock);
259
260 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
261 if (index < 0) {
262 ALOGE("%s AudioTrack client not found for portId %d", __FUNCTION__, portId);
263 return INVALID_OPERATION;
264 }
Eric Laurentdea15412014-10-28 15:46:45 -0700265 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700266 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800267 return NO_INIT;
268 }
269 ALOGV("stopOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700270 mOutputCommandThread->stopOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800271 return NO_ERROR;
272}
273
Eric Laurentd7fe0862018-07-14 16:48:01 -0700274status_t AudioPolicyService::doStopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800275{
Eric Laurentd7fe0862018-07-14 16:48:01 -0700276 ALOGV("doStopOutput");
277 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700278 sp<AudioPolicyEffects>audioPolicyEffects;
279 {
280 Mutex::Autolock _l(mLock);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700281
282 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
283 if (index < 0) {
284 ALOGE("%s AudioTrack client not found for portId %d", __FUNCTION__, portId);
285 return INVALID_OPERATION;
286 }
287 client = mAudioPlaybackClients.valueAt(index);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700288 audioPolicyEffects = mAudioPolicyEffects;
bryant_liuba2b4392014-06-11 16:49:30 +0800289 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700290 if (audioPolicyEffects != 0) {
291 // release audio processors from the stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700292 status_t status = audioPolicyEffects->releaseOutputSessionEffects(
293 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700294 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700295 ALOGW("Failed to release effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700296 }
297 }
298 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700299 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700300 status_t status = mAudioPolicyManager->stopOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700301 if (status == NO_ERROR) {
302 client->active = false;
303 }
304 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800305}
306
Eric Laurentd7fe0862018-07-14 16:48:01 -0700307void AudioPolicyService::releaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800308{
Eric Laurentdce54a12014-03-10 12:19:46 -0700309 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800310 return;
311 }
312 ALOGV("releaseOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700313 mOutputCommandThread->releaseOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800314}
315
Eric Laurentd7fe0862018-07-14 16:48:01 -0700316void AudioPolicyService::doReleaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800317{
318 ALOGV("doReleaseOutput from tid %d", gettid());
319 Mutex::Autolock _l(mLock);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700320 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
321 if (index < 0) {
322 ALOGE("%s AudioTrack client not found for portId %d", __FUNCTION__, portId);
323 return;
324 }
325 sp<AudioPlaybackClient> client = mAudioPlaybackClients.valueAt(index);
326 mAudioRecordClients.removeItem(portId);
327
Eric Laurent10b71232018-04-13 18:14:44 -0700328 // called from internal thread: no need to clear caller identity
Eric Laurent8fc147b2018-07-22 19:13:55 -0700329 mAudioPolicyManager->releaseOutput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800330}
331
Eric Laurentcaf7f482014-11-25 17:50:47 -0800332status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
333 audio_io_handle_t *input,
334 audio_session_t session,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700335 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700336 uid_t uid,
Eric Laurentfee19762018-01-29 18:44:13 -0800337 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800338 const audio_config_base_t *config,
Paul McLean466dc8e2015-04-17 13:15:36 -0600339 audio_input_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700340 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800341 audio_port_handle_t *portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800342{
Eric Laurentdce54a12014-03-10 12:19:46 -0700343 if (mAudioPolicyManager == NULL) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800344 return NO_INIT;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800345 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800346
Eric Laurent2d388ec2014-03-07 13:25:54 -0800347 // already checked by client, but double-check in case the client wrapper is bypassed
Eric Laurentfe231122017-11-17 17:48:06 -0800348 if (attr->source < AUDIO_SOURCE_DEFAULT && attr->source >= AUDIO_SOURCE_CNT &&
349 attr->source != AUDIO_SOURCE_HOTWORD && attr->source != AUDIO_SOURCE_FM_TUNER) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800350 return BAD_VALUE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800351 }
352
Eric Laurentb2379ba2016-05-23 17:42:12 -0700353 bool updatePid = (pid == -1);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700354 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700355 if (!isAudioServerOrMediaServerUid(callingUid)) {
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700356 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Marco Nelissendcb346b2015-09-09 10:47:29 -0700357 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
358 uid = callingUid;
Eric Laurentb2379ba2016-05-23 17:42:12 -0700359 updatePid = true;
360 }
361
362 if (updatePid) {
363 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700364 ALOGW_IF(pid != (pid_t)-1 && pid != callingPid,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700365 "%s uid %d pid %d tried to pass itself off as pid %d",
366 __func__, callingUid, callingPid, pid);
367 pid = callingPid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700368 }
369
Eric Laurent7dca8a82018-01-29 18:44:26 -0800370 // check calling permissions
371 if (!recordingAllowed(opPackageName, pid, uid)) {
372 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
373 __func__, uid, pid);
374 return PERMISSION_DENIED;
375 }
376
Nadav Bar744be482018-05-08 13:26:21 +0300377 if ((attr->source == AUDIO_SOURCE_VOICE_UPLINK ||
378 attr->source == AUDIO_SOURCE_VOICE_DOWNLINK ||
379 attr->source == AUDIO_SOURCE_VOICE_CALL) &&
380 !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) {
407 case AudioPolicyInterface::API_INPUT_LEGACY:
408 break;
Eric Laurent82db2692015-08-07 13:59:42 -0700409 case AudioPolicyInterface::API_INPUT_TELEPHONY_RX:
410 // FIXME: use the same permission as for remote submix for now.
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800411 case AudioPolicyInterface::API_INPUT_MIX_CAPTURE:
Eric Laurentb2379ba2016-05-23 17:42:12 -0700412 if (!captureAudioOutputAllowed(pid, uid)) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800413 ALOGE("getInputForAttr() permission denied: capture not allowed");
414 status = PERMISSION_DENIED;
415 }
416 break;
417 case AudioPolicyInterface::API_INPUT_MIX_EXT_POLICY_REROUTE:
418 if (!modifyAudioRoutingAllowed()) {
419 ALOGE("getInputForAttr() permission denied: modify audio routing not allowed");
420 status = PERMISSION_DENIED;
421 }
422 break;
423 case AudioPolicyInterface::API_INPUT_INVALID:
424 default:
425 LOG_ALWAYS_FATAL("getInputForAttr() encountered an invalid input type %d",
426 (int)inputType);
427 }
428 }
429
430 if (status != NO_ERROR) {
431 if (status == PERMISSION_DENIED) {
Eric Laurent10b71232018-04-13 18:14:44 -0700432 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700433 mAudioPolicyManager->releaseInput(*portId);
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800434 }
435 return status;
436 }
Eric Laurentfee19762018-01-29 18:44:13 -0800437
Eric Laurentd7fe0862018-07-14 16:48:01 -0700438 sp<AudioRecordClient> client = new AudioRecordClient(*attr, *input, uid, pid, session,
439 *selectedDeviceId, opPackageName);
Eric Laurentfee19762018-01-29 18:44:13 -0800440 mAudioRecordClients.add(*portId, client);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700441 }
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800442
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700443 if (audioPolicyEffects != 0) {
444 // create audio pre processors according to input source
Eric Laurentcaf7f482014-11-25 17:50:47 -0800445 status_t status = audioPolicyEffects->addInputEffects(*input, attr->source, session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700446 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800447 ALOGW("Failed to add effects on input %d", *input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700448 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800449 }
Eric Laurentcaf7f482014-11-25 17:50:47 -0800450 return NO_ERROR;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800451}
452
Ray Essick84e84a52018-05-03 18:45:07 -0700453// this is replicated from frameworks/av/media/libaudioclient/AudioRecord.cpp
454// XXX -- figure out how to put it into a common, shared location
455
456static std::string audioSourceString(audio_source_t value) {
457 std::string source;
458 if (SourceTypeConverter::toString(value, source)) {
459 return source;
460 }
461 char rawbuffer[16]; // room for "%d"
462 snprintf(rawbuffer, sizeof(rawbuffer), "%d", value);
463 return rawbuffer;
464}
465
Eric Laurent99fcae42018-05-17 16:59:18 -0700466static std::string audioConcurrencyString(
467 AudioPolicyInterface::concurrency_type__mask_t concurrency)
Ray Essick84e84a52018-05-03 18:45:07 -0700468{
469 char buffer[64]; // oversized
470 if (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_ALL) {
471 snprintf(buffer, sizeof(buffer), "%s%s%s%s",
472 (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_CALL)? ",call":"",
473 (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_CAPTURE)? ",capture":"",
474 (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_HOTWORD)? ",hotword":"",
475 (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_PREEMPT)? ",preempt":"");
476 } else {
477 snprintf(buffer, sizeof(buffer), ",none");
478 }
479
480 return &buffer[1];
481}
482
Eric Laurent99fcae42018-05-17 16:59:18 -0700483std::string AudioPolicyService::getDeviceTypeStrForPortId(audio_port_handle_t portId) {
484 std::string typeStr;
485 struct audio_port port = {};
486 port.id = portId;
487 status_t status = mAudioPolicyManager->getAudioPort(&port);
488 if (status == NO_ERROR && port.type == AUDIO_PORT_TYPE_DEVICE) {
489 deviceToString(port.ext.device.type, typeStr);
490 }
491 return typeStr;
492}
493
Eric Laurentfee19762018-01-29 18:44:13 -0800494status_t AudioPolicyService::startInput(audio_port_handle_t portId, bool *silenced)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800495{
Eric Laurentdce54a12014-03-10 12:19:46 -0700496 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800497 return NO_INIT;
498 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800499 sp<AudioRecordClient> client;
500 {
501 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800502
Eric Laurent7dca8a82018-01-29 18:44:26 -0800503 ssize_t index = mAudioRecordClients.indexOfKey(portId);
504 if (index < 0) {
505 return INVALID_OPERATION;
506 }
507 client = mAudioRecordClients.valueAt(index);
Eric Laurentfee19762018-01-29 18:44:13 -0800508 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800509
510 // check calling permissions
Svet Ganov6e641372018-03-02 09:21:30 -0800511 if (!startRecording(client->opPackageName, client->pid, client->uid)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800512 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
513 __func__, client->uid, client->pid);
514 return PERMISSION_DENIED;
515 }
Eric Laurentfee19762018-01-29 18:44:13 -0800516
517 // If UID inactive it records silence until becoming active
518 *silenced = !mUidPolicy->isUidActive(client->uid) && !client->isVirtualDevice;
519
Eric Laurent7dca8a82018-01-29 18:44:26 -0800520 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800521 AudioPolicyInterface::concurrency_type__mask_t concurrency =
522 AudioPolicyInterface::API_INPUT_CONCURRENCY_NONE;
Eric Laurentfee19762018-01-29 18:44:13 -0800523
Eric Laurent10b71232018-04-13 18:14:44 -0700524 status_t status;
525 {
526 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700527 status = mAudioPolicyManager->startInput(portId, *silenced, &concurrency);
Ray Essick84e84a52018-05-03 18:45:07 -0700528
529 }
530
Ray Essickf6a57cd2018-05-22 16:20:54 -0700531 // including successes gets very verbose
532 if (status != NO_ERROR) {
Ray Essick84e84a52018-05-03 18:45:07 -0700533
534 static constexpr char kAudioPolicy[] = "audiopolicy";
535
536 static constexpr char kAudioPolicyReason[] = "android.media.audiopolicy.reason";
537 static constexpr char kAudioPolicyStatus[] = "android.media.audiopolicy.status";
538 static constexpr char kAudioPolicyRqstSrc[] = "android.media.audiopolicy.rqst.src";
539 static constexpr char kAudioPolicyRqstPkg[] = "android.media.audiopolicy.rqst.pkg";
540 static constexpr char kAudioPolicyRqstSession[] = "android.media.audiopolicy.rqst.session";
Eric Laurent99fcae42018-05-17 16:59:18 -0700541 static constexpr char kAudioPolicyRqstDevice[] =
542 "android.media.audiopolicy.rqst.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700543 static constexpr char kAudioPolicyActiveSrc[] = "android.media.audiopolicy.active.src";
544 static constexpr char kAudioPolicyActivePkg[] = "android.media.audiopolicy.active.pkg";
Eric Laurent99fcae42018-05-17 16:59:18 -0700545 static constexpr char kAudioPolicyActiveSession[] =
546 "android.media.audiopolicy.active.session";
547 static constexpr char kAudioPolicyActiveDevice[] =
548 "android.media.audiopolicy.active.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700549
550 MediaAnalyticsItem *item = new MediaAnalyticsItem(kAudioPolicy);
551 if (item != NULL) {
552
553 item->setCString(kAudioPolicyReason, audioConcurrencyString(concurrency).c_str());
554 item->setInt32(kAudioPolicyStatus, status);
555
Eric Laurent99fcae42018-05-17 16:59:18 -0700556 item->setCString(kAudioPolicyRqstSrc,
557 audioSourceString(client->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700558 item->setInt32(kAudioPolicyRqstSession, client->session);
Ray Essick51866952018-05-30 11:22:27 -0700559 if (client->opPackageName.size() != 0) {
560 item->setCString(kAudioPolicyRqstPkg,
561 std::string(String8(client->opPackageName).string()).c_str());
562 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700563 item->setCString(kAudioPolicyRqstPkg, std::to_string(client->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700564 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700565 item->setCString(
566 kAudioPolicyRqstDevice, getDeviceTypeStrForPortId(client->deviceId).c_str());
567
Ray Essick84e84a52018-05-03 18:45:07 -0700568 // figure out who is active
569 // NB: might the other party have given up the microphone since then? how sure.
570 // perhaps could have given up on it.
571 // we hold mLock, so perhaps we're safe for this looping
572 if (concurrency != AudioPolicyInterface::API_INPUT_CONCURRENCY_NONE) {
573 int count = mAudioRecordClients.size();
574 for (int i = 0; i<count ; i++) {
575 if (portId == mAudioRecordClients.keyAt(i)) {
576 continue;
577 }
578 sp<AudioRecordClient> other = mAudioRecordClients.valueAt(i);
579 if (other->active) {
580 // keeps the last of the clients marked active
581 item->setCString(kAudioPolicyActiveSrc,
582 audioSourceString(other->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700583 item->setInt32(kAudioPolicyActiveSession, other->session);
Ray Essick51866952018-05-30 11:22:27 -0700584 if (other->opPackageName.size() != 0) {
585 item->setCString(kAudioPolicyActivePkg,
586 std::string(String8(other->opPackageName).string()).c_str());
587 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700588 item->setCString(kAudioPolicyRqstPkg,
589 std::to_string(other->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700590 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700591 item->setCString(kAudioPolicyActiveDevice,
592 getDeviceTypeStrForPortId(other->deviceId).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700593 }
594 }
595 }
596 item->selfrecord();
597 delete item;
598 item = NULL;
599 }
Eric Laurent10b71232018-04-13 18:14:44 -0700600 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800601
Eric Laurentfb66dd92016-01-28 18:32:03 -0800602 if (status == NO_ERROR) {
Eric Laurent43423352016-02-05 11:57:57 -0800603 LOG_ALWAYS_FATAL_IF(concurrency & ~AudioPolicyInterface::API_INPUT_CONCURRENCY_ALL,
604 "startInput(): invalid concurrency type %d", (int)concurrency);
605
Eric Laurentfb66dd92016-01-28 18:32:03 -0800606 // enforce permission (if any) required for each type of concurrency
Eric Laurent43423352016-02-05 11:57:57 -0800607 if (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_CALL) {
Eric Laurentfb66dd92016-01-28 18:32:03 -0800608 //TODO: check incall capture permission
Eric Laurent43423352016-02-05 11:57:57 -0800609 }
610 if (concurrency & AudioPolicyInterface::API_INPUT_CONCURRENCY_CAPTURE) {
Eric Laurentfb66dd92016-01-28 18:32:03 -0800611 //TODO: check concurrent capture permission
Eric Laurentfb66dd92016-01-28 18:32:03 -0800612 }
Ray Essick84e84a52018-05-03 18:45:07 -0700613
614 client->active = true;
Svet Ganov6e641372018-03-02 09:21:30 -0800615 } else {
616 finishRecording(client->opPackageName, client->uid);
Eric Laurentfb66dd92016-01-28 18:32:03 -0800617 }
618
619 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800620}
621
Eric Laurentfee19762018-01-29 18:44:13 -0800622status_t AudioPolicyService::stopInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800623{
Eric Laurentdce54a12014-03-10 12:19:46 -0700624 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800625 return NO_INIT;
626 }
627 Mutex::Autolock _l(mLock);
628
Eric Laurentfee19762018-01-29 18:44:13 -0800629 ssize_t index = mAudioRecordClients.indexOfKey(portId);
630 if (index < 0) {
631 return INVALID_OPERATION;
632 }
633 sp<AudioRecordClient> client = mAudioRecordClients.valueAt(index);
634
Ray Essick84e84a52018-05-03 18:45:07 -0700635 client->active = false;
636
Svet Ganov6e641372018-03-02 09:21:30 -0800637 // finish the recording app op
638 finishRecording(client->opPackageName, client->uid);
Eric Laurent10b71232018-04-13 18:14:44 -0700639 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700640 return mAudioPolicyManager->stopInput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800641}
642
Eric Laurentfee19762018-01-29 18:44:13 -0800643void AudioPolicyService::releaseInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800644{
Eric Laurentdce54a12014-03-10 12:19:46 -0700645 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800646 return;
647 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700648 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800649 sp<AudioRecordClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700650 {
651 Mutex::Autolock _l(mLock);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700652 audioPolicyEffects = mAudioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800653 ssize_t index = mAudioRecordClients.indexOfKey(portId);
654 if (index < 0) {
655 return;
656 }
657 client = mAudioRecordClients.valueAt(index);
658 mAudioRecordClients.removeItem(portId);
659 }
660 if (client == 0) {
661 return;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700662 }
663 if (audioPolicyEffects != 0) {
664 // release audio processors from the input
Eric Laurentd7fe0862018-07-14 16:48:01 -0700665 status_t status = audioPolicyEffects->releaseInputEffects(client->io, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700666 if(status != NO_ERROR) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700667 ALOGW("Failed to release effects on input %d", client->io);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700668 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800669 }
Eric Laurentf10c7092016-12-06 17:09:56 -0800670 {
671 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700672 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700673 mAudioPolicyManager->releaseInput(portId);
Eric Laurentf10c7092016-12-06 17:09:56 -0800674 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800675}
676
677status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
678 int indexMin,
679 int indexMax)
680{
Eric Laurentdce54a12014-03-10 12:19:46 -0700681 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800682 return NO_INIT;
683 }
684 if (!settingsAllowed()) {
685 return PERMISSION_DENIED;
686 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800687 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800688 return BAD_VALUE;
689 }
690 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700691 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700692 mAudioPolicyManager->initStreamVolume(stream, indexMin, indexMax);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800693 return NO_ERROR;
694}
695
696status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
697 int index,
698 audio_devices_t device)
699{
Eric Laurentdce54a12014-03-10 12:19:46 -0700700 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800701 return NO_INIT;
702 }
703 if (!settingsAllowed()) {
704 return PERMISSION_DENIED;
705 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800706 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800707 return BAD_VALUE;
708 }
709 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700710 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700711 return mAudioPolicyManager->setStreamVolumeIndex(stream,
712 index,
713 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800714}
715
716status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
717 int *index,
718 audio_devices_t device)
719{
Eric Laurentdce54a12014-03-10 12:19:46 -0700720 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800721 return NO_INIT;
722 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800723 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800724 return BAD_VALUE;
725 }
726 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700727 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700728 return mAudioPolicyManager->getStreamVolumeIndex(stream,
729 index,
730 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800731}
732
733uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
734{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800735 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700736 return 0;
Eric Laurentdea15412014-10-28 15:46:45 -0700737 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700738 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800739 return 0;
740 }
Eric Laurent10b71232018-04-13 18:14:44 -0700741 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700742 return mAudioPolicyManager->getStrategyForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800743}
744
745//audio policy: use audio_device_t appropriately
746
747audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
748{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800749 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700750 return AUDIO_DEVICE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700751 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700752 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700753 return AUDIO_DEVICE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800754 }
Haynes Mathew Georgedfb9f3b2015-10-26 18:22:13 -0700755 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700756 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700757 return mAudioPolicyManager->getDevicesForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800758}
759
760audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
761{
762 // FIXME change return type to status_t, and return NO_INIT here
Eric Laurentdce54a12014-03-10 12:19:46 -0700763 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800764 return 0;
765 }
766 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700767 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700768 return mAudioPolicyManager->getOutputForEffect(desc);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800769}
770
771status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
772 audio_io_handle_t io,
773 uint32_t strategy,
Glenn Kastend848eb42016-03-08 13:42:11 -0800774 audio_session_t session,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800775 int id)
776{
Eric Laurentdce54a12014-03-10 12:19:46 -0700777 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800778 return NO_INIT;
779 }
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700780 Mutex::Autolock _l(mEffectsLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700781 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700782 return mAudioPolicyManager->registerEffect(desc, io, strategy, session, id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800783}
784
785status_t AudioPolicyService::unregisterEffect(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->unregisterEffect(id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800793}
794
795status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
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->setEffectEnabled(id, enabled);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800803}
804
805bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
806{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800807 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700808 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700809 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700810 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700811 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800812 }
813 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700814 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700815 return mAudioPolicyManager->isStreamActive(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800816}
817
818bool AudioPolicyService::isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs) const
819{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800820 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700821 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700822 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700823 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700824 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800825 }
826 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700827 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700828 return mAudioPolicyManager->isStreamActiveRemotely(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800829}
830
831bool AudioPolicyService::isSourceActive(audio_source_t source) const
832{
Eric Laurentdce54a12014-03-10 12:19:46 -0700833 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800834 return false;
835 }
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->isSourceActive(source);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800839}
840
Glenn Kastend848eb42016-03-08 13:42:11 -0800841status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800842 effect_descriptor_t *descriptors,
843 uint32_t *count)
844{
Eric Laurentdce54a12014-03-10 12:19:46 -0700845 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800846 *count = 0;
847 return NO_INIT;
848 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700849 sp<AudioPolicyEffects>audioPolicyEffects;
850 {
851 Mutex::Autolock _l(mLock);
852 audioPolicyEffects = mAudioPolicyEffects;
853 }
854 if (audioPolicyEffects == 0) {
855 *count = 0;
856 return NO_INIT;
857 }
Eric Laurentfb66dd92016-01-28 18:32:03 -0800858 return audioPolicyEffects->queryDefaultInputEffects(
859 (audio_session_t)audioSession, descriptors, count);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800860}
861
862bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
863{
Eric Laurentdce54a12014-03-10 12:19:46 -0700864 if (mAudioPolicyManager == NULL) {
865 ALOGV("mAudioPolicyManager == NULL");
Eric Laurent2d388ec2014-03-07 13:25:54 -0800866 return false;
867 }
Andy Hung2ddee192015-12-18 17:34:44 -0800868 Mutex::Autolock _l(mLock);
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700869 Mutex::Autolock _le(mEffectsLock); // isOffloadSupported queries for
870 // non-offloadable effects
Eric Laurent10b71232018-04-13 18:14:44 -0700871 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700872 return mAudioPolicyManager->isOffloadSupported(info);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800873}
874
Eric Laurent6a94d692014-05-20 11:18:06 -0700875status_t AudioPolicyService::listAudioPorts(audio_port_role_t role,
876 audio_port_type_t type,
Eric Laurent203b1a12014-04-01 10:34:16 -0700877 unsigned int *num_ports,
Eric Laurent6a94d692014-05-20 11:18:06 -0700878 struct audio_port *ports,
879 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -0700880{
Eric Laurent6a94d692014-05-20 11:18:06 -0700881 Mutex::Autolock _l(mLock);
882 if (mAudioPolicyManager == NULL) {
883 return NO_INIT;
884 }
Eric Laurent10b71232018-04-13 18:14:44 -0700885 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700886 return mAudioPolicyManager->listAudioPorts(role, type, num_ports, ports, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -0700887}
888
Eric Laurent6a94d692014-05-20 11:18:06 -0700889status_t AudioPolicyService::getAudioPort(struct audio_port *port)
Eric Laurent203b1a12014-04-01 10:34:16 -0700890{
Eric Laurent6a94d692014-05-20 11:18:06 -0700891 Mutex::Autolock _l(mLock);
892 if (mAudioPolicyManager == NULL) {
893 return NO_INIT;
894 }
Eric Laurent10b71232018-04-13 18:14:44 -0700895 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700896 return mAudioPolicyManager->getAudioPort(port);
Eric Laurent203b1a12014-04-01 10:34:16 -0700897}
898
Eric Laurent6a94d692014-05-20 11:18:06 -0700899status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch,
900 audio_patch_handle_t *handle)
Eric Laurent203b1a12014-04-01 10:34:16 -0700901{
Eric Laurent6a94d692014-05-20 11:18:06 -0700902 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -0700903 if(!modifyAudioRoutingAllowed()) {
904 return PERMISSION_DENIED;
905 }
Eric Laurent6a94d692014-05-20 11:18:06 -0700906 if (mAudioPolicyManager == NULL) {
907 return NO_INIT;
908 }
Eric Laurent10b71232018-04-13 18:14:44 -0700909 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700910 return mAudioPolicyManager->createAudioPatch(patch, handle,
911 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -0700912}
913
Eric Laurent6a94d692014-05-20 11:18:06 -0700914status_t AudioPolicyService::releaseAudioPatch(audio_patch_handle_t handle)
Eric Laurent203b1a12014-04-01 10:34:16 -0700915{
Eric Laurent6a94d692014-05-20 11:18:06 -0700916 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -0700917 if(!modifyAudioRoutingAllowed()) {
918 return PERMISSION_DENIED;
919 }
Eric Laurent6a94d692014-05-20 11:18:06 -0700920 if (mAudioPolicyManager == NULL) {
921 return NO_INIT;
922 }
Eric Laurent10b71232018-04-13 18:14:44 -0700923 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700924 return mAudioPolicyManager->releaseAudioPatch(handle,
925 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -0700926}
927
928status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
Eric Laurent6a94d692014-05-20 11:18:06 -0700929 struct audio_patch *patches,
930 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -0700931{
Eric Laurent6a94d692014-05-20 11:18:06 -0700932 Mutex::Autolock _l(mLock);
933 if (mAudioPolicyManager == NULL) {
934 return NO_INIT;
935 }
Eric Laurent10b71232018-04-13 18:14:44 -0700936 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700937 return mAudioPolicyManager->listAudioPatches(num_patches, patches, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -0700938}
939
Eric Laurent6a94d692014-05-20 11:18:06 -0700940status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config)
Eric Laurent203b1a12014-04-01 10:34:16 -0700941{
Eric Laurent6a94d692014-05-20 11:18:06 -0700942 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -0700943 if(!modifyAudioRoutingAllowed()) {
944 return PERMISSION_DENIED;
945 }
Eric Laurent6a94d692014-05-20 11:18:06 -0700946 if (mAudioPolicyManager == NULL) {
947 return NO_INIT;
948 }
Eric Laurent10b71232018-04-13 18:14:44 -0700949 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -0700950 return mAudioPolicyManager->setAudioPortConfig(config);
Eric Laurent203b1a12014-04-01 10:34:16 -0700951}
Eric Laurent2d388ec2014-03-07 13:25:54 -0800952
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700953status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session,
954 audio_io_handle_t *ioHandle,
955 audio_devices_t *device)
956{
Andy Hungf759b8c2017-08-15 12:48:54 -0700957 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700958 if (mAudioPolicyManager == NULL) {
959 return NO_INIT;
960 }
Eric Laurent10b71232018-04-13 18:14:44 -0700961 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700962 return mAudioPolicyManager->acquireSoundTriggerSession(session, ioHandle, device);
963}
964
965status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session)
966{
Andy Hungf759b8c2017-08-15 12:48:54 -0700967 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700968 if (mAudioPolicyManager == NULL) {
969 return NO_INIT;
970 }
Eric Laurent10b71232018-04-13 18:14:44 -0700971 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700972 return mAudioPolicyManager->releaseSoundTriggerSession(session);
973}
974
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -0700975status_t AudioPolicyService::registerPolicyMixes(const Vector<AudioMix>& mixes, bool registration)
Eric Laurentbaac1832014-12-01 17:52:59 -0800976{
977 Mutex::Autolock _l(mLock);
978 if(!modifyAudioRoutingAllowed()) {
979 return PERMISSION_DENIED;
980 }
981 if (mAudioPolicyManager == NULL) {
982 return NO_INIT;
983 }
Eric Laurent10b71232018-04-13 18:14:44 -0700984 AutoCallerClear acc;
Eric Laurentbaac1832014-12-01 17:52:59 -0800985 if (registration) {
986 return mAudioPolicyManager->registerPolicyMixes(mixes);
987 } else {
988 return mAudioPolicyManager->unregisterPolicyMixes(mixes);
989 }
990}
991
Eric Laurent554a2772015-04-10 11:29:24 -0700992status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
Eric Laurent3e6c7e12018-07-27 17:09:23 -0700993 const audio_attributes_t *attributes,
994 audio_port_handle_t *portId)
Eric Laurent554a2772015-04-10 11:29:24 -0700995{
996 Mutex::Autolock _l(mLock);
997 if (mAudioPolicyManager == NULL) {
998 return NO_INIT;
999 }
Eric Laurent10b71232018-04-13 18:14:44 -07001000 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001001 return mAudioPolicyManager->startAudioSource(source, attributes, portId,
Eric Laurentd60560a2015-04-10 11:31:20 -07001002 IPCThreadState::self()->getCallingUid());
Eric Laurent554a2772015-04-10 11:29:24 -07001003}
1004
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001005status_t AudioPolicyService::stopAudioSource(audio_port_handle_t portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001006{
1007 Mutex::Autolock _l(mLock);
1008 if (mAudioPolicyManager == NULL) {
1009 return NO_INIT;
1010 }
Eric Laurent10b71232018-04-13 18:14:44 -07001011 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001012 return mAudioPolicyManager->stopAudioSource(portId);
Eric Laurent554a2772015-04-10 11:29:24 -07001013}
1014
Andy Hung2ddee192015-12-18 17:34:44 -08001015status_t AudioPolicyService::setMasterMono(bool mono)
1016{
1017 if (mAudioPolicyManager == NULL) {
1018 return NO_INIT;
1019 }
1020 if (!settingsAllowed()) {
1021 return PERMISSION_DENIED;
1022 }
1023 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001024 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001025 return mAudioPolicyManager->setMasterMono(mono);
1026}
1027
1028status_t AudioPolicyService::getMasterMono(bool *mono)
1029{
1030 if (mAudioPolicyManager == NULL) {
1031 return NO_INIT;
1032 }
1033 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001034 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001035 return mAudioPolicyManager->getMasterMono(mono);
1036}
1037
Eric Laurentac9cef52017-06-09 15:46:26 -07001038
1039float AudioPolicyService::getStreamVolumeDB(
1040 audio_stream_type_t stream, int index, audio_devices_t device)
1041{
1042 if (mAudioPolicyManager == NULL) {
1043 return NAN;
1044 }
1045 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001046 AutoCallerClear acc;
Eric Laurentac9cef52017-06-09 15:46:26 -07001047 return mAudioPolicyManager->getStreamVolumeDB(stream, index, device);
1048}
1049
jiabin81772902018-04-02 17:52:27 -07001050status_t AudioPolicyService::getSurroundFormats(unsigned int *numSurroundFormats,
1051 audio_format_t *surroundFormats,
1052 bool *surroundFormatsEnabled,
1053 bool reported)
1054{
1055 if (mAudioPolicyManager == NULL) {
1056 return NO_INIT;
1057 }
1058 Mutex::Autolock _l(mLock);
1059 AutoCallerClear acc;
1060 return mAudioPolicyManager->getSurroundFormats(numSurroundFormats, surroundFormats,
1061 surroundFormatsEnabled, reported);
1062}
1063
1064status_t AudioPolicyService::setSurroundFormatEnabled(audio_format_t audioFormat, bool enabled)
1065{
1066 if (mAudioPolicyManager == NULL) {
1067 return NO_INIT;
1068 }
1069 Mutex::Autolock _l(mLock);
1070 AutoCallerClear acc;
1071 return mAudioPolicyManager->setSurroundFormatEnabled(audioFormat, enabled);
1072}
Eric Laurentac9cef52017-06-09 15:46:26 -07001073
Mikhail Naganov1b2a7942017-12-08 10:18:09 -08001074} // namespace android