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 |
Glenn Kasten | a075db4 | 2012-03-06 11:22:44 -0800 | [diff] [blame] | 52 | }; |
| 53 | typedef uint32_t track_flags_t; |
| 54 | |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 55 | /* create an audio track and registers it with AudioFlinger. |
| 56 | * return null if the track cannot be created. |
| 57 | */ |
| 58 | virtual sp<IAudioTrack> createTrack( |
| 59 | pid_t pid, |
Glenn Kasten | fff6d71 | 2012-01-12 16:38:12 -0800 | [diff] [blame] | 60 | audio_stream_type_t streamType, |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 61 | uint32_t sampleRate, |
Glenn Kasten | 58f3021 | 2012-01-12 12:27:51 -0800 | [diff] [blame] | 62 | audio_format_t format, |
Glenn Kasten | dd8104c | 2012-07-02 12:42:44 -0700 | [diff] [blame] | 63 | audio_channel_mask_t channelMask, |
Glenn Kasten | e33054e | 2012-11-14 12:54:39 -0800 | [diff] [blame^] | 64 | size_t frameCount, |
Glenn Kasten | e0b0717 | 2012-11-06 15:03:34 -0800 | [diff] [blame] | 65 | track_flags_t *flags, |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 66 | const sp<IMemory>& sharedBuffer, |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 67 | audio_io_handle_t output, |
Glenn Kasten | 3acbd05 | 2012-02-28 10:39:56 -0800 | [diff] [blame] | 68 | pid_t tid, // -1 means unused, otherwise must be valid non-0 |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 69 | int *sessionId, |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 70 | status_t *status) = 0; |
| 71 | |
| 72 | virtual sp<IAudioRecord> openRecord( |
| 73 | pid_t pid, |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 74 | audio_io_handle_t input, |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 75 | uint32_t sampleRate, |
Glenn Kasten | 58f3021 | 2012-01-12 12:27:51 -0800 | [diff] [blame] | 76 | audio_format_t format, |
Glenn Kasten | dd8104c | 2012-07-02 12:42:44 -0700 | [diff] [blame] | 77 | audio_channel_mask_t channelMask, |
Glenn Kasten | e33054e | 2012-11-14 12:54:39 -0800 | [diff] [blame^] | 78 | size_t frameCount, |
Glenn Kasten | a075db4 | 2012-03-06 11:22:44 -0800 | [diff] [blame] | 79 | track_flags_t flags, |
Glenn Kasten | 1879fff | 2012-07-11 15:36:59 -0700 | [diff] [blame] | 80 | pid_t tid, // -1 means unused, otherwise must be valid non-0 |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 81 | int *sessionId, |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 82 | status_t *status) = 0; |
| 83 | |
| 84 | /* query the audio hardware state. This state never changes, |
| 85 | * and therefore can be cached. |
| 86 | */ |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 87 | virtual uint32_t sampleRate(audio_io_handle_t output) const = 0; |
Glenn Kasten | dd8104c | 2012-07-02 12:42:44 -0700 | [diff] [blame] | 88 | #if 0 |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 89 | virtual int channelCount(audio_io_handle_t output) const = 0; |
Glenn Kasten | dd8104c | 2012-07-02 12:42:44 -0700 | [diff] [blame] | 90 | #endif |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 91 | virtual audio_format_t format(audio_io_handle_t output) const = 0; |
| 92 | virtual size_t frameCount(audio_io_handle_t output) const = 0; |
Glenn Kasten | 688aac7 | 2012-03-09 10:30:26 -0800 | [diff] [blame] | 93 | |
| 94 | // return estimated latency in milliseconds |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 95 | 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] | 96 | |
| 97 | /* set/get the audio hardware state. This will probably be used by |
| 98 | * the preference panel, mostly. |
| 99 | */ |
| 100 | virtual status_t setMasterVolume(float value) = 0; |
| 101 | virtual status_t setMasterMute(bool muted) = 0; |
| 102 | |
| 103 | virtual float masterVolume() const = 0; |
| 104 | virtual bool masterMute() const = 0; |
| 105 | |
| 106 | /* set/get stream type state. This will probably be used by |
| 107 | * the preference panel, mostly. |
| 108 | */ |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 109 | virtual status_t setStreamVolume(audio_stream_type_t stream, float value, |
| 110 | audio_io_handle_t output) = 0; |
Glenn Kasten | fff6d71 | 2012-01-12 16:38:12 -0800 | [diff] [blame] | 111 | 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] | 112 | |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 113 | virtual float streamVolume(audio_stream_type_t stream, |
| 114 | audio_io_handle_t output) const = 0; |
Glenn Kasten | fff6d71 | 2012-01-12 16:38:12 -0800 | [diff] [blame] | 115 | 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] | 116 | |
Eric Laurent | c2f1f07 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 117 | // set audio mode |
Glenn Kasten | f78aee7 | 2012-01-04 11:00:47 -0800 | [diff] [blame] | 118 | virtual status_t setMode(audio_mode_t mode) = 0; |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 119 | |
| 120 | // mic mute/state |
| 121 | virtual status_t setMicMute(bool state) = 0; |
| 122 | virtual bool getMicMute() const = 0; |
| 123 | |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 124 | virtual status_t setParameters(audio_io_handle_t ioHandle, |
| 125 | const String8& keyValuePairs) = 0; |
Glenn Kasten | 85ab62c | 2012-11-01 11:11:38 -0700 | [diff] [blame] | 126 | virtual String8 getParameters(audio_io_handle_t ioHandle, const String8& keys) |
| 127 | const = 0; |
Eric Laurent | f0ee6f4 | 2009-10-21 08:14:22 -0700 | [diff] [blame] | 128 | |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 129 | // register a current process for audio output change notifications |
| 130 | virtual void registerClient(const sp<IAudioFlingerClient>& client) = 0; |
Eric Laurent | f0ee6f4 | 2009-10-21 08:14:22 -0700 | [diff] [blame] | 131 | |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 132 | // retrieve the audio recording buffer size |
Glenn Kasten | dd8104c | 2012-07-02 12:42:44 -0700 | [diff] [blame] | 133 | virtual size_t getInputBufferSize(uint32_t sampleRate, audio_format_t format, |
| 134 | audio_channel_mask_t channelMask) const = 0; |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 135 | |
Eric Laurent | a4c5a55 | 2012-03-29 10:12:40 -0700 | [diff] [blame] | 136 | virtual audio_io_handle_t openOutput(audio_module_handle_t module, |
| 137 | audio_devices_t *pDevices, |
| 138 | uint32_t *pSamplingRate, |
| 139 | audio_format_t *pFormat, |
| 140 | audio_channel_mask_t *pChannelMask, |
| 141 | uint32_t *pLatencyMs, |
Eric Laurent | 0ca3cf9 | 2012-04-18 09:24:29 -0700 | [diff] [blame] | 142 | audio_output_flags_t flags) = 0; |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 143 | virtual audio_io_handle_t openDuplicateOutput(audio_io_handle_t output1, |
| 144 | audio_io_handle_t output2) = 0; |
| 145 | virtual status_t closeOutput(audio_io_handle_t output) = 0; |
| 146 | virtual status_t suspendOutput(audio_io_handle_t output) = 0; |
| 147 | virtual status_t restoreOutput(audio_io_handle_t output) = 0; |
Eric Laurent | c2f1f07 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 148 | |
Eric Laurent | a4c5a55 | 2012-03-29 10:12:40 -0700 | [diff] [blame] | 149 | virtual audio_io_handle_t openInput(audio_module_handle_t module, |
| 150 | audio_devices_t *pDevices, |
| 151 | uint32_t *pSamplingRate, |
| 152 | audio_format_t *pFormat, |
| 153 | audio_channel_mask_t *pChannelMask) = 0; |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 154 | virtual status_t closeInput(audio_io_handle_t input) = 0; |
Eric Laurent | c2f1f07 | 2009-07-17 12:17:14 -0700 | [diff] [blame] | 155 | |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 156 | virtual status_t setStreamOutput(audio_stream_type_t stream, audio_io_handle_t output) = 0; |
Eric Laurent | f0ee6f4 | 2009-10-21 08:14:22 -0700 | [diff] [blame] | 157 | |
| 158 | virtual status_t setVoiceVolume(float volume) = 0; |
Eric Laurent | 05bca2f | 2010-02-26 02:47:27 -0800 | [diff] [blame] | 159 | |
Glenn Kasten | e33054e | 2012-11-14 12:54:39 -0800 | [diff] [blame^] | 160 | virtual status_t getRenderPosition(size_t *halFrames, size_t *dspFrames, |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 161 | audio_io_handle_t output) const = 0; |
Eric Laurent | 05bca2f | 2010-02-26 02:47:27 -0800 | [diff] [blame] | 162 | |
Glenn Kasten | e33054e | 2012-11-14 12:54:39 -0800 | [diff] [blame^] | 163 | virtual size_t getInputFramesLost(audio_io_handle_t ioHandle) const = 0; |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 164 | |
| 165 | virtual int newAudioSessionId() = 0; |
| 166 | |
Marco Nelissen | 3a34bef | 2011-08-02 13:33:41 -0700 | [diff] [blame] | 167 | virtual void acquireAudioSessionId(int audioSession) = 0; |
| 168 | virtual void releaseAudioSessionId(int audioSession) = 0; |
| 169 | |
Glenn Kasten | f587ba5 | 2012-01-26 16:25:10 -0800 | [diff] [blame] | 170 | virtual status_t queryNumberEffects(uint32_t *numEffects) const = 0; |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 171 | |
Glenn Kasten | f587ba5 | 2012-01-26 16:25:10 -0800 | [diff] [blame] | 172 | 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] | 173 | |
Glenn Kasten | 5e92a78 | 2012-01-30 07:40:52 -0800 | [diff] [blame] | 174 | virtual status_t getEffectDescriptor(const effect_uuid_t *pEffectUUID, |
Glenn Kasten | f587ba5 | 2012-01-26 16:25:10 -0800 | [diff] [blame] | 175 | effect_descriptor_t *pDescriptor) const = 0; |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 176 | |
| 177 | virtual sp<IEffect> createEffect(pid_t pid, |
| 178 | effect_descriptor_t *pDesc, |
| 179 | const sp<IEffectClient>& client, |
| 180 | int32_t priority, |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 181 | audio_io_handle_t output, |
Eric Laurent | be916aa | 2010-06-01 23:49:17 -0700 | [diff] [blame] | 182 | int sessionId, |
| 183 | status_t *status, |
| 184 | int *id, |
| 185 | int *enabled) = 0; |
Eric Laurent | de07013 | 2010-07-13 04:45:46 -0700 | [diff] [blame] | 186 | |
Glenn Kasten | 72ef00d | 2012-01-17 11:09:42 -0800 | [diff] [blame] | 187 | virtual status_t moveEffects(int session, audio_io_handle_t srcOutput, |
| 188 | audio_io_handle_t dstOutput) = 0; |
Eric Laurent | a4c5a55 | 2012-03-29 10:12:40 -0700 | [diff] [blame] | 189 | |
| 190 | virtual audio_module_handle_t loadHwModule(const char *name) = 0; |
Glenn Kasten | cc0f1cf | 2012-09-24 11:27:18 -0700 | [diff] [blame] | 191 | |
| 192 | // helpers for android.media.AudioManager.getProperty(), see description there for meaning |
| 193 | // FIXME move these APIs to AudioPolicy to permit a more accurate implementation |
| 194 | // 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] | 195 | virtual uint32_t getPrimaryOutputSamplingRate() = 0; |
Glenn Kasten | e33054e | 2012-11-14 12:54:39 -0800 | [diff] [blame^] | 196 | virtual size_t getPrimaryOutputFrameCount() = 0; |
Glenn Kasten | cc0f1cf | 2012-09-24 11:27:18 -0700 | [diff] [blame] | 197 | |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 198 | }; |
| 199 | |
| 200 | |
| 201 | // ---------------------------------------------------------------------------- |
| 202 | |
| 203 | class BnAudioFlinger : public BnInterface<IAudioFlinger> |
| 204 | { |
| 205 | public: |
| 206 | virtual status_t onTransact( uint32_t code, |
| 207 | const Parcel& data, |
| 208 | Parcel* reply, |
| 209 | uint32_t flags = 0); |
| 210 | }; |
| 211 | |
| 212 | // ---------------------------------------------------------------------------- |
| 213 | |
| 214 | }; // namespace android |
| 215 | |
| 216 | #endif // ANDROID_IAUDIOFLINGER_H |