The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2007 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_IAUDIOFLINGER_H |
| 18 | #define ANDROID_IAUDIOFLINGER_H |
| 19 | |
| 20 | #include <stdint.h> |
| 21 | #include <sys/types.h> |
| 22 | #include <unistd.h> |
| 23 | |
| 24 | #include <utils/RefBase.h> |
| 25 | #include <utils/Errors.h> |
Mathias Agopian | 7562408 | 2009-05-19 19:08:10 -0700 | [diff] [blame] | 26 | #include <binder/IInterface.h> |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 27 | #include <media/IAudioTrack.h> |
| 28 | #include <media/IAudioRecord.h> |
| 29 | #include <media/IAudioFlingerClient.h> |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 30 | #include <system/audio.h> |
Glenn Kasten | 18868c5 | 2012-03-07 09:15:37 -0800 | [diff] [blame] | 31 | #include <system/audio_policy.h> |
Eric Laurent | a4c5a55 | 2012-03-29 10:12:40 -0700 | [diff] [blame] | 32 | #include <hardware/audio_policy.h> |
Eric Laurent | e1315cf | 2011-05-17 19:16:02 -0700 | [diff] [blame] | 33 | #include <hardware/audio_effect.h> |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 34 | #include <media/IEffect.h> |
| 35 | #include <media/IEffectClient.h> |
Eric Laurent | c2f1f07 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 36 | #include <utils/String8.h> |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 37 | |
| 38 | namespace android { |
| 39 | |
| 40 | // ---------------------------------------------------------------------------- |
| 41 | |
| 42 | class IAudioFlinger : public IInterface |
| 43 | { |
| 44 | public: |
| 45 | DECLARE_META_INTERFACE(AudioFlinger); |
| 46 | |
Glenn Kasten | a075db4 | 2012-03-06 11:22:44 -0800 | [diff] [blame] | 47 | // or-able bits shared by createTrack and openRecord, but not all combinations make sense |
| 48 | enum { |
Glenn Kasten | cc1110d | 2012-03-19 12:07:35 -0700 | [diff] [blame] | 49 | TRACK_DEFAULT = 0, // client requests a default AudioTrack |
| 50 | TRACK_TIMED = 1, // client requests a TimedAudioTrack |
Glenn Kasten | 1879fff | 2012-07-11 15:36:59 -0700 | [diff] [blame] | 51 | TRACK_FAST = 2, // client requests a fast AudioTrack or AudioRecord |
Richard Fitzgerald | ad3af33 | 2013-03-25 16:54:37 +0000 | [diff] [blame] | 52 | TRACK_OFFLOAD = 4, // client requests offload to hw codec |
Eric Laurent | ab5cdba | 2014-06-09 17:22:27 -0700 | [diff] [blame] | 53 | TRACK_DIRECT = 8, // client requests a direct output |
Glenn Kasten | a075db4 | 2012-03-06 11:22:44 -0800 | [diff] [blame] | 54 | }; |
| 55 | typedef uint32_t track_flags_t; |
| 56 | |
Glenn Kasten | e93cf2c | 2013-09-24 11:52:37 -0700 | [diff] [blame] | 57 | // invariant on exit for all APIs that return an sp<>: |
| 58 | // (return value != 0) == (*status == NO_ERROR) |
| 59 | |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 60 | /* create an audio track and registers it with AudioFlinger. |
| 61 | * return null if the track cannot be created. |
| 62 | */ |
| 63 | virtual sp<IAudioTrack> createTrack( |
Glenn Kasten | fff6d71 | 2012-01-12 16:38:12 -0800 | [diff] [blame] | 64 | audio_stream_type_t streamType, |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 65 | uint32_t sampleRate, |
Glenn Kasten | 58f3021 | 2012-01-12 12:27:51 -0800 | [diff] [blame] | 66 | audio_format_t format, |
Glenn Kasten | dd8104c | 2012-07-02 12:42:44 -0700 | [diff] [blame] | 67 | audio_channel_mask_t channelMask, |
Glenn Kasten | 74935e4 | 2013-12-19 08:56:45 -0800 | [diff] [blame] | 68 | size_t *pFrameCount, |
Glenn Kasten | e0b0717 | 2012-11-06 15:03:34 -0800 | [diff] [blame] | 69 | track_flags_t *flags, |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 70 | const sp<IMemory>& sharedBuffer, |
Glenn Kasten | d631d96 | 2014-01-16 12:31:12 -0800 | [diff] [blame] | 71 | // On successful return, AudioFlinger takes over the handle |
| 72 | // reference and will release it when the track is destroyed. |
| 73 | // However on failure, the client is responsible for release. |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 74 | audio_io_handle_t output, |
Glenn Kasten | 3acbd05 | 2012-02-28 10:39:56 -0800 | [diff] [blame] | 75 | pid_t tid, // -1 means unused, otherwise must be valid non-0 |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 76 | int *sessionId, |
Marco Nelissen | 462fd2f | 2013-01-14 14:12:05 -0800 | [diff] [blame] | 77 | int clientUid, |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 78 | status_t *status) = 0; |
| 79 | |
| 80 | virtual sp<IAudioRecord> openRecord( |
Glenn Kasten | d631d96 | 2014-01-16 12:31:12 -0800 | [diff] [blame] | 81 | // On successful return, AudioFlinger takes over the handle |
| 82 | // reference and will release it when the track is destroyed. |
| 83 | // However on failure, the client is responsible for release. |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 84 | audio_io_handle_t input, |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 85 | uint32_t sampleRate, |
Glenn Kasten | 58f3021 | 2012-01-12 12:27:51 -0800 | [diff] [blame] | 86 | audio_format_t format, |
Glenn Kasten | dd8104c | 2012-07-02 12:42:44 -0700 | [diff] [blame] | 87 | audio_channel_mask_t channelMask, |
Glenn Kasten | 74935e4 | 2013-12-19 08:56:45 -0800 | [diff] [blame] | 88 | size_t *pFrameCount, |
Glenn Kasten | eeca326 | 2013-07-31 16:12:48 -0700 | [diff] [blame] | 89 | track_flags_t *flags, |
Glenn Kasten | 1879fff | 2012-07-11 15:36:59 -0700 | [diff] [blame] | 90 | pid_t tid, // -1 means unused, otherwise must be valid non-0 |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 91 | int *sessionId, |
Glenn Kasten | 7df8c0b | 2014-07-03 12:23:29 -0700 | [diff] [blame] | 92 | size_t *notificationFrames, |
Glenn Kasten | d776ac6 | 2014-05-07 09:16:09 -0700 | [diff] [blame] | 93 | sp<IMemory>& cblk, |
| 94 | sp<IMemory>& buffers, // return value 0 means it follows cblk |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 95 | status_t *status) = 0; |
| 96 | |
| 97 | /* query the audio hardware state. This state never changes, |
| 98 | * and therefore can be cached. |
| 99 | */ |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 100 | virtual uint32_t sampleRate(audio_io_handle_t output) const = 0; |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 101 | virtual audio_format_t format(audio_io_handle_t output) const = 0; |
| 102 | virtual size_t frameCount(audio_io_handle_t output) const = 0; |
Glenn Kasten | 688aac7 | 2012-03-09 10:30:26 -0800 | [diff] [blame] | 103 | |
| 104 | // return estimated latency in milliseconds |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 105 | virtual uint32_t latency(audio_io_handle_t output) const = 0; |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 106 | |
| 107 | /* set/get the audio hardware state. This will probably be used by |
| 108 | * the preference panel, mostly. |
| 109 | */ |
| 110 | virtual status_t setMasterVolume(float value) = 0; |
| 111 | virtual status_t setMasterMute(bool muted) = 0; |
| 112 | |
| 113 | virtual float masterVolume() const = 0; |
| 114 | virtual bool masterMute() const = 0; |
| 115 | |
| 116 | /* set/get stream type state. This will probably be used by |
| 117 | * the preference panel, mostly. |
| 118 | */ |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 119 | virtual status_t setStreamVolume(audio_stream_type_t stream, float value, |
| 120 | audio_io_handle_t output) = 0; |
Glenn Kasten | fff6d71 | 2012-01-12 16:38:12 -0800 | [diff] [blame] | 121 | virtual status_t setStreamMute(audio_stream_type_t stream, bool muted) = 0; |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 122 | |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 123 | virtual float streamVolume(audio_stream_type_t stream, |
| 124 | audio_io_handle_t output) const = 0; |
Glenn Kasten | fff6d71 | 2012-01-12 16:38:12 -0800 | [diff] [blame] | 125 | virtual bool streamMute(audio_stream_type_t stream) const = 0; |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 126 | |
Eric Laurent | c2f1f07 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 127 | // set audio mode |
Glenn Kasten | f78aee7 | 2012-01-04 11:00:47 -0800 | [diff] [blame] | 128 | virtual status_t setMode(audio_mode_t mode) = 0; |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 129 | |
| 130 | // mic mute/state |
| 131 | virtual status_t setMicMute(bool state) = 0; |
| 132 | virtual bool getMicMute() const = 0; |
| 133 | |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 134 | virtual status_t setParameters(audio_io_handle_t ioHandle, |
| 135 | const String8& keyValuePairs) = 0; |
Glenn Kasten | 85ab62c | 2012-11-01 11:11:38 -0700 | [diff] [blame] | 136 | virtual String8 getParameters(audio_io_handle_t ioHandle, const String8& keys) |
| 137 | const = 0; |
Eric Laurent | f0ee6f4 | 2009-10-21 08:14:22 -0700 | [diff] [blame] | 138 | |
Glenn Kasten | fb1fdc9 | 2013-07-10 17:03:19 -0700 | [diff] [blame] | 139 | // Register an object to receive audio input/output change and track notifications. |
| 140 | // For a given calling pid, AudioFlinger disregards any registrations after the first. |
| 141 | // Thus the IAudioFlingerClient must be a singleton per process. |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 142 | virtual void registerClient(const sp<IAudioFlingerClient>& client) = 0; |
Eric Laurent | f0ee6f4 | 2009-10-21 08:14:22 -0700 | [diff] [blame] | 143 | |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 144 | // retrieve the audio recording buffer size |
Glenn Kasten | f5e837e | 2014-07-03 10:17:10 -0700 | [diff] [blame^] | 145 | // FIXME This API assumes a route, and so should be deprecated. |
Glenn Kasten | dd8104c | 2012-07-02 12:42:44 -0700 | [diff] [blame] | 146 | virtual size_t getInputBufferSize(uint32_t sampleRate, audio_format_t format, |
| 147 | audio_channel_mask_t channelMask) const = 0; |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 148 | |
Eric Laurent | cf2c021 | 2014-07-25 16:20:43 -0700 | [diff] [blame] | 149 | virtual status_t openOutput(audio_module_handle_t module, |
| 150 | audio_io_handle_t *output, |
| 151 | audio_config_t *config, |
| 152 | audio_devices_t *devices, |
| 153 | const String8& address, |
| 154 | uint32_t *latencyMs, |
| 155 | audio_output_flags_t flags) = 0; |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 156 | virtual audio_io_handle_t openDuplicateOutput(audio_io_handle_t output1, |
| 157 | audio_io_handle_t output2) = 0; |
| 158 | virtual status_t closeOutput(audio_io_handle_t output) = 0; |
| 159 | virtual status_t suspendOutput(audio_io_handle_t output) = 0; |
| 160 | virtual status_t restoreOutput(audio_io_handle_t output) = 0; |
Eric Laurent | c2f1f07 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 161 | |
Eric Laurent | cf2c021 | 2014-07-25 16:20:43 -0700 | [diff] [blame] | 162 | virtual status_t openInput(audio_module_handle_t module, |
| 163 | audio_io_handle_t *input, |
| 164 | audio_config_t *config, |
| 165 | audio_devices_t *device, |
| 166 | const String8& address, |
| 167 | audio_source_t source, |
| 168 | audio_input_flags_t flags) = 0; |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 169 | virtual status_t closeInput(audio_io_handle_t input) = 0; |
Eric Laurent | c2f1f07 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 170 | |
Glenn Kasten | d2304db | 2014-02-03 07:40:31 -0800 | [diff] [blame] | 171 | virtual status_t invalidateStream(audio_stream_type_t stream) = 0; |
Eric Laurent | f0ee6f4 | 2009-10-21 08:14:22 -0700 | [diff] [blame] | 172 | |
| 173 | virtual status_t setVoiceVolume(float volume) = 0; |
Eric Laurent | 05bca2f | 2010-02-26 02:47:27 -0800 | [diff] [blame] | 174 | |
Kévin PETIT | 377b2ec | 2014-02-03 12:35:36 +0000 | [diff] [blame] | 175 | virtual status_t getRenderPosition(uint32_t *halFrames, uint32_t *dspFrames, |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 176 | audio_io_handle_t output) const = 0; |
Eric Laurent | 05bca2f | 2010-02-26 02:47:27 -0800 | [diff] [blame] | 177 | |
Glenn Kasten | 5f972c0 | 2014-01-13 09:59:31 -0800 | [diff] [blame] | 178 | virtual uint32_t getInputFramesLost(audio_io_handle_t ioHandle) const = 0; |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 179 | |
Eric Laurent | de3f839 | 2014-07-27 18:38:22 -0700 | [diff] [blame] | 180 | virtual audio_unique_id_t newAudioUniqueId() = 0; |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 181 | |
Marco Nelissen | d457c97 | 2014-02-11 08:47:07 -0800 | [diff] [blame] | 182 | virtual void acquireAudioSessionId(int audioSession, pid_t pid) = 0; |
| 183 | virtual void releaseAudioSessionId(int audioSession, pid_t pid) = 0; |
Marco Nelissen | 3a34bef | 2011-08-02 13:33:41 -0700 | [diff] [blame] | 184 | |
Glenn Kasten | f587ba5 | 2012-01-26 16:25:10 -0800 | [diff] [blame] | 185 | virtual status_t queryNumberEffects(uint32_t *numEffects) const = 0; |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 186 | |
Glenn Kasten | f587ba5 | 2012-01-26 16:25:10 -0800 | [diff] [blame] | 187 | virtual status_t queryEffect(uint32_t index, effect_descriptor_t *pDescriptor) const = 0; |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 188 | |
Glenn Kasten | 5e92a78 | 2012-01-30 07:40:52 -0800 | [diff] [blame] | 189 | virtual status_t getEffectDescriptor(const effect_uuid_t *pEffectUUID, |
Glenn Kasten | f587ba5 | 2012-01-26 16:25:10 -0800 | [diff] [blame] | 190 | effect_descriptor_t *pDescriptor) const = 0; |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 191 | |
Glenn Kasten | 8d6cc84 | 2012-02-03 11:06:53 -0800 | [diff] [blame] | 192 | virtual sp<IEffect> createEffect( |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 193 | effect_descriptor_t *pDesc, |
| 194 | const sp<IEffectClient>& client, |
| 195 | int32_t priority, |
Glenn Kasten | d631d96 | 2014-01-16 12:31:12 -0800 | [diff] [blame] | 196 | // AudioFlinger doesn't take over handle reference from client |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 197 | audio_io_handle_t output, |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 198 | int sessionId, |
| 199 | status_t *status, |
| 200 | int *id, |
| 201 | int *enabled) = 0; |
Eric Laurent | de07013 | 2010-07-13 04:45:46 -0700 | [diff] [blame] | 202 | |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 203 | virtual status_t moveEffects(int session, audio_io_handle_t srcOutput, |
| 204 | audio_io_handle_t dstOutput) = 0; |
Eric Laurent | a4c5a55 | 2012-03-29 10:12:40 -0700 | [diff] [blame] | 205 | |
| 206 | virtual audio_module_handle_t loadHwModule(const char *name) = 0; |
Glenn Kasten | cc0f1cf | 2012-09-24 11:27:18 -0700 | [diff] [blame] | 207 | |
| 208 | // helpers for android.media.AudioManager.getProperty(), see description there for meaning |
| 209 | // FIXME move these APIs to AudioPolicy to permit a more accurate implementation |
| 210 | // that looks on primary device for a stream with fast flag, primary flag, or first one. |
Glenn Kasten | 3b16c76 | 2012-11-14 08:44:39 -0800 | [diff] [blame] | 211 | virtual uint32_t getPrimaryOutputSamplingRate() = 0; |
Glenn Kasten | e33054e | 2012-11-14 12:54:39 -0800 | [diff] [blame] | 212 | virtual size_t getPrimaryOutputFrameCount() = 0; |
Glenn Kasten | cc0f1cf | 2012-09-24 11:27:18 -0700 | [diff] [blame] | 213 | |
Glenn Kasten | 4182c4e | 2013-07-15 14:45:07 -0700 | [diff] [blame] | 214 | // Intended for AudioService to inform AudioFlinger of device's low RAM attribute, |
| 215 | // and should be called at most once. For a definition of what "low RAM" means, see |
| 216 | // android.app.ActivityManager.isLowRamDevice(). |
| 217 | virtual status_t setLowRamDevice(bool isLowRamDevice) = 0; |
Eric Laurent | 4b12340 | 2014-04-11 09:22:20 -0700 | [diff] [blame] | 218 | |
| 219 | /* List available audio ports and their attributes */ |
| 220 | virtual status_t listAudioPorts(unsigned int *num_ports, |
| 221 | struct audio_port *ports) = 0; |
| 222 | |
| 223 | /* Get attributes for a given audio port */ |
| 224 | virtual status_t getAudioPort(struct audio_port *port) = 0; |
| 225 | |
| 226 | /* Create an audio patch between several source and sink ports */ |
| 227 | virtual status_t createAudioPatch(const struct audio_patch *patch, |
| 228 | audio_patch_handle_t *handle) = 0; |
| 229 | |
| 230 | /* Release an audio patch */ |
| 231 | virtual status_t releaseAudioPatch(audio_patch_handle_t handle) = 0; |
| 232 | |
| 233 | /* List existing audio patches */ |
| 234 | virtual status_t listAudioPatches(unsigned int *num_patches, |
| 235 | struct audio_patch *patches) = 0; |
| 236 | /* Set audio port configuration */ |
| 237 | virtual status_t setAudioPortConfig(const struct audio_port_config *config) = 0; |
| 238 | |
Eric Laurent | 93c3d41 | 2014-08-01 14:48:35 -0700 | [diff] [blame] | 239 | /* Get the HW synchronization source used for an audio session */ |
| 240 | virtual audio_hw_sync_t getAudioHwSyncForSession(audio_session_t sessionId) = 0; |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 241 | }; |
| 242 | |
| 243 | |
| 244 | // ---------------------------------------------------------------------------- |
| 245 | |
| 246 | class BnAudioFlinger : public BnInterface<IAudioFlinger> |
| 247 | { |
| 248 | public: |
| 249 | virtual status_t onTransact( uint32_t code, |
| 250 | const Parcel& data, |
| 251 | Parcel* reply, |
| 252 | uint32_t flags = 0); |
| 253 | }; |
| 254 | |
| 255 | // ---------------------------------------------------------------------------- |
| 256 | |
| 257 | }; // namespace android |
| 258 | |
| 259 | #endif // ANDROID_IAUDIOFLINGER_H |