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