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