The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2008 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 | |
| 17 | #ifndef ANDROID_AUDIOSYSTEM_H_ |
| 18 | #define ANDROID_AUDIOSYSTEM_H_ |
| 19 | |
| 20 | #include <utils/RefBase.h> |
| 21 | #include <utils/threads.h> |
| 22 | #include <media/IAudioFlinger.h> |
| 23 | |
Dima Zavin | 34bb419 | 2011-05-11 14:15:23 -0700 | [diff] [blame] | 24 | #include <system/audio.h> |
Dima Zavin | 290029d | 2011-06-13 18:16:26 -0700 | [diff] [blame] | 25 | #include <system/audio_policy.h> |
Dima Zavin | 24fc2fb | 2011-04-19 22:30:36 -0700 | [diff] [blame] | 26 | |
Dima Zavin | 4dc22e7 | 2011-04-19 22:20:55 -0700 | [diff] [blame] | 27 | /* XXX: Should be include by all the users instead */ |
| 28 | #include <media/AudioParameter.h> |
| 29 | |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 30 | namespace android { |
| 31 | |
| 32 | typedef void (*audio_error_callback)(status_t err); |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 33 | |
| 34 | class IAudioPolicyService; |
| 35 | class String8; |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 36 | |
| 37 | class AudioSystem |
| 38 | { |
| 39 | public: |
| 40 | |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 41 | /* These are static methods to control the system-wide AudioFlinger |
| 42 | * only privileged processes can have access to them |
| 43 | */ |
| 44 | |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 45 | // mute/unmute microphone |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 46 | static status_t muteMicrophone(bool state); |
| 47 | static status_t isMicrophoneMuted(bool *state); |
| 48 | |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 49 | // set/get master volume |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 50 | static status_t setMasterVolume(float value); |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 51 | static status_t getMasterVolume(float* volume); |
Glenn Kasten | ed0079d | 2011-04-04 10:50:50 -0700 | [diff] [blame] | 52 | |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 53 | // mute/unmute audio outputs |
| 54 | static status_t setMasterMute(bool mute); |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 55 | static status_t getMasterMute(bool* mute); |
| 56 | |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 57 | // set/get stream volume on specified output |
Glenn Kasten | 39d00cb | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 58 | static status_t setStreamVolume(audio_stream_type_t stream, float value, |
| 59 | audio_io_handle_t output); |
| 60 | static status_t getStreamVolume(audio_stream_type_t stream, float* volume, |
| 61 | audio_io_handle_t output); |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 62 | |
| 63 | // mute/unmute stream |
Glenn Kasten | bc1d77b | 2012-01-12 16:38:12 -0800 | [diff] [blame] | 64 | static status_t setStreamMute(audio_stream_type_t stream, bool mute); |
| 65 | static status_t getStreamMute(audio_stream_type_t stream, bool* mute); |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 66 | |
Glenn Kasten | accb114 | 2012-01-04 11:00:47 -0800 | [diff] [blame] | 67 | // set audio mode in audio hardware |
| 68 | static status_t setMode(audio_mode_t mode); |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 69 | |
Eric Laurent | 25101b0 | 2011-02-02 09:33:30 -0800 | [diff] [blame] | 70 | // returns true in *state if tracks are active on the specified stream or has been active |
| 71 | // in the past inPastMs milliseconds |
Glenn Kasten | bc1d77b | 2012-01-12 16:38:12 -0800 | [diff] [blame] | 72 | static status_t isStreamActive(audio_stream_type_t stream, bool *state, uint32_t inPastMs = 0); |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 73 | |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 74 | // set/get audio hardware parameters. The function accepts a list of parameters |
| 75 | // key value pairs in the form: key1=value1;key2=value2;... |
| 76 | // Some keys are reserved for standard parameters (See AudioParameter class). |
| 77 | static status_t setParameters(audio_io_handle_t ioHandle, const String8& keyValuePairs); |
| 78 | static String8 getParameters(audio_io_handle_t ioHandle, const String8& keys); |
| 79 | |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 80 | static void setErrorCallback(audio_error_callback cb); |
| 81 | |
| 82 | // helper function to obtain AudioFlinger service handle |
| 83 | static const sp<IAudioFlinger>& get_audio_flinger(); |
| 84 | |
| 85 | static float linearToLog(int volume); |
| 86 | static int logToLinear(float volume); |
| 87 | |
Glenn Kasten | bc1d77b | 2012-01-12 16:38:12 -0800 | [diff] [blame] | 88 | static status_t getOutputSamplingRate(int* samplingRate, audio_stream_type_t stream = AUDIO_STREAM_DEFAULT); |
| 89 | static status_t getOutputFrameCount(int* frameCount, audio_stream_type_t stream = AUDIO_STREAM_DEFAULT); |
| 90 | static status_t getOutputLatency(uint32_t* latency, audio_stream_type_t stream = AUDIO_STREAM_DEFAULT); |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 91 | |
Andreas Huber | 28ea013 | 2012-01-18 10:51:55 -0800 | [diff] [blame] | 92 | // DEPRECATED |
| 93 | static status_t getOutputSamplingRate(int* samplingRate, int stream = AUDIO_STREAM_DEFAULT); |
| 94 | |
| 95 | // DEPRECATED |
| 96 | static status_t getOutputFrameCount(int* frameCount, int stream = AUDIO_STREAM_DEFAULT); |
| 97 | |
Glenn Kasten | bc1d77b | 2012-01-12 16:38:12 -0800 | [diff] [blame] | 98 | static bool routedToA2dpOutput(audio_stream_type_t streamType); |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 99 | |
Glenn Kasten | 0a204ed | 2012-01-12 12:27:51 -0800 | [diff] [blame] | 100 | static status_t getInputBufferSize(uint32_t sampleRate, audio_format_t format, int channelCount, |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 101 | size_t* buffSize); |
| 102 | |
Eric Laurent | 415f3e2 | 2009-10-21 08:14:22 -0700 | [diff] [blame] | 103 | static status_t setVoiceVolume(float volume); |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 104 | |
Eric Laurent | 0986e79 | 2010-01-19 17:37:09 -0800 | [diff] [blame] | 105 | // return the number of audio frames written by AudioFlinger to audio HAL and |
Glenn Kasten | ed0079d | 2011-04-04 10:50:50 -0700 | [diff] [blame] | 106 | // audio dsp to DAC since the output on which the specified stream is playing |
Eric Laurent | 0986e79 | 2010-01-19 17:37:09 -0800 | [diff] [blame] | 107 | // has exited standby. |
| 108 | // returned status (from utils/Errors.h) can be: |
| 109 | // - NO_ERROR: successful operation, halFrames and dspFrames point to valid data |
| 110 | // - INVALID_OPERATION: Not supported on current hardware platform |
| 111 | // - BAD_VALUE: invalid parameter |
| 112 | // NOTE: this feature is not supported on all hardware platforms and it is |
| 113 | // necessary to check returned status before using the returned values. |
Glenn Kasten | bc1d77b | 2012-01-12 16:38:12 -0800 | [diff] [blame] | 114 | static status_t getRenderPosition(uint32_t *halFrames, uint32_t *dspFrames, audio_stream_type_t stream = AUDIO_STREAM_DEFAULT); |
Eric Laurent | 0986e79 | 2010-01-19 17:37:09 -0800 | [diff] [blame] | 115 | |
Eric Laurent | 47d0a92 | 2010-02-26 02:47:27 -0800 | [diff] [blame] | 116 | static unsigned int getInputFramesLost(audio_io_handle_t ioHandle); |
Eric Laurent | 65b6545 | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 117 | |
| 118 | static int newAudioSessionId(); |
Marco Nelissen | c74b93f | 2011-08-02 13:33:41 -0700 | [diff] [blame] | 119 | static void acquireAudioSessionId(int audioSession); |
| 120 | static void releaseAudioSessionId(int audioSession); |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 121 | |
| 122 | // types of io configuration change events received with ioConfigChanged() |
| 123 | enum io_config_event { |
| 124 | OUTPUT_OPENED, |
| 125 | OUTPUT_CLOSED, |
| 126 | OUTPUT_CONFIG_CHANGED, |
| 127 | INPUT_OPENED, |
| 128 | INPUT_CLOSED, |
| 129 | INPUT_CONFIG_CHANGED, |
| 130 | STREAM_CONFIG_CHANGED, |
| 131 | NUM_CONFIG_EVENTS |
| 132 | }; |
| 133 | |
Glenn Kasten | b3db213 | 2012-01-19 08:59:58 -0800 | [diff] [blame] | 134 | // audio output descriptor used to cache output configurations in client process to avoid frequent calls |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 135 | // through IAudioFlinger |
| 136 | class OutputDescriptor { |
| 137 | public: |
| 138 | OutputDescriptor() |
Glenn Kasten | 0a204ed | 2012-01-12 12:27:51 -0800 | [diff] [blame] | 139 | : samplingRate(0), format(AUDIO_FORMAT_DEFAULT), channels(0), frameCount(0), latency(0) {} |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 140 | |
| 141 | uint32_t samplingRate; |
| 142 | int32_t format; |
| 143 | int32_t channels; |
| 144 | size_t frameCount; |
| 145 | uint32_t latency; |
| 146 | }; |
| 147 | |
| 148 | // |
| 149 | // IAudioPolicyService interface (see AudioPolicyInterface for method descriptions) |
| 150 | // |
Dima Zavin | 24fc2fb | 2011-04-19 22:30:36 -0700 | [diff] [blame] | 151 | static status_t setDeviceConnectionState(audio_devices_t device, audio_policy_dev_state_t state, const char *device_address); |
| 152 | static audio_policy_dev_state_t getDeviceConnectionState(audio_devices_t device, const char *device_address); |
Glenn Kasten | accb114 | 2012-01-04 11:00:47 -0800 | [diff] [blame] | 153 | static status_t setPhoneState(audio_mode_t state); |
Dima Zavin | 24fc2fb | 2011-04-19 22:30:36 -0700 | [diff] [blame] | 154 | static status_t setForceUse(audio_policy_force_use_t usage, audio_policy_forced_cfg_t config); |
| 155 | static audio_policy_forced_cfg_t getForceUse(audio_policy_force_use_t usage); |
| 156 | static audio_io_handle_t getOutput(audio_stream_type_t stream, |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 157 | uint32_t samplingRate = 0, |
Glenn Kasten | 0a204ed | 2012-01-12 12:27:51 -0800 | [diff] [blame] | 158 | audio_format_t format = AUDIO_FORMAT_DEFAULT, |
Dima Zavin | 24fc2fb | 2011-04-19 22:30:36 -0700 | [diff] [blame] | 159 | uint32_t channels = AUDIO_CHANNEL_OUT_STEREO, |
Eric Laurent | 45d8c80 | 2012-03-01 09:38:00 -0800 | [diff] [blame] | 160 | audio_policy_output_flags_t flags = AUDIO_POLICY_OUTPUT_FLAG_NONE); |
Eric Laurent | 8ed6ed0 | 2010-07-13 04:45:46 -0700 | [diff] [blame] | 161 | static status_t startOutput(audio_io_handle_t output, |
Dima Zavin | 24fc2fb | 2011-04-19 22:30:36 -0700 | [diff] [blame] | 162 | audio_stream_type_t stream, |
Eric Laurent | 8ed6ed0 | 2010-07-13 04:45:46 -0700 | [diff] [blame] | 163 | int session = 0); |
| 164 | static status_t stopOutput(audio_io_handle_t output, |
Dima Zavin | 24fc2fb | 2011-04-19 22:30:36 -0700 | [diff] [blame] | 165 | audio_stream_type_t stream, |
Eric Laurent | 8ed6ed0 | 2010-07-13 04:45:46 -0700 | [diff] [blame] | 166 | int session = 0); |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 167 | static void releaseOutput(audio_io_handle_t output); |
Glenn Kasten | 0f0fbd9 | 2012-01-23 13:58:49 -0800 | [diff] [blame] | 168 | static audio_io_handle_t getInput(audio_source_t inputSource, |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 169 | uint32_t samplingRate = 0, |
Glenn Kasten | 0a204ed | 2012-01-12 12:27:51 -0800 | [diff] [blame] | 170 | audio_format_t format = AUDIO_FORMAT_DEFAULT, |
Dima Zavin | 24fc2fb | 2011-04-19 22:30:36 -0700 | [diff] [blame] | 171 | uint32_t channels = AUDIO_CHANNEL_IN_MONO, |
Eric Laurent | 464d5b3 | 2011-06-17 21:29:58 -0700 | [diff] [blame] | 172 | audio_in_acoustics_t acoustics = (audio_in_acoustics_t)0, |
| 173 | int sessionId = 0); |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 174 | static status_t startInput(audio_io_handle_t input); |
| 175 | static status_t stopInput(audio_io_handle_t input); |
| 176 | static void releaseInput(audio_io_handle_t input); |
Dima Zavin | 24fc2fb | 2011-04-19 22:30:36 -0700 | [diff] [blame] | 177 | static status_t initStreamVolume(audio_stream_type_t stream, |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 178 | int indexMin, |
| 179 | int indexMax); |
Eric Laurent | 9bc8358d | 2011-11-18 16:43:31 -0800 | [diff] [blame] | 180 | static status_t setStreamVolumeIndex(audio_stream_type_t stream, |
| 181 | int index, |
| 182 | audio_devices_t device); |
| 183 | static status_t getStreamVolumeIndex(audio_stream_type_t stream, |
| 184 | int *index, |
| 185 | audio_devices_t device); |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 186 | |
Dima Zavin | 24fc2fb | 2011-04-19 22:30:36 -0700 | [diff] [blame] | 187 | static uint32_t getStrategyForStream(audio_stream_type_t stream); |
Eric Laurent | c9ab9f5 | 2012-03-08 13:42:42 -0800 | [diff] [blame^] | 188 | static audio_devices_t getDevicesForStream(audio_stream_type_t stream); |
Eric Laurent | 8ed6ed0 | 2010-07-13 04:45:46 -0700 | [diff] [blame] | 189 | |
| 190 | static audio_io_handle_t getOutputForEffect(effect_descriptor_t *desc); |
| 191 | static status_t registerEffect(effect_descriptor_t *desc, |
Eric Laurent | 464d5b3 | 2011-06-17 21:29:58 -0700 | [diff] [blame] | 192 | audio_io_handle_t io, |
Eric Laurent | 8ed6ed0 | 2010-07-13 04:45:46 -0700 | [diff] [blame] | 193 | uint32_t strategy, |
| 194 | int session, |
| 195 | int id); |
| 196 | static status_t unregisterEffect(int id); |
Eric Laurent | 6752ec8 | 2011-08-10 10:37:50 -0700 | [diff] [blame] | 197 | static status_t setEffectEnabled(int id, bool enabled); |
Eric Laurent | 8ed6ed0 | 2010-07-13 04:45:46 -0700 | [diff] [blame] | 198 | |
Eric Laurent | 05ce094 | 2011-08-30 10:18:54 -0700 | [diff] [blame] | 199 | // clear stream to output mapping cache (gStreamOutputMap) |
| 200 | // and output configuration cache (gOutputs) |
| 201 | static void clearAudioConfigCache(); |
| 202 | |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 203 | static const sp<IAudioPolicyService>& get_audio_policy_service(); |
| 204 | |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 205 | // ---------------------------------------------------------------------------- |
| 206 | |
| 207 | private: |
| 208 | |
| 209 | class AudioFlingerClient: public IBinder::DeathRecipient, public BnAudioFlingerClient |
| 210 | { |
| 211 | public: |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 212 | AudioFlingerClient() { |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 213 | } |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 214 | |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 215 | // DeathRecipient |
| 216 | virtual void binderDied(const wp<IBinder>& who); |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 217 | |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 218 | // IAudioFlingerClient |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 219 | |
| 220 | // indicate a change in the configuration of an output or input: keeps the cached |
| 221 | // values for output/input parameters upto date in client process |
Glenn Kasten | 39d00cb | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 222 | virtual void ioConfigChanged(int event, audio_io_handle_t ioHandle, void *param2); |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 223 | }; |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 224 | |
| 225 | class AudioPolicyServiceClient: public IBinder::DeathRecipient |
| 226 | { |
| 227 | public: |
| 228 | AudioPolicyServiceClient() { |
| 229 | } |
| 230 | |
| 231 | // DeathRecipient |
| 232 | virtual void binderDied(const wp<IBinder>& who); |
| 233 | }; |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 234 | |
| 235 | static sp<AudioFlingerClient> gAudioFlingerClient; |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 236 | static sp<AudioPolicyServiceClient> gAudioPolicyServiceClient; |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 237 | friend class AudioFlingerClient; |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 238 | friend class AudioPolicyServiceClient; |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 239 | |
| 240 | static Mutex gLock; |
| 241 | static sp<IAudioFlinger> gAudioFlinger; |
| 242 | static audio_error_callback gAudioErrorCallback; |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 243 | |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 244 | static size_t gInBuffSize; |
| 245 | // previous parameters for recording buffer size queries |
| 246 | static uint32_t gPrevInSamplingRate; |
Glenn Kasten | 0a204ed | 2012-01-12 12:27:51 -0800 | [diff] [blame] | 247 | static audio_format_t gPrevInFormat; |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 248 | static int gPrevInChannelCount; |
| 249 | |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 250 | static sp<IAudioPolicyService> gAudioPolicyService; |
| 251 | |
| 252 | // mapping between stream types and outputs |
Glenn Kasten | b7cffb4 | 2012-01-20 09:37:45 -0800 | [diff] [blame] | 253 | static DefaultKeyedVector<audio_stream_type_t, audio_io_handle_t> gStreamOutputMap; |
Eric Laurent | 05ce094 | 2011-08-30 10:18:54 -0700 | [diff] [blame] | 254 | // list of output descriptors containing cached parameters |
| 255 | // (sampling rate, framecount, channel count...) |
Eric Laurent | a553c25 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 256 | static DefaultKeyedVector<audio_io_handle_t, OutputDescriptor *> gOutputs; |
| 257 | }; |
| 258 | |
The Android Open Source Project | 9066cfe | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 259 | }; // namespace android |
| 260 | |
| 261 | #endif /*ANDROID_AUDIOSYSTEM_H_*/ |