blob: 227adc774c863b6394a5072bcf328a3a8395740e [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
Mikhail Naganov3de4f262020-03-06 17:02:19 -080031void AudioPolicyService::doOnNewAudioModulesAvailable()
32{
33 if (mAudioPolicyManager == NULL) return;
34 Mutex::Autolock _l(mLock);
35 AutoCallerClear acc;
36 mAudioPolicyManager->onNewAudioModulesAvailable();
37}
38
Eric Laurent2d388ec2014-03-07 13:25:54 -080039status_t AudioPolicyService::setDeviceConnectionState(audio_devices_t device,
40 audio_policy_dev_state_t state,
Paul McLeane743a472015-01-28 11:07:31 -080041 const char *device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080042 const char *device_name,
43 audio_format_t encodedFormat)
Eric Laurent2d388ec2014-03-07 13:25:54 -080044{
Eric Laurentdce54a12014-03-10 12:19:46 -070045 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080046 return NO_INIT;
47 }
48 if (!settingsAllowed()) {
49 return PERMISSION_DENIED;
50 }
Eric Laurent2d388ec2014-03-07 13:25:54 -080051 if (state != AUDIO_POLICY_DEVICE_STATE_AVAILABLE &&
52 state != AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE) {
53 return BAD_VALUE;
54 }
55
56 ALOGV("setDeviceConnectionState()");
57 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -070058 AutoCallerClear acc;
Paul McLeane743a472015-01-28 11:07:31 -080059 return mAudioPolicyManager->setDeviceConnectionState(device, state,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080060 device_address, device_name, encodedFormat);
Eric Laurent2d388ec2014-03-07 13:25:54 -080061}
62
63audio_policy_dev_state_t AudioPolicyService::getDeviceConnectionState(
64 audio_devices_t device,
65 const char *device_address)
66{
Eric Laurentdce54a12014-03-10 12:19:46 -070067 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080068 return AUDIO_POLICY_DEVICE_STATE_UNAVAILABLE;
69 }
Eric Laurent10b71232018-04-13 18:14:44 -070070 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -070071 return mAudioPolicyManager->getDeviceConnectionState(device,
Eric Laurent2d388ec2014-03-07 13:25:54 -080072 device_address);
73}
74
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080075status_t AudioPolicyService::handleDeviceConfigChange(audio_devices_t device,
76 const char *device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080077 const char *device_name,
78 audio_format_t encodedFormat)
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080079{
80 if (mAudioPolicyManager == NULL) {
81 return NO_INIT;
82 }
83 if (!settingsAllowed()) {
84 return PERMISSION_DENIED;
85 }
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080086
87 ALOGV("handleDeviceConfigChange()");
88 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -070089 AutoCallerClear acc;
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080090 return mAudioPolicyManager->handleDeviceConfigChange(device, device_address,
Aniket Kumar Lata4e464702019-01-10 23:38:46 -080091 device_name, encodedFormat);
Pavlin Radoslavovf862bc62016-12-26 18:57:22 -080092}
93
Eric Laurent2d388ec2014-03-07 13:25:54 -080094status_t AudioPolicyService::setPhoneState(audio_mode_t state)
95{
Eric Laurentdce54a12014-03-10 12:19:46 -070096 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -080097 return NO_INIT;
98 }
99 if (!settingsAllowed()) {
100 return PERMISSION_DENIED;
101 }
102 if (uint32_t(state) >= AUDIO_MODE_CNT) {
103 return BAD_VALUE;
104 }
105
106 ALOGV("setPhoneState()");
107
Eric Laurentbeb07fe2015-09-16 15:49:30 -0700108 // acquire lock before calling setMode() so that setMode() + setPhoneState() are an atomic
109 // operation from policy manager standpoint (no other operation (e.g track start or stop)
110 // can be interleaved).
111 Mutex::Autolock _l(mLock);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800112 // TODO: check if it is more appropriate to do it in platform specific policy manager
113 AudioSystem::setMode(state);
114
Eric Laurent10b71232018-04-13 18:14:44 -0700115 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700116 mAudioPolicyManager->setPhoneState(state);
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700117 mPhoneState = state;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800118 return NO_ERROR;
119}
120
Eric Laurentbb6c9a02014-09-25 14:11:47 -0700121audio_mode_t AudioPolicyService::getPhoneState()
122{
123 Mutex::Autolock _l(mLock);
124 return mPhoneState;
125}
126
Eric Laurent2d388ec2014-03-07 13:25:54 -0800127status_t AudioPolicyService::setForceUse(audio_policy_force_use_t usage,
128 audio_policy_forced_cfg_t config)
129{
Eric Laurentdce54a12014-03-10 12:19:46 -0700130 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800131 return NO_INIT;
132 }
Eric Laurente17378d2018-05-09 14:43:01 -0700133
134 if (!modifyAudioRoutingAllowed()) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800135 return PERMISSION_DENIED;
136 }
Eric Laurente17378d2018-05-09 14:43:01 -0700137
Eric Laurent2d388ec2014-03-07 13:25:54 -0800138 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
139 return BAD_VALUE;
140 }
141 if (config < 0 || config >= AUDIO_POLICY_FORCE_CFG_CNT) {
142 return BAD_VALUE;
143 }
144 ALOGV("setForceUse()");
145 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700146 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700147 mAudioPolicyManager->setForceUse(usage, config);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800148 return NO_ERROR;
149}
150
151audio_policy_forced_cfg_t AudioPolicyService::getForceUse(audio_policy_force_use_t usage)
152{
Eric Laurentdce54a12014-03-10 12:19:46 -0700153 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800154 return AUDIO_POLICY_FORCE_NONE;
155 }
156 if (usage < 0 || usage >= AUDIO_POLICY_FORCE_USE_CNT) {
157 return AUDIO_POLICY_FORCE_NONE;
158 }
Eric Laurent10b71232018-04-13 18:14:44 -0700159 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700160 return mAudioPolicyManager->getForceUse(usage);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800161}
162
Eric Laurentf4e63452017-11-06 19:31:46 +0000163audio_io_handle_t AudioPolicyService::getOutput(audio_stream_type_t stream)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800164{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800165 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700166 return AUDIO_IO_HANDLE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700167 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700168 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700169 return AUDIO_IO_HANDLE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800170 }
171 ALOGV("getOutput()");
172 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700173 AutoCallerClear acc;
Eric Laurentf4e63452017-11-06 19:31:46 +0000174 return mAudioPolicyManager->getOutput(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800175}
176
Eric Laurent42984412019-05-09 17:57:03 -0700177status_t AudioPolicyService::getOutputForAttr(audio_attributes_t *attr,
Eric Laurente83b55d2014-11-14 10:06:21 -0800178 audio_io_handle_t *output,
179 audio_session_t session,
180 audio_stream_type_t *stream,
Nadav Bar766fb022018-01-07 12:18:03 +0200181 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700182 uid_t uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800183 const audio_config_t *config,
Eric Laurente83b55d2014-11-14 10:06:21 -0800184 audio_output_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700185 audio_port_handle_t *selectedDeviceId,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800186 audio_port_handle_t *portId,
187 std::vector<audio_io_handle_t> *secondaryOutputs)
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700188{
189 if (mAudioPolicyManager == NULL) {
Eric Laurente83b55d2014-11-14 10:06:21 -0800190 return NO_INIT;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700191 }
Eric Laurentf4e63452017-11-06 19:31:46 +0000192 ALOGV("getOutputForAttr()");
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700193 Mutex::Autolock _l(mLock);
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700194
Marco Nelissendcb346b2015-09-09 10:47:29 -0700195 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700196 if (!isAudioServerOrMediaServerUid(callingUid) || uid == (uid_t)-1) {
Marco Nelissendcb346b2015-09-09 10:47:29 -0700197 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
198 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
199 uid = callingUid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700200 }
Kevin Rocard8be94972019-02-22 13:26:25 -0800201 if (!mPackageManager.allowPlaybackCapture(uid)) {
Eric Laurent42984412019-05-09 17:57:03 -0700202 attr->flags |= AUDIO_FLAG_NO_MEDIA_PROJECTION;
203 }
Eric Laurent6ede98f2019-06-11 14:50:30 -0700204 if (((attr->flags & (AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE)) != 0)
205 && !bypassInterruptionPolicyAllowed(pid, uid)) {
Eric Laurent42984412019-05-09 17:57:03 -0700206 attr->flags &= ~(AUDIO_FLAG_BYPASS_INTERRUPTION_POLICY|AUDIO_FLAG_BYPASS_MUTE);
Kevin Rocard8be94972019-02-22 13:26:25 -0800207 }
Nadav Bar766fb022018-01-07 12:18:03 +0200208 audio_output_flags_t originalFlags = flags;
Eric Laurent10b71232018-04-13 18:14:44 -0700209 AutoCallerClear acc;
Eric Laurent42984412019-05-09 17:57:03 -0700210 status_t result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800211 config,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800212 &flags, selectedDeviceId, portId,
213 secondaryOutputs);
Nadav Bar766fb022018-01-07 12:18:03 +0200214
215 // FIXME: Introduce a way to check for the the telephony device before opening the output
216 if ((result == NO_ERROR) &&
217 (flags & AUDIO_OUTPUT_FLAG_INCALL_MUSIC) &&
218 !modifyPhoneStateAllowed(pid, uid)) {
219 // If the app tries to play music through the telephony device and doesn't have permission
220 // the fallback to the default output device.
Eric Laurent8fc147b2018-07-22 19:13:55 -0700221 mAudioPolicyManager->releaseOutput(*portId);
Nadav Bar766fb022018-01-07 12:18:03 +0200222 flags = originalFlags;
223 *selectedDeviceId = AUDIO_PORT_HANDLE_NONE;
224 *portId = AUDIO_PORT_HANDLE_NONE;
Kevin Rocard153f92d2018-12-18 18:33:28 -0800225 secondaryOutputs->clear();
Eric Laurent42984412019-05-09 17:57:03 -0700226 result = mAudioPolicyManager->getOutputForAttr(attr, output, session, stream, uid, config,
Kevin Rocard153f92d2018-12-18 18:33:28 -0800227 &flags, selectedDeviceId, portId,
228 secondaryOutputs);
Nadav Bar766fb022018-01-07 12:18:03 +0200229 }
Eric Laurentd7fe0862018-07-14 16:48:01 -0700230
231 if (result == NO_ERROR) {
232 sp <AudioPlaybackClient> client =
Eric Laurent42984412019-05-09 17:57:03 -0700233 new AudioPlaybackClient(*attr, *output, uid, pid, session, *selectedDeviceId, *stream);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700234 mAudioPlaybackClients.add(*portId, client);
235 }
Nadav Bar766fb022018-01-07 12:18:03 +0200236 return result;
Jean-Michel Trivi5bd3f382014-06-13 16:06:54 -0700237}
238
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700239void AudioPolicyService::getPlaybackClientAndEffects(audio_port_handle_t portId,
240 sp<AudioPlaybackClient>& client,
241 sp<AudioPolicyEffects>& effects,
242 const char *context)
243{
244 Mutex::Autolock _l(mLock);
245 const ssize_t index = mAudioPlaybackClients.indexOfKey(portId);
246 if (index < 0) {
247 ALOGE("%s AudioTrack client not found for portId %d", context, portId);
248 return;
249 }
250 client = mAudioPlaybackClients.valueAt(index);
251 effects = mAudioPolicyEffects;
252}
253
Eric Laurentd7fe0862018-07-14 16:48:01 -0700254status_t AudioPolicyService::startOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800255{
Eric Laurentdce54a12014-03-10 12:19:46 -0700256 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800257 return NO_INIT;
258 }
259 ALOGV("startOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700260 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700261 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700262
263 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
264
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700265 if (audioPolicyEffects != 0) {
266 // create audio processors according to stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700267 status_t status = audioPolicyEffects->addOutputSessionEffects(
268 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700269 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700270 ALOGW("Failed to add effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700271 }
272 }
273 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700274 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700275 status_t status = mAudioPolicyManager->startOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700276 if (status == NO_ERROR) {
277 client->active = true;
278 }
279 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800280}
281
Eric Laurentd7fe0862018-07-14 16:48:01 -0700282status_t AudioPolicyService::stopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800283{
Eric Laurentdce54a12014-03-10 12:19:46 -0700284 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800285 return NO_INIT;
286 }
287 ALOGV("stopOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700288 mOutputCommandThread->stopOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800289 return NO_ERROR;
290}
291
Eric Laurentd7fe0862018-07-14 16:48:01 -0700292status_t AudioPolicyService::doStopOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800293{
Eric Laurentd7fe0862018-07-14 16:48:01 -0700294 ALOGV("doStopOutput");
295 sp<AudioPlaybackClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700296 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentd7fe0862018-07-14 16:48:01 -0700297
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700298 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
299
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700300 if (audioPolicyEffects != 0) {
301 // release audio processors from the stream
Eric Laurentd7fe0862018-07-14 16:48:01 -0700302 status_t status = audioPolicyEffects->releaseOutputSessionEffects(
303 client->io, client->stream, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700304 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700305 ALOGW("Failed to release effects on session %d", client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700306 }
307 }
308 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700309 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700310 status_t status = mAudioPolicyManager->stopOutput(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700311 if (status == NO_ERROR) {
312 client->active = false;
313 }
314 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800315}
316
Eric Laurentd7fe0862018-07-14 16:48:01 -0700317void AudioPolicyService::releaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800318{
Eric Laurentdce54a12014-03-10 12:19:46 -0700319 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800320 return;
321 }
322 ALOGV("releaseOutput()");
Eric Laurentd7fe0862018-07-14 16:48:01 -0700323 mOutputCommandThread->releaseOutputCommand(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800324}
325
Eric Laurentd7fe0862018-07-14 16:48:01 -0700326void AudioPolicyService::doReleaseOutput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800327{
328 ALOGV("doReleaseOutput from tid %d", gettid());
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700329 sp<AudioPlaybackClient> client;
330 sp<AudioPolicyEffects> audioPolicyEffects;
331
332 getPlaybackClientAndEffects(portId, client, audioPolicyEffects, __func__);
333
334 if (audioPolicyEffects != 0 && client->active) {
335 // clean up effects if output was not stopped before being released
336 audioPolicyEffects->releaseOutputSessionEffects(
337 client->io, client->stream, client->session);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700338 }
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700339 Mutex::Autolock _l(mLock);
Eric Laurentd4007242019-03-27 12:42:16 -0700340 mAudioPlaybackClients.removeItem(portId);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700341
Eric Laurent10b71232018-04-13 18:14:44 -0700342 // called from internal thread: no need to clear caller identity
Eric Laurent8fc147b2018-07-22 19:13:55 -0700343 mAudioPolicyManager->releaseOutput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800344}
345
Eric Laurentcaf7f482014-11-25 17:50:47 -0800346status_t AudioPolicyService::getInputForAttr(const audio_attributes_t *attr,
347 audio_io_handle_t *input,
Mikhail Naganov2996f672019-04-18 12:29:59 -0700348 audio_unique_id_t riid,
Eric Laurentcaf7f482014-11-25 17:50:47 -0800349 audio_session_t session,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700350 pid_t pid,
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700351 uid_t uid,
Eric Laurentfee19762018-01-29 18:44:13 -0800352 const String16& opPackageName,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800353 const audio_config_base_t *config,
Paul McLean466dc8e2015-04-17 13:15:36 -0600354 audio_input_flags_t flags,
Eric Laurent9ae8c592017-06-22 17:17:09 -0700355 audio_port_handle_t *selectedDeviceId,
Eric Laurent20b9ef02016-12-05 11:03:16 -0800356 audio_port_handle_t *portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800357{
Eric Laurentdce54a12014-03-10 12:19:46 -0700358 if (mAudioPolicyManager == NULL) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800359 return NO_INIT;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800360 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800361
Hiroaki Hayashi685a9712019-07-18 19:50:47 +0900362 audio_source_t inputSource = attr->source;
363 if (inputSource == AUDIO_SOURCE_DEFAULT) {
364 inputSource = AUDIO_SOURCE_MIC;
365 }
366
Eric Laurent2d388ec2014-03-07 13:25:54 -0800367 // already checked by client, but double-check in case the client wrapper is bypassed
Hiroaki Hayashi685a9712019-07-18 19:50:47 +0900368 if ((inputSource < AUDIO_SOURCE_DEFAULT)
369 || (inputSource >= AUDIO_SOURCE_CNT
370 && inputSource != AUDIO_SOURCE_HOTWORD
371 && inputSource != AUDIO_SOURCE_FM_TUNER
372 && inputSource != AUDIO_SOURCE_ECHO_REFERENCE)) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800373 return BAD_VALUE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800374 }
375
Eric Laurentb2379ba2016-05-23 17:42:12 -0700376 bool updatePid = (pid == -1);
Marco Nelissendcb346b2015-09-09 10:47:29 -0700377 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Andy Hung4ef19fa2018-05-15 19:35:29 -0700378 if (!isAudioServerOrMediaServerUid(callingUid)) {
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700379 ALOGW_IF(uid != (uid_t)-1 && uid != callingUid,
Marco Nelissendcb346b2015-09-09 10:47:29 -0700380 "%s uid %d tried to pass itself off as %d", __FUNCTION__, callingUid, uid);
381 uid = callingUid;
Eric Laurentb2379ba2016-05-23 17:42:12 -0700382 updatePid = true;
383 }
384
385 if (updatePid) {
386 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
Eric Laurent9f39f8d2016-05-25 12:34:48 -0700387 ALOGW_IF(pid != (pid_t)-1 && pid != callingPid,
Eric Laurentb2379ba2016-05-23 17:42:12 -0700388 "%s uid %d pid %d tried to pass itself off as pid %d",
389 __func__, callingUid, callingPid, pid);
390 pid = callingPid;
Eric Laurent8c7e6da2015-04-21 17:37:00 -0700391 }
392
Eric Laurent7dca8a82018-01-29 18:44:26 -0800393 // check calling permissions
394 if (!recordingAllowed(opPackageName, pid, uid)) {
395 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
396 __func__, uid, pid);
397 return PERMISSION_DENIED;
398 }
399
Eric Laurent1ff16a72019-03-14 18:35:04 -0700400 bool canCaptureOutput = captureAudioOutputAllowed(pid, uid);
Hiroaki Hayashi685a9712019-07-18 19:50:47 +0900401 if ((inputSource == AUDIO_SOURCE_VOICE_UPLINK ||
402 inputSource == AUDIO_SOURCE_VOICE_DOWNLINK ||
403 inputSource == AUDIO_SOURCE_VOICE_CALL ||
404 inputSource == AUDIO_SOURCE_ECHO_REFERENCE) &&
Eric Laurent1ff16a72019-03-14 18:35:04 -0700405 !canCaptureOutput) {
Nadav Bar744be482018-05-08 13:26:21 +0300406 return PERMISSION_DENIED;
407 }
408
jiabin68e0df72019-03-18 17:55:35 -0700409 bool canCaptureHotword = captureHotwordAllowed(opPackageName, pid, uid);
Hiroaki Hayashi685a9712019-07-18 19:50:47 +0900410 if ((inputSource == AUDIO_SOURCE_HOTWORD) && !canCaptureHotword) {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700411 return BAD_VALUE;
412 }
413
414 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700415 {
Eric Laurent7504b9e2017-08-15 18:17:26 -0700416 status_t status;
417 AudioPolicyInterface::input_type_t inputType;
418
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700419 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700420 {
421 AutoCallerClear acc;
422 // the audio_in_acoustics_t parameter is ignored by get_input()
Mikhail Naganov2996f672019-04-18 12:29:59 -0700423 status = mAudioPolicyManager->getInputForAttr(attr, input, riid, session, uid,
Eric Laurent10b71232018-04-13 18:14:44 -0700424 config,
425 flags, selectedDeviceId,
426 &inputType, portId);
427 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700428 audioPolicyEffects = mAudioPolicyEffects;
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800429
430 if (status == NO_ERROR) {
431 // enforce permission (if any) required for each type of input
432 switch (inputType) {
Kevin Rocard25f9b052019-02-27 15:08:54 -0800433 case AudioPolicyInterface::API_INPUT_MIX_PUBLIC_CAPTURE_PLAYBACK:
434 // this use case has been validated in audio service with a MediaProjection token,
435 // and doesn't rely on regular permissions
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800436 case AudioPolicyInterface::API_INPUT_LEGACY:
437 break;
Eric Laurent82db2692015-08-07 13:59:42 -0700438 case AudioPolicyInterface::API_INPUT_TELEPHONY_RX:
439 // FIXME: use the same permission as for remote submix for now.
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800440 case AudioPolicyInterface::API_INPUT_MIX_CAPTURE:
Eric Laurent1ff16a72019-03-14 18:35:04 -0700441 if (!canCaptureOutput) {
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800442 ALOGE("getInputForAttr() permission denied: capture not allowed");
443 status = PERMISSION_DENIED;
444 }
445 break;
446 case AudioPolicyInterface::API_INPUT_MIX_EXT_POLICY_REROUTE:
447 if (!modifyAudioRoutingAllowed()) {
448 ALOGE("getInputForAttr() permission denied: modify audio routing not allowed");
449 status = PERMISSION_DENIED;
450 }
451 break;
452 case AudioPolicyInterface::API_INPUT_INVALID:
453 default:
454 LOG_ALWAYS_FATAL("getInputForAttr() encountered an invalid input type %d",
455 (int)inputType);
456 }
457 }
458
459 if (status != NO_ERROR) {
460 if (status == PERMISSION_DENIED) {
Eric Laurent10b71232018-04-13 18:14:44 -0700461 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700462 mAudioPolicyManager->releaseInput(*portId);
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800463 }
464 return status;
465 }
Eric Laurentfee19762018-01-29 18:44:13 -0800466
Eric Laurentd7fe0862018-07-14 16:48:01 -0700467 sp<AudioRecordClient> client = new AudioRecordClient(*attr, *input, uid, pid, session,
Eric Laurent1ff16a72019-03-14 18:35:04 -0700468 *selectedDeviceId, opPackageName,
469 canCaptureOutput, canCaptureHotword);
Eric Laurentfee19762018-01-29 18:44:13 -0800470 mAudioRecordClients.add(*portId, client);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700471 }
Jean-Michel Trivi97bb33f2014-12-12 16:23:43 -0800472
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700473 if (audioPolicyEffects != 0) {
474 // create audio pre processors according to input source
Hiroaki Hayashi685a9712019-07-18 19:50:47 +0900475 status_t status = audioPolicyEffects->addInputEffects(*input, inputSource, session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700476 if (status != NO_ERROR && status != ALREADY_EXISTS) {
Eric Laurentcaf7f482014-11-25 17:50:47 -0800477 ALOGW("Failed to add effects on input %d", *input);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700478 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800479 }
Eric Laurentcaf7f482014-11-25 17:50:47 -0800480 return NO_ERROR;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800481}
482
Eric Laurent99fcae42018-05-17 16:59:18 -0700483std::string AudioPolicyService::getDeviceTypeStrForPortId(audio_port_handle_t portId) {
Eric Laurent99fcae42018-05-17 16:59:18 -0700484 struct audio_port port = {};
485 port.id = portId;
486 status_t status = mAudioPolicyManager->getAudioPort(&port);
487 if (status == NO_ERROR && port.type == AUDIO_PORT_TYPE_DEVICE) {
Andy Hung9b181952019-02-25 14:53:36 -0800488 return toString(port.ext.device.type);
Eric Laurent99fcae42018-05-17 16:59:18 -0700489 }
Andy Hung9b181952019-02-25 14:53:36 -0800490 return {};
Eric Laurent99fcae42018-05-17 16:59:18 -0700491}
492
Eric Laurent4eb58f12018-12-07 16:41:02 -0800493status_t AudioPolicyService::startInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800494{
Eric Laurentdce54a12014-03-10 12:19:46 -0700495 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800496 return NO_INIT;
497 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800498 sp<AudioRecordClient> client;
499 {
500 Mutex::Autolock _l(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800501
Eric Laurent7dca8a82018-01-29 18:44:26 -0800502 ssize_t index = mAudioRecordClients.indexOfKey(portId);
503 if (index < 0) {
504 return INVALID_OPERATION;
505 }
506 client = mAudioRecordClients.valueAt(index);
Eric Laurentfee19762018-01-29 18:44:13 -0800507 }
Eric Laurent7dca8a82018-01-29 18:44:26 -0800508
509 // check calling permissions
Svet Ganov6e641372018-03-02 09:21:30 -0800510 if (!startRecording(client->opPackageName, client->pid, client->uid)) {
Eric Laurent7dca8a82018-01-29 18:44:26 -0800511 ALOGE("%s permission denied: recording not allowed for uid %d pid %d",
512 __func__, client->uid, client->pid);
513 return PERMISSION_DENIED;
514 }
Eric Laurentfee19762018-01-29 18:44:13 -0800515
Eric Laurentdf628922018-12-06 21:45:51 +0000516 Mutex::Autolock _l(mLock);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800517
518 client->active = true;
519 client->startTimeNs = systemTime();
520 updateUidStates_l();
Eric Laurentfee19762018-01-29 18:44:13 -0800521
Eric Laurent10b71232018-04-13 18:14:44 -0700522 status_t status;
523 {
524 AutoCallerClear acc;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800525 status = mAudioPolicyManager->startInput(portId);
Ray Essick84e84a52018-05-03 18:45:07 -0700526
527 }
528
Ray Essickf6a57cd2018-05-22 16:20:54 -0700529 // including successes gets very verbose
Ray Essick6ce27e52019-02-15 10:58:05 -0800530 // but once we cut over to westworld, log them all.
Ray Essickf6a57cd2018-05-22 16:20:54 -0700531 if (status != NO_ERROR) {
Ray Essick84e84a52018-05-03 18:45:07 -0700532
533 static constexpr char kAudioPolicy[] = "audiopolicy";
534
Ray Essick84e84a52018-05-03 18:45:07 -0700535 static constexpr char kAudioPolicyStatus[] = "android.media.audiopolicy.status";
536 static constexpr char kAudioPolicyRqstSrc[] = "android.media.audiopolicy.rqst.src";
537 static constexpr char kAudioPolicyRqstPkg[] = "android.media.audiopolicy.rqst.pkg";
538 static constexpr char kAudioPolicyRqstSession[] = "android.media.audiopolicy.rqst.session";
Eric Laurent99fcae42018-05-17 16:59:18 -0700539 static constexpr char kAudioPolicyRqstDevice[] =
540 "android.media.audiopolicy.rqst.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700541 static constexpr char kAudioPolicyActiveSrc[] = "android.media.audiopolicy.active.src";
542 static constexpr char kAudioPolicyActivePkg[] = "android.media.audiopolicy.active.pkg";
Eric Laurent99fcae42018-05-17 16:59:18 -0700543 static constexpr char kAudioPolicyActiveSession[] =
544 "android.media.audiopolicy.active.session";
545 static constexpr char kAudioPolicyActiveDevice[] =
546 "android.media.audiopolicy.active.device";
Ray Essick84e84a52018-05-03 18:45:07 -0700547
Ray Essick6a305222019-01-28 20:33:18 -0800548 MediaAnalyticsItem *item = MediaAnalyticsItem::create(kAudioPolicy);
Ray Essick84e84a52018-05-03 18:45:07 -0700549 if (item != NULL) {
550
Ray Essick84e84a52018-05-03 18:45:07 -0700551 item->setInt32(kAudioPolicyStatus, status);
552
Eric Laurent99fcae42018-05-17 16:59:18 -0700553 item->setCString(kAudioPolicyRqstSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800554 toString(client->attributes.source).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700555 item->setInt32(kAudioPolicyRqstSession, client->session);
Ray Essick51866952018-05-30 11:22:27 -0700556 if (client->opPackageName.size() != 0) {
557 item->setCString(kAudioPolicyRqstPkg,
558 std::string(String8(client->opPackageName).string()).c_str());
559 } else {
Kevin Rocardfbdfebe2018-06-18 12:30:40 -0700560 item->setCString(kAudioPolicyRqstPkg, std::to_string(client->uid).c_str());
Ray Essick51866952018-05-30 11:22:27 -0700561 }
Eric Laurent99fcae42018-05-17 16:59:18 -0700562 item->setCString(
563 kAudioPolicyRqstDevice, getDeviceTypeStrForPortId(client->deviceId).c_str());
564
Eric Laurent4eb58f12018-12-07 16:41:02 -0800565 int count = mAudioRecordClients.size();
566 for (int i = 0; i < count ; i++) {
567 if (portId == mAudioRecordClients.keyAt(i)) {
568 continue;
569 }
570 sp<AudioRecordClient> other = mAudioRecordClients.valueAt(i);
571 if (other->active) {
572 // keeps the last of the clients marked active
573 item->setCString(kAudioPolicyActiveSrc,
Andy Hung9b181952019-02-25 14:53:36 -0800574 toString(other->attributes.source).c_str());
Eric Laurent4eb58f12018-12-07 16:41:02 -0800575 item->setInt32(kAudioPolicyActiveSession, other->session);
576 if (other->opPackageName.size() != 0) {
577 item->setCString(kAudioPolicyActivePkg,
578 std::string(String8(other->opPackageName).string()).c_str());
579 } else {
580 item->setCString(kAudioPolicyRqstPkg,
581 std::to_string(other->uid).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700582 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800583 item->setCString(kAudioPolicyActiveDevice,
584 getDeviceTypeStrForPortId(other->deviceId).c_str());
Ray Essick84e84a52018-05-03 18:45:07 -0700585 }
586 }
587 item->selfrecord();
588 delete item;
589 item = NULL;
590 }
Ray Essick6ce27e52019-02-15 10:58:05 -0800591 }
592
593 if (status != NO_ERROR) {
Eric Laurent4eb58f12018-12-07 16:41:02 -0800594 client->active = false;
595 client->startTimeNs = 0;
596 updateUidStates_l();
Svet Ganov6e641372018-03-02 09:21:30 -0800597 finishRecording(client->opPackageName, client->uid);
Eric Laurentfb66dd92016-01-28 18:32:03 -0800598 }
599
600 return status;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800601}
602
Eric Laurentfee19762018-01-29 18:44:13 -0800603status_t AudioPolicyService::stopInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800604{
Eric Laurentdce54a12014-03-10 12:19:46 -0700605 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800606 return NO_INIT;
607 }
Eric Laurent4eb58f12018-12-07 16:41:02 -0800608
Eric Laurent2d388ec2014-03-07 13:25:54 -0800609 Mutex::Autolock _l(mLock);
610
Eric Laurentfee19762018-01-29 18:44:13 -0800611 ssize_t index = mAudioRecordClients.indexOfKey(portId);
612 if (index < 0) {
613 return INVALID_OPERATION;
614 }
615 sp<AudioRecordClient> client = mAudioRecordClients.valueAt(index);
616
Ray Essick84e84a52018-05-03 18:45:07 -0700617 client->active = false;
Eric Laurent4eb58f12018-12-07 16:41:02 -0800618 client->startTimeNs = 0;
619
620 updateUidStates_l();
Ray Essick84e84a52018-05-03 18:45:07 -0700621
Svet Ganov6e641372018-03-02 09:21:30 -0800622 // finish the recording app op
623 finishRecording(client->opPackageName, client->uid);
Eric Laurent10b71232018-04-13 18:14:44 -0700624 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700625 return mAudioPolicyManager->stopInput(portId);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800626}
627
Eric Laurentfee19762018-01-29 18:44:13 -0800628void AudioPolicyService::releaseInput(audio_port_handle_t portId)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800629{
Eric Laurentdce54a12014-03-10 12:19:46 -0700630 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800631 return;
632 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700633 sp<AudioPolicyEffects>audioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800634 sp<AudioRecordClient> client;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700635 {
636 Mutex::Autolock _l(mLock);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700637 audioPolicyEffects = mAudioPolicyEffects;
Eric Laurentfee19762018-01-29 18:44:13 -0800638 ssize_t index = mAudioRecordClients.indexOfKey(portId);
639 if (index < 0) {
640 return;
641 }
642 client = mAudioRecordClients.valueAt(index);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800643
644 if (client->active) {
645 ALOGW("%s releasing active client portId %d", __FUNCTION__, portId);
646 client->active = false;
647 client->startTimeNs = 0;
648 updateUidStates_l();
649 }
650
Eric Laurentfee19762018-01-29 18:44:13 -0800651 mAudioRecordClients.removeItem(portId);
652 }
653 if (client == 0) {
654 return;
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700655 }
656 if (audioPolicyEffects != 0) {
657 // release audio processors from the input
Eric Laurentd7fe0862018-07-14 16:48:01 -0700658 status_t status = audioPolicyEffects->releaseInputEffects(client->io, client->session);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700659 if(status != NO_ERROR) {
Eric Laurentd7fe0862018-07-14 16:48:01 -0700660 ALOGW("Failed to release effects on input %d", client->io);
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700661 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800662 }
Eric Laurentf10c7092016-12-06 17:09:56 -0800663 {
664 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700665 AutoCallerClear acc;
Eric Laurent8fc147b2018-07-22 19:13:55 -0700666 mAudioPolicyManager->releaseInput(portId);
Eric Laurentf10c7092016-12-06 17:09:56 -0800667 }
Eric Laurent2d388ec2014-03-07 13:25:54 -0800668}
669
670status_t AudioPolicyService::initStreamVolume(audio_stream_type_t stream,
671 int indexMin,
672 int indexMax)
673{
Eric Laurentdce54a12014-03-10 12:19:46 -0700674 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800675 return NO_INIT;
676 }
677 if (!settingsAllowed()) {
678 return PERMISSION_DENIED;
679 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800680 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800681 return BAD_VALUE;
682 }
683 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700684 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700685 mAudioPolicyManager->initStreamVolume(stream, indexMin, indexMax);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800686 return NO_ERROR;
687}
688
689status_t AudioPolicyService::setStreamVolumeIndex(audio_stream_type_t stream,
690 int index,
691 audio_devices_t device)
692{
Eric Laurentdce54a12014-03-10 12:19:46 -0700693 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800694 return NO_INIT;
695 }
696 if (!settingsAllowed()) {
697 return PERMISSION_DENIED;
698 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800699 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800700 return BAD_VALUE;
701 }
702 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700703 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700704 return mAudioPolicyManager->setStreamVolumeIndex(stream,
705 index,
706 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800707}
708
709status_t AudioPolicyService::getStreamVolumeIndex(audio_stream_type_t stream,
710 int *index,
711 audio_devices_t device)
712{
Eric Laurentdce54a12014-03-10 12:19:46 -0700713 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800714 return NO_INIT;
715 }
Eric Laurent223fd5c2014-11-11 13:43:36 -0800716 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800717 return BAD_VALUE;
718 }
719 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700720 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700721 return mAudioPolicyManager->getStreamVolumeIndex(stream,
722 index,
723 device);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800724}
725
François Gaffiecfe17322018-11-07 13:41:29 +0100726status_t AudioPolicyService::setVolumeIndexForAttributes(const audio_attributes_t &attributes,
727 int index, audio_devices_t device)
728{
729 if (mAudioPolicyManager == NULL) {
730 return NO_INIT;
731 }
732 if (!settingsAllowed()) {
733 return PERMISSION_DENIED;
734 }
735 Mutex::Autolock _l(mLock);
736 AutoCallerClear acc;
737 return mAudioPolicyManager->setVolumeIndexForAttributes(attributes, index, device);
738}
739
740status_t AudioPolicyService::getVolumeIndexForAttributes(const audio_attributes_t &attributes,
741 int &index, audio_devices_t device)
742{
743 if (mAudioPolicyManager == NULL) {
744 return NO_INIT;
745 }
746 Mutex::Autolock _l(mLock);
747 AutoCallerClear acc;
748 return mAudioPolicyManager->getVolumeIndexForAttributes(attributes, index, device);
749}
750
751status_t AudioPolicyService::getMinVolumeIndexForAttributes(const audio_attributes_t &attributes,
752 int &index)
753{
754 if (mAudioPolicyManager == NULL) {
755 return NO_INIT;
756 }
757 Mutex::Autolock _l(mLock);
758 AutoCallerClear acc;
759 return mAudioPolicyManager->getMinVolumeIndexForAttributes(attributes, index);
760}
761
762status_t AudioPolicyService::getMaxVolumeIndexForAttributes(const audio_attributes_t &attributes,
763 int &index)
764{
765 if (mAudioPolicyManager == NULL) {
766 return NO_INIT;
767 }
768 Mutex::Autolock _l(mLock);
769 AutoCallerClear acc;
770 return mAudioPolicyManager->getMaxVolumeIndexForAttributes(attributes, index);
771}
772
Eric Laurent2d388ec2014-03-07 13:25:54 -0800773uint32_t AudioPolicyService::getStrategyForStream(audio_stream_type_t stream)
774{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800775 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
François Gaffiec005e562018-11-06 15:04:49 +0100776 return PRODUCT_STRATEGY_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700777 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700778 if (mAudioPolicyManager == NULL) {
François Gaffiec005e562018-11-06 15:04:49 +0100779 return PRODUCT_STRATEGY_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800780 }
François Gaffiec005e562018-11-06 15:04:49 +0100781 // DO NOT LOCK, may be called from AudioFlinger with lock held, reaching deadlock
Eric Laurent10b71232018-04-13 18:14:44 -0700782 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700783 return mAudioPolicyManager->getStrategyForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800784}
785
786//audio policy: use audio_device_t appropriately
787
788audio_devices_t AudioPolicyService::getDevicesForStream(audio_stream_type_t stream)
789{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800790 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700791 return AUDIO_DEVICE_NONE;
Eric Laurentdea15412014-10-28 15:46:45 -0700792 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700793 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700794 return AUDIO_DEVICE_NONE;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800795 }
Haynes Mathew Georgedfb9f3b2015-10-26 18:22:13 -0700796 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700797 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700798 return mAudioPolicyManager->getDevicesForStream(stream);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800799}
800
801audio_io_handle_t AudioPolicyService::getOutputForEffect(const effect_descriptor_t *desc)
802{
803 // FIXME change return type to status_t, and return NO_INIT here
Eric Laurentdce54a12014-03-10 12:19:46 -0700804 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800805 return 0;
806 }
807 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700808 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700809 return mAudioPolicyManager->getOutputForEffect(desc);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800810}
811
812status_t AudioPolicyService::registerEffect(const effect_descriptor_t *desc,
813 audio_io_handle_t io,
814 uint32_t strategy,
Glenn Kastend848eb42016-03-08 13:42:11 -0800815 audio_session_t session,
Eric Laurent2d388ec2014-03-07 13:25:54 -0800816 int id)
817{
Eric Laurentdce54a12014-03-10 12:19:46 -0700818 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800819 return NO_INIT;
820 }
Eric Laurent6c796322019-04-09 14:13:17 -0700821 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700822 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700823 return mAudioPolicyManager->registerEffect(desc, io, strategy, session, id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800824}
825
826status_t AudioPolicyService::unregisterEffect(int id)
827{
Eric Laurentdce54a12014-03-10 12:19:46 -0700828 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800829 return NO_INIT;
830 }
Eric Laurent6c796322019-04-09 14:13:17 -0700831 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700832 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700833 return mAudioPolicyManager->unregisterEffect(id);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800834}
835
836status_t AudioPolicyService::setEffectEnabled(int id, bool enabled)
837{
Eric Laurentdce54a12014-03-10 12:19:46 -0700838 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800839 return NO_INIT;
840 }
Eric Laurent6c796322019-04-09 14:13:17 -0700841 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700842 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700843 return mAudioPolicyManager->setEffectEnabled(id, enabled);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800844}
845
Eric Laurent6c796322019-04-09 14:13:17 -0700846status_t AudioPolicyService::moveEffectsToIo(const std::vector<int>& ids, audio_io_handle_t io)
847{
848 if (mAudioPolicyManager == NULL) {
849 return NO_INIT;
850 }
851 Mutex::Autolock _l(mLock);
852 AutoCallerClear acc;
853 return mAudioPolicyManager->moveEffectsToIo(ids, io);
854}
855
Eric Laurent2d388ec2014-03-07 13:25:54 -0800856bool AudioPolicyService::isStreamActive(audio_stream_type_t stream, uint32_t inPastMs) const
857{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800858 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700859 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700860 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700861 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700862 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800863 }
864 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700865 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700866 return mAudioPolicyManager->isStreamActive(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800867}
868
869bool AudioPolicyService::isStreamActiveRemotely(audio_stream_type_t stream, uint32_t inPastMs) const
870{
Eric Laurent223fd5c2014-11-11 13:43:36 -0800871 if (uint32_t(stream) >= AUDIO_STREAM_PUBLIC_CNT) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700872 return false;
Eric Laurentdea15412014-10-28 15:46:45 -0700873 }
Eric Laurentdce54a12014-03-10 12:19:46 -0700874 if (mAudioPolicyManager == NULL) {
Eric Laurentb1322c72014-10-30 14:59:13 -0700875 return false;
Eric Laurent2d388ec2014-03-07 13:25:54 -0800876 }
877 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700878 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700879 return mAudioPolicyManager->isStreamActiveRemotely(stream, inPastMs);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800880}
881
882bool AudioPolicyService::isSourceActive(audio_source_t source) const
883{
Eric Laurentdce54a12014-03-10 12:19:46 -0700884 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800885 return false;
886 }
887 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -0700888 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -0700889 return mAudioPolicyManager->isSourceActive(source);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800890}
891
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700892status_t AudioPolicyService::getAudioPolicyEffects(sp<AudioPolicyEffects>& audioPolicyEffects)
Eric Laurent2d388ec2014-03-07 13:25:54 -0800893{
Eric Laurentdce54a12014-03-10 12:19:46 -0700894 if (mAudioPolicyManager == NULL) {
Eric Laurent2d388ec2014-03-07 13:25:54 -0800895 return NO_INIT;
896 }
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700897 {
898 Mutex::Autolock _l(mLock);
899 audioPolicyEffects = mAudioPolicyEffects;
900 }
901 if (audioPolicyEffects == 0) {
Eric Laurent8b1e80b2014-10-07 09:08:47 -0700902 return NO_INIT;
903 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700904
905 return OK;
906}
907
908status_t AudioPolicyService::queryDefaultPreProcessing(audio_session_t audioSession,
909 effect_descriptor_t *descriptors,
910 uint32_t *count)
911{
912 sp<AudioPolicyEffects>audioPolicyEffects;
913 status_t status = getAudioPolicyEffects(audioPolicyEffects);
914 if (status != OK) {
915 *count = 0;
916 return status;
917 }
Eric Laurentfb66dd92016-01-28 18:32:03 -0800918 return audioPolicyEffects->queryDefaultInputEffects(
919 (audio_session_t)audioSession, descriptors, count);
Eric Laurent2d388ec2014-03-07 13:25:54 -0800920}
921
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700922status_t AudioPolicyService::addSourceDefaultEffect(const effect_uuid_t *type,
923 const String16& opPackageName,
924 const effect_uuid_t *uuid,
925 int32_t priority,
926 audio_source_t source,
927 audio_unique_id_t* id)
928{
929 sp<AudioPolicyEffects>audioPolicyEffects;
930 status_t status = getAudioPolicyEffects(audioPolicyEffects);
931 if (status != OK) {
932 return status;
933 }
934 if (!modifyDefaultAudioEffectsAllowed()) {
935 return PERMISSION_DENIED;
936 }
937 return audioPolicyEffects->addSourceDefaultEffect(
938 type, opPackageName, uuid, priority, source, id);
939}
940
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700941status_t AudioPolicyService::addStreamDefaultEffect(const effect_uuid_t *type,
942 const String16& opPackageName,
943 const effect_uuid_t *uuid,
944 int32_t priority,
945 audio_usage_t usage,
946 audio_unique_id_t* id)
947{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700948 sp<AudioPolicyEffects>audioPolicyEffects;
949 status_t status = getAudioPolicyEffects(audioPolicyEffects);
950 if (status != OK) {
951 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700952 }
953 if (!modifyDefaultAudioEffectsAllowed()) {
954 return PERMISSION_DENIED;
955 }
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700956 return audioPolicyEffects->addStreamDefaultEffect(
957 type, opPackageName, uuid, priority, usage, id);
958}
959
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700960status_t AudioPolicyService::removeSourceDefaultEffect(audio_unique_id_t id)
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700961{
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700962 sp<AudioPolicyEffects>audioPolicyEffects;
963 status_t status = getAudioPolicyEffects(audioPolicyEffects);
964 if (status != OK) {
965 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700966 }
967 if (!modifyDefaultAudioEffectsAllowed()) {
968 return PERMISSION_DENIED;
969 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700970 return audioPolicyEffects->removeSourceDefaultEffect(id);
971}
972
973status_t AudioPolicyService::removeStreamDefaultEffect(audio_unique_id_t id)
974{
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700975 sp<AudioPolicyEffects>audioPolicyEffects;
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700976 status_t status = getAudioPolicyEffects(audioPolicyEffects);
977 if (status != OK) {
978 return status;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700979 }
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700980 if (!modifyDefaultAudioEffectsAllowed()) {
981 return PERMISSION_DENIED;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700982 }
983 return audioPolicyEffects->removeStreamDefaultEffect(id);
984}
985
Kevin Rocardb99cc752019-03-21 20:52:24 -0700986status_t AudioPolicyService::setAllowedCapturePolicy(uid_t uid, audio_flags_mask_t capturePolicy) {
987 Mutex::Autolock _l(mLock);
988 if (mAudioPolicyManager == NULL) {
989 ALOGV("%s() mAudioPolicyManager == NULL", __func__);
990 return NO_INIT;
991 }
992 uint_t callingUid = IPCThreadState::self()->getCallingUid();
993 if (uid != callingUid) {
994 ALOGD("%s() uid invalid %d != %d", __func__, uid, callingUid);
995 return PERMISSION_DENIED;
996 }
997 return mAudioPolicyManager->setAllowedCapturePolicy(uid, capturePolicy);
998}
999
Eric Laurent2d388ec2014-03-07 13:25:54 -08001000bool AudioPolicyService::isOffloadSupported(const audio_offload_info_t& info)
1001{
Eric Laurentdce54a12014-03-10 12:19:46 -07001002 if (mAudioPolicyManager == NULL) {
1003 ALOGV("mAudioPolicyManager == NULL");
Eric Laurent2d388ec2014-03-07 13:25:54 -08001004 return false;
1005 }
Andy Hung2ddee192015-12-18 17:34:44 -08001006 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001007 AutoCallerClear acc;
Eric Laurentdce54a12014-03-10 12:19:46 -07001008 return mAudioPolicyManager->isOffloadSupported(info);
Eric Laurent2d388ec2014-03-07 13:25:54 -08001009}
1010
Michael Chana94fbb22018-04-24 14:31:19 +10001011bool AudioPolicyService::isDirectOutputSupported(const audio_config_base_t& config,
1012 const audio_attributes_t& attributes) {
1013 if (mAudioPolicyManager == NULL) {
1014 ALOGV("mAudioPolicyManager == NULL");
1015 return false;
1016 }
1017 Mutex::Autolock _l(mLock);
1018 return mAudioPolicyManager->isDirectOutputSupported(config, attributes);
1019}
1020
1021
Eric Laurent6a94d692014-05-20 11:18:06 -07001022status_t AudioPolicyService::listAudioPorts(audio_port_role_t role,
1023 audio_port_type_t type,
Eric Laurent203b1a12014-04-01 10:34:16 -07001024 unsigned int *num_ports,
Eric Laurent6a94d692014-05-20 11:18:06 -07001025 struct audio_port *ports,
1026 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001027{
Eric Laurent6a94d692014-05-20 11:18:06 -07001028 Mutex::Autolock _l(mLock);
1029 if (mAudioPolicyManager == NULL) {
1030 return NO_INIT;
1031 }
Eric Laurent10b71232018-04-13 18:14:44 -07001032 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001033 return mAudioPolicyManager->listAudioPorts(role, type, num_ports, ports, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001034}
1035
Eric Laurent6a94d692014-05-20 11:18:06 -07001036status_t AudioPolicyService::getAudioPort(struct audio_port *port)
Eric Laurent203b1a12014-04-01 10:34:16 -07001037{
Eric Laurent6a94d692014-05-20 11:18:06 -07001038 Mutex::Autolock _l(mLock);
1039 if (mAudioPolicyManager == NULL) {
1040 return NO_INIT;
1041 }
Eric Laurent10b71232018-04-13 18:14:44 -07001042 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001043 return mAudioPolicyManager->getAudioPort(port);
Eric Laurent203b1a12014-04-01 10:34:16 -07001044}
1045
Eric Laurent6a94d692014-05-20 11:18:06 -07001046status_t AudioPolicyService::createAudioPatch(const struct audio_patch *patch,
1047 audio_patch_handle_t *handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001048{
Eric Laurent6a94d692014-05-20 11:18:06 -07001049 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001050 if(!modifyAudioRoutingAllowed()) {
1051 return PERMISSION_DENIED;
1052 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001053 if (mAudioPolicyManager == NULL) {
1054 return NO_INIT;
1055 }
Eric Laurent10b71232018-04-13 18:14:44 -07001056 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001057 return mAudioPolicyManager->createAudioPatch(patch, handle,
1058 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001059}
1060
Eric Laurent6a94d692014-05-20 11:18:06 -07001061status_t AudioPolicyService::releaseAudioPatch(audio_patch_handle_t handle)
Eric Laurent203b1a12014-04-01 10:34:16 -07001062{
Eric Laurent6a94d692014-05-20 11:18:06 -07001063 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001064 if(!modifyAudioRoutingAllowed()) {
1065 return PERMISSION_DENIED;
1066 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001067 if (mAudioPolicyManager == NULL) {
1068 return NO_INIT;
1069 }
Eric Laurent10b71232018-04-13 18:14:44 -07001070 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001071 return mAudioPolicyManager->releaseAudioPatch(handle,
1072 IPCThreadState::self()->getCallingUid());
Eric Laurent203b1a12014-04-01 10:34:16 -07001073}
1074
1075status_t AudioPolicyService::listAudioPatches(unsigned int *num_patches,
Eric Laurent6a94d692014-05-20 11:18:06 -07001076 struct audio_patch *patches,
1077 unsigned int *generation)
Eric Laurent203b1a12014-04-01 10:34:16 -07001078{
Eric Laurent6a94d692014-05-20 11:18:06 -07001079 Mutex::Autolock _l(mLock);
1080 if (mAudioPolicyManager == NULL) {
1081 return NO_INIT;
1082 }
Eric Laurent10b71232018-04-13 18:14:44 -07001083 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001084 return mAudioPolicyManager->listAudioPatches(num_patches, patches, generation);
Eric Laurent203b1a12014-04-01 10:34:16 -07001085}
1086
Eric Laurent6a94d692014-05-20 11:18:06 -07001087status_t AudioPolicyService::setAudioPortConfig(const struct audio_port_config *config)
Eric Laurent203b1a12014-04-01 10:34:16 -07001088{
Eric Laurent6a94d692014-05-20 11:18:06 -07001089 Mutex::Autolock _l(mLock);
Eric Laurent5284ed52014-05-29 14:37:38 -07001090 if(!modifyAudioRoutingAllowed()) {
1091 return PERMISSION_DENIED;
1092 }
Eric Laurent6a94d692014-05-20 11:18:06 -07001093 if (mAudioPolicyManager == NULL) {
1094 return NO_INIT;
1095 }
Eric Laurent10b71232018-04-13 18:14:44 -07001096 AutoCallerClear acc;
Eric Laurent6a94d692014-05-20 11:18:06 -07001097 return mAudioPolicyManager->setAudioPortConfig(config);
Eric Laurent203b1a12014-04-01 10:34:16 -07001098}
Eric Laurent2d388ec2014-03-07 13:25:54 -08001099
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001100status_t AudioPolicyService::acquireSoundTriggerSession(audio_session_t *session,
1101 audio_io_handle_t *ioHandle,
1102 audio_devices_t *device)
1103{
Andy Hungf759b8c2017-08-15 12:48:54 -07001104 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001105 if (mAudioPolicyManager == NULL) {
1106 return NO_INIT;
1107 }
Eric Laurent10b71232018-04-13 18:14:44 -07001108 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001109 return mAudioPolicyManager->acquireSoundTriggerSession(session, ioHandle, device);
1110}
1111
1112status_t AudioPolicyService::releaseSoundTriggerSession(audio_session_t session)
1113{
Andy Hungf759b8c2017-08-15 12:48:54 -07001114 Mutex::Autolock _l(mLock);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001115 if (mAudioPolicyManager == NULL) {
1116 return NO_INIT;
1117 }
Eric Laurent10b71232018-04-13 18:14:44 -07001118 AutoCallerClear acc;
Eric Laurentdf3dc7e2014-07-27 18:39:40 -07001119 return mAudioPolicyManager->releaseSoundTriggerSession(session);
1120}
1121
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -07001122status_t AudioPolicyService::registerPolicyMixes(const Vector<AudioMix>& mixes, bool registration)
Eric Laurentbaac1832014-12-01 17:52:59 -08001123{
1124 Mutex::Autolock _l(mLock);
Kevin Rocardbe201852019-02-20 22:33:28 -08001125
1126 // loopback|render only need a MediaProjection (checked in caller AudioService.java)
1127 bool needModifyAudioRouting = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
1128 return !is_mix_loopback_render(mix.mRouteFlags); });
1129 if (needModifyAudioRouting && !modifyAudioRoutingAllowed()) {
Eric Laurentbaac1832014-12-01 17:52:59 -08001130 return PERMISSION_DENIED;
1131 }
Kevin Rocardbe201852019-02-20 22:33:28 -08001132
Kevin Rocard36b17552019-03-07 18:48:07 -08001133 bool needCaptureMediaOutput = std::any_of(mixes.begin(), mixes.end(), [](auto& mix) {
1134 return mix.mAllowPrivilegedPlaybackCapture; });
1135 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
1136 const pid_t callingPid = IPCThreadState::self()->getCallingPid();
1137 if (needCaptureMediaOutput && !captureMediaOutputAllowed(callingPid, callingUid)) {
1138 return PERMISSION_DENIED;
1139 }
1140
Eric Laurentbaac1832014-12-01 17:52:59 -08001141 if (mAudioPolicyManager == NULL) {
1142 return NO_INIT;
1143 }
Eric Laurent10b71232018-04-13 18:14:44 -07001144 AutoCallerClear acc;
Eric Laurentbaac1832014-12-01 17:52:59 -08001145 if (registration) {
1146 return mAudioPolicyManager->registerPolicyMixes(mixes);
1147 } else {
1148 return mAudioPolicyManager->unregisterPolicyMixes(mixes);
1149 }
1150}
1151
Jean-Michel Trivibda70da2018-12-19 07:30:15 -08001152status_t AudioPolicyService::setUidDeviceAffinities(uid_t uid,
1153 const Vector<AudioDeviceTypeAddr>& devices) {
1154 Mutex::Autolock _l(mLock);
1155 if(!modifyAudioRoutingAllowed()) {
1156 return PERMISSION_DENIED;
1157 }
1158 if (mAudioPolicyManager == NULL) {
1159 return NO_INIT;
1160 }
1161 AutoCallerClear acc;
1162 return mAudioPolicyManager->setUidDeviceAffinities(uid, devices);
1163}
1164
1165status_t AudioPolicyService::removeUidDeviceAffinities(uid_t uid) {
1166 Mutex::Autolock _l(mLock);
1167 if(!modifyAudioRoutingAllowed()) {
1168 return PERMISSION_DENIED;
1169 }
1170 if (mAudioPolicyManager == NULL) {
1171 return NO_INIT;
1172 }
1173 AutoCallerClear acc;
1174 return mAudioPolicyManager->removeUidDeviceAffinities(uid);
1175}
1176
Eric Laurent554a2772015-04-10 11:29:24 -07001177status_t AudioPolicyService::startAudioSource(const struct audio_port_config *source,
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001178 const audio_attributes_t *attributes,
1179 audio_port_handle_t *portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001180{
1181 Mutex::Autolock _l(mLock);
1182 if (mAudioPolicyManager == NULL) {
1183 return NO_INIT;
1184 }
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001185 // startAudioSource should be created as the calling uid
1186 const uid_t callingUid = IPCThreadState::self()->getCallingUid();
Eric Laurent10b71232018-04-13 18:14:44 -07001187 AutoCallerClear acc;
Hongwei Wang5cd1f1d2019-03-26 15:21:11 -07001188 return mAudioPolicyManager->startAudioSource(source, attributes, portId, callingUid);
Eric Laurent554a2772015-04-10 11:29:24 -07001189}
1190
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001191status_t AudioPolicyService::stopAudioSource(audio_port_handle_t portId)
Eric Laurent554a2772015-04-10 11:29:24 -07001192{
1193 Mutex::Autolock _l(mLock);
1194 if (mAudioPolicyManager == NULL) {
1195 return NO_INIT;
1196 }
Eric Laurent10b71232018-04-13 18:14:44 -07001197 AutoCallerClear acc;
Eric Laurent3e6c7e12018-07-27 17:09:23 -07001198 return mAudioPolicyManager->stopAudioSource(portId);
Eric Laurent554a2772015-04-10 11:29:24 -07001199}
1200
Andy Hung2ddee192015-12-18 17:34:44 -08001201status_t AudioPolicyService::setMasterMono(bool mono)
1202{
1203 if (mAudioPolicyManager == NULL) {
1204 return NO_INIT;
1205 }
1206 if (!settingsAllowed()) {
1207 return PERMISSION_DENIED;
1208 }
1209 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001210 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001211 return mAudioPolicyManager->setMasterMono(mono);
1212}
1213
1214status_t AudioPolicyService::getMasterMono(bool *mono)
1215{
1216 if (mAudioPolicyManager == NULL) {
1217 return NO_INIT;
1218 }
1219 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001220 AutoCallerClear acc;
Andy Hung2ddee192015-12-18 17:34:44 -08001221 return mAudioPolicyManager->getMasterMono(mono);
1222}
1223
Eric Laurentac9cef52017-06-09 15:46:26 -07001224
1225float AudioPolicyService::getStreamVolumeDB(
1226 audio_stream_type_t stream, int index, audio_devices_t device)
1227{
1228 if (mAudioPolicyManager == NULL) {
1229 return NAN;
1230 }
1231 Mutex::Autolock _l(mLock);
Eric Laurent10b71232018-04-13 18:14:44 -07001232 AutoCallerClear acc;
Eric Laurentac9cef52017-06-09 15:46:26 -07001233 return mAudioPolicyManager->getStreamVolumeDB(stream, index, device);
1234}
1235
jiabin81772902018-04-02 17:52:27 -07001236status_t AudioPolicyService::getSurroundFormats(unsigned int *numSurroundFormats,
1237 audio_format_t *surroundFormats,
1238 bool *surroundFormatsEnabled,
1239 bool reported)
1240{
1241 if (mAudioPolicyManager == NULL) {
1242 return NO_INIT;
1243 }
1244 Mutex::Autolock _l(mLock);
1245 AutoCallerClear acc;
1246 return mAudioPolicyManager->getSurroundFormats(numSurroundFormats, surroundFormats,
1247 surroundFormatsEnabled, reported);
1248}
1249
Arun Mirpuri11029ad2018-12-19 20:45:19 -08001250status_t AudioPolicyService::getHwOffloadEncodingFormatsSupportedForA2DP(
1251 std::vector<audio_format_t> *formats)
1252{
1253 if (mAudioPolicyManager == NULL) {
1254 return NO_INIT;
1255 }
1256 Mutex::Autolock _l(mLock);
1257 AutoCallerClear acc;
1258 return mAudioPolicyManager->getHwOffloadEncodingFormatsSupportedForA2DP(formats);
1259}
1260
jiabin81772902018-04-02 17:52:27 -07001261status_t AudioPolicyService::setSurroundFormatEnabled(audio_format_t audioFormat, bool enabled)
1262{
1263 if (mAudioPolicyManager == NULL) {
1264 return NO_INIT;
1265 }
1266 Mutex::Autolock _l(mLock);
1267 AutoCallerClear acc;
1268 return mAudioPolicyManager->setSurroundFormatEnabled(audioFormat, enabled);
1269}
Eric Laurentac9cef52017-06-09 15:46:26 -07001270
Eric Laurentb78763e2018-10-17 10:08:02 -07001271status_t AudioPolicyService::setAssistantUid(uid_t uid)
1272{
1273 Mutex::Autolock _l(mLock);
1274 mUidPolicy->setAssistantUid(uid);
1275 return NO_ERROR;
1276}
1277
1278status_t AudioPolicyService::setA11yServicesUids(const std::vector<uid_t>& uids)
1279{
1280 Mutex::Autolock _l(mLock);
1281 mUidPolicy->setA11yUids(uids);
1282 return NO_ERROR;
1283}
1284
jiabin6012f912018-11-02 17:06:30 -07001285bool AudioPolicyService::isHapticPlaybackSupported()
1286{
1287 if (mAudioPolicyManager == NULL) {
1288 ALOGW("%s, mAudioPolicyManager == NULL", __func__);
1289 return false;
1290 }
1291 Mutex::Autolock _l(mLock);
1292 AutoCallerClear acc;
1293 return mAudioPolicyManager->isHapticPlaybackSupported();
1294}
1295
François Gaffied0ba9ed2018-11-05 11:50:42 +01001296status_t AudioPolicyService::listAudioProductStrategies(AudioProductStrategyVector &strategies)
1297{
1298 if (mAudioPolicyManager == NULL) {
1299 return NO_INIT;
1300 }
1301 Mutex::Autolock _l(mLock);
1302 return mAudioPolicyManager->listAudioProductStrategies(strategies);
1303}
1304
François Gaffie4b2018b2018-11-07 11:18:59 +01001305status_t AudioPolicyService::getProductStrategyFromAudioAttributes(
1306 const AudioAttributes &aa, product_strategy_t &productStrategy)
François Gaffied0ba9ed2018-11-05 11:50:42 +01001307{
1308 if (mAudioPolicyManager == NULL) {
François Gaffie4b2018b2018-11-07 11:18:59 +01001309 return NO_INIT;
François Gaffied0ba9ed2018-11-05 11:50:42 +01001310 }
1311 Mutex::Autolock _l(mLock);
François Gaffie4b2018b2018-11-07 11:18:59 +01001312 return mAudioPolicyManager->getProductStrategyFromAudioAttributes(aa, productStrategy);
1313}
1314
1315status_t AudioPolicyService::listAudioVolumeGroups(AudioVolumeGroupVector &groups)
1316{
1317 if (mAudioPolicyManager == NULL) {
1318 return NO_INIT;
1319 }
1320 Mutex::Autolock _l(mLock);
1321 return mAudioPolicyManager->listAudioVolumeGroups(groups);
1322}
1323
1324status_t AudioPolicyService::getVolumeGroupFromAudioAttributes(const AudioAttributes &aa,
1325 volume_group_t &volumeGroup)
1326{
1327 if (mAudioPolicyManager == NULL) {
1328 return NO_INIT;
1329 }
1330 Mutex::Autolock _l(mLock);
1331 return mAudioPolicyManager->getVolumeGroupFromAudioAttributes(aa, volumeGroup);
François Gaffied0ba9ed2018-11-05 11:50:42 +01001332}
Eric Laurent6ede98f2019-06-11 14:50:30 -07001333
1334status_t AudioPolicyService::setRttEnabled(bool enabled)
1335{
1336 Mutex::Autolock _l(mLock);
1337 mUidPolicy->setRttEnabled(enabled);
1338 return NO_ERROR;
1339}
1340
Jean-Michel Trivi2deb4782019-11-01 11:04:15 -07001341status_t AudioPolicyService::setPreferredDeviceForStrategy(product_strategy_t strategy,
1342 const AudioDeviceTypeAddr &device)
1343{
1344 if (mAudioPolicyManager == NULL) {
1345 return NO_INIT;
1346 }
1347 Mutex::Autolock _l(mLock);
1348 return mAudioPolicyManager->setPreferredDeviceForStrategy(strategy, device);
1349}
1350
1351status_t AudioPolicyService::removePreferredDeviceForStrategy(product_strategy_t strategy)
1352{
1353 if (mAudioPolicyManager == NULL) {
1354 return NO_INIT;
1355 }
1356 Mutex::Autolock _l(mLock);
1357 return mAudioPolicyManager->removePreferredDeviceForStrategy(strategy);
1358}
1359
1360status_t AudioPolicyService::getPreferredDeviceForStrategy(product_strategy_t strategy,
1361 AudioDeviceTypeAddr &device)
1362{
1363 if (mAudioPolicyManager == NULL) {
1364 return NO_INIT;
1365 }
1366 Mutex::Autolock _l(mLock);
1367 return mAudioPolicyManager->getPreferredDeviceForStrategy(strategy, device);
1368}
1369
Mikhail Naganov1b2a7942017-12-08 10:18:09 -08001370} // namespace android