blob: c1190be34337e261f9f57ddfd9aebc88812b43a8 [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>
Kevin Rocardbe201852019-02-20 22:33:28 -080023#include <media/AudioPolicy.h>
Eric Laurentd7fe0862018-07-14 16:48:01 -070024#include <utils/Log.h>
Eric Laurent2d388ec2014-03-07 13:25:54 -080025
Eric Laurent2d388ec2014-03-07 13:25:54 -080026namespace android {
27
28
29// ----------------------------------------------------------------------------
30
31status_t AudioPolicyService::setDeviceConnectionState(audio_devices_t device,
32 audio_policy_dev_state_t state,
Paul McLeane743a472015-01-28 11:07:31 -080033 const char *device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080034 const char *device_name,
35 audio_format_t encodedFormat)
Eric Laurent2d388ec2014-03-07 13:25:54 -080036{
Eric Laurentdce54a12014-03-10 12:19:46 -070037 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080038 return NO_INIT;
39 }
40 if (!settingsAllowed()) {
41 return PERMISSION_DENIED;
42 }
Eric Laurent2d388ec2014-03-07 13:25:54 -080043 if (state != AUDIO_POLICY_DEVICE_STATE_AVAILABLE &&
44 state != AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE) {
45 return BAD_VALUE;
46 }
47
48 ALOGV("setDeviceConnectionState()");
49 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -070050 AutoCallerClear acc;
Paul McLeane743a472015-01-28 11:07:31 -080051 return mAudioPolicyManager->setDeviceConnectionState(device, state,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080052 device_address, device_name, encodedFormat);
Eric Laurent2d388ec2014-03-07 13:25:54 -080053}
54
55audio_policy_dev_state_t AudioPolicyService::getDeviceConnectionState(
56 audio_devices_t device,
57 const char *device_address)
58{
Eric Laurentdce54a12014-03-10 12:19:46 -070059 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080060 return AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE;
61 }
Eric Laurent10b71232018-04-13 18:14:44 -070062 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -070063 return mAudioPolicyManager->getDeviceConnectionState(device,
Eric Laurent2d388ec2014-03-07 13:25:54 -080064 device_address);
65}
66
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080067status_t AudioPolicyService::handleDeviceConfigChange(audio_devices_t device,
68 const char *device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080069 const char *device_name,
70 audio_format_t encodedFormat)
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080071{
72 if (mAudioPolicyManager == NULL) {
73 return NO_INIT;
74 }
75 if (!settingsAllowed()) {
76 return PERMISSION_DENIED;
77 }
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080078
79 ALOGV("handleDeviceConfigChange()");
80 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -070081 AutoCallerClear acc;
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080082 return mAudioPolicyManager->handleDeviceConfigChange(device, device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080083 device_name, encodedFormat);
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080084}
85
Eric Laurent2d388ec2014-03-07 13:25:54 -080086status_t AudioPolicyService::setPhoneState(audio_mode_t state)
87{
Eric Laurentdce54a12014-03-10 12:19:46 -070088 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080089 return NO_INIT;
90 }
91 if (!settingsAllowed()) {
92 return PERMISSION_DENIED;
93 }
94 if (uint32_t(state) >= AUDIO_MODE_CNT) {
95 return BAD_VALUE;
96 }
97
98 ALOGV("setPhoneState()");
99
Eric Laurentbeb07fe2015-09-16 15:49:30 -0700100 // acquire lock before calling setMode() so that setMode() + setPhoneState() are an atomic
101 // operation from policy manager standpoint (no other operation (e.g track start or stop)
102 // can be interleaved).
103 Mutex::Autolock _l(mLock);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800104 // TODO: check if it is more appropriate to do it in platform specific policy manager
105 AudioSystem::setMode(state);
106
Eric Laurent10b71232018-04-13 18:14:44 -0700107 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700108 mAudioPolicyManager->setPhoneState(state);
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700109 mPhoneState = state;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800110 return NO_ERROR;
111}
112
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700113audio_mode_t AudioPolicyService::getPhoneState()
114{
115 Mutex::Autolock _l(mLock);
116 return mPhoneState;
117}
118
Eric Laurent2d388ec2014-03-07 13:25:54 -0800119status_t AudioPolicyService::setForceUse(audio_policy_force_use_t usage,
120 audio_policy_forced_cfg_t config)
121{
Eric Laurentdce54a12014-03-10 12:19:46 -0700122 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800123 return NO_INIT;
124 }
Eric Laurente17378d2018-05-09 14:43:01 -0700125
126 if (!modifyAudioRoutingAllowed()) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800127 return PERMISSION_DENIED;
128 }
Eric Laurente17378d2018-05-09 14:43:01 -0700129
Eric Laurent2d388ec2014-03-07 13:25:54 -0800130 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
131 return BAD_VALUE;
132 }
133 if (config < 0 || config >= AUDIO_POLICY_FORCE_CFG_CNT) {
134 return BAD_VALUE;
135 }
136 ALOGV("setForceUse()");
137 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700138 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700139 mAudioPolicyManager->setForceUse(usage, config);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800140 return NO_ERROR;
141}
142
143audio_policy_forced_cfg_t AudioPolicyService::getForceUse(audio_policy_force_use_t usage)
144{
Eric Laurentdce54a12014-03-10 12:19:46 -0700145 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800146 return AUDIO_POLICY_FORCE_NONE;
147 }
148 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
149 return AUDIO_POLICY_FORCE_NONE;
150 }
Eric Laurent10b71232018-04-13 18:14:44 -0700151 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700152 return mAudioPolicyManager->getForceUse(usage);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800153}
154
Eric Laurentf4e63452017-11-06 19:31:46 +0000155audio_io_handle_t AudioPolicyService::getOutput(audio_stream_type_t stream)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800156{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800157 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700158 return AUDIO_IO_HANDLE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700159 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700160 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700161 return AUDIO_IO_HANDLE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800162 }
163 ALOGV("getOutput()");
164 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700165 AutoCallerClear acc;
Eric Laurentf4e63452017-11-06 19:31:46 +0000166 return mAudioPolicyManager->getOutput(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800167}
168
Eric Laurent42984412019-05-09 17:57:03 -0700169status_t AudioPolicyService::getOutputForAttr(audio_attributes_t *attr,
Eric Laurente83b55d2014-11-14 10:06:21 -0800170 audio_io_handle_t *output,
171 audio_session_t session,
172 audio_stream_type_t *stream,
Nadav Bar766fb022018-01-07 12:18:03 +0200173 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700174 uid_t uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800175 const audio_config_t *config,
Eric Laurente83b55d2014-11-14 10:06:21 -0800176 audio_output_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700177 audio_port_handle_t *selectedDeviceId,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800178 audio_port_handle_t *portId,
179 std::vector<audio_io_handle_t> *secondaryOutputs)
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700180{
181 if (mAudioPolicyManager == NULL) {
Eric Laurente83b55d2014-11-14 10:06:21 -0800182 return NO_INIT;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700183 }
Eric Laurentf4e63452017-11-06 19:31:46 +0000184 ALOGV("getOutputForAttr()");
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700185 Mutex::Autolock _l(mLock);
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700186
Marco Nelissendcb346b2015-09-09 10:47:29 -0700187 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700188 if (!isAudioServerOrMediaServerUid(callingUid) || uid == (uid_t)-1) {
Marco Nelissendcb346b2015-09-09 10:47:29 -0700189 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
190 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
191 uid = callingUid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700192 }
Kevin Rocard8be94972019-02-22 13:26:25 -0800193 if (!mPackageManager.allowPlaybackCapture(uid)) {
Eric Laurent42984412019-05-09 17:57:03 -0700194 attr->flags |= AUDIO_FLAG_NO_MEDIA_PROJECTION;
195 }
Eric Laurent6ede98f2019-06-11 14:50:30 -0700196 if (((attr->flags & (AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE)) != 0)
197 && !bypassInterruptionPolicyAllowed(pid, uid)) {
Eric Laurent42984412019-05-09 17:57:03 -0700198 attr->flags &= ~(AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE);
Kevin Rocard8be94972019-02-22 13:26:25 -0800199 }
Nadav Bar766fb022018-01-07 12:18:03 +0200200 audio_output_flags_t originalFlags = flags;
Eric Laurent10b71232018-04-13 18:14:44 -0700201 AutoCallerClear acc;
Eric Laurent42984412019-05-09 17:57:03 -0700202 status_t result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800203 config,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800204 &flags, selectedDeviceId, portId,
205 secondaryOutputs);
Nadav Bar766fb022018-01-07 12:18:03 +0200206
207 // FIXME: Introduce a way to check for the the telephony device before opening the output
208 if ((result == NO_ERROR) &&
209 (flags & AUDIO_OUTPUT_FLAG_INCALL_MUSIC) &&
210 !modifyPhoneStateAllowed(pid, uid)) {
211 // If the app tries to play music through the telephony device and doesn't have permission
212 // the fallback to the default output device.
Eric Laurent8fc147b2018-07-22 19:13:55 -0700213 mAudioPolicyManager->releaseOutput(*portId);
Nadav Bar766fb022018-01-07 12:18:03 +0200214 flags = originalFlags;
215 *selectedDeviceId = AUDIO_PORT_HANDLE_NONE;
216 *portId = AUDIO_PORT_HANDLE_NONE;
Kevin Rocard153f92d2018-12-18 18:33:28 -0800217 secondaryOutputs->clear();
Eric Laurent42984412019-05-09 17:57:03 -0700218 result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid, config,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800219 &flags, selectedDeviceId, portId,
220 secondaryOutputs);
Nadav Bar766fb022018-01-07 12:18:03 +0200221 }
Eric Laurentd7fe0862018-07-14 16:48:01 -0700222
223 if (result == NO_ERROR) {
224 sp <AudioPlaybackClient> client =
Eric Laurent42984412019-05-09 17:57:03 -0700225 new AudioPlaybackClient(*attr, *output, uid, pid, session, *selectedDeviceId, *stream);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700226 mAudioPlaybackClients.add(*portId, client);
227 }
Nadav Bar766fb022018-01-07 12:18:03 +0200228 return result;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700229}
230
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700231void AudioPolicyService::getPlaybackClientAndEffects(audio_port_handle_t portId,
232 sp<AudioPlaybackClient>& client,
233 sp<AudioPolicyEffects>& effects,
234 const char *context)
235{
236 Mutex::Autolock _l(mLock);
237 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
238 if (index < 0) {
239 ALOGE("%s AudioTrack client not found for portId %d", context, portId);
240 return;
241 }
242 client = mAudioPlaybackClients.valueAt(index);
243 effects = mAudioPolicyEffects;
244}
245
Eric Laurentd7fe0862018-07-14 16:48:01 -0700246status_t AudioPolicyService::startOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800247{
Eric Laurentdce54a12014-03-10 12:19:46 -0700248 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800249 return NO_INIT;
250 }
251 ALOGV("startOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700252 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700253 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700254
255 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
256
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700257 if (audioPolicyEffects != 0) {
258 // create audio processors according to stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700259 status_t status = audioPolicyEffects->addOutputSessionEffects(
260 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700261 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700262 ALOGW("Failed to add effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700263 }
264 }
265 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700266 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700267 status_t status = mAudioPolicyManager->startOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700268 if (status == NO_ERROR) {
269 client->active = true;
270 }
271 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800272}
273
Eric Laurentd7fe0862018-07-14 16:48:01 -0700274status_t AudioPolicyService::stopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800275{
Eric Laurentdce54a12014-03-10 12:19:46 -0700276 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800277 return NO_INIT;
278 }
279 ALOGV("stopOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700280 mOutputCommandThread->stopOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800281 return NO_ERROR;
282}
283
Eric Laurentd7fe0862018-07-14 16:48:01 -0700284status_t AudioPolicyService::doStopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800285{
Eric Laurentd7fe0862018-07-14 16:48:01 -0700286 ALOGV("doStopOutput");
287 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700288 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentd7fe0862018-07-14 16:48:01 -0700289
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700290 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
291
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700292 if (audioPolicyEffects != 0) {
293 // release audio processors from the stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700294 status_t status = audioPolicyEffects->releaseOutputSessionEffects(
295 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700296 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700297 ALOGW("Failed to release effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700298 }
299 }
300 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700301 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700302 status_t status = mAudioPolicyManager->stopOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700303 if (status == NO_ERROR) {
304 client->active = false;
305 }
306 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800307}
308
Eric Laurentd7fe0862018-07-14 16:48:01 -0700309void AudioPolicyService::releaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800310{
Eric Laurentdce54a12014-03-10 12:19:46 -0700311 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800312 return;
313 }
314 ALOGV("releaseOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700315 mOutputCommandThread->releaseOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800316}
317
Eric Laurentd7fe0862018-07-14 16:48:01 -0700318void AudioPolicyService::doReleaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800319{
320 ALOGV("doReleaseOutput from tid %d", gettid());
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700321 sp<AudioPlaybackClient> client;
322 sp<AudioPolicyEffects> audioPolicyEffects;
323
324 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
325
326 if (audioPolicyEffects != 0 && client->active) {
327 // clean up effects if output was not stopped before being released
328 audioPolicyEffects->releaseOutputSessionEffects(
329 client->io, client->stream, client->session);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700330 }
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700331 Mutex::Autolock _l(mLock);
Eric Laurentd4007242019-03-27 12:42:16 -0700332 mAudioPlaybackClients.removeItem(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700333
Eric Laurent10b71232018-04-13 18:14:44 -0700334 // called from internal thread: no need to clear caller identity
Eric Laurent8fc147b2018-07-22 19:13:55 -0700335 mAudioPolicyManager->releaseOutput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800336}
337
Eric Laurentcaf7f482014-11-25 17:50:47 -0800338status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
339 audio_io_handle_t *input,
Mikhail Naganov2996f672019-04-18 12:29:59 -0700340 audio_unique_id_t riid,
Eric Laurentcaf7f482014-11-25 17:50:47 -0800341 audio_session_t session,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700342 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700343 uid_t uid,
Eric Laurentfee19762018-01-29 18:44:13 -0800344 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800345 const audio_config_base_t *config,
Paul McLean466dc8e2015-04-17 13:15:36 -0600346 audio_input_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700347 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800348 audio_port_handle_t *portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800349{
Eric Laurentdce54a12014-03-10 12:19:46 -0700350 if (mAudioPolicyManager == NULL) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800351 return NO_INIT;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800352 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800353
Hiroaki Hayashi685a9712019-07-18 19:50:47 +0900354 audio_source_t inputSource = attr->source;
355 if (inputSource == AUDIO_SOURCE_DEFAULT) {
356 inputSource = AUDIO_SOURCE_MIC;
357 }
358
Eric Laurent2d388ec2014-03-07 13:25:54 -0800359 // already checked by client, but double-check in case the client wrapper is bypassed
Hiroaki Hayashi685a9712019-07-18 19:50:47 +0900360 if ((inputSource < AUDIO_SOURCE_DEFAULT)
361 || (inputSource >= AUDIO_SOURCE_CNT
362 && inputSource != AUDIO_SOURCE_HOTWORD
363 && inputSource != AUDIO_SOURCE_FM_TUNER
364 && inputSource != AUDIO_SOURCE_ECHO_REFERENCE)) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800365 return BAD_VALUE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800366 }
367
Eric Laurentb2379ba2016-05-23 17:42:12 -0700368 bool updatePid = (pid == -1);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700369 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700370 if (!isAudioServerOrMediaServerUid(callingUid)) {
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700371 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Marco Nelissendcb346b2015-09-09 10:47:29 -0700372 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
373 uid = callingUid;
Eric Laurentb2379ba2016-05-23 17:42:12 -0700374 updatePid = true;
375 }
376
377 if (updatePid) {
378 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700379 ALOGW_IF(pid != (pid_t)-1 && pid != callingPid,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700380 "%s uid %d pid %d tried to pass itself off as pid %d",
381 __func__, callingUid, callingPid, pid);
382 pid = callingPid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700383 }
384
Eric Laurent7dca8a82018-01-29 18:44:26 -0800385 // check calling permissions
386 if (!recordingAllowed(opPackageName, pid, uid)) {
387 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
388 __func__, uid, pid);
389 return PERMISSION_DENIED;
390 }
391
Eric Laurent1ff16a72019-03-14 18:35:04 -0700392 bool canCaptureOutput = captureAudioOutputAllowed(pid, uid);
Hiroaki Hayashi685a9712019-07-18 19:50:47 +0900393 if ((inputSource == AUDIO_SOURCE_VOICE_UPLINK ||
394 inputSource == AUDIO_SOURCE_VOICE_DOWNLINK ||
395 inputSource == AUDIO_SOURCE_VOICE_CALL ||
396 inputSource == AUDIO_SOURCE_ECHO_REFERENCE) &&
Eric Laurent1ff16a72019-03-14 18:35:04 -0700397 !canCaptureOutput) {
Nadav Bar744be482018-05-08 13:26:21 +0300398 return PERMISSION_DENIED;
399 }
400
jiabin68e0df72019-03-18 17:55:35 -0700401 bool canCaptureHotword = captureHotwordAllowed(opPackageName, pid, uid);
Hiroaki Hayashi685a9712019-07-18 19:50:47 +0900402 if ((inputSource == AUDIO_SOURCE_HOTWORD) && !canCaptureHotword) {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700403 return BAD_VALUE;
404 }
405
406 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700407 {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700408 status_t status;
409 AudioPolicyInterface::input_type_t inputType;
410
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700411 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700412 {
413 AutoCallerClear acc;
414 // the audio_in_acoustics_t parameter is ignored by get_input()
Mikhail Naganov2996f672019-04-18 12:29:59 -0700415 status = mAudioPolicyManager->getInputForAttr(attr, input, riid, session, uid,
Eric Laurent10b71232018-04-13 18:14:44 -0700416 config,
417 flags, selectedDeviceId,
418 &inputType, portId);
419 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700420 audioPolicyEffects = mAudioPolicyEffects;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800421
422 if (status == NO_ERROR) {
423 // enforce permission (if any) required for each type of input
424 switch (inputType) {
Kevin Rocard25f9b052019-02-27 15:08:54 -0800425 case AudioPolicyInterface::API_INPUT_MIX_PUBLIC_CAPTURE_PLAYBACK:
426 // this use case has been validated in audio service with a MediaProjection token,
427 // and doesn't rely on regular permissions
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800428 case AudioPolicyInterface::API_INPUT_LEGACY:
429 break;
Eric Laurent82db2692015-08-07 13:59:42 -0700430 case AudioPolicyInterface::API_INPUT_TELEPHONY_RX:
431 // FIXME: use the same permission as for remote submix for now.
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800432 case AudioPolicyInterface::API_INPUT_MIX_CAPTURE:
Eric Laurent1ff16a72019-03-14 18:35:04 -0700433 if (!canCaptureOutput) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800434 ALOGE("getInputForAttr() permission denied: capture not allowed");
435 status = PERMISSION_DENIED;
436 }
437 break;
438 case AudioPolicyInterface::API_INPUT_MIX_EXT_POLICY_REROUTE:
439 if (!modifyAudioRoutingAllowed()) {
440 ALOGE("getInputForAttr() permission denied: modify audio routing not allowed");
441 status = PERMISSION_DENIED;
442 }
443 break;
444 case AudioPolicyInterface::API_INPUT_INVALID:
445 default:
446 LOG_ALWAYS_FATAL("getInputForAttr() encountered an invalid input type %d",
447 (int)inputType);
448 }
449 }
450
451 if (status != NO_ERROR) {
452 if (status == PERMISSION_DENIED) {
Eric Laurent10b71232018-04-13 18:14:44 -0700453 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700454 mAudioPolicyManager->releaseInput(*portId);
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800455 }
456 return status;
457 }
Eric Laurentfee19762018-01-29 18:44:13 -0800458
Eric Laurentd7fe0862018-07-14 16:48:01 -0700459 sp<AudioRecordClient> client = new AudioRecordClient(*attr, *input, uid, pid, session,
Eric Laurent1ff16a72019-03-14 18:35:04 -0700460 *selectedDeviceId, opPackageName,
461 canCaptureOutput, canCaptureHotword);
Eric Laurentfee19762018-01-29 18:44:13 -0800462 mAudioRecordClients.add(*portId, client);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700463 }
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800464
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700465 if (audioPolicyEffects != 0) {
466 // create audio pre processors according to input source
Hiroaki Hayashi685a9712019-07-18 19:50:47 +0900467 status_t status = audioPolicyEffects->addInputEffects(*input, inputSource, session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700468 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800469 ALOGW("Failed to add effects on input %d", *input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700470 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800471 }
Eric Laurentcaf7f482014-11-25 17:50:47 -0800472 return NO_ERROR;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800473}
474
Eric Laurent99fcae42018-05-17 16:59:18 -0700475std::string AudioPolicyService::getDeviceTypeStrForPortId(audio_port_handle_t portId) {
Eric Laurent99fcae42018-05-17 16:59:18 -0700476 struct audio_port port = {};
477 port.id = portId;
478 status_t status = mAudioPolicyManager->getAudioPort(&port);
479 if (status == NO_ERROR && port.type == AUDIO_PORT_TYPE_DEVICE) {
Andy Hung9b181952019-02-25 14:53:36 -0800480 return toString(port.ext.device.type);
Eric Laurent99fcae42018-05-17 16:59:18 -0700481 }
Andy Hung9b181952019-02-25 14:53:36 -0800482 return {};
Eric Laurent99fcae42018-05-17 16:59:18 -0700483}
484
Eric Laurent4eb58f12018-12-07 16:41:02 -0800485status_t AudioPolicyService::startInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800486{
Eric Laurentdce54a12014-03-10 12:19:46 -0700487 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800488 return NO_INIT;
489 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800490 sp<AudioRecordClient> client;
491 {
492 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800493
Eric Laurent7dca8a82018-01-29 18:44:26 -0800494 ssize_t index = mAudioRecordClients.indexOfKey(portId);
495 if (index < 0) {
496 return INVALID_OPERATION;
497 }
498 client = mAudioRecordClients.valueAt(index);
Eric Laurentfee19762018-01-29 18:44:13 -0800499 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800500
501 // check calling permissions
Svet Ganov6e641372018-03-02 09:21:30 -0800502 if (!startRecording(client->opPackageName, client->pid, client->uid)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800503 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
504 __func__, client->uid, client->pid);
505 return PERMISSION_DENIED;
506 }
Eric Laurentfee19762018-01-29 18:44:13 -0800507
Eric Laurentdf628922018-12-06 21:45:51 +0000508 Mutex::Autolock _l(mLock);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800509
510 client->active = true;
511 client->startTimeNs = systemTime();
512 updateUidStates_l();
Eric Laurentfee19762018-01-29 18:44:13 -0800513
Eric Laurent10b71232018-04-13 18:14:44 -0700514 status_t status;
515 {
516 AutoCallerClear acc;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800517 status = mAudioPolicyManager->startInput(portId);
Ray Essick84e84a52018-05-03 18:45:07 -0700518
519 }
520
Ray Essickf6a57cd2018-05-22 16:20:54 -0700521 // including successes gets very verbose
Ray Essick6ce27e52019-02-15 10:58:05 -0800522 // but once we cut over to westworld, log them all.
Ray Essickf6a57cd2018-05-22 16:20:54 -0700523 if (status != NO_ERROR) {
Ray Essick84e84a52018-05-03 18:45:07 -0700524
525 static constexpr char kAudioPolicy[] = "audiopolicy";
526
Ray Essick84e84a52018-05-03 18:45:07 -0700527 static constexpr char kAudioPolicyStatus[] = "android.media.audiopolicy.status";
528 static constexpr char kAudioPolicyRqstSrc[] = "android.media.audiopolicy.rqst.src";
529 static constexpr char kAudioPolicyRqstPkg[] = "android.media.audiopolicy.rqst.pkg";
530 static constexpr char kAudioPolicyRqstSession[] = "android.media.audiopolicy.rqst.session";
Eric Laurent99fcae42018-05-17 16:59:18 -0700531 static constexpr char kAudioPolicyRqstDevice[] =
532 "android.media.audiopolicy.rqst.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700533 static constexpr char kAudioPolicyActiveSrc[] = "android.media.audiopolicy.active.src";
534 static constexpr char kAudioPolicyActivePkg[] = "android.media.audiopolicy.active.pkg";
Eric Laurent99fcae42018-05-17 16:59:18 -0700535 static constexpr char kAudioPolicyActiveSession[] =
536 "android.media.audiopolicy.active.session";
537 static constexpr char kAudioPolicyActiveDevice[] =
538 "android.media.audiopolicy.active.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700539
Ray Essick6a305222019-01-28 20:33:18 -0800540 MediaAnalyticsItem *item = MediaAnalyticsItem::create(kAudioPolicy);
Ray Essick84e84a52018-05-03 18:45:07 -0700541 if (item != NULL) {
542
Ray Essick84e84a52018-05-03 18:45:07 -0700543 item->setInt32(kAudioPolicyStatus, status);
544
Eric Laurent99fcae42018-05-17 16:59:18 -0700545 item->setCString(kAudioPolicyRqstSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800546 toString(client->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700547 item->setInt32(kAudioPolicyRqstSession, client->session);
Ray Essick51866952018-05-30 11:22:27 -0700548 if (client->opPackageName.size() != 0) {
549 item->setCString(kAudioPolicyRqstPkg,
550 std::string(String8(client->opPackageName).string()).c_str());
551 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700552 item->setCString(kAudioPolicyRqstPkg, std::to_string(client->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700553 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700554 item->setCString(
555 kAudioPolicyRqstDevice, getDeviceTypeStrForPortId(client->deviceId).c_str());
556
Eric Laurent4eb58f12018-12-07 16:41:02 -0800557 int count = mAudioRecordClients.size();
558 for (int i = 0; i < count ; i++) {
559 if (portId == mAudioRecordClients.keyAt(i)) {
560 continue;
561 }
562 sp<AudioRecordClient> other = mAudioRecordClients.valueAt(i);
563 if (other->active) {
564 // keeps the last of the clients marked active
565 item->setCString(kAudioPolicyActiveSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800566 toString(other->attributes.source).c_str());
Eric Laurent4eb58f12018-12-07 16:41:02 -0800567 item->setInt32(kAudioPolicyActiveSession, other->session);
568 if (other->opPackageName.size() != 0) {
569 item->setCString(kAudioPolicyActivePkg,
570 std::string(String8(other->opPackageName).string()).c_str());
571 } else {
572 item->setCString(kAudioPolicyRqstPkg,
573 std::to_string(other->uid).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700574 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800575 item->setCString(kAudioPolicyActiveDevice,
576 getDeviceTypeStrForPortId(other->deviceId).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700577 }
578 }
579 item->selfrecord();
580 delete item;
581 item = NULL;
582 }
Ray Essick6ce27e52019-02-15 10:58:05 -0800583 }
584
585 if (status != NO_ERROR) {
Eric Laurent4eb58f12018-12-07 16:41:02 -0800586 client->active = false;
587 client->startTimeNs = 0;
588 updateUidStates_l();
Svet Ganov6e641372018-03-02 09:21:30 -0800589 finishRecording(client->opPackageName, client->uid);
Eric Laurentfb66dd92016-01-28 18:32:03 -0800590 }
591
592 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800593}
594
Eric Laurentfee19762018-01-29 18:44:13 -0800595status_t AudioPolicyService::stopInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800596{
Eric Laurentdce54a12014-03-10 12:19:46 -0700597 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800598 return NO_INIT;
599 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800600
Eric Laurent2d388ec2014-03-07 13:25:54 -0800601 Mutex::Autolock _l(mLock);
602
Eric Laurentfee19762018-01-29 18:44:13 -0800603 ssize_t index = mAudioRecordClients.indexOfKey(portId);
604 if (index < 0) {
605 return INVALID_OPERATION;
606 }
607 sp<AudioRecordClient> client = mAudioRecordClients.valueAt(index);
608
Ray Essick84e84a52018-05-03 18:45:07 -0700609 client->active = false;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800610 client->startTimeNs = 0;
611
612 updateUidStates_l();
Ray Essick84e84a52018-05-03 18:45:07 -0700613
Svet Ganov6e641372018-03-02 09:21:30 -0800614 // finish the recording app op
615 finishRecording(client->opPackageName, client->uid);
Eric Laurent10b71232018-04-13 18:14:44 -0700616 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700617 return mAudioPolicyManager->stopInput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800618}
619
Eric Laurentfee19762018-01-29 18:44:13 -0800620void AudioPolicyService::releaseInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800621{
Eric Laurentdce54a12014-03-10 12:19:46 -0700622 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800623 return;
624 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700625 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800626 sp<AudioRecordClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700627 {
628 Mutex::Autolock _l(mLock);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700629 audioPolicyEffects = mAudioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800630 ssize_t index = mAudioRecordClients.indexOfKey(portId);
631 if (index < 0) {
632 return;
633 }
634 client = mAudioRecordClients.valueAt(index);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800635
636 if (client->active) {
637 ALOGW("%s releasing active client portId %d", __FUNCTION__, portId);
638 client->active = false;
639 client->startTimeNs = 0;
640 updateUidStates_l();
641 }
642
Eric Laurentfee19762018-01-29 18:44:13 -0800643 mAudioRecordClients.removeItem(portId);
644 }
645 if (client == 0) {
646 return;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700647 }
648 if (audioPolicyEffects != 0) {
649 // release audio processors from the input
Eric Laurentd7fe0862018-07-14 16:48:01 -0700650 status_t status = audioPolicyEffects->releaseInputEffects(client->io, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700651 if(status != NO_ERROR) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700652 ALOGW("Failed to release effects on input %d", client->io);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700653 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800654 }
Eric Laurentf10c7092016-12-06 17:09:56 -0800655 {
656 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700657 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700658 mAudioPolicyManager->releaseInput(portId);
Eric Laurentf10c7092016-12-06 17:09:56 -0800659 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800660}
661
662status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
663 int indexMin,
664 int indexMax)
665{
Eric Laurentdce54a12014-03-10 12:19:46 -0700666 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800667 return NO_INIT;
668 }
669 if (!settingsAllowed()) {
670 return PERMISSION_DENIED;
671 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800672 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800673 return BAD_VALUE;
674 }
675 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700676 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700677 mAudioPolicyManager->initStreamVolume(stream, indexMin, indexMax);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800678 return NO_ERROR;
679}
680
681status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
682 int index,
683 audio_devices_t device)
684{
Eric Laurentdce54a12014-03-10 12:19:46 -0700685 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800686 return NO_INIT;
687 }
688 if (!settingsAllowed()) {
689 return PERMISSION_DENIED;
690 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800691 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800692 return BAD_VALUE;
693 }
694 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700695 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700696 return mAudioPolicyManager->setStreamVolumeIndex(stream,
697 index,
698 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800699}
700
701status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
702 int *index,
703 audio_devices_t device)
704{
Eric Laurentdce54a12014-03-10 12:19:46 -0700705 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800706 return NO_INIT;
707 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800708 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800709 return BAD_VALUE;
710 }
711 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700712 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700713 return mAudioPolicyManager->getStreamVolumeIndex(stream,
714 index,
715 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800716}
717
François Gaffiecfe17322018-11-07 13:41:29 +0100718status_t AudioPolicyService::setVolumeIndexForAttributes(const audio_attributes_t &attributes,
719 int index, audio_devices_t device)
720{
721 if (mAudioPolicyManager == NULL) {
722 return NO_INIT;
723 }
724 if (!settingsAllowed()) {
725 return PERMISSION_DENIED;
726 }
727 Mutex::Autolock _l(mLock);
728 AutoCallerClear acc;
729 return mAudioPolicyManager->setVolumeIndexForAttributes(attributes, index, device);
730}
731
732status_t AudioPolicyService::getVolumeIndexForAttributes(const audio_attributes_t &attributes,
733 int &index, audio_devices_t device)
734{
735 if (mAudioPolicyManager == NULL) {
736 return NO_INIT;
737 }
738 Mutex::Autolock _l(mLock);
739 AutoCallerClear acc;
740 return mAudioPolicyManager->getVolumeIndexForAttributes(attributes, index, device);
741}
742
743status_t AudioPolicyService::getMinVolumeIndexForAttributes(const audio_attributes_t &attributes,
744 int &index)
745{
746 if (mAudioPolicyManager == NULL) {
747 return NO_INIT;
748 }
749 Mutex::Autolock _l(mLock);
750 AutoCallerClear acc;
751 return mAudioPolicyManager->getMinVolumeIndexForAttributes(attributes, index);
752}
753
754status_t AudioPolicyService::getMaxVolumeIndexForAttributes(const audio_attributes_t &attributes,
755 int &index)
756{
757 if (mAudioPolicyManager == NULL) {
758 return NO_INIT;
759 }
760 Mutex::Autolock _l(mLock);
761 AutoCallerClear acc;
762 return mAudioPolicyManager->getMaxVolumeIndexForAttributes(attributes, index);
763}
764
Eric Laurent2d388ec2014-03-07 13:25:54 -0800765uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
766{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800767 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
François Gaffiec005e562018-11-06 15:04:49 +0100768 return PRODUCT_STRATEGY_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700769 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700770 if (mAudioPolicyManager == NULL) {
François Gaffiec005e562018-11-06 15:04:49 +0100771 return PRODUCT_STRATEGY_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800772 }
François Gaffiec005e562018-11-06 15:04:49 +0100773 // DO NOT LOCK, may be called from AudioFlinger with lock held, reaching deadlock
Eric Laurent10b71232018-04-13 18:14:44 -0700774 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700775 return mAudioPolicyManager->getStrategyForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800776}
777
778//audio policy: use audio_device_t appropriately
779
780audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
781{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800782 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700783 return AUDIO_DEVICE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700784 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700785 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700786 return AUDIO_DEVICE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800787 }
Haynes Mathew Georgedfb9f3b2015-10-26 18:22:13 -0700788 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700789 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700790 return mAudioPolicyManager->getDevicesForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800791}
792
793audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
794{
795 // FIXME change return type to status_t, and return NO_INIT here
Eric Laurentdce54a12014-03-10 12:19:46 -0700796 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800797 return 0;
798 }
799 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700800 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700801 return mAudioPolicyManager->getOutputForEffect(desc);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800802}
803
804status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
805 audio_io_handle_t io,
806 uint32_t strategy,
Glenn Kastend848eb42016-03-08 13:42:11 -0800807 audio_session_t session,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800808 int id)
809{
Eric Laurentdce54a12014-03-10 12:19:46 -0700810 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800811 return NO_INIT;
812 }
Eric Laurent6c796322019-04-09 14:13:17 -0700813 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700814 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700815 return mAudioPolicyManager->registerEffect(desc, io, strategy, session, id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800816}
817
818status_t AudioPolicyService::unregisterEffect(int id)
819{
Eric Laurentdce54a12014-03-10 12:19:46 -0700820 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800821 return NO_INIT;
822 }
Eric Laurent6c796322019-04-09 14:13:17 -0700823 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700824 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700825 return mAudioPolicyManager->unregisterEffect(id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800826}
827
828status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
829{
Eric Laurentdce54a12014-03-10 12:19:46 -0700830 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800831 return NO_INIT;
832 }
Eric Laurent6c796322019-04-09 14:13:17 -0700833 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700834 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700835 return mAudioPolicyManager->setEffectEnabled(id, enabled);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800836}
837
Eric Laurent6c796322019-04-09 14:13:17 -0700838status_t AudioPolicyService::moveEffectsToIo(const std::vector<int>& ids, audio_io_handle_t io)
839{
840 if (mAudioPolicyManager == NULL) {
841 return NO_INIT;
842 }
843 Mutex::Autolock _l(mLock);
844 AutoCallerClear acc;
845 return mAudioPolicyManager->moveEffectsToIo(ids, io);
846}
847
Eric Laurent2d388ec2014-03-07 13:25:54 -0800848bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
849{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800850 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700851 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700852 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700853 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700854 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800855 }
856 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700857 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700858 return mAudioPolicyManager->isStreamActive(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800859}
860
861bool AudioPolicyService::isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs) const
862{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800863 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700864 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700865 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700866 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700867 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800868 }
869 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700870 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700871 return mAudioPolicyManager->isStreamActiveRemotely(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800872}
873
874bool AudioPolicyService::isSourceActive(audio_source_t source) const
875{
Eric Laurentdce54a12014-03-10 12:19:46 -0700876 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800877 return false;
878 }
879 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700880 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700881 return mAudioPolicyManager->isSourceActive(source);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800882}
883
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700884status_t AudioPolicyService::getAudioPolicyEffects(sp<AudioPolicyEffects>& audioPolicyEffects)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800885{
Eric Laurentdce54a12014-03-10 12:19:46 -0700886 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800887 return NO_INIT;
888 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700889 {
890 Mutex::Autolock _l(mLock);
891 audioPolicyEffects = mAudioPolicyEffects;
892 }
893 if (audioPolicyEffects == 0) {
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700894 return NO_INIT;
895 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700896
897 return OK;
898}
899
900status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
901 effect_descriptor_t *descriptors,
902 uint32_t *count)
903{
904 sp<AudioPolicyEffects>audioPolicyEffects;
905 status_t status = getAudioPolicyEffects(audioPolicyEffects);
906 if (status != OK) {
907 *count = 0;
908 return status;
909 }
Eric Laurentfb66dd92016-01-28 18:32:03 -0800910 return audioPolicyEffects->queryDefaultInputEffects(
911 (audio_session_t)audioSession, descriptors, count);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800912}
913
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700914status_t AudioPolicyService::addSourceDefaultEffect(const effect_uuid_t *type,
915 const String16& opPackageName,
916 const effect_uuid_t *uuid,
917 int32_t priority,
918 audio_source_t source,
919 audio_unique_id_t* id)
920{
921 sp<AudioPolicyEffects>audioPolicyEffects;
922 status_t status = getAudioPolicyEffects(audioPolicyEffects);
923 if (status != OK) {
924 return status;
925 }
926 if (!modifyDefaultAudioEffectsAllowed()) {
927 return PERMISSION_DENIED;
928 }
929 return audioPolicyEffects->addSourceDefaultEffect(
930 type, opPackageName, uuid, priority, source, id);
931}
932
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700933status_t AudioPolicyService::addStreamDefaultEffect(const effect_uuid_t *type,
934 const String16& opPackageName,
935 const effect_uuid_t *uuid,
936 int32_t priority,
937 audio_usage_t usage,
938 audio_unique_id_t* id)
939{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700940 sp<AudioPolicyEffects>audioPolicyEffects;
941 status_t status = getAudioPolicyEffects(audioPolicyEffects);
942 if (status != OK) {
943 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700944 }
945 if (!modifyDefaultAudioEffectsAllowed()) {
946 return PERMISSION_DENIED;
947 }
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700948 return audioPolicyEffects->addStreamDefaultEffect(
949 type, opPackageName, uuid, priority, usage, id);
950}
951
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700952status_t AudioPolicyService::removeSourceDefaultEffect(audio_unique_id_t id)
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700953{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700954 sp<AudioPolicyEffects>audioPolicyEffects;
955 status_t status = getAudioPolicyEffects(audioPolicyEffects);
956 if (status != OK) {
957 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700958 }
959 if (!modifyDefaultAudioEffectsAllowed()) {
960 return PERMISSION_DENIED;
961 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700962 return audioPolicyEffects->removeSourceDefaultEffect(id);
963}
964
965status_t AudioPolicyService::removeStreamDefaultEffect(audio_unique_id_t id)
966{
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700967 sp<AudioPolicyEffects>audioPolicyEffects;
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700968 status_t status = getAudioPolicyEffects(audioPolicyEffects);
969 if (status != OK) {
970 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700971 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700972 if (!modifyDefaultAudioEffectsAllowed()) {
973 return PERMISSION_DENIED;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700974 }
975 return audioPolicyEffects->removeStreamDefaultEffect(id);
976}
977
Kevin Rocardb99cc752019-03-21 20:52:24 -0700978status_t AudioPolicyService::setAllowedCapturePolicy(uid_t uid, audio_flags_mask_t capturePolicy) {
979 Mutex::Autolock _l(mLock);
980 if (mAudioPolicyManager == NULL) {
981 ALOGV("%s() mAudioPolicyManager == NULL", __func__);
982 return NO_INIT;
983 }
984 uint_t callingUid = IPCThreadState::self()->getCallingUid();
985 if (uid != callingUid) {
986 ALOGD("%s() uid invalid %d != %d", __func__, uid, callingUid);
987 return PERMISSION_DENIED;
988 }
989 return mAudioPolicyManager->setAllowedCapturePolicy(uid, capturePolicy);
990}
991
Eric Laurent2d388ec2014-03-07 13:25:54 -0800992bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
993{
Eric Laurentdce54a12014-03-10 12:19:46 -0700994 if (mAudioPolicyManager == NULL) {
995 ALOGV("mAudioPolicyManager == NULL");
Eric Laurent2d388ec2014-03-07 13:25:54 -0800996 return false;
997 }
Andy Hung2ddee192015-12-18 17:34:44 -0800998 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700999 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -07001000 return mAudioPolicyManager->isOffloadSupported(info);
Eric Laurent2d388ec2014-03-07 13:25:54 -08001001}
1002
Michael Chana94fbb22018-04-24 14:31:19 +10001003bool AudioPolicyService::isDirectOutputSupported(const audio_config_base_t& config,
1004 const audio_attributes_t& attributes) {
1005 if (mAudioPolicyManager == NULL) {
1006 ALOGV("mAudioPolicyManager == NULL");
1007 return false;
1008 }
1009 Mutex::Autolock _l(mLock);
1010 return mAudioPolicyManager->isDirectOutputSupported(config, attributes);
1011}
1012
1013
Eric Laurent6a94d692014-05-20 11:18:06 -07001014status_t AudioPolicyService::listAudioPorts(audio_port_role_t role,
1015 audio_port_type_t type,
Eric Laurent203b1a12014-04-01 10:34:16 -07001016 unsigned int *num_ports,
Eric Laurent6a94d692014-05-20 11:18:06 -07001017 struct audio_port *ports,
1018 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001019{
Eric Laurent6a94d692014-05-20 11:18:06 -07001020 Mutex::Autolock _l(mLock);
1021 if (mAudioPolicyManager == NULL) {
1022 return NO_INIT;
1023 }
Eric Laurent10b71232018-04-13 18:14:44 -07001024 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001025 return mAudioPolicyManager->listAudioPorts(role, type, num_ports, ports, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001026}
1027
Eric Laurent6a94d692014-05-20 11:18:06 -07001028status_t AudioPolicyService::getAudioPort(struct audio_port *port)
Eric Laurent203b1a12014-04-01 10:34:16 -07001029{
Eric Laurent6a94d692014-05-20 11:18:06 -07001030 Mutex::Autolock _l(mLock);
1031 if (mAudioPolicyManager == NULL) {
1032 return NO_INIT;
1033 }
Eric Laurent10b71232018-04-13 18:14:44 -07001034 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001035 return mAudioPolicyManager->getAudioPort(port);
Eric Laurent203b1a12014-04-01 10:34:16 -07001036}
1037
Eric Laurent6a94d692014-05-20 11:18:06 -07001038status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch,
1039 audio_patch_handle_t *handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001040{
Eric Laurent6a94d692014-05-20 11:18:06 -07001041 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001042 if(!modifyAudioRoutingAllowed()) {
1043 return PERMISSION_DENIED;
1044 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001045 if (mAudioPolicyManager == NULL) {
1046 return NO_INIT;
1047 }
Eric Laurent10b71232018-04-13 18:14:44 -07001048 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001049 return mAudioPolicyManager->createAudioPatch(patch, handle,
1050 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001051}
1052
Eric Laurent6a94d692014-05-20 11:18:06 -07001053status_t AudioPolicyService::releaseAudioPatch(audio_patch_handle_t handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001054{
Eric Laurent6a94d692014-05-20 11:18:06 -07001055 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001056 if(!modifyAudioRoutingAllowed()) {
1057 return PERMISSION_DENIED;
1058 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001059 if (mAudioPolicyManager == NULL) {
1060 return NO_INIT;
1061 }
Eric Laurent10b71232018-04-13 18:14:44 -07001062 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001063 return mAudioPolicyManager->releaseAudioPatch(handle,
1064 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001065}
1066
1067status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
Eric Laurent6a94d692014-05-20 11:18:06 -07001068 struct audio_patch *patches,
1069 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001070{
Eric Laurent6a94d692014-05-20 11:18:06 -07001071 Mutex::Autolock _l(mLock);
1072 if (mAudioPolicyManager == NULL) {
1073 return NO_INIT;
1074 }
Eric Laurent10b71232018-04-13 18:14:44 -07001075 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001076 return mAudioPolicyManager->listAudioPatches(num_patches, patches, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001077}
1078
Eric Laurent6a94d692014-05-20 11:18:06 -07001079status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config)
Eric Laurent203b1a12014-04-01 10:34:16 -07001080{
Eric Laurent6a94d692014-05-20 11:18:06 -07001081 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001082 if(!modifyAudioRoutingAllowed()) {
1083 return PERMISSION_DENIED;
1084 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001085 if (mAudioPolicyManager == NULL) {
1086 return NO_INIT;
1087 }
Eric Laurent10b71232018-04-13 18:14:44 -07001088 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001089 return mAudioPolicyManager->setAudioPortConfig(config);
Eric Laurent203b1a12014-04-01 10:34:16 -07001090}
Eric Laurent2d388ec2014-03-07 13:25:54 -08001091
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001092status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session,
1093 audio_io_handle_t *ioHandle,
1094 audio_devices_t *device)
1095{
Andy Hungf759b8c2017-08-15 12:48:54 -07001096 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001097 if (mAudioPolicyManager == NULL) {
1098 return NO_INIT;
1099 }
Eric Laurent10b71232018-04-13 18:14:44 -07001100 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001101 return mAudioPolicyManager->acquireSoundTriggerSession(session, ioHandle, device);
1102}
1103
1104status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session)
1105{
Andy Hungf759b8c2017-08-15 12:48:54 -07001106 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001107 if (mAudioPolicyManager == NULL) {
1108 return NO_INIT;
1109 }
Eric Laurent10b71232018-04-13 18:14:44 -07001110 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001111 return mAudioPolicyManager->releaseSoundTriggerSession(session);
1112}
1113
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -07001114status_t AudioPolicyService::registerPolicyMixes(const Vector<AudioMix>& mixes, bool registration)
Eric Laurentbaac1832014-12-01 17:52:59 -08001115{
1116 Mutex::Autolock _l(mLock);
Kevin Rocardbe201852019-02-20 22:33:28 -08001117
1118 // loopback|render only need a MediaProjection (checked in caller AudioService.java)
1119 bool needModifyAudioRouting = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
1120 return !is_mix_loopback_render(mix.mRouteFlags); });
1121 if (needModifyAudioRouting && !modifyAudioRoutingAllowed()) {
Eric Laurentbaac1832014-12-01 17:52:59 -08001122 return PERMISSION_DENIED;
1123 }
Kevin Rocardbe201852019-02-20 22:33:28 -08001124
Kevin Rocard36b17552019-03-07 18:48:07 -08001125 bool needCaptureMediaOutput = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
1126 return mix.mAllowPrivilegedPlaybackCapture; });
1127 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
1128 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
1129 if (needCaptureMediaOutput && !captureMediaOutputAllowed(callingPid, callingUid)) {
1130 return PERMISSION_DENIED;
1131 }
1132
Eric Laurentbaac1832014-12-01 17:52:59 -08001133 if (mAudioPolicyManager == NULL) {
1134 return NO_INIT;
1135 }
Eric Laurent10b71232018-04-13 18:14:44 -07001136 AutoCallerClear acc;
Eric Laurentbaac1832014-12-01 17:52:59 -08001137 if (registration) {
1138 return mAudioPolicyManager->registerPolicyMixes(mixes);
1139 } else {
1140 return mAudioPolicyManager->unregisterPolicyMixes(mixes);
1141 }
1142}
1143
Jean-Michel Trivibda70da2018-12-19 07:30:15 -08001144status_t AudioPolicyService::setUidDeviceAffinities(uid_t uid,
1145 const Vector<AudioDeviceTypeAddr>& devices) {
1146 Mutex::Autolock _l(mLock);
1147 if(!modifyAudioRoutingAllowed()) {
1148 return PERMISSION_DENIED;
1149 }
1150 if (mAudioPolicyManager == NULL) {
1151 return NO_INIT;
1152 }
1153 AutoCallerClear acc;
1154 return mAudioPolicyManager->setUidDeviceAffinities(uid, devices);
1155}
1156
1157status_t AudioPolicyService::removeUidDeviceAffinities(uid_t uid) {
1158 Mutex::Autolock _l(mLock);
1159 if(!modifyAudioRoutingAllowed()) {
1160 return PERMISSION_DENIED;
1161 }
1162 if (mAudioPolicyManager == NULL) {
1163 return NO_INIT;
1164 }
1165 AutoCallerClear acc;
1166 return mAudioPolicyManager->removeUidDeviceAffinities(uid);
1167}
1168
Eric Laurent554a2772015-04-10 11:29:24 -07001169status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001170 const audio_attributes_t *attributes,
1171 audio_port_handle_t *portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001172{
1173 Mutex::Autolock _l(mLock);
1174 if (mAudioPolicyManager == NULL) {
1175 return NO_INIT;
1176 }
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001177 // startAudioSource should be created as the calling uid
1178 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Eric Laurent10b71232018-04-13 18:14:44 -07001179 AutoCallerClear acc;
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001180 return mAudioPolicyManager->startAudioSource(source, attributes, portId, callingUid);
Eric Laurent554a2772015-04-10 11:29:24 -07001181}
1182
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001183status_t AudioPolicyService::stopAudioSource(audio_port_handle_t portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001184{
1185 Mutex::Autolock _l(mLock);
1186 if (mAudioPolicyManager == NULL) {
1187 return NO_INIT;
1188 }
Eric Laurent10b71232018-04-13 18:14:44 -07001189 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001190 return mAudioPolicyManager->stopAudioSource(portId);
Eric Laurent554a2772015-04-10 11:29:24 -07001191}
1192
Andy Hung2ddee192015-12-18 17:34:44 -08001193status_t AudioPolicyService::setMasterMono(bool mono)
1194{
1195 if (mAudioPolicyManager == NULL) {
1196 return NO_INIT;
1197 }
1198 if (!settingsAllowed()) {
1199 return PERMISSION_DENIED;
1200 }
1201 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001202 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001203 return mAudioPolicyManager->setMasterMono(mono);
1204}
1205
1206status_t AudioPolicyService::getMasterMono(bool *mono)
1207{
1208 if (mAudioPolicyManager == NULL) {
1209 return NO_INIT;
1210 }
1211 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001212 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001213 return mAudioPolicyManager->getMasterMono(mono);
1214}
1215
Eric Laurentac9cef52017-06-09 15:46:26 -07001216
1217float AudioPolicyService::getStreamVolumeDB(
1218 audio_stream_type_t stream, int index, audio_devices_t device)
1219{
1220 if (mAudioPolicyManager == NULL) {
1221 return NAN;
1222 }
1223 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001224 AutoCallerClear acc;
Eric Laurentac9cef52017-06-09 15:46:26 -07001225 return mAudioPolicyManager->getStreamVolumeDB(stream, index, device);
1226}
1227
jiabin81772902018-04-02 17:52:27 -07001228status_t AudioPolicyService::getSurroundFormats(unsigned int *numSurroundFormats,
1229 audio_format_t *surroundFormats,
1230 bool *surroundFormatsEnabled,
1231 bool reported)
1232{
1233 if (mAudioPolicyManager == NULL) {
1234 return NO_INIT;
1235 }
1236 Mutex::Autolock _l(mLock);
1237 AutoCallerClear acc;
1238 return mAudioPolicyManager->getSurroundFormats(numSurroundFormats, surroundFormats,
1239 surroundFormatsEnabled, reported);
1240}
1241
Arun Mirpuri11029ad2018-12-19 20:45:19 -08001242status_t AudioPolicyService::getHwOffloadEncodingFormatsSupportedForA2DP(
1243 std::vector<audio_format_t> *formats)
1244{
1245 if (mAudioPolicyManager == NULL) {
1246 return NO_INIT;
1247 }
1248 Mutex::Autolock _l(mLock);
1249 AutoCallerClear acc;
1250 return mAudioPolicyManager->getHwOffloadEncodingFormatsSupportedForA2DP(formats);
1251}
1252
jiabin81772902018-04-02 17:52:27 -07001253status_t AudioPolicyService::setSurroundFormatEnabled(audio_format_t audioFormat, bool enabled)
1254{
1255 if (mAudioPolicyManager == NULL) {
1256 return NO_INIT;
1257 }
1258 Mutex::Autolock _l(mLock);
1259 AutoCallerClear acc;
1260 return mAudioPolicyManager->setSurroundFormatEnabled(audioFormat, enabled);
1261}
Eric Laurentac9cef52017-06-09 15:46:26 -07001262
Eric Laurentb78763e2018-10-17 10:08:02 -07001263status_t AudioPolicyService::setAssistantUid(uid_t uid)
1264{
1265 Mutex::Autolock _l(mLock);
1266 mUidPolicy->setAssistantUid(uid);
1267 return NO_ERROR;
1268}
1269
1270status_t AudioPolicyService::setA11yServicesUids(const std::vector<uid_t>& uids)
1271{
1272 Mutex::Autolock _l(mLock);
1273 mUidPolicy->setA11yUids(uids);
1274 return NO_ERROR;
1275}
1276
jiabin6012f912018-11-02 17:06:30 -07001277bool AudioPolicyService::isHapticPlaybackSupported()
1278{
1279 if (mAudioPolicyManager == NULL) {
1280 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1281 return false;
1282 }
1283 Mutex::Autolock _l(mLock);
1284 AutoCallerClear acc;
1285 return mAudioPolicyManager->isHapticPlaybackSupported();
1286}
1287
François Gaffied0ba9ed2018-11-05 11:50:42 +01001288status_t AudioPolicyService::listAudioProductStrategies(AudioProductStrategyVector &strategies)
1289{
1290 if (mAudioPolicyManager == NULL) {
1291 return NO_INIT;
1292 }
1293 Mutex::Autolock _l(mLock);
1294 return mAudioPolicyManager->listAudioProductStrategies(strategies);
1295}
1296
François Gaffie4b2018b2018-11-07 11:18:59 +01001297status_t AudioPolicyService::getProductStrategyFromAudioAttributes(
1298 const AudioAttributes &aa, product_strategy_t &productStrategy)
François Gaffied0ba9ed2018-11-05 11:50:42 +01001299{
1300 if (mAudioPolicyManager == NULL) {
François Gaffie4b2018b2018-11-07 11:18:59 +01001301 return NO_INIT;
François Gaffied0ba9ed2018-11-05 11:50:42 +01001302 }
1303 Mutex::Autolock _l(mLock);
François Gaffie4b2018b2018-11-07 11:18:59 +01001304 return mAudioPolicyManager->getProductStrategyFromAudioAttributes(aa, productStrategy);
1305}
1306
1307status_t AudioPolicyService::listAudioVolumeGroups(AudioVolumeGroupVector &groups)
1308{
1309 if (mAudioPolicyManager == NULL) {
1310 return NO_INIT;
1311 }
1312 Mutex::Autolock _l(mLock);
1313 return mAudioPolicyManager->listAudioVolumeGroups(groups);
1314}
1315
1316status_t AudioPolicyService::getVolumeGroupFromAudioAttributes(const AudioAttributes &aa,
1317 volume_group_t &volumeGroup)
1318{
1319 if (mAudioPolicyManager == NULL) {
1320 return NO_INIT;
1321 }
1322 Mutex::Autolock _l(mLock);
1323 return mAudioPolicyManager->getVolumeGroupFromAudioAttributes(aa, volumeGroup);
François Gaffied0ba9ed2018-11-05 11:50:42 +01001324}
Eric Laurent6ede98f2019-06-11 14:50:30 -07001325
1326status_t AudioPolicyService::setRttEnabled(bool enabled)
1327{
1328 Mutex::Autolock _l(mLock);
1329 mUidPolicy->setRttEnabled(enabled);
1330 return NO_ERROR;
1331}
1332
Jean-Michel Trivi2deb4782019-11-01 11:04:15 -07001333status_t AudioPolicyService::setPreferredDeviceForStrategy(product_strategy_t strategy,
1334 const AudioDeviceTypeAddr &device)
1335{
1336 if (mAudioPolicyManager == NULL) {
1337 return NO_INIT;
1338 }
1339 Mutex::Autolock _l(mLock);
1340 return mAudioPolicyManager->setPreferredDeviceForStrategy(strategy, device);
1341}
1342
1343status_t AudioPolicyService::removePreferredDeviceForStrategy(product_strategy_t strategy)
1344{
1345 if (mAudioPolicyManager == NULL) {
1346 return NO_INIT;
1347 }
1348 Mutex::Autolock _l(mLock);
1349 return mAudioPolicyManager->removePreferredDeviceForStrategy(strategy);
1350}
1351
1352status_t AudioPolicyService::getPreferredDeviceForStrategy(product_strategy_t strategy,
1353 AudioDeviceTypeAddr &device)
1354{
1355 if (mAudioPolicyManager == NULL) {
1356 return NO_INIT;
1357 }
1358 Mutex::Autolock _l(mLock);
1359 return mAudioPolicyManager->getPreferredDeviceForStrategy(strategy, device);
1360}
1361
Mikhail Naganov1b2a7942017-12-08 10:18:09 -08001362} // namespace android