blob: ed766b0936007bf122321f4a42bc4a53f86d98f6 [file] [log] [blame]
Svet Ganov3e5f14f2021-05-13 22:51:08 +00001
Mathias Agopian65ab4712010-07-14 17:59:35 -07002/*
3 * Copyright (C) 2009 The Android Open Source Project
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
18#ifndef ANDROID_AUDIOPOLICYSERVICE_H
19#define ANDROID_AUDIOPOLICYSERVICE_H
20
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -080021#include <android/media/BnAudioPolicyService.h>
Eric Laurent81dd0f52021-07-05 11:54:40 +020022#include <android/media/GetSpatializerResponse.h>
Mikhail Naganov197d50a2020-04-30 22:37:43 +000023#include <android-base/thread_annotations.h>
Eric Laurent7c7f10b2011-06-17 21:29:58 -070024#include <cutils/misc.h>
25#include <cutils/config_utils.h>
Mathias Agopiane762be92013-05-09 16:26:45 -070026#include <cutils/compiler.h>
Glenn Kastend1d8f232011-07-08 09:34:50 -070027#include <utils/String8.h>
Mathias Agopian65ab4712010-07-14 17:59:35 -070028#include <utils/Vector.h>
Eric Laurent7c7f10b2011-06-17 21:29:58 -070029#include <utils/SortedVector.h>
Steven Moreland2f348142019-07-02 15:59:07 -070030#include <binder/ActivityManager.h>
Eric Laurented726cc2021-07-01 14:26:41 +020031#include <binder/AppOpsManager.h>
Glenn Kastend2dcb082011-02-03 16:55:26 -080032#include <binder/BinderService.h>
Svet Ganovf4ddfef2018-01-16 07:37:58 -080033#include <binder/IUidObserver.h>
Dima Zavin64760242011-05-11 14:15:23 -070034#include <system/audio.h>
Dima Zavin7394a4f2011-06-13 18:16:26 -070035#include <system/audio_policy.h>
Eric Laurent7c7f10b2011-06-17 21:29:58 -070036#include <media/ToneGenerator.h>
37#include <media/AudioEffect.h>
Eric Laurentbaac1832014-12-01 17:52:59 -080038#include <media/AudioPolicy.h>
Kevin Rocard8be94972019-02-22 13:26:25 -080039#include <mediautils/ServiceUtilities.h>
bryant_liuba2b4392014-06-11 16:49:30 +080040#include "AudioPolicyEffects.h"
Ytai Ben-Tsvi1ef846b2020-03-26 09:41:15 -070041#include "CaptureStateNotifier.h"
Eric Laurent81dd0f52021-07-05 11:54:40 +020042#include "Spatializer.h"
François Gaffie962ba212019-04-03 16:21:39 +020043#include <AudioPolicyInterface.h>
Michael Groovercfd28302018-12-11 19:16:46 -080044#include <android/hardware/BnSensorPrivacyListener.h>
Svet Ganov3e5f14f2021-05-13 22:51:08 +000045#include <android/content/AttributionSourceState.h>
Philip P. Moltmannbda45752020-07-17 16:41:18 -070046
Svet Ganovf4ddfef2018-01-16 07:37:58 -080047#include <unordered_map>
bryant_liuba2b4392014-06-11 16:49:30 +080048
Mathias Agopian65ab4712010-07-14 17:59:35 -070049namespace android {
50
Svet Ganov3e5f14f2021-05-13 22:51:08 +000051using content::AttributionSourceState;
Mikhail Naganovdbf03642021-08-25 18:15:32 -070052using media::audio::common::AudioConfig;
53using media::audio::common::AudioConfigBase;
Mikhail Naganov57bd06f2021-08-10 16:41:54 -070054using media::audio::common::AudioFormatDescription;
Mikhail Naganovddceecc2021-09-03 13:58:56 -070055using media::audio::common::AudioMode;
56using media::audio::common::AudioSource;
Mikhail Naganovdbf03642021-08-25 18:15:32 -070057using media::audio::common::AudioStreamType;
58using media::audio::common::AudioUsage;
Mikhail Naganovddceecc2021-09-03 13:58:56 -070059using media::audio::common::AudioUuid;
Svet Ganov3e5f14f2021-05-13 22:51:08 +000060
Mathias Agopian65ab4712010-07-14 17:59:35 -070061// ----------------------------------------------------------------------------
62
Glenn Kastend2dcb082011-02-03 16:55:26 -080063class AudioPolicyService :
64 public BinderService<AudioPolicyService>,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -080065 public media::BnAudioPolicyService,
Eric Laurent81dd0f52021-07-05 11:54:40 +020066 public IBinder::DeathRecipient,
67 public SpatializerPolicyCallback
Mathias Agopian65ab4712010-07-14 17:59:35 -070068{
Glenn Kastend2dcb082011-02-03 16:55:26 -080069 friend class BinderService<AudioPolicyService>;
Mathias Agopian65ab4712010-07-14 17:59:35 -070070
71public:
Glenn Kastend2dcb082011-02-03 16:55:26 -080072 // for BinderService
Mathias Agopiane762be92013-05-09 16:26:45 -070073 static const char *getServiceName() ANDROID_API { return "media.audio_policy"; }
Mathias Agopian65ab4712010-07-14 17:59:35 -070074
75 virtual status_t dump(int fd, const Vector<String16>& args);
76
77 //
78 // BnAudioPolicyService (see AudioPolicyInterface for method descriptions)
79 //
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -080080 binder::Status onNewAudioModulesAvailable() override;
81 binder::Status setDeviceConnectionState(
82 const media::AudioDevice& device,
83 media::AudioPolicyDeviceState state,
84 const std::string& deviceName,
Mikhail Naganov57bd06f2021-08-10 16:41:54 -070085 const AudioFormatDescription& encodedFormat) override;
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -080086 binder::Status getDeviceConnectionState(const media::AudioDevice& device,
87 media::AudioPolicyDeviceState* _aidl_return) override;
88 binder::Status handleDeviceConfigChange(
89 const media::AudioDevice& device,
90 const std::string& deviceName,
Mikhail Naganov57bd06f2021-08-10 16:41:54 -070091 const AudioFormatDescription& encodedFormat) override;
Mikhail Naganovddceecc2021-09-03 13:58:56 -070092 binder::Status setPhoneState(AudioMode state, int32_t uid) override;
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -080093 binder::Status setForceUse(media::AudioPolicyForceUse usage,
94 media::AudioPolicyForcedConfig config) override;
95 binder::Status getForceUse(media::AudioPolicyForceUse usage,
96 media::AudioPolicyForcedConfig* _aidl_return) override;
Mikhail Naganovdbf03642021-08-25 18:15:32 -070097 binder::Status getOutput(AudioStreamType stream, int32_t* _aidl_return) override;
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -080098 binder::Status getOutputForAttr(const media::AudioAttributesInternal& attr, int32_t session,
Svet Ganov3e5f14f2021-05-13 22:51:08 +000099 const AttributionSourceState &attributionSource,
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700100 const AudioConfig& config,
Eric Laurentf99edd32021-02-01 15:57:33 +0100101 int32_t flags, int32_t selectedDeviceId,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800102 media::GetOutputForAttrResponse* _aidl_return) override;
103 binder::Status startOutput(int32_t portId) override;
104 binder::Status stopOutput(int32_t portId) override;
105 binder::Status releaseOutput(int32_t portId) override;
106 binder::Status getInputForAttr(const media::AudioAttributesInternal& attr, int32_t input,
Philip P. Moltmannbda45752020-07-17 16:41:18 -0700107 int32_t riid, int32_t session,
Svet Ganov3e5f14f2021-05-13 22:51:08 +0000108 const AttributionSourceState &attributionSource,
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700109 const AudioConfigBase& config, int32_t flags,
Eric Laurentf99edd32021-02-01 15:57:33 +0100110 int32_t selectedDeviceId,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800111 media::GetInputForAttrResponse* _aidl_return) override;
112 binder::Status startInput(int32_t portId) override;
113 binder::Status stopInput(int32_t portId) override;
114 binder::Status releaseInput(int32_t portId) override;
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700115 binder::Status initStreamVolume(AudioStreamType stream, int32_t indexMin,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800116 int32_t indexMax) override;
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700117 binder::Status setStreamVolumeIndex(AudioStreamType stream,
Mikhail Naganov21a32ec2021-07-08 14:40:12 -0700118 const media::AudioDeviceDescription& device,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800119 int32_t index) override;
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700120 binder::Status getStreamVolumeIndex(AudioStreamType stream,
Mikhail Naganov21a32ec2021-07-08 14:40:12 -0700121 const media::AudioDeviceDescription& device,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800122 int32_t* _aidl_return) override;
123 binder::Status setVolumeIndexForAttributes(const media::AudioAttributesInternal& attr,
Mikhail Naganov21a32ec2021-07-08 14:40:12 -0700124 const media::AudioDeviceDescription& device,
125 int32_t index) override;
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800126 binder::Status getVolumeIndexForAttributes(const media::AudioAttributesInternal& attr,
Mikhail Naganov21a32ec2021-07-08 14:40:12 -0700127 const media::AudioDeviceDescription& device,
128 int32_t* _aidl_return) override;
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800129 binder::Status getMaxVolumeIndexForAttributes(const media::AudioAttributesInternal& attr,
130 int32_t* _aidl_return) override;
131 binder::Status getMinVolumeIndexForAttributes(const media::AudioAttributesInternal& attr,
132 int32_t* _aidl_return) override;
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700133 binder::Status getStrategyForStream(AudioStreamType stream,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800134 int32_t* _aidl_return) override;
Mikhail Naganov21a32ec2021-07-08 14:40:12 -0700135 binder::Status getDevicesForStream(
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700136 AudioStreamType stream,
Mikhail Naganov21a32ec2021-07-08 14:40:12 -0700137 std::vector<media::AudioDeviceDescription>* _aidl_return) override;
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800138 binder::Status getDevicesForAttributes(const media::AudioAttributesEx& attr,
139 std::vector<media::AudioDevice>* _aidl_return) override;
140 binder::Status getOutputForEffect(const media::EffectDescriptor& desc,
141 int32_t* _aidl_return) override;
142 binder::Status registerEffect(const media::EffectDescriptor& desc, int32_t io, int32_t strategy,
143 int32_t session, int32_t id) override;
144 binder::Status unregisterEffect(int32_t id) override;
145 binder::Status setEffectEnabled(int32_t id, bool enabled) override;
146 binder::Status moveEffectsToIo(const std::vector<int32_t>& ids, int32_t io) override;
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700147 binder::Status isStreamActive(AudioStreamType stream, int32_t inPastMs,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800148 bool* _aidl_return) override;
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700149 binder::Status isStreamActiveRemotely(AudioStreamType stream, int32_t inPastMs,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800150 bool* _aidl_return) override;
Mikhail Naganovddceecc2021-09-03 13:58:56 -0700151 binder::Status isSourceActive(AudioSource source, bool* _aidl_return) override;
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800152 binder::Status queryDefaultPreProcessing(
153 int32_t audioSession, media::Int* count,
154 std::vector<media::EffectDescriptor>* _aidl_return) override;
Mikhail Naganovddceecc2021-09-03 13:58:56 -0700155 binder::Status addSourceDefaultEffect(const AudioUuid& type,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800156 const std::string& opPackageName,
Mikhail Naganovddceecc2021-09-03 13:58:56 -0700157 const AudioUuid& uuid, int32_t priority,
158 AudioSource source,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800159 int32_t* _aidl_return) override;
Mikhail Naganovddceecc2021-09-03 13:58:56 -0700160 binder::Status addStreamDefaultEffect(const AudioUuid& type,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800161 const std::string& opPackageName,
Mikhail Naganovddceecc2021-09-03 13:58:56 -0700162 const AudioUuid& uuid, int32_t priority,
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700163 AudioUsage usage, int32_t* _aidl_return) override;
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800164 binder::Status removeSourceDefaultEffect(int32_t id) override;
165 binder::Status removeStreamDefaultEffect(int32_t id) override;
166 binder::Status setSupportedSystemUsages(
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700167 const std::vector<AudioUsage>& systemUsages) override;
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800168 binder::Status setAllowedCapturePolicy(int32_t uid, int32_t capturePolicy) override;
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700169 binder::Status getOffloadSupport(const media::audio::common::AudioOffloadInfo& info,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800170 media::AudioOffloadMode* _aidl_return) override;
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700171 binder::Status isDirectOutputSupported(const AudioConfigBase& config,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800172 const media::AudioAttributesInternal& attributes,
173 bool* _aidl_return) override;
174 binder::Status listAudioPorts(media::AudioPortRole role, media::AudioPortType type,
175 media::Int* count, std::vector<media::AudioPort>* ports,
176 int32_t* _aidl_return) override;
177 binder::Status getAudioPort(const media::AudioPort& port,
178 media::AudioPort* _aidl_return) override;
179 binder::Status createAudioPatch(const media::AudioPatch& patch, int32_t handle,
180 int32_t* _aidl_return) override;
181 binder::Status releaseAudioPatch(int32_t handle) override;
182 binder::Status listAudioPatches(media::Int* count, std::vector<media::AudioPatch>* patches,
183 int32_t* _aidl_return) override;
184 binder::Status setAudioPortConfig(const media::AudioPortConfig& config) override;
185 binder::Status registerClient(const sp<media::IAudioPolicyServiceClient>& client) override;
186 binder::Status setAudioPortCallbacksEnabled(bool enabled) override;
187 binder::Status setAudioVolumeGroupCallbacksEnabled(bool enabled) override;
188 binder::Status acquireSoundTriggerSession(media::SoundTriggerSession* _aidl_return) override;
189 binder::Status releaseSoundTriggerSession(int32_t session) override;
Mikhail Naganovddceecc2021-09-03 13:58:56 -0700190 binder::Status getPhoneState(AudioMode* _aidl_return) override;
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800191 binder::Status registerPolicyMixes(const std::vector<media::AudioMix>& mixes,
192 bool registration) override;
193 binder::Status setUidDeviceAffinities(int32_t uid,
194 const std::vector<media::AudioDevice>& devices) override;
195 binder::Status removeUidDeviceAffinities(int32_t uid) override;
196 binder::Status setUserIdDeviceAffinities(
197 int32_t userId,
198 const std::vector<media::AudioDevice>& devices) override;
199 binder::Status removeUserIdDeviceAffinities(int32_t userId) override;
200 binder::Status startAudioSource(const media::AudioPortConfig& source,
201 const media::AudioAttributesInternal& attributes,
202 int32_t* _aidl_return) override;
203 binder::Status stopAudioSource(int32_t portId) override;
204 binder::Status setMasterMono(bool mono) override;
205 binder::Status getMasterMono(bool* _aidl_return) override;
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700206 binder::Status getStreamVolumeDB(AudioStreamType stream, int32_t index,
Mikhail Naganov21a32ec2021-07-08 14:40:12 -0700207 const media::AudioDeviceDescription& device,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800208 float* _aidl_return) override;
Kriti Dang6537def2021-03-02 13:46:59 +0100209 binder::Status getSurroundFormats(media::Int* count,
Mikhail Naganov57bd06f2021-08-10 16:41:54 -0700210 std::vector<AudioFormatDescription>* formats,
Kriti Dang877b27e2021-02-02 12:10:40 +0100211 std::vector<bool>* formatsEnabled) override;
Kriti Dang6537def2021-03-02 13:46:59 +0100212 binder::Status getReportedSurroundFormats(
Mikhail Naganov57bd06f2021-08-10 16:41:54 -0700213 media::Int* count, std::vector<AudioFormatDescription>* formats) override;
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800214 binder::Status getHwOffloadEncodingFormatsSupportedForA2DP(
Mikhail Naganov57bd06f2021-08-10 16:41:54 -0700215 std::vector<AudioFormatDescription>* _aidl_return) override;
216 binder::Status setSurroundFormatEnabled(const AudioFormatDescription& audioFormat,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800217 bool enabled) override;
218 binder::Status setAssistantUid(int32_t uid) override;
Ahaan Ugalef51ce002021-08-04 16:34:20 -0700219 binder::Status setHotwordDetectionServiceUid(int32_t uid) override;
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800220 binder::Status setA11yServicesUids(const std::vector<int32_t>& uids) override;
221 binder::Status setCurrentImeUid(int32_t uid) override;
222 binder::Status isHapticPlaybackSupported(bool* _aidl_return) override;
223 binder::Status listAudioProductStrategies(
224 std::vector<media::AudioProductStrategy>* _aidl_return) override;
225 binder::Status getProductStrategyFromAudioAttributes(const media::AudioAttributesEx& aa,
Francois Gaffie11b65922020-09-24 16:59:08 +0200226 bool fallbackOnDefault,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800227 int32_t* _aidl_return) override;
228 binder::Status listAudioVolumeGroups(
229 std::vector<media::AudioVolumeGroup>* _aidl_return) override;
230 binder::Status getVolumeGroupFromAudioAttributes(const media::AudioAttributesEx& aa,
Francois Gaffie11b65922020-09-24 16:59:08 +0200231 bool fallbackOnDefault,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800232 int32_t* _aidl_return) override;
233 binder::Status setRttEnabled(bool enabled) override;
234 binder::Status isCallScreenModeSupported(bool* _aidl_return) override;
235 binder::Status setDevicesRoleForStrategy(
236 int32_t strategy, media::DeviceRole role,
237 const std::vector<media::AudioDevice>& devices) override;
238 binder::Status removeDevicesRoleForStrategy(int32_t strategy, media::DeviceRole role) override;
239 binder::Status getDevicesForRoleAndStrategy(
240 int32_t strategy, media::DeviceRole role,
241 std::vector<media::AudioDevice>* _aidl_return) override;
242 binder::Status setDevicesRoleForCapturePreset(
Mikhail Naganovddceecc2021-09-03 13:58:56 -0700243 AudioSource audioSource,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800244 media::DeviceRole role,
245 const std::vector<media::AudioDevice>& devices) override;
246 binder::Status addDevicesRoleForCapturePreset(
Mikhail Naganovddceecc2021-09-03 13:58:56 -0700247 AudioSource audioSource,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800248 media::DeviceRole role,
249 const std::vector<media::AudioDevice>& devices) override;
250 binder::Status removeDevicesRoleForCapturePreset(
Mikhail Naganovddceecc2021-09-03 13:58:56 -0700251 AudioSource audioSource,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800252 media::DeviceRole role,
253 const std::vector<media::AudioDevice>& devices) override;
Mikhail Naganovddceecc2021-09-03 13:58:56 -0700254 binder::Status clearDevicesRoleForCapturePreset(AudioSource audioSource,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800255 media::DeviceRole role) override;
256 binder::Status getDevicesForRoleAndCapturePreset(
Mikhail Naganovddceecc2021-09-03 13:58:56 -0700257 AudioSource audioSource,
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800258 media::DeviceRole role,
259 std::vector<media::AudioDevice>* _aidl_return) override;
260 binder::Status registerSoundTriggerCaptureStateListener(
261 const sp<media::ICaptureStateListener>& listener, bool* _aidl_return) override;
Ari Hausman-Cohen433722e2018-04-24 14:25:22 -0700262
Eric Laurent81dd0f52021-07-05 11:54:40 +0200263 binder::Status getSpatializer(const sp<media::INativeSpatializerCallback>& callback,
264 media::GetSpatializerResponse* _aidl_return) override;
265 binder::Status canBeSpatialized(
266 const std::optional<media::AudioAttributesInternal>& attr,
Mikhail Naganovdbf03642021-08-25 18:15:32 -0700267 const std::optional<AudioConfig>& config,
Eric Laurent81dd0f52021-07-05 11:54:40 +0200268 const std::vector<media::AudioDevice>& devices,
269 bool* _aidl_return) override;
270
271 status_t onTransact(uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags) override;
Mathias Agopian65ab4712010-07-14 17:59:35 -0700272
273 // IBinder::DeathRecipient
274 virtual void binderDied(const wp<IBinder>& who);
275
Eric Laurentf5ada6e2014-10-09 17:49:00 -0700276 // RefBase
277 virtual void onFirstRef();
278
Mathias Agopian65ab4712010-07-14 17:59:35 -0700279 //
Dima Zavinfce7a472011-04-19 22:30:36 -0700280 // Helpers for the struct audio_policy_service_ops implementation.
281 // This is used by the audio policy manager for certain operations that
282 // are implemented by the policy service.
Mathias Agopian65ab4712010-07-14 17:59:35 -0700283 //
Dima Zavinfce7a472011-04-19 22:30:36 -0700284 virtual void setParameters(audio_io_handle_t ioHandle,
285 const char *keyValuePairs,
286 int delayMs);
287
288 virtual status_t setStreamVolume(audio_stream_type_t stream,
Eric Laurentde070132010-07-13 04:45:46 -0700289 float volume,
290 audio_io_handle_t output,
291 int delayMs = 0);
Mathias Agopian65ab4712010-07-14 17:59:35 -0700292 virtual status_t setVoiceVolume(float volume, int delayMs = 0);
Mathias Agopian65ab4712010-07-14 17:59:35 -0700293
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800294 void doOnNewAudioModulesAvailable();
295 status_t doStopOutput(audio_port_handle_t portId);
296 void doReleaseOutput(audio_port_handle_t portId);
Eric Laurent203b1a12014-04-01 10:34:16 -0700297
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800298 status_t clientCreateAudioPatch(const struct audio_patch *patch,
299 audio_patch_handle_t *handle,
300 int delayMs);
301 status_t clientReleaseAudioPatch(audio_patch_handle_t handle,
302 int delayMs);
303 virtual status_t clientSetAudioPortConfig(const struct audio_port_config *config,
304 int delayMs);
Eric Laurentb52c1522014-05-20 11:27:36 -0700305
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800306 void removeNotificationClient(uid_t uid, pid_t pid);
307 void onAudioPortListUpdate();
308 void doOnAudioPortListUpdate();
309 void onAudioPatchListUpdate();
310 void doOnAudioPatchListUpdate();
Eric Laurente8726fe2015-06-26 09:39:24 -0700311
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800312 void onDynamicPolicyMixStateUpdate(const String8& regId, int32_t state);
313 void doOnDynamicPolicyMixStateUpdate(const String8& regId, int32_t state);
314 void onRecordingConfigurationUpdate(int event,
315 const record_client_info_t *clientInfo,
316 const audio_config_base_t *clientConfig,
317 std::vector<effect_descriptor_t> clientEffects,
318 const audio_config_base_t *deviceConfig,
319 std::vector<effect_descriptor_t> effects,
320 audio_patch_handle_t patchHandle,
321 audio_source_t source);
322 void doOnRecordingConfigurationUpdate(int event,
323 const record_client_info_t *clientInfo,
324 const audio_config_base_t *clientConfig,
325 std::vector<effect_descriptor_t> clientEffects,
326 const audio_config_base_t *deviceConfig,
327 std::vector<effect_descriptor_t> effects,
328 audio_patch_handle_t patchHandle,
329 audio_source_t source);
François Gaffiecfe17322018-11-07 13:41:29 +0100330
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800331 void onAudioVolumeGroupChanged(volume_group_t group, int flags);
332 void doOnAudioVolumeGroupChanged(volume_group_t group, int flags);
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700333
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800334 void onRoutingUpdated();
335 void doOnRoutingUpdated();
Eric Laurentdf3dc7e2014-07-27 18:39:40 -0700336
Eric Laurent81dd0f52021-07-05 11:54:40 +0200337 /**
338 * Spatializer SpatializerPolicyCallback implementation.
339 * onCheckSpatializer() sends an event on mOutputCommandThread which executes
340 * doOnCheckSpatializer() to check if a Spatializer output must be opened or closed
341 * by audio policy manager and attach/detach the spatializer effect accordingly.
342 */
343 void onCheckSpatializer() override;
Eric Laurent39095982021-08-24 18:29:27 +0200344 void onCheckSpatializer_l();
Eric Laurent81dd0f52021-07-05 11:54:40 +0200345 void doOnCheckSpatializer();
346
Ytai Ben-Tsvi0a4904a2021-01-06 12:57:05 -0800347 void setEffectSuspended(int effectId,
348 audio_session_t sessionId,
349 bool suspended);
François Gaffiecfe17322018-11-07 13:41:29 +0100350
Mathias Agopian65ab4712010-07-14 17:59:35 -0700351private:
Mathias Agopiane762be92013-05-09 16:26:45 -0700352 AudioPolicyService() ANDROID_API;
Mathias Agopian65ab4712010-07-14 17:59:35 -0700353 virtual ~AudioPolicyService();
354
Mikhail Naganov197d50a2020-04-30 22:37:43 +0000355 status_t dumpInternals(int fd) REQUIRES(mLock);
Mathias Agopian65ab4712010-07-14 17:59:35 -0700356
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800357 // Handles binder shell commands
358 virtual status_t shellCommand(int in, int out, int err, Vector<String16>& args);
359
Eric Laurent8c7ef892021-06-10 13:32:16 +0200360 class AudioRecordClient;
361
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800362 // Sets whether the given UID records only silence
Eric Laurent8c7ef892021-06-10 13:32:16 +0200363 virtual void setAppState_l(sp<AudioRecordClient> client, app_state_t state) REQUIRES(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800364
365 // Overrides the UID state as if it is idle
366 status_t handleSetUidState(Vector<String16>& args, int err);
367
368 // Clears the override for the UID state
369 status_t handleResetUidState(Vector<String16>& args, int err);
370
371 // Gets the UID state
372 status_t handleGetUidState(Vector<String16>& args, int out, int err);
373
374 // Prints the shell command help
375 status_t printHelp(int out);
376
Eric Laurent99fcae42018-05-17 16:59:18 -0700377 std::string getDeviceTypeStrForPortId(audio_port_handle_t portId);
378
Ari Hausman-Cohen24628312018-08-13 15:01:09 -0700379 status_t getAudioPolicyEffects(sp<AudioPolicyEffects>& audioPolicyEffects);
380
Eric Laurente8c8b432018-10-17 10:08:02 -0700381 app_state_t apmStatFromAmState(int amState);
382
Hayden Gomes524159d2019-12-23 14:41:47 -0800383 bool isSupportedSystemUsage(audio_usage_t usage);
384 status_t validateUsage(audio_usage_t usage);
Svet Ganov3e5f14f2021-05-13 22:51:08 +0000385 status_t validateUsage(audio_usage_t usage, const AttributionSourceState& attributionSource);
Hayden Gomes524159d2019-12-23 14:41:47 -0800386
Eric Laurente8c8b432018-10-17 10:08:02 -0700387 void updateUidStates();
Mikhail Naganov197d50a2020-04-30 22:37:43 +0000388 void updateUidStates_l() REQUIRES(mLock);
Eric Laurente8c8b432018-10-17 10:08:02 -0700389
Mikhail Naganov197d50a2020-04-30 22:37:43 +0000390 void silenceAllRecordings_l() REQUIRES(mLock);
Michael Groovercfd28302018-12-11 19:16:46 -0800391
Eric Laurent2dc962b2019-03-01 08:25:25 -0800392 static bool isVirtualSource(audio_source_t source);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800393
Eric Laurented726cc2021-07-01 14:26:41 +0200394 /** returns true if the audio source must be silenced when the corresponding app op is denied.
395 * false if the audio source does not actually capture from the microphone while still
396 * being mapped to app op OP_RECORD_AUDIO and not a specialized op tracked separately.
397 * See getOpForSource().
398 */
399 static bool isAppOpSource(audio_source_t source);
400
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800401 // If recording we need to make sure the UID is allowed to do that. If the UID is idle
402 // then it cannot record and gets buffers with zeros - silence. As soon as the UID
403 // transitions to an active state we will start reporting buffers with data. This approach
404 // transparently handles recording while the UID transitions between idle/active state
405 // avoiding to get stuck in a state receiving non-empty buffers while idle or in a state
406 // receiving empty buffers while active.
Mikhail Naganoveae73eb2018-04-03 16:57:36 -0700407 class UidPolicy : public BnUidObserver, public virtual IBinder::DeathRecipient {
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800408 public:
409 explicit UidPolicy(wp<AudioPolicyService> service)
Eric Laurent6ede98f2019-06-11 14:50:30 -0700410 : mService(service), mObserverRegistered(false),
Ahaan Ugalef51ce002021-08-04 16:34:20 -0700411 mAssistantUid(0), mHotwordDetectionServiceUid(0), mCurrentImeUid(0),
412 mRttEnabled(false) {}
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800413
414 void registerSelf();
415 void unregisterSelf();
416
Mikhail Naganoveae73eb2018-04-03 16:57:36 -0700417 // IBinder::DeathRecipient implementation
418 void binderDied(const wp<IBinder> &who) override;
419
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800420 bool isUidActive(uid_t uid);
Eric Laurente8c8b432018-10-17 10:08:02 -0700421 int getUidState(uid_t uid);
Ahaan Ugalef51ce002021-08-04 16:34:20 -0700422 void setAssistantUid(uid_t uid) { mAssistantUid = uid; };
423 void setHotwordDetectionServiceUid(uid_t uid) { mHotwordDetectionServiceUid = uid; }
424 bool isAssistantUid(uid_t uid) const {
425 // The HotwordDetectionService is part of the Assistant package but runs with a separate
426 // (isolated) uid, so we check for either uid here.
427 return uid == mAssistantUid || uid == mHotwordDetectionServiceUid;
428 }
Eric Laurentb78763e2018-10-17 10:08:02 -0700429 void setA11yUids(const std::vector<uid_t>& uids) { mA11yUids.clear(); mA11yUids = uids; }
430 bool isA11yUid(uid_t uid);
Eric Laurent4eb58f12018-12-07 16:41:02 -0800431 bool isA11yOnTop();
Kohsuke Yatoha623a132020-03-24 20:10:26 -0700432 void setCurrentImeUid(uid_t uid) { mCurrentImeUid = uid; }
433 bool isCurrentImeUid(uid_t uid) { return uid == mCurrentImeUid; }
Eric Laurent6ede98f2019-06-11 14:50:30 -0700434 void setRttEnabled(bool enabled) { mRttEnabled = enabled; }
435 bool isRttEnabled() { return mRttEnabled; }
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800436
Mikhail Naganoveae73eb2018-04-03 16:57:36 -0700437 // BnUidObserver implementation
438 void onUidActive(uid_t uid) override;
439 void onUidGone(uid_t uid, bool disabled) override;
440 void onUidIdle(uid_t uid, bool disabled) override;
Hui Yu13ad0eb2019-09-09 10:27:07 -0700441 void onUidStateChanged(uid_t uid, int32_t procState, int64_t procStateSeq,
442 int32_t capability);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800443
Mikhail Naganoveae73eb2018-04-03 16:57:36 -0700444 void addOverrideUid(uid_t uid, bool active) { updateOverrideUid(uid, active, true); }
445 void removeOverrideUid(uid_t uid) { updateOverrideUid(uid, false, false); }
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800446
Eric Laurente8c8b432018-10-17 10:08:02 -0700447 void updateUid(std::unordered_map<uid_t, std::pair<bool, int>> *uids,
448 uid_t uid, bool active, int state, bool insert);
449
450 private:
451 void notifyService();
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800452 void updateOverrideUid(uid_t uid, bool active, bool insert);
Eric Laurente8c8b432018-10-17 10:08:02 -0700453 void updateUidLocked(std::unordered_map<uid_t, std::pair<bool, int>> *uids,
454 uid_t uid, bool active, int state, bool insert);
455 void checkRegistered();
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800456
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800457 wp<AudioPolicyService> mService;
Mikhail Naganoveae73eb2018-04-03 16:57:36 -0700458 Mutex mLock;
Steven Moreland2f348142019-07-02 15:59:07 -0700459 ActivityManager mAm;
Mikhail Naganov197d50a2020-04-30 22:37:43 +0000460 bool mObserverRegistered = false;
Eric Laurente8c8b432018-10-17 10:08:02 -0700461 std::unordered_map<uid_t, std::pair<bool, int>> mOverrideUids;
462 std::unordered_map<uid_t, std::pair<bool, int>> mCachedUids;
Mikhail Naganov197d50a2020-04-30 22:37:43 +0000463 uid_t mAssistantUid = -1;
Ahaan Ugalef51ce002021-08-04 16:34:20 -0700464 uid_t mHotwordDetectionServiceUid = -1;
Eric Laurentb78763e2018-10-17 10:08:02 -0700465 std::vector<uid_t> mA11yUids;
Mikhail Naganov197d50a2020-04-30 22:37:43 +0000466 uid_t mCurrentImeUid = -1;
467 bool mRttEnabled = false;
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800468 };
469
Michael Groovercfd28302018-12-11 19:16:46 -0800470 // If sensor privacy is enabled then all apps, including those that are active, should be
471 // prevented from recording. This is handled similar to idle UIDs, any app that attempts
472 // to record while sensor privacy is enabled will receive buffers with zeros. As soon as
473 // sensor privacy is disabled active apps will receive the expected data when recording.
474 class SensorPrivacyPolicy : public hardware::BnSensorPrivacyListener {
475 public:
476 explicit SensorPrivacyPolicy(wp<AudioPolicyService> service)
477 : mService(service) {}
478
479 void registerSelf();
Evan Severson241d9592021-01-08 12:16:02 -0800480 void registerSelfForMicrophoneOnly(int userId);
Michael Groovercfd28302018-12-11 19:16:46 -0800481 void unregisterSelf();
482
483 bool isSensorPrivacyEnabled();
484
485 binder::Status onSensorPrivacyChanged(bool enabled);
486
487 private:
488 wp<AudioPolicyService> mService;
Mikhail Naganov197d50a2020-04-30 22:37:43 +0000489 std::atomic_bool mSensorPrivacyEnabled = false;
Michael Groovercfd28302018-12-11 19:16:46 -0800490 };
491
Eric Laurentdcd4ab12018-06-29 17:45:13 -0700492 // Thread used to send audio config commands to audio flinger
Glenn Kasten85ab62c2012-11-01 11:11:38 -0700493 // For audio config commands, it is necessary because audio flinger requires that the calling
494 // process (user) has permission to modify audio settings.
Mathias Agopian65ab4712010-07-14 17:59:35 -0700495 class AudioCommandThread : public Thread {
496 class AudioCommand;
497 public:
498
499 // commands for tone AudioCommand
500 enum {
Mathias Agopian65ab4712010-07-14 17:59:35 -0700501 SET_VOLUME,
502 SET_PARAMETERS,
Eric Laurentbfb1b832013-01-07 09:53:42 -0800503 SET_VOICE_VOLUME,
504 STOP_OUTPUT,
Eric Laurent951f4552014-05-20 10:48:17 -0700505 RELEASE_OUTPUT,
506 CREATE_AUDIO_PATCH,
507 RELEASE_AUDIO_PATCH,
Eric Laurentb52c1522014-05-20 11:27:36 -0700508 UPDATE_AUDIOPORT_LIST,
Eric Laurente1715a42014-05-20 11:30:42 -0700509 UPDATE_AUDIOPATCH_LIST,
François Gaffiecfe17322018-11-07 13:41:29 +0100510 CHANGED_AUDIOVOLUMEGROUP,
Eric Laurente1715a42014-05-20 11:30:42 -0700511 SET_AUDIOPORT_CONFIG,
Jean-Michel Trivi2f4fe9f2015-12-04 16:20:59 -0800512 DYN_POLICY_MIX_STATE_UPDATE,
Eric Laurentb20cf7d2019-04-05 19:37:34 -0700513 RECORDING_CONFIGURATION_UPDATE,
514 SET_EFFECT_SUSPENDED,
Mikhail Naganov88b30d22020-03-09 19:43:13 +0000515 AUDIO_MODULES_UPDATE,
Jean-Michel Trivi9a6b9ad2020-10-22 16:46:43 -0700516 ROUTING_UPDATED,
Eric Laurent81dd0f52021-07-05 11:54:40 +0200517 UPDATE_UID_STATES,
518 CHECK_SPATIALIZER
Mathias Agopian65ab4712010-07-14 17:59:35 -0700519 };
520
Eric Laurentbfb1b832013-01-07 09:53:42 -0800521 AudioCommandThread (String8 name, const wp<AudioPolicyService>& service);
Mathias Agopian65ab4712010-07-14 17:59:35 -0700522 virtual ~AudioCommandThread();
523
524 status_t dump(int fd);
525
526 // Thread virtuals
527 virtual void onFirstRef();
528 virtual bool threadLoop();
529
530 void exit();
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800531 status_t volumeCommand(audio_stream_type_t stream, float volume,
532 audio_io_handle_t output, int delayMs = 0);
533 status_t parametersCommand(audio_io_handle_t ioHandle,
534 const char *keyValuePairs, int delayMs = 0);
Mathias Agopian65ab4712010-07-14 17:59:35 -0700535 status_t voiceVolumeCommand(float volume, int delayMs = 0);
Eric Laurentd7fe0862018-07-14 16:48:01 -0700536 void stopOutputCommand(audio_port_handle_t portId);
537 void releaseOutputCommand(audio_port_handle_t portId);
Eric Laurent0ede8922014-05-09 18:04:42 -0700538 status_t sendCommand(sp<AudioCommand>& command, int delayMs = 0);
539 void insertCommand_l(sp<AudioCommand>& command, int delayMs = 0);
Eric Laurent951f4552014-05-20 10:48:17 -0700540 status_t createAudioPatchCommand(const struct audio_patch *patch,
541 audio_patch_handle_t *handle,
542 int delayMs);
543 status_t releaseAudioPatchCommand(audio_patch_handle_t handle,
544 int delayMs);
Eric Laurentb52c1522014-05-20 11:27:36 -0700545 void updateAudioPortListCommand();
546 void updateAudioPatchListCommand();
François Gaffiecfe17322018-11-07 13:41:29 +0100547 void changeAudioVolumeGroupCommand(volume_group_t group, int flags);
Eric Laurente1715a42014-05-20 11:30:42 -0700548 status_t setAudioPortConfigCommand(const struct audio_port_config *config,
549 int delayMs);
Eric Laurenta9f86652018-11-28 17:23:11 -0800550 void dynamicPolicyMixStateUpdateCommand(const String8& regId,
551 int32_t state);
Jean-Michel Trivi2f4fe9f2015-12-04 16:20:59 -0800552 void recordingConfigurationUpdateCommand(
Eric Laurenta9f86652018-11-28 17:23:11 -0800553 int event,
554 const record_client_info_t *clientInfo,
555 const audio_config_base_t *clientConfig,
556 std::vector<effect_descriptor_t> clientEffects,
557 const audio_config_base_t *deviceConfig,
558 std::vector<effect_descriptor_t> effects,
559 audio_patch_handle_t patchHandle,
560 audio_source_t source);
Eric Laurentb20cf7d2019-04-05 19:37:34 -0700561 void setEffectSuspendedCommand(int effectId,
562 audio_session_t sessionId,
563 bool suspended);
Mikhail Naganov88b30d22020-03-09 19:43:13 +0000564 void audioModulesUpdateCommand();
Jean-Michel Trivi9a6b9ad2020-10-22 16:46:43 -0700565 void routingChangedCommand();
Eric Laurented726cc2021-07-01 14:26:41 +0200566 void updateUidStatesCommand();
Eric Laurent81dd0f52021-07-05 11:54:40 +0200567 void checkSpatializerCommand();
Eric Laurent951f4552014-05-20 10:48:17 -0700568 void insertCommand_l(AudioCommand *command, int delayMs = 0);
Mathias Agopian65ab4712010-07-14 17:59:35 -0700569 private:
Jesper Tragardh48412dc2014-03-24 14:12:43 +0100570 class AudioCommandData;
571
Mathias Agopian65ab4712010-07-14 17:59:35 -0700572 // descriptor for requested tone playback event
Eric Laurent0ede8922014-05-09 18:04:42 -0700573 class AudioCommand: public RefBase {
Mathias Agopian65ab4712010-07-14 17:59:35 -0700574
575 public:
576 AudioCommand()
Eric Laurent0ede8922014-05-09 18:04:42 -0700577 : mCommand(-1), mStatus(NO_ERROR), mWaitStatus(false) {}
Mathias Agopian65ab4712010-07-14 17:59:35 -0700578
579 void dump(char* buffer, size_t size);
580
Eric Laurentdcd4ab12018-06-29 17:45:13 -0700581 int mCommand; // SET_VOLUME, SET_PARAMETERS...
Mathias Agopian65ab4712010-07-14 17:59:35 -0700582 nsecs_t mTime; // time stamp
Eric Laurent0ede8922014-05-09 18:04:42 -0700583 Mutex mLock; // mutex associated to mCond
Mathias Agopian65ab4712010-07-14 17:59:35 -0700584 Condition mCond; // condition for status return
585 status_t mStatus; // command status
586 bool mWaitStatus; // true if caller is waiting for status
Eric Laurent0ede8922014-05-09 18:04:42 -0700587 sp<AudioCommandData> mParam; // command specific parameter data
Mathias Agopian65ab4712010-07-14 17:59:35 -0700588 };
589
Eric Laurent0ede8922014-05-09 18:04:42 -0700590 class AudioCommandData: public RefBase {
Jesper Tragardh48412dc2014-03-24 14:12:43 +0100591 public:
592 virtual ~AudioCommandData() {}
593 protected:
594 AudioCommandData() {}
595 };
596
Jesper Tragardh48412dc2014-03-24 14:12:43 +0100597 class VolumeData : public AudioCommandData {
Mathias Agopian65ab4712010-07-14 17:59:35 -0700598 public:
Glenn Kastenfff6d712012-01-12 16:38:12 -0800599 audio_stream_type_t mStream;
Mathias Agopian65ab4712010-07-14 17:59:35 -0700600 float mVolume;
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800601 audio_io_handle_t mIO;
Mathias Agopian65ab4712010-07-14 17:59:35 -0700602 };
603
Jesper Tragardh48412dc2014-03-24 14:12:43 +0100604 class ParametersData : public AudioCommandData {
Mathias Agopian65ab4712010-07-14 17:59:35 -0700605 public:
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800606 audio_io_handle_t mIO;
Mathias Agopian65ab4712010-07-14 17:59:35 -0700607 String8 mKeyValuePairs;
608 };
609
Jesper Tragardh48412dc2014-03-24 14:12:43 +0100610 class VoiceVolumeData : public AudioCommandData {
Mathias Agopian65ab4712010-07-14 17:59:35 -0700611 public:
612 float mVolume;
613 };
614
Jesper Tragardh48412dc2014-03-24 14:12:43 +0100615 class StopOutputData : public AudioCommandData {
Eric Laurentbfb1b832013-01-07 09:53:42 -0800616 public:
Eric Laurentd7fe0862018-07-14 16:48:01 -0700617 audio_port_handle_t mPortId;
Eric Laurentbfb1b832013-01-07 09:53:42 -0800618 };
619
Jesper Tragardh48412dc2014-03-24 14:12:43 +0100620 class ReleaseOutputData : public AudioCommandData {
Eric Laurentbfb1b832013-01-07 09:53:42 -0800621 public:
Eric Laurentd7fe0862018-07-14 16:48:01 -0700622 audio_port_handle_t mPortId;
Eric Laurentbfb1b832013-01-07 09:53:42 -0800623 };
624
Eric Laurent951f4552014-05-20 10:48:17 -0700625 class CreateAudioPatchData : public AudioCommandData {
626 public:
627 struct audio_patch mPatch;
628 audio_patch_handle_t mHandle;
629 };
630
631 class ReleaseAudioPatchData : public AudioCommandData {
632 public:
633 audio_patch_handle_t mHandle;
634 };
635
François Gaffiecfe17322018-11-07 13:41:29 +0100636 class AudioVolumeGroupData : public AudioCommandData {
637 public:
638 volume_group_t mGroup;
639 int mFlags;
640 };
641
Eric Laurente1715a42014-05-20 11:30:42 -0700642 class SetAudioPortConfigData : public AudioCommandData {
643 public:
644 struct audio_port_config mConfig;
645 };
646
Jean-Michel Trivide801052015-04-14 19:10:14 -0700647 class DynPolicyMixStateUpdateData : public AudioCommandData {
648 public:
649 String8 mRegId;
650 int32_t mState;
651 };
652
Jean-Michel Trivi2f4fe9f2015-12-04 16:20:59 -0800653 class RecordingConfigurationUpdateData : public AudioCommandData {
654 public:
655 int mEvent;
Jean-Michel Triviac4e4292016-12-22 11:39:31 -0800656 record_client_info_t mClientInfo;
Jean-Michel Trivi7281aa92016-02-17 15:33:40 -0800657 struct audio_config_base mClientConfig;
Eric Laurenta9f86652018-11-28 17:23:11 -0800658 std::vector<effect_descriptor_t> mClientEffects;
Jean-Michel Trivi7281aa92016-02-17 15:33:40 -0800659 struct audio_config_base mDeviceConfig;
Eric Laurenta9f86652018-11-28 17:23:11 -0800660 std::vector<effect_descriptor_t> mEffects;
Jean-Michel Trivi8c7cf3b2016-02-25 17:08:24 -0800661 audio_patch_handle_t mPatchHandle;
Eric Laurenta9f86652018-11-28 17:23:11 -0800662 audio_source_t mSource;
Jean-Michel Trivi2f4fe9f2015-12-04 16:20:59 -0800663 };
664
Eric Laurentb20cf7d2019-04-05 19:37:34 -0700665 class SetEffectSuspendedData : public AudioCommandData {
666 public:
667 int mEffectId;
668 audio_session_t mSessionId;
669 bool mSuspended;
670 };
671
Mathias Agopian65ab4712010-07-14 17:59:35 -0700672 Mutex mLock;
673 Condition mWaitWorkCV;
Eric Laurent0ede8922014-05-09 18:04:42 -0700674 Vector < sp<AudioCommand> > mAudioCommands; // list of pending commands
Eric Laurent0ede8922014-05-09 18:04:42 -0700675 sp<AudioCommand> mLastCommand; // last processed command (used by dump)
Mathias Agopian65ab4712010-07-14 17:59:35 -0700676 String8 mName; // string used by wake lock fo delayed commands
Eric Laurentbfb1b832013-01-07 09:53:42 -0800677 wp<AudioPolicyService> mService;
Mathias Agopian65ab4712010-07-14 17:59:35 -0700678 };
679
Eric Laurentdce54a12014-03-10 12:19:46 -0700680 class AudioPolicyClient : public AudioPolicyClientInterface
681 {
682 public:
Chih-Hung Hsiehe964d4e2016-08-09 14:31:32 -0700683 explicit AudioPolicyClient(AudioPolicyService *service) : mAudioPolicyService(service) {}
Eric Laurentdce54a12014-03-10 12:19:46 -0700684 virtual ~AudioPolicyClient() {}
685
686 //
687 // Audio HW module functions
688 //
689
690 // loads a HW module.
691 virtual audio_module_handle_t loadHwModule(const char *name);
692
693 //
694 // Audio output Control functions
695 //
696
697 // opens an audio output with the requested parameters. The parameter values can indicate to use the default values
698 // in case the audio policy manager has no specific requirements for the output being opened.
699 // When the function returns, the parameter values reflect the actual values used by the audio hardware output stream.
700 // The audio policy manager can check if the proposed parameters are suitable or not and act accordingly.
Eric Laurentcf2c0212014-07-25 16:20:43 -0700701 virtual status_t openOutput(audio_module_handle_t module,
702 audio_io_handle_t *output,
Eric Laurentf1f22e72021-07-13 14:04:14 +0200703 audio_config_t *halConfig,
704 audio_config_base_t *mixerConfig,
jiabin43810402019-10-24 14:58:31 -0700705 const sp<DeviceDescriptorBase>& device,
Eric Laurentcf2c0212014-07-25 16:20:43 -0700706 uint32_t *latencyMs,
707 audio_output_flags_t flags);
Eric Laurentdce54a12014-03-10 12:19:46 -0700708 // creates a special output that is duplicated to the two outputs passed as arguments. The duplication is performed by
709 // a special mixer thread in the AudioFlinger.
710 virtual audio_io_handle_t openDuplicateOutput(audio_io_handle_t output1, audio_io_handle_t output2);
711 // closes the output stream
712 virtual status_t closeOutput(audio_io_handle_t output);
713 // suspends the output. When an output is suspended, the corresponding audio hardware output stream is placed in
714 // standby and the AudioTracks attached to the mixer thread are still processed but the output mix is discarded.
715 virtual status_t suspendOutput(audio_io_handle_t output);
716 // restores a suspended output.
717 virtual status_t restoreOutput(audio_io_handle_t output);
718
719 //
720 // Audio input Control functions
721 //
722
723 // opens an audio input
724 virtual audio_io_handle_t openInput(audio_module_handle_t module,
Eric Laurentcf2c0212014-07-25 16:20:43 -0700725 audio_io_handle_t *input,
726 audio_config_t *config,
727 audio_devices_t *devices,
728 const String8& address,
729 audio_source_t source,
Glenn Kastenec40d282014-07-15 15:31:26 -0700730 audio_input_flags_t flags);
Eric Laurentdce54a12014-03-10 12:19:46 -0700731 // closes an audio input
732 virtual status_t closeInput(audio_io_handle_t input);
733 //
734 // misc control functions
735 //
736
737 // set a stream volume for a particular output. For the same user setting, a given stream type can have different volumes
738 // for each output (destination device) it is attached to.
739 virtual status_t setStreamVolume(audio_stream_type_t stream, float volume, audio_io_handle_t output, int delayMs = 0);
740
741 // invalidate a stream type, causing a reroute to an unspecified new output
742 virtual status_t invalidateStream(audio_stream_type_t stream);
743
744 // function enabling to send proprietary informations directly from audio policy manager to audio hardware interface.
745 virtual void setParameters(audio_io_handle_t ioHandle, const String8& keyValuePairs, int delayMs = 0);
746 // function enabling to receive proprietary informations directly from audio hardware interface to audio policy manager.
747 virtual String8 getParameters(audio_io_handle_t ioHandle, const String8& keys);
748
Eric Laurentdce54a12014-03-10 12:19:46 -0700749 // set down link audio volume.
750 virtual status_t setVoiceVolume(float volume, int delayMs = 0);
751
752 // move effect to the specified output
Glenn Kastend848eb42016-03-08 13:42:11 -0800753 virtual status_t moveEffects(audio_session_t session,
Eric Laurentdce54a12014-03-10 12:19:46 -0700754 audio_io_handle_t srcOutput,
755 audio_io_handle_t dstOutput);
756
Eric Laurentb20cf7d2019-04-05 19:37:34 -0700757 void setEffectSuspended(int effectId,
758 audio_session_t sessionId,
759 bool suspended) override;
760
Eric Laurent951f4552014-05-20 10:48:17 -0700761 /* Create a patch between several source and sink ports */
762 virtual status_t createAudioPatch(const struct audio_patch *patch,
763 audio_patch_handle_t *handle,
764 int delayMs);
765
766 /* Release a patch */
767 virtual status_t releaseAudioPatch(audio_patch_handle_t handle,
768 int delayMs);
769
Eric Laurente1715a42014-05-20 11:30:42 -0700770 /* Set audio port configuration */
771 virtual status_t setAudioPortConfig(const struct audio_port_config *config, int delayMs);
772
Eric Laurentb52c1522014-05-20 11:27:36 -0700773 virtual void onAudioPortListUpdate();
774 virtual void onAudioPatchListUpdate();
Jean-Michel Trivide801052015-04-14 19:10:14 -0700775 virtual void onDynamicPolicyMixStateUpdate(String8 regId, int32_t state);
Jean-Michel Trivi2f4fe9f2015-12-04 16:20:59 -0800776 virtual void onRecordingConfigurationUpdate(int event,
Eric Laurenta9f86652018-11-28 17:23:11 -0800777 const record_client_info_t *clientInfo,
778 const audio_config_base_t *clientConfig,
779 std::vector<effect_descriptor_t> clientEffects,
780 const audio_config_base_t *deviceConfig,
781 std::vector<effect_descriptor_t> effects,
782 audio_patch_handle_t patchHandle,
783 audio_source_t source);
Eric Laurentb52c1522014-05-20 11:27:36 -0700784
François Gaffiecfe17322018-11-07 13:41:29 +0100785 virtual void onAudioVolumeGroupChanged(volume_group_t group, int flags);
786
Jean-Michel Trivi9a6b9ad2020-10-22 16:46:43 -0700787 virtual void onRoutingUpdated();
788
Glenn Kasteneeecb982016-02-26 10:44:04 -0800789 virtual audio_unique_id_t newAudioUniqueId(audio_unique_id_use_t use);
Eric Laurentde3f8392014-07-27 18:38:22 -0700790
Ytai Ben-Tsvi74cd6b02019-10-25 10:06:40 -0700791 void setSoundTriggerCaptureState(bool active) override;
792
jiabinb4fed192020-09-22 14:45:40 -0700793 status_t getAudioPort(struct audio_port_v7 *port) override;
794
jiabin10a03f12021-05-07 23:46:28 +0000795 status_t updateSecondaryOutputs(
796 const TrackSecondaryOutputsMap& trackSecondaryOutputs) override;
797
Eric Laurentdce54a12014-03-10 12:19:46 -0700798 private:
799 AudioPolicyService *mAudioPolicyService;
800 };
801
Eric Laurentb52c1522014-05-20 11:27:36 -0700802 // --- Notification Client ---
803 class NotificationClient : public IBinder::DeathRecipient {
804 public:
805 NotificationClient(const sp<AudioPolicyService>& service,
Ytai Ben-Tsvi7e7a79d2020-12-15 16:48:16 -0800806 const sp<media::IAudioPolicyServiceClient>& client,
luochaojiang908c7d72018-06-21 14:58:04 +0800807 uid_t uid, pid_t pid);
Eric Laurentb52c1522014-05-20 11:27:36 -0700808 virtual ~NotificationClient();
809
Jean-Michel Trivide801052015-04-14 19:10:14 -0700810 void onAudioPortListUpdate();
811 void onAudioPatchListUpdate();
Eric Laurenta9f86652018-11-28 17:23:11 -0800812 void onDynamicPolicyMixStateUpdate(const String8& regId,
813 int32_t state);
François Gaffiecfe17322018-11-07 13:41:29 +0100814 void onAudioVolumeGroupChanged(volume_group_t group, int flags);
Jean-Michel Trivi2f4fe9f2015-12-04 16:20:59 -0800815 void onRecordingConfigurationUpdate(
Eric Laurenta9f86652018-11-28 17:23:11 -0800816 int event,
817 const record_client_info_t *clientInfo,
818 const audio_config_base_t *clientConfig,
819 std::vector<effect_descriptor_t> clientEffects,
820 const audio_config_base_t *deviceConfig,
821 std::vector<effect_descriptor_t> effects,
822 audio_patch_handle_t patchHandle,
823 audio_source_t source);
Jean-Michel Trivi9a6b9ad2020-10-22 16:46:43 -0700824 void onRoutingUpdated();
Eric Laurente8726fe2015-06-26 09:39:24 -0700825 void setAudioPortCallbacksEnabled(bool enabled);
François Gaffiecfe17322018-11-07 13:41:29 +0100826 void setAudioVolumeGroupCallbacksEnabled(bool enabled);
Eric Laurentb52c1522014-05-20 11:27:36 -0700827
luochaojiang908c7d72018-06-21 14:58:04 +0800828 uid_t uid() {
829 return mUid;
830 }
831
Eric Laurentb52c1522014-05-20 11:27:36 -0700832 // IBinder::DeathRecipient
833 virtual void binderDied(const wp<IBinder>& who);
834
835 private:
836 NotificationClient(const NotificationClient&);
837 NotificationClient& operator = (const NotificationClient&);
838
Ytai Ben-Tsvi7e7a79d2020-12-15 16:48:16 -0800839 const wp<AudioPolicyService> mService;
840 const uid_t mUid;
841 const pid_t mPid;
842 const sp<media::IAudioPolicyServiceClient> mAudioPolicyServiceClient;
843 bool mAudioPortCallbacksEnabled;
844 bool mAudioVolumeGroupCallbacksEnabled;
Eric Laurentb52c1522014-05-20 11:27:36 -0700845 };
846
Eric Laurentd7fe0862018-07-14 16:48:01 -0700847 class AudioClient : public virtual RefBase {
848 public:
849 AudioClient(const audio_attributes_t attributes,
Philip P. Moltmannbda45752020-07-17 16:41:18 -0700850 const audio_io_handle_t io,
Svet Ganov3e5f14f2021-05-13 22:51:08 +0000851 const AttributionSourceState& attributionSource,
Eric Laurent5ada82e2019-08-29 17:53:54 -0700852 const audio_session_t session, audio_port_handle_t portId,
853 const audio_port_handle_t deviceId) :
Svet Ganov3e5f14f2021-05-13 22:51:08 +0000854 attributes(attributes), io(io), attributionSource(
855 attributionSource), session(session), portId(portId),
856 deviceId(deviceId), active(false) {}
Eric Laurentd7fe0862018-07-14 16:48:01 -0700857 ~AudioClient() override = default;
858
859
860 const audio_attributes_t attributes; // source, flags ...
861 const audio_io_handle_t io; // audio HAL stream IO handle
Svet Ganov3e5f14f2021-05-13 22:51:08 +0000862 const AttributionSourceState& attributionSource; //client attributionsource
Eric Laurentd7fe0862018-07-14 16:48:01 -0700863 const audio_session_t session; // audio session ID
Eric Laurent5ada82e2019-08-29 17:53:54 -0700864 const audio_port_handle_t portId;
Eric Laurentd7fe0862018-07-14 16:48:01 -0700865 const audio_port_handle_t deviceId; // selected input device port ID
866 bool active; // Playback/Capture is active or inactive
867 };
868
Eric Laurented726cc2021-07-01 14:26:41 +0200869 // Checks and monitors app ops for AudioRecordClient
870 class OpRecordAudioMonitor : public RefBase {
871 public:
872 ~OpRecordAudioMonitor() override;
873 bool hasOp() const;
874 int32_t getOp() const { return mAppOp; }
875
876 static sp<OpRecordAudioMonitor> createIfNeeded(
877 const AttributionSourceState& attributionSource,
878 const audio_attributes_t& attr, wp<AudioCommandThread> commandThread);
879
880 private:
881 OpRecordAudioMonitor(const AttributionSourceState& attributionSource, int32_t appOp,
882 wp<AudioCommandThread> commandThread);
883
884 void onFirstRef() override;
885
886 AppOpsManager mAppOpsManager;
887
888 class RecordAudioOpCallback : public BnAppOpsCallback {
889 public:
890 explicit RecordAudioOpCallback(const wp<OpRecordAudioMonitor>& monitor);
891 void opChanged(int32_t op, const String16& packageName) override;
892
893 private:
894 const wp<OpRecordAudioMonitor> mMonitor;
895 };
896
897 sp<RecordAudioOpCallback> mOpCallback;
898 // called by RecordAudioOpCallback when the app op for this OpRecordAudioMonitor is updated
899 // in AppOp callback and in onFirstRef()
900 // updateUidStates is true when the silenced state of active AudioRecordClients must be
901 // re-evaluated
902 void checkOp(bool updateUidStates = false);
903
904 std::atomic_bool mHasOp;
905 const AttributionSourceState mAttributionSource;
906 const int32_t mAppOp;
907 wp<AudioCommandThread> mCommandThread;
908 };
909
Eric Laurentfee19762018-01-29 18:44:13 -0800910 // --- AudioRecordClient ---
911 // Information about each registered AudioRecord client
912 // (between calls to getInputForAttr() and releaseInput())
Eric Laurentd7fe0862018-07-14 16:48:01 -0700913 class AudioRecordClient : public AudioClient {
Eric Laurentfee19762018-01-29 18:44:13 -0800914 public:
915 AudioRecordClient(const audio_attributes_t attributes,
Philip P. Moltmannbda45752020-07-17 16:41:18 -0700916 const audio_io_handle_t io,
Eric Laurent5ada82e2019-08-29 17:53:54 -0700917 const audio_session_t session, audio_port_handle_t portId,
Philip P. Moltmannbda45752020-07-17 16:41:18 -0700918 const audio_port_handle_t deviceId,
Svet Ganov3e5f14f2021-05-13 22:51:08 +0000919 const AttributionSourceState& attributionSource,
Eric Laurented726cc2021-07-01 14:26:41 +0200920 bool canCaptureOutput, bool canCaptureHotword,
921 wp<AudioCommandThread> commandThread) :
Svet Ganov3e5f14f2021-05-13 22:51:08 +0000922 AudioClient(attributes, io, attributionSource,
923 session, portId, deviceId), attributionSource(attributionSource),
924 startTimeNs(0), canCaptureOutput(canCaptureOutput),
Eric Laurented726cc2021-07-01 14:26:41 +0200925 canCaptureHotword(canCaptureHotword), silenced(false),
926 mOpRecordAudioMonitor(
927 OpRecordAudioMonitor::createIfNeeded(attributionSource,
928 attributes, commandThread)) {}
Eric Laurentd7fe0862018-07-14 16:48:01 -0700929 ~AudioRecordClient() override = default;
Eric Laurentfee19762018-01-29 18:44:13 -0800930
Eric Laurented726cc2021-07-01 14:26:41 +0200931 bool hasOp() const {
932 return mOpRecordAudioMonitor ? mOpRecordAudioMonitor->hasOp() : true;
933 }
934
Svet Ganov3e5f14f2021-05-13 22:51:08 +0000935 const AttributionSourceState attributionSource; // attribution source of client
Eric Laurent4eb58f12018-12-07 16:41:02 -0800936 nsecs_t startTimeNs;
Ricardo Correa57a37692020-03-23 17:27:25 -0700937 const bool canCaptureOutput;
Eric Laurent1ff16a72019-03-14 18:35:04 -0700938 const bool canCaptureHotword;
Eric Laurent8c7ef892021-06-10 13:32:16 +0200939 bool silenced;
Eric Laurented726cc2021-07-01 14:26:41 +0200940
941 private:
942 sp<OpRecordAudioMonitor> mOpRecordAudioMonitor;
Eric Laurentd7fe0862018-07-14 16:48:01 -0700943 };
944
Eric Laurented726cc2021-07-01 14:26:41 +0200945
Eric Laurentd7fe0862018-07-14 16:48:01 -0700946 // --- AudioPlaybackClient ---
947 // Information about each registered AudioTrack client
948 // (between calls to getOutputForAttr() and releaseOutput())
949 class AudioPlaybackClient : public AudioClient {
950 public:
951 AudioPlaybackClient(const audio_attributes_t attributes,
Svet Ganov3e5f14f2021-05-13 22:51:08 +0000952 const audio_io_handle_t io, AttributionSourceState attributionSource,
Eric Laurent5ada82e2019-08-29 17:53:54 -0700953 const audio_session_t session, audio_port_handle_t portId,
954 audio_port_handle_t deviceId, audio_stream_type_t stream) :
Svet Ganov3e5f14f2021-05-13 22:51:08 +0000955 AudioClient(attributes, io, attributionSource, session, portId,
Philip P. Moltmannbda45752020-07-17 16:41:18 -0700956 deviceId), stream(stream) {}
Eric Laurentd7fe0862018-07-14 16:48:01 -0700957 ~AudioPlaybackClient() override = default;
958
959 const audio_stream_type_t stream;
Eric Laurentfee19762018-01-29 18:44:13 -0800960 };
961
Eric Laurentbcfe5be2019-04-09 19:56:39 -0700962 void getPlaybackClientAndEffects(audio_port_handle_t portId,
963 sp<AudioPlaybackClient>& client,
964 sp<AudioPolicyEffects>& effects,
965 const char *context);
966
967
Eric Laurent10b71232018-04-13 18:14:44 -0700968 // A class automatically clearing and restoring binder caller identity inside
969 // a code block (scoped variable)
970 // Declare one systematically before calling AudioPolicyManager methods so that they are
971 // executed with the same level of privilege as audioserver process.
972 class AutoCallerClear {
973 public:
974 AutoCallerClear() :
975 mToken(IPCThreadState::self()->clearCallingIdentity()) {}
976 ~AutoCallerClear() {
977 IPCThreadState::self()->restoreCallingIdentity(mToken);
978 }
979
980 private:
981 const int64_t mToken;
982 };
983
Mathias Agopian65ab4712010-07-14 17:59:35 -0700984 // Internal dump utilities.
985 status_t dumpPermissionDenial(int fd);
Jaideep Sharmaba9053b2021-01-25 21:24:26 +0530986 void loadAudioPolicyManager();
987 void unloadAudioPolicyManager();
Mathias Agopian65ab4712010-07-14 17:59:35 -0700988
Eric Laurenteda6c362011-02-02 09:33:30 -0800989 mutable Mutex mLock; // prevents concurrent access to AudioPolicy manager functions changing
990 // device connection state or routing
Haynes Mathew Georgebab7bf42015-10-30 18:02:23 -0700991 // Note: lock acquisition order is always mLock > mEffectsLock:
992 // mLock protects AudioPolicyManager methods that can call into audio flinger
993 // and possibly back in to audio policy service and acquire mEffectsLock.
Glenn Kastene53b9ea2012-03-12 16:29:55 -0700994 sp<AudioCommandThread> mAudioCommandThread; // audio commands thread
Eric Laurentbfb1b832013-01-07 09:53:42 -0800995 sp<AudioCommandThread> mOutputCommandThread; // process stop and release output
Eric Laurentf269b8e2014-06-09 20:01:29 -0700996 AudioPolicyInterface *mAudioPolicyManager;
Eric Laurentdce54a12014-03-10 12:19:46 -0700997 AudioPolicyClient *mAudioPolicyClient;
Hayden Gomes524159d2019-12-23 14:41:47 -0800998 std::vector<audio_usage_t> mSupportedSystemUsages;
Eric Laurentdce54a12014-03-10 12:19:46 -0700999
Mikhail Naganov197d50a2020-04-30 22:37:43 +00001000 Mutex mNotificationClientsLock;
1001 DefaultKeyedVector<int64_t, sp<NotificationClient>> mNotificationClients
1002 GUARDED_BY(mNotificationClientsLock);
bryant_liuba2b4392014-06-11 16:49:30 +08001003 // Manage all effects configured in audio_effects.conf
Eric Laurent6c796322019-04-09 14:13:17 -07001004 // never hold AudioPolicyService::mLock when calling AudioPolicyEffects methods as
1005 // those can call back into AudioPolicyService methods and try to acquire the mutex
Mikhail Naganov197d50a2020-04-30 22:37:43 +00001006 sp<AudioPolicyEffects> mAudioPolicyEffects GUARDED_BY(mLock);
1007 audio_mode_t mPhoneState GUARDED_BY(mLock);
1008 uid_t mPhoneStateOwnerUid GUARDED_BY(mLock);
Svet Ganovf4ddfef2018-01-16 07:37:58 -08001009
Mikhail Naganov197d50a2020-04-30 22:37:43 +00001010 sp<UidPolicy> mUidPolicy GUARDED_BY(mLock);
1011 sp<SensorPrivacyPolicy> mSensorPrivacyPolicy GUARDED_BY(mLock);
Michael Groovercfd28302018-12-11 19:16:46 -08001012
Mikhail Naganov197d50a2020-04-30 22:37:43 +00001013 DefaultKeyedVector<audio_port_handle_t, sp<AudioRecordClient>> mAudioRecordClients
1014 GUARDED_BY(mLock);
1015 DefaultKeyedVector<audio_port_handle_t, sp<AudioPlaybackClient>> mAudioPlaybackClients
1016 GUARDED_BY(mLock);
Kevin Rocard8be94972019-02-22 13:26:25 -08001017
1018 MediaPackageManager mPackageManager; // To check allowPlaybackCapture
Ytai Ben-Tsvi1ef846b2020-03-26 09:41:15 -07001019
1020 CaptureStateNotifier mCaptureStateNotifier;
Evan Severson241d9592021-01-08 12:16:02 -08001021
Eric Laurent81dd0f52021-07-05 11:54:40 +02001022 sp<Spatializer> mSpatializer;
1023
Jaideep Sharmaba9053b2021-01-25 21:24:26 +05301024 void *mLibraryHandle = nullptr;
1025 CreateAudioPolicyManagerInstance mCreateAudioPolicyManager;
1026 DestroyAudioPolicyManagerInstance mDestroyAudioPolicyManager;
Mathias Agopian65ab4712010-07-14 17:59:35 -07001027};
1028
Mikhail Naganov1b2a7942017-12-08 10:18:09 -08001029} // namespace android
Mathias Agopian65ab4712010-07-14 17:59:35 -07001030
1031#endif // ANDROID_AUDIOPOLICYSERVICE_H