blob: 84e8beef17f42070c2425afbf965008b4781e603 [file] [log] [blame]
Marco Nelissen3a34bef2011-08-02 13:33:41 -07001/*
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08002**
3** Copyright 2007, The Android Open Source Project
4**
5** Licensed under the Apache License, Version 2.0 (the "License");
6** you may not use this file except in compliance with the License.
7** You may obtain a copy of the License at
8**
9** http://www.apache.org/licenses/LICENSE-2.0
10**
11** Unless required by applicable law or agreed to in writing, software
12** distributed under the License is distributed on an "AS IS" BASIS,
13** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14** See the License for the specific language governing permissions and
15** limitations under the License.
16*/
17
18#define LOG_TAG "IAudioFlinger"
Eric Laurentc2f1f072009-07-17 12:17:14 -070019//#define LOG_NDEBUG 0
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080020#include <utils/Log.h>
21
22#include <stdint.h>
23#include <sys/types.h>
24
Eric Laurentb1cc36b2017-12-11 12:14:16 -080025#include <binder/IPCThreadState.h>
Mathias Agopian75624082009-05-19 19:08:10 -070026#include <binder/Parcel.h>
Eric Laurent3528c932018-02-23 17:17:22 -080027#include <media/TimeCheck.h>
Andy Hung4ef19fa2018-05-15 19:35:29 -070028#include <mediautils/ServiceUtilities.h>
Steven Moreland25a9e552017-04-17 14:30:39 -070029#include "IAudioFlinger.h"
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080030
31namespace android {
32
33enum {
34 CREATE_TRACK = IBinder::FIRST_CALL_TRANSACTION,
Eric Laurentf14db3c2017-12-08 14:20:36 -080035 CREATE_RECORD,
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080036 SAMPLE_RATE,
Glenn Kasten5876f2f2012-11-30 10:52:16 -080037 RESERVED, // obsolete, was CHANNEL_COUNT
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080038 FORMAT,
39 FRAME_COUNT,
40 LATENCY,
41 SET_MASTER_VOLUME,
42 SET_MASTER_MUTE,
43 MASTER_VOLUME,
44 MASTER_MUTE,
45 SET_STREAM_VOLUME,
46 SET_STREAM_MUTE,
47 STREAM_VOLUME,
48 STREAM_MUTE,
49 SET_MODE,
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080050 SET_MIC_MUTE,
51 GET_MIC_MUTE,
Svet Ganovf4ddfef2018-01-16 07:37:58 -080052 SET_RECORD_SILENCED,
Eric Laurentc2f1f072009-07-17 12:17:14 -070053 SET_PARAMETERS,
54 GET_PARAMETERS,
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080055 REGISTER_CLIENT,
56 GET_INPUTBUFFERSIZE,
Eric Laurentc2f1f072009-07-17 12:17:14 -070057 OPEN_OUTPUT,
58 OPEN_DUPLICATE_OUTPUT,
59 CLOSE_OUTPUT,
60 SUSPEND_OUTPUT,
61 RESTORE_OUTPUT,
62 OPEN_INPUT,
63 CLOSE_INPUT,
Glenn Kastend2304db2014-02-03 07:40:31 -080064 INVALIDATE_STREAM,
Eric Laurent342e9cf2010-01-19 17:37:09 -080065 SET_VOICE_VOLUME,
Eric Laurent05bca2f2010-02-26 02:47:27 -080066 GET_RENDER_POSITION,
Eric Laurentbe916aa2010-06-01 23:49:17 -070067 GET_INPUT_FRAMES_LOST,
Glenn Kasten9eae0362016-04-19 09:09:14 -070068 NEW_AUDIO_UNIQUE_ID,
Marco Nelissen3a34bef2011-08-02 13:33:41 -070069 ACQUIRE_AUDIO_SESSION_ID,
70 RELEASE_AUDIO_SESSION_ID,
Eric Laurentbe916aa2010-06-01 23:49:17 -070071 QUERY_NUM_EFFECTS,
Eric Laurentffe9c252010-06-23 17:38:20 -070072 QUERY_EFFECT,
Eric Laurentbe916aa2010-06-01 23:49:17 -070073 GET_EFFECT_DESCRIPTOR,
Eric Laurentde070132010-07-13 04:45:46 -070074 CREATE_EFFECT,
Eric Laurenta4c5a552012-03-29 10:12:40 -070075 MOVE_EFFECTS,
Glenn Kastencc0f1cf2012-09-24 11:27:18 -070076 LOAD_HW_MODULE,
77 GET_PRIMARY_OUTPUT_SAMPLING_RATE,
78 GET_PRIMARY_OUTPUT_FRAME_COUNT,
Glenn Kasten4182c4e2013-07-15 14:45:07 -070079 SET_LOW_RAM_DEVICE,
Eric Laurent4b123402014-04-11 09:22:20 -070080 LIST_AUDIO_PORTS,
81 GET_AUDIO_PORT,
82 CREATE_AUDIO_PATCH,
83 RELEASE_AUDIO_PATCH,
84 LIST_AUDIO_PATCHES,
Eric Laurent93c3d412014-08-01 14:48:35 -070085 SET_AUDIO_PORT_CONFIG,
Glenn Kasten9eae0362016-04-19 09:09:14 -070086 GET_AUDIO_HW_SYNC_FOR_SESSION,
Glenn Kasten4a8308b2016-04-18 14:10:01 -070087 SYSTEM_READY,
88 FRAME_COUNT_HAL,
jiabin9ff780e2018-03-19 18:19:52 -070089 GET_MICROPHONES,
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080090};
91
Eric Laurentf75c2fe2015-04-02 13:49:15 -070092#define MAX_ITEMS_PER_LIST 1024
93
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080094class BpAudioFlinger : public BpInterface<IAudioFlinger>
95{
96public:
Chih-Hung Hsieh090ef602016-04-27 10:39:54 -070097 explicit BpAudioFlinger(const sp<IBinder>& impl)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080098 : BpInterface<IAudioFlinger>(impl)
99 {
100 }
101
Eric Laurent21da6472017-11-09 16:29:26 -0800102 virtual sp<IAudioTrack> createTrack(const CreateTrackInput& input,
103 CreateTrackOutput& output,
104 status_t *status)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800105 {
106 Parcel data, reply;
Eric Laurent5841db72009-09-09 05:16:08 -0700107 sp<IAudioTrack> track;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800108 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurent21da6472017-11-09 16:29:26 -0800109
110 if (status == nullptr) {
111 return track;
Eric Laurent3d00aa62013-09-24 09:53:27 -0700112 }
Eric Laurent21da6472017-11-09 16:29:26 -0800113
114 input.writeToParcel(&data);
115
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800116 status_t lStatus = remote()->transact(CREATE_TRACK, data, &reply);
117 if (lStatus != NO_ERROR) {
Eric Laurent21da6472017-11-09 16:29:26 -0800118 ALOGE("createTrack transaction error %d", lStatus);
119 *status = DEAD_OBJECT;
120 return track;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800121 }
Eric Laurent21da6472017-11-09 16:29:26 -0800122 *status = reply.readInt32();
123 if (*status != NO_ERROR) {
124 ALOGE("createTrack returned error %d", *status);
125 return track;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800126 }
Eric Laurent21da6472017-11-09 16:29:26 -0800127 track = interface_cast<IAudioTrack>(reply.readStrongBinder());
128 if (track == 0) {
129 ALOGE("createTrack returned an NULL IAudioTrack with status OK");
130 *status = DEAD_OBJECT;
131 return track;
132 }
133 output.readFromParcel(&reply);
Eric Laurent5841db72009-09-09 05:16:08 -0700134 return track;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800135 }
136
Eric Laurentf14db3c2017-12-08 14:20:36 -0800137 virtual sp<media::IAudioRecord> createRecord(const CreateRecordInput& input,
138 CreateRecordOutput& output,
139 status_t *status)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800140 {
141 Parcel data, reply;
Ivan Lozanoff6900d2017-08-01 15:47:38 -0700142 sp<media::IAudioRecord> record;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800143 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurentf14db3c2017-12-08 14:20:36 -0800144
145 if (status == nullptr) {
146 return record;
Eric Laurentbe916aa2010-06-01 23:49:17 -0700147 }
Eric Laurentf14db3c2017-12-08 14:20:36 -0800148
149 input.writeToParcel(&data);
150
151 status_t lStatus = remote()->transact(CREATE_RECORD, data, &reply);
Eric Laurent5841db72009-09-09 05:16:08 -0700152 if (lStatus != NO_ERROR) {
Eric Laurentf14db3c2017-12-08 14:20:36 -0800153 ALOGE("createRecord transaction error %d", lStatus);
154 *status = DEAD_OBJECT;
155 return record;
Eric Laurent5841db72009-09-09 05:16:08 -0700156 }
Eric Laurentf14db3c2017-12-08 14:20:36 -0800157 *status = reply.readInt32();
158 if (*status != NO_ERROR) {
159 ALOGE("createRecord returned error %d", *status);
160 return record;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800161 }
Eric Laurentf14db3c2017-12-08 14:20:36 -0800162
163 record = interface_cast<media::IAudioRecord>(reply.readStrongBinder());
164 if (record == 0) {
165 ALOGE("createRecord returned a NULL IAudioRecord with status OK");
166 *status = DEAD_OBJECT;
167 return record;
168 }
169 output.readFromParcel(&reply);
Eric Laurent5841db72009-09-09 05:16:08 -0700170 return record;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800171 }
172
Glenn Kasten2c073da2016-02-26 09:14:08 -0800173 virtual uint32_t sampleRate(audio_io_handle_t ioHandle) const
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800174 {
175 Parcel data, reply;
176 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten2c073da2016-02-26 09:14:08 -0800177 data.writeInt32((int32_t) ioHandle);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800178 remote()->transact(SAMPLE_RATE, data, &reply);
179 return reply.readInt32();
180 }
181
Glenn Kasten4a8308b2016-04-18 14:10:01 -0700182 // RESERVED for channelCount()
183
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800184 virtual audio_format_t format(audio_io_handle_t output) const
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800185 {
186 Parcel data, reply;
187 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800188 data.writeInt32((int32_t) output);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800189 remote()->transact(FORMAT, data, &reply);
Glenn Kasten58f30212012-01-12 12:27:51 -0800190 return (audio_format_t) reply.readInt32();
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800191 }
192
Glenn Kasten2c073da2016-02-26 09:14:08 -0800193 virtual size_t frameCount(audio_io_handle_t ioHandle) const
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800194 {
195 Parcel data, reply;
196 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten2c073da2016-02-26 09:14:08 -0800197 data.writeInt32((int32_t) ioHandle);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800198 remote()->transact(FRAME_COUNT, data, &reply);
Glenn Kastene03dd222014-01-28 11:04:39 -0800199 return reply.readInt64();
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800200 }
201
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800202 virtual uint32_t latency(audio_io_handle_t output) const
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800203 {
204 Parcel data, reply;
205 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800206 data.writeInt32((int32_t) output);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800207 remote()->transact(LATENCY, data, &reply);
208 return reply.readInt32();
209 }
210
211 virtual status_t setMasterVolume(float value)
212 {
213 Parcel data, reply;
214 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
215 data.writeFloat(value);
216 remote()->transact(SET_MASTER_VOLUME, data, &reply);
217 return reply.readInt32();
218 }
219
220 virtual status_t setMasterMute(bool muted)
221 {
222 Parcel data, reply;
223 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
224 data.writeInt32(muted);
225 remote()->transact(SET_MASTER_MUTE, data, &reply);
226 return reply.readInt32();
227 }
228
229 virtual float masterVolume() const
230 {
231 Parcel data, reply;
232 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
233 remote()->transact(MASTER_VOLUME, data, &reply);
234 return reply.readFloat();
235 }
236
237 virtual bool masterMute() const
238 {
239 Parcel data, reply;
240 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
241 remote()->transact(MASTER_MUTE, data, &reply);
242 return reply.readInt32();
243 }
244
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800245 virtual status_t setStreamVolume(audio_stream_type_t stream, float value,
246 audio_io_handle_t output)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800247 {
248 Parcel data, reply;
249 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kastenfff6d712012-01-12 16:38:12 -0800250 data.writeInt32((int32_t) stream);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800251 data.writeFloat(value);
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800252 data.writeInt32((int32_t) output);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800253 remote()->transact(SET_STREAM_VOLUME, data, &reply);
254 return reply.readInt32();
255 }
256
Glenn Kastenfff6d712012-01-12 16:38:12 -0800257 virtual status_t setStreamMute(audio_stream_type_t stream, bool muted)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800258 {
259 Parcel data, reply;
260 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kastenfff6d712012-01-12 16:38:12 -0800261 data.writeInt32((int32_t) stream);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800262 data.writeInt32(muted);
263 remote()->transact(SET_STREAM_MUTE, data, &reply);
264 return reply.readInt32();
265 }
266
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800267 virtual float streamVolume(audio_stream_type_t stream, audio_io_handle_t output) const
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800268 {
269 Parcel data, reply;
270 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kastenfff6d712012-01-12 16:38:12 -0800271 data.writeInt32((int32_t) stream);
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800272 data.writeInt32((int32_t) output);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800273 remote()->transact(STREAM_VOLUME, data, &reply);
274 return reply.readFloat();
275 }
276
Glenn Kastenfff6d712012-01-12 16:38:12 -0800277 virtual bool streamMute(audio_stream_type_t stream) const
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800278 {
279 Parcel data, reply;
280 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kastenfff6d712012-01-12 16:38:12 -0800281 data.writeInt32((int32_t) stream);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800282 remote()->transact(STREAM_MUTE, data, &reply);
283 return reply.readInt32();
284 }
285
Glenn Kastenf78aee72012-01-04 11:00:47 -0800286 virtual status_t setMode(audio_mode_t mode)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800287 {
288 Parcel data, reply;
289 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
290 data.writeInt32(mode);
291 remote()->transact(SET_MODE, data, &reply);
292 return reply.readInt32();
293 }
294
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800295 virtual status_t setMicMute(bool state)
296 {
297 Parcel data, reply;
298 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
299 data.writeInt32(state);
300 remote()->transact(SET_MIC_MUTE, data, &reply);
301 return reply.readInt32();
302 }
303
304 virtual bool getMicMute() const
305 {
306 Parcel data, reply;
307 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
308 remote()->transact(GET_MIC_MUTE, data, &reply);
309 return reply.readInt32();
310 }
311
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800312 virtual void setRecordSilenced(uid_t uid, bool silenced)
313 {
314 Parcel data, reply;
315 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
316 data.writeInt32(uid);
317 data.writeInt32(silenced ? 1 : 0);
318 remote()->transact(SET_RECORD_SILENCED, data, &reply);
319 }
320
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800321 virtual status_t setParameters(audio_io_handle_t ioHandle, const String8& keyValuePairs)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800322 {
323 Parcel data, reply;
324 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800325 data.writeInt32((int32_t) ioHandle);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700326 data.writeString8(keyValuePairs);
327 remote()->transact(SET_PARAMETERS, data, &reply);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800328 return reply.readInt32();
329 }
Eric Laurentc2f1f072009-07-17 12:17:14 -0700330
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800331 virtual String8 getParameters(audio_io_handle_t ioHandle, const String8& keys) const
Eric Laurentc2f1f072009-07-17 12:17:14 -0700332 {
333 Parcel data, reply;
334 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800335 data.writeInt32((int32_t) ioHandle);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700336 data.writeString8(keys);
337 remote()->transact(GET_PARAMETERS, data, &reply);
338 return reply.readString8();
339 }
340
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800341 virtual void registerClient(const sp<IAudioFlingerClient>& client)
342 {
343 Parcel data, reply;
344 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Marco Nelissen06b46062014-11-14 07:58:25 -0800345 data.writeStrongBinder(IInterface::asBinder(client));
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800346 remote()->transact(REGISTER_CLIENT, data, &reply);
347 }
Eric Laurentc2f1f072009-07-17 12:17:14 -0700348
Glenn Kastendd8104c2012-07-02 12:42:44 -0700349 virtual size_t getInputBufferSize(uint32_t sampleRate, audio_format_t format,
350 audio_channel_mask_t channelMask) const
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800351 {
352 Parcel data, reply;
353 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
354 data.writeInt32(sampleRate);
355 data.writeInt32(format);
Glenn Kastendd8104c2012-07-02 12:42:44 -0700356 data.writeInt32(channelMask);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800357 remote()->transact(GET_INPUTBUFFERSIZE, data, &reply);
Glenn Kastene03dd222014-01-28 11:04:39 -0800358 return reply.readInt64();
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800359 }
Eric Laurentc2f1f072009-07-17 12:17:14 -0700360
Eric Laurentcf2c0212014-07-25 16:20:43 -0700361 virtual status_t openOutput(audio_module_handle_t module,
362 audio_io_handle_t *output,
363 audio_config_t *config,
364 audio_devices_t *devices,
365 const String8& address,
366 uint32_t *latencyMs,
367 audio_output_flags_t flags)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800368 {
Eric Laurentcf2c0212014-07-25 16:20:43 -0700369 if (output == NULL || config == NULL || devices == NULL || latencyMs == NULL) {
370 return BAD_VALUE;
371 }
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800372 Parcel data, reply;
373 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurenta4c5a552012-03-29 10:12:40 -0700374 data.writeInt32(module);
Eric Laurentcf2c0212014-07-25 16:20:43 -0700375 data.write(config, sizeof(audio_config_t));
376 data.writeInt32(*devices);
377 data.writeString8(address);
Glenn Kasten18868c52012-03-07 09:15:37 -0800378 data.writeInt32((int32_t) flags);
Eric Laurentcf2c0212014-07-25 16:20:43 -0700379 status_t status = remote()->transact(OPEN_OUTPUT, data, &reply);
380 if (status != NO_ERROR) {
381 *output = AUDIO_IO_HANDLE_NONE;
382 return status;
Richard Fitzgeraldb1a270d2013-05-14 12:12:21 +0100383 }
Eric Laurentcf2c0212014-07-25 16:20:43 -0700384 status = (status_t)reply.readInt32();
385 if (status != NO_ERROR) {
386 *output = AUDIO_IO_HANDLE_NONE;
387 return status;
Glenn Kasten507b2862013-07-31 16:12:13 -0700388 }
Eric Laurentcf2c0212014-07-25 16:20:43 -0700389 *output = (audio_io_handle_t)reply.readInt32();
390 ALOGV("openOutput() returned output, %d", *output);
391 reply.read(config, sizeof(audio_config_t));
392 *devices = (audio_devices_t)reply.readInt32();
393 *latencyMs = reply.readInt32();
394 return NO_ERROR;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800395 }
396
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800397 virtual audio_io_handle_t openDuplicateOutput(audio_io_handle_t output1,
398 audio_io_handle_t output2)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800399 {
400 Parcel data, reply;
401 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800402 data.writeInt32((int32_t) output1);
403 data.writeInt32((int32_t) output2);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700404 remote()->transact(OPEN_DUPLICATE_OUTPUT, data, &reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800405 return (audio_io_handle_t) reply.readInt32();
Eric Laurentc2f1f072009-07-17 12:17:14 -0700406 }
407
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800408 virtual status_t closeOutput(audio_io_handle_t output)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700409 {
410 Parcel data, reply;
411 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800412 data.writeInt32((int32_t) output);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700413 remote()->transact(CLOSE_OUTPUT, data, &reply);
414 return reply.readInt32();
415 }
416
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800417 virtual status_t suspendOutput(audio_io_handle_t output)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700418 {
419 Parcel data, reply;
420 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800421 data.writeInt32((int32_t) output);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700422 remote()->transact(SUSPEND_OUTPUT, data, &reply);
423 return reply.readInt32();
424 }
425
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800426 virtual status_t restoreOutput(audio_io_handle_t output)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700427 {
428 Parcel data, reply;
429 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800430 data.writeInt32((int32_t) output);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700431 remote()->transact(RESTORE_OUTPUT, data, &reply);
432 return reply.readInt32();
433 }
434
Eric Laurentcf2c0212014-07-25 16:20:43 -0700435 virtual status_t openInput(audio_module_handle_t module,
436 audio_io_handle_t *input,
437 audio_config_t *config,
438 audio_devices_t *device,
439 const String8& address,
440 audio_source_t source,
441 audio_input_flags_t flags)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700442 {
Eric Laurentcf2c0212014-07-25 16:20:43 -0700443 if (input == NULL || config == NULL || device == NULL) {
444 return BAD_VALUE;
445 }
Eric Laurentc2f1f072009-07-17 12:17:14 -0700446 Parcel data, reply;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700447 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurenta4c5a552012-03-29 10:12:40 -0700448 data.writeInt32(module);
Eric Laurentcf2c0212014-07-25 16:20:43 -0700449 data.writeInt32(*input);
450 data.write(config, sizeof(audio_config_t));
451 data.writeInt32(*device);
452 data.writeString8(address);
453 data.writeInt32(source);
Glenn Kastenec40d282014-07-15 15:31:26 -0700454 data.writeInt32(flags);
Eric Laurentcf2c0212014-07-25 16:20:43 -0700455 status_t status = remote()->transact(OPEN_INPUT, data, &reply);
456 if (status != NO_ERROR) {
457 *input = AUDIO_IO_HANDLE_NONE;
458 return status;
Glenn Kasten507b2862013-07-31 16:12:13 -0700459 }
Eric Laurentcf2c0212014-07-25 16:20:43 -0700460 status = (status_t)reply.readInt32();
461 if (status != NO_ERROR) {
462 *input = AUDIO_IO_HANDLE_NONE;
463 return status;
Glenn Kasten507b2862013-07-31 16:12:13 -0700464 }
Eric Laurentcf2c0212014-07-25 16:20:43 -0700465 *input = (audio_io_handle_t)reply.readInt32();
466 reply.read(config, sizeof(audio_config_t));
467 *device = (audio_devices_t)reply.readInt32();
468 return NO_ERROR;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700469 }
470
Eric Laurentfa2877b2009-07-28 08:44:33 -0700471 virtual status_t closeInput(int input)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700472 {
473 Parcel data, reply;
474 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurentfa2877b2009-07-28 08:44:33 -0700475 data.writeInt32(input);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700476 remote()->transact(CLOSE_INPUT, data, &reply);
477 return reply.readInt32();
478 }
479
Glenn Kastend2304db2014-02-03 07:40:31 -0800480 virtual status_t invalidateStream(audio_stream_type_t stream)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700481 {
482 Parcel data, reply;
483 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kastenfff6d712012-01-12 16:38:12 -0800484 data.writeInt32((int32_t) stream);
Glenn Kastend2304db2014-02-03 07:40:31 -0800485 remote()->transact(INVALIDATE_STREAM, data, &reply);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700486 return reply.readInt32();
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800487 }
Eric Laurentf0ee6f42009-10-21 08:14:22 -0700488
489 virtual status_t setVoiceVolume(float volume)
490 {
491 Parcel data, reply;
492 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
493 data.writeFloat(volume);
494 remote()->transact(SET_VOICE_VOLUME, data, &reply);
495 return reply.readInt32();
496 }
Eric Laurent342e9cf2010-01-19 17:37:09 -0800497
Kévin PETIT377b2ec2014-02-03 12:35:36 +0000498 virtual status_t getRenderPosition(uint32_t *halFrames, uint32_t *dspFrames,
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800499 audio_io_handle_t output) const
Eric Laurent342e9cf2010-01-19 17:37:09 -0800500 {
501 Parcel data, reply;
502 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800503 data.writeInt32((int32_t) output);
Eric Laurent342e9cf2010-01-19 17:37:09 -0800504 remote()->transact(GET_RENDER_POSITION, data, &reply);
505 status_t status = reply.readInt32();
506 if (status == NO_ERROR) {
507 uint32_t tmp = reply.readInt32();
Glenn Kasten507b2862013-07-31 16:12:13 -0700508 if (halFrames != NULL) {
Eric Laurent342e9cf2010-01-19 17:37:09 -0800509 *halFrames = tmp;
510 }
511 tmp = reply.readInt32();
Glenn Kasten507b2862013-07-31 16:12:13 -0700512 if (dspFrames != NULL) {
Eric Laurent342e9cf2010-01-19 17:37:09 -0800513 *dspFrames = tmp;
514 }
515 }
516 return status;
517 }
Eric Laurent05bca2f2010-02-26 02:47:27 -0800518
Glenn Kasten5f972c02014-01-13 09:59:31 -0800519 virtual uint32_t getInputFramesLost(audio_io_handle_t ioHandle) const
Eric Laurent05bca2f2010-02-26 02:47:27 -0800520 {
521 Parcel data, reply;
522 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800523 data.writeInt32((int32_t) ioHandle);
Glenn Kasten5f972c02014-01-13 09:59:31 -0800524 status_t status = remote()->transact(GET_INPUT_FRAMES_LOST, data, &reply);
525 if (status != NO_ERROR) {
526 return 0;
527 }
528 return (uint32_t) reply.readInt32();
Eric Laurent05bca2f2010-02-26 02:47:27 -0800529 }
Eric Laurentbe916aa2010-06-01 23:49:17 -0700530
Glenn Kasteneeecb982016-02-26 10:44:04 -0800531 virtual audio_unique_id_t newAudioUniqueId(audio_unique_id_use_t use)
Eric Laurentbe916aa2010-06-01 23:49:17 -0700532 {
533 Parcel data, reply;
534 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasteneeecb982016-02-26 10:44:04 -0800535 data.writeInt32((int32_t) use);
Glenn Kasten9eae0362016-04-19 09:09:14 -0700536 status_t status = remote()->transact(NEW_AUDIO_UNIQUE_ID, data, &reply);
537 audio_unique_id_t id = AUDIO_UNIQUE_ID_ALLOCATE;
Eric Laurentbe916aa2010-06-01 23:49:17 -0700538 if (status == NO_ERROR) {
539 id = reply.readInt32();
540 }
541 return id;
542 }
543
Glenn Kastend848eb42016-03-08 13:42:11 -0800544 virtual void acquireAudioSessionId(audio_session_t audioSession, int pid)
Marco Nelissen3a34bef2011-08-02 13:33:41 -0700545 {
546 Parcel data, reply;
547 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
548 data.writeInt32(audioSession);
Marco Nelissend457c972014-02-11 08:47:07 -0800549 data.writeInt32(pid);
Marco Nelissen3a34bef2011-08-02 13:33:41 -0700550 remote()->transact(ACQUIRE_AUDIO_SESSION_ID, data, &reply);
551 }
552
Glenn Kastend848eb42016-03-08 13:42:11 -0800553 virtual void releaseAudioSessionId(audio_session_t audioSession, int pid)
Marco Nelissen3a34bef2011-08-02 13:33:41 -0700554 {
555 Parcel data, reply;
556 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
557 data.writeInt32(audioSession);
Marco Nelissend457c972014-02-11 08:47:07 -0800558 data.writeInt32(pid);
Marco Nelissen3a34bef2011-08-02 13:33:41 -0700559 remote()->transact(RELEASE_AUDIO_SESSION_ID, data, &reply);
560 }
561
Glenn Kastenf587ba52012-01-26 16:25:10 -0800562 virtual status_t queryNumberEffects(uint32_t *numEffects) const
Eric Laurentbe916aa2010-06-01 23:49:17 -0700563 {
564 Parcel data, reply;
565 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
566 status_t status = remote()->transact(QUERY_NUM_EFFECTS, data, &reply);
567 if (status != NO_ERROR) {
568 return status;
569 }
570 status = reply.readInt32();
571 if (status != NO_ERROR) {
572 return status;
573 }
Glenn Kasten9d1f02d2012-02-08 17:47:58 -0800574 if (numEffects != NULL) {
Eric Laurentbe916aa2010-06-01 23:49:17 -0700575 *numEffects = (uint32_t)reply.readInt32();
576 }
577 return NO_ERROR;
578 }
579
Glenn Kastenf587ba52012-01-26 16:25:10 -0800580 virtual status_t queryEffect(uint32_t index, effect_descriptor_t *pDescriptor) const
Eric Laurentbe916aa2010-06-01 23:49:17 -0700581 {
582 if (pDescriptor == NULL) {
583 return BAD_VALUE;
584 }
585 Parcel data, reply;
586 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurentffe9c252010-06-23 17:38:20 -0700587 data.writeInt32(index);
588 status_t status = remote()->transact(QUERY_EFFECT, data, &reply);
Eric Laurentbe916aa2010-06-01 23:49:17 -0700589 if (status != NO_ERROR) {
590 return status;
591 }
592 status = reply.readInt32();
593 if (status != NO_ERROR) {
594 return status;
595 }
596 reply.read(pDescriptor, sizeof(effect_descriptor_t));
597 return NO_ERROR;
598 }
599
Glenn Kasten5e92a782012-01-30 07:40:52 -0800600 virtual status_t getEffectDescriptor(const effect_uuid_t *pUuid,
Glenn Kastenf587ba52012-01-26 16:25:10 -0800601 effect_descriptor_t *pDescriptor) const
Eric Laurentbe916aa2010-06-01 23:49:17 -0700602 {
603 if (pUuid == NULL || pDescriptor == NULL) {
604 return BAD_VALUE;
605 }
606 Parcel data, reply;
607 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
608 data.write(pUuid, sizeof(effect_uuid_t));
609 status_t status = remote()->transact(GET_EFFECT_DESCRIPTOR, data, &reply);
610 if (status != NO_ERROR) {
611 return status;
612 }
613 status = reply.readInt32();
614 if (status != NO_ERROR) {
615 return status;
616 }
617 reply.read(pDescriptor, sizeof(effect_descriptor_t));
618 return NO_ERROR;
619 }
620
Glenn Kasten8d6cc842012-02-03 11:06:53 -0800621 virtual sp<IEffect> createEffect(
Eric Laurentbe916aa2010-06-01 23:49:17 -0700622 effect_descriptor_t *pDesc,
623 const sp<IEffectClient>& client,
624 int32_t priority,
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800625 audio_io_handle_t output,
Glenn Kastend848eb42016-03-08 13:42:11 -0800626 audio_session_t sessionId,
Svet Ganovbe71aa22015-04-28 12:06:02 -0700627 const String16& opPackageName,
Eric Laurentb6436272016-12-07 19:24:50 -0800628 pid_t pid,
Eric Laurentbe916aa2010-06-01 23:49:17 -0700629 status_t *status,
630 int *id,
631 int *enabled)
632 {
633 Parcel data, reply;
634 sp<IEffect> effect;
635
636 if (pDesc == NULL) {
Glenn Kastene53b9ea2012-03-12 16:29:55 -0700637 return effect;
Glenn Kasten507b2862013-07-31 16:12:13 -0700638 if (status != NULL) {
Glenn Kastene53b9ea2012-03-12 16:29:55 -0700639 *status = BAD_VALUE;
640 }
641 }
Eric Laurentbe916aa2010-06-01 23:49:17 -0700642
643 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurentbe916aa2010-06-01 23:49:17 -0700644 data.write(pDesc, sizeof(effect_descriptor_t));
Marco Nelissen06b46062014-11-14 07:58:25 -0800645 data.writeStrongBinder(IInterface::asBinder(client));
Eric Laurentbe916aa2010-06-01 23:49:17 -0700646 data.writeInt32(priority);
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800647 data.writeInt32((int32_t) output);
Eric Laurentbe916aa2010-06-01 23:49:17 -0700648 data.writeInt32(sessionId);
Svet Ganovbe71aa22015-04-28 12:06:02 -0700649 data.writeString16(opPackageName);
Eric Laurentb6436272016-12-07 19:24:50 -0800650 data.writeInt32((int32_t) pid);
Eric Laurentbe916aa2010-06-01 23:49:17 -0700651
652 status_t lStatus = remote()->transact(CREATE_EFFECT, data, &reply);
653 if (lStatus != NO_ERROR) {
Steve Block29357bc2012-01-06 19:20:56 +0000654 ALOGE("createEffect error: %s", strerror(-lStatus));
Eric Laurentbe916aa2010-06-01 23:49:17 -0700655 } else {
656 lStatus = reply.readInt32();
657 int tmp = reply.readInt32();
Glenn Kasten507b2862013-07-31 16:12:13 -0700658 if (id != NULL) {
Eric Laurentbe916aa2010-06-01 23:49:17 -0700659 *id = tmp;
660 }
661 tmp = reply.readInt32();
Glenn Kastena0d68332012-01-27 16:47:15 -0800662 if (enabled != NULL) {
Eric Laurentbe916aa2010-06-01 23:49:17 -0700663 *enabled = tmp;
664 }
665 effect = interface_cast<IEffect>(reply.readStrongBinder());
666 reply.read(pDesc, sizeof(effect_descriptor_t));
667 }
Glenn Kasten507b2862013-07-31 16:12:13 -0700668 if (status != NULL) {
Eric Laurentbe916aa2010-06-01 23:49:17 -0700669 *status = lStatus;
670 }
671
672 return effect;
673 }
Eric Laurentde070132010-07-13 04:45:46 -0700674
Glenn Kastend848eb42016-03-08 13:42:11 -0800675 virtual status_t moveEffects(audio_session_t session, audio_io_handle_t srcOutput,
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800676 audio_io_handle_t dstOutput)
Eric Laurentde070132010-07-13 04:45:46 -0700677 {
678 Parcel data, reply;
679 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
680 data.writeInt32(session);
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800681 data.writeInt32((int32_t) srcOutput);
682 data.writeInt32((int32_t) dstOutput);
Eric Laurentde070132010-07-13 04:45:46 -0700683 remote()->transact(MOVE_EFFECTS, data, &reply);
684 return reply.readInt32();
685 }
Eric Laurenta4c5a552012-03-29 10:12:40 -0700686
687 virtual audio_module_handle_t loadHwModule(const char *name)
688 {
689 Parcel data, reply;
690 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
691 data.writeCString(name);
692 remote()->transact(LOAD_HW_MODULE, data, &reply);
693 return (audio_module_handle_t) reply.readInt32();
694 }
Glenn Kastencc0f1cf2012-09-24 11:27:18 -0700695
Glenn Kasten3b16c762012-11-14 08:44:39 -0800696 virtual uint32_t getPrimaryOutputSamplingRate()
Glenn Kastencc0f1cf2012-09-24 11:27:18 -0700697 {
698 Parcel data, reply;
699 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
700 remote()->transact(GET_PRIMARY_OUTPUT_SAMPLING_RATE, data, &reply);
701 return reply.readInt32();
702 }
703
Glenn Kastene33054e2012-11-14 12:54:39 -0800704 virtual size_t getPrimaryOutputFrameCount()
Glenn Kastencc0f1cf2012-09-24 11:27:18 -0700705 {
706 Parcel data, reply;
707 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
708 remote()->transact(GET_PRIMARY_OUTPUT_FRAME_COUNT, data, &reply);
Glenn Kastene03dd222014-01-28 11:04:39 -0800709 return reply.readInt64();
Glenn Kastencc0f1cf2012-09-24 11:27:18 -0700710 }
711
Andy Hung6f248bb2018-01-23 14:04:37 -0800712 virtual status_t setLowRamDevice(bool isLowRamDevice, int64_t totalMemory) override
Glenn Kasten4182c4e2013-07-15 14:45:07 -0700713 {
714 Parcel data, reply;
Andy Hung6f248bb2018-01-23 14:04:37 -0800715
716 static_assert(NO_ERROR == 0, "NO_ERROR must be 0");
717 return data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor())
718 ?: data.writeInt32((int) isLowRamDevice)
719 ?: data.writeInt64(totalMemory)
720 ?: remote()->transact(SET_LOW_RAM_DEVICE, data, &reply)
721 ?: reply.readInt32();
Glenn Kasten4182c4e2013-07-15 14:45:07 -0700722 }
Andy Hung6f248bb2018-01-23 14:04:37 -0800723
Eric Laurent4b123402014-04-11 09:22:20 -0700724 virtual status_t listAudioPorts(unsigned int *num_ports,
725 struct audio_port *ports)
726 {
727 if (num_ports == NULL || *num_ports == 0 || ports == NULL) {
728 return BAD_VALUE;
729 }
730 Parcel data, reply;
731 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
732 data.writeInt32(*num_ports);
733 status_t status = remote()->transact(LIST_AUDIO_PORTS, data, &reply);
734 if (status != NO_ERROR ||
735 (status = (status_t)reply.readInt32()) != NO_ERROR) {
736 return status;
737 }
738 *num_ports = (unsigned int)reply.readInt32();
739 reply.read(ports, *num_ports * sizeof(struct audio_port));
740 return status;
741 }
742 virtual status_t getAudioPort(struct audio_port *port)
743 {
744 if (port == NULL) {
745 return BAD_VALUE;
746 }
747 Parcel data, reply;
748 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
749 data.write(port, sizeof(struct audio_port));
750 status_t status = remote()->transact(GET_AUDIO_PORT, data, &reply);
751 if (status != NO_ERROR ||
752 (status = (status_t)reply.readInt32()) != NO_ERROR) {
753 return status;
754 }
755 reply.read(port, sizeof(struct audio_port));
756 return status;
757 }
758 virtual status_t createAudioPatch(const struct audio_patch *patch,
759 audio_patch_handle_t *handle)
760 {
761 if (patch == NULL || handle == NULL) {
762 return BAD_VALUE;
763 }
764 Parcel data, reply;
765 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
766 data.write(patch, sizeof(struct audio_patch));
767 data.write(handle, sizeof(audio_patch_handle_t));
768 status_t status = remote()->transact(CREATE_AUDIO_PATCH, data, &reply);
769 if (status != NO_ERROR ||
770 (status = (status_t)reply.readInt32()) != NO_ERROR) {
771 return status;
772 }
773 reply.read(handle, sizeof(audio_patch_handle_t));
774 return status;
775 }
776 virtual status_t releaseAudioPatch(audio_patch_handle_t handle)
777 {
778 Parcel data, reply;
779 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
780 data.write(&handle, sizeof(audio_patch_handle_t));
781 status_t status = remote()->transact(RELEASE_AUDIO_PATCH, data, &reply);
782 if (status != NO_ERROR) {
783 status = (status_t)reply.readInt32();
784 }
785 return status;
786 }
787 virtual status_t listAudioPatches(unsigned int *num_patches,
788 struct audio_patch *patches)
789 {
790 if (num_patches == NULL || *num_patches == 0 || patches == NULL) {
791 return BAD_VALUE;
792 }
793 Parcel data, reply;
794 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
795 data.writeInt32(*num_patches);
796 status_t status = remote()->transact(LIST_AUDIO_PATCHES, data, &reply);
797 if (status != NO_ERROR ||
798 (status = (status_t)reply.readInt32()) != NO_ERROR) {
799 return status;
800 }
801 *num_patches = (unsigned int)reply.readInt32();
802 reply.read(patches, *num_patches * sizeof(struct audio_patch));
803 return status;
804 }
805 virtual status_t setAudioPortConfig(const struct audio_port_config *config)
806 {
807 if (config == NULL) {
808 return BAD_VALUE;
809 }
810 Parcel data, reply;
811 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
812 data.write(config, sizeof(struct audio_port_config));
813 status_t status = remote()->transact(SET_AUDIO_PORT_CONFIG, data, &reply);
814 if (status != NO_ERROR) {
815 status = (status_t)reply.readInt32();
816 }
817 return status;
818 }
Eric Laurent93c3d412014-08-01 14:48:35 -0700819 virtual audio_hw_sync_t getAudioHwSyncForSession(audio_session_t sessionId)
820 {
821 Parcel data, reply;
822 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
823 data.writeInt32(sessionId);
Glenn Kasten9eae0362016-04-19 09:09:14 -0700824 status_t status = remote()->transact(GET_AUDIO_HW_SYNC_FOR_SESSION, data, &reply);
Eric Laurent93c3d412014-08-01 14:48:35 -0700825 if (status != NO_ERROR) {
826 return AUDIO_HW_SYNC_INVALID;
827 }
828 return (audio_hw_sync_t)reply.readInt32();
829 }
Eric Laurent72e3f392015-05-20 14:43:50 -0700830 virtual status_t systemReady()
831 {
832 Parcel data, reply;
833 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
834 return remote()->transact(SYSTEM_READY, data, &reply, IBinder::FLAG_ONEWAY);
835 }
Glenn Kasten4a8308b2016-04-18 14:10:01 -0700836 virtual size_t frameCountHAL(audio_io_handle_t ioHandle) const
837 {
838 Parcel data, reply;
839 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
840 data.writeInt32((int32_t) ioHandle);
841 status_t status = remote()->transact(FRAME_COUNT_HAL, data, &reply);
842 if (status != NO_ERROR) {
843 return 0;
844 }
845 return reply.readInt64();
846 }
jiabin46a76fa2018-01-05 10:18:21 -0800847 virtual status_t getMicrophones(std::vector<media::MicrophoneInfo> *microphones)
848 {
849 Parcel data, reply;
850 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
jiabin9ff780e2018-03-19 18:19:52 -0700851 status_t status = remote()->transact(GET_MICROPHONES, data, &reply);
jiabin46a76fa2018-01-05 10:18:21 -0800852 if (status != NO_ERROR ||
853 (status = (status_t)reply.readInt32()) != NO_ERROR) {
854 return status;
855 }
856 status = reply.readParcelableVector(microphones);
857 return status;
858 }
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800859};
860
861IMPLEMENT_META_INTERFACE(AudioFlinger, "android.media.IAudioFlinger");
862
863// ----------------------------------------------------------------------
864
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800865status_t BnAudioFlinger::onTransact(
866 uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags)
867{
Eric Laurentb1cc36b2017-12-11 12:14:16 -0800868 // make sure transactions reserved to AudioPolicyManager do not come from other processes
869 switch (code) {
870 case SET_STREAM_VOLUME:
871 case SET_STREAM_MUTE:
Eric Laurentb1cc36b2017-12-11 12:14:16 -0800872 case OPEN_OUTPUT:
873 case OPEN_DUPLICATE_OUTPUT:
874 case CLOSE_OUTPUT:
875 case SUSPEND_OUTPUT:
876 case RESTORE_OUTPUT:
877 case OPEN_INPUT:
878 case CLOSE_INPUT:
879 case INVALIDATE_STREAM:
880 case SET_VOICE_VOLUME:
881 case MOVE_EFFECTS:
882 case LOAD_HW_MODULE:
883 case LIST_AUDIO_PORTS:
884 case GET_AUDIO_PORT:
885 case CREATE_AUDIO_PATCH:
886 case RELEASE_AUDIO_PATCH:
887 case LIST_AUDIO_PATCHES:
888 case SET_AUDIO_PORT_CONFIG:
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800889 case SET_RECORD_SILENCED:
Eric Laurentb1cc36b2017-12-11 12:14:16 -0800890 ALOGW("%s: transaction %d received from PID %d",
891 __func__, code, IPCThreadState::self()->getCallingPid());
Eric Laurentef92bff2018-04-26 10:44:50 -0700892 // return status only for non void methods
893 switch (code) {
894 case SET_RECORD_SILENCED:
895 break;
896 default:
897 reply->writeInt32(static_cast<int32_t> (INVALID_OPERATION));
898 break;
899 }
900 return OK;
Eric Laurentb1cc36b2017-12-11 12:14:16 -0800901 default:
902 break;
903 }
904
Eric Laurent4980df22018-01-26 18:04:09 -0800905 // make sure the following transactions come from system components
906 switch (code) {
907 case SET_MASTER_VOLUME:
908 case SET_MASTER_MUTE:
909 case SET_MODE:
910 case SET_MIC_MUTE:
911 case SET_LOW_RAM_DEVICE:
Eric Laurent96c7eed2018-03-26 17:57:01 -0700912 case SYSTEM_READY: {
Andy Hung4ef19fa2018-05-15 19:35:29 -0700913 if (!isServiceUid(IPCThreadState::self()->getCallingUid())) {
Eric Laurent4980df22018-01-26 18:04:09 -0800914 ALOGW("%s: transaction %d received from PID %d unauthorized UID %d",
915 __func__, code, IPCThreadState::self()->getCallingPid(),
916 IPCThreadState::self()->getCallingUid());
Eric Laurentef92bff2018-04-26 10:44:50 -0700917 // return status only for non void methods
918 switch (code) {
919 case SYSTEM_READY:
920 break;
921 default:
922 reply->writeInt32(static_cast<int32_t> (INVALID_OPERATION));
923 break;
924 }
925 return OK;
Eric Laurent4980df22018-01-26 18:04:09 -0800926 }
Eric Laurent96c7eed2018-03-26 17:57:01 -0700927 } break;
Eric Laurent4980df22018-01-26 18:04:09 -0800928 default:
929 break;
930 }
931
Nicolas Rouletdcdfaec2017-02-14 10:18:39 -0800932 // Whitelist of relevant events to trigger log merging.
933 // Log merging should activate during audio activity of any kind. This are considered the
934 // most relevant events.
935 // TODO should select more wisely the items from the list
936 switch (code) {
937 case CREATE_TRACK:
Eric Laurentf14db3c2017-12-08 14:20:36 -0800938 case CREATE_RECORD:
Nicolas Rouletdcdfaec2017-02-14 10:18:39 -0800939 case SET_MASTER_VOLUME:
940 case SET_MASTER_MUTE:
Nicolas Rouletdcdfaec2017-02-14 10:18:39 -0800941 case SET_MIC_MUTE:
942 case SET_PARAMETERS:
Nicolas Rouletdcdfaec2017-02-14 10:18:39 -0800943 case CREATE_EFFECT:
944 case SYSTEM_READY: {
945 requestLogMerge();
946 break;
947 }
948 default:
949 break;
950 }
Eric Laurentb1cc36b2017-12-11 12:14:16 -0800951
Eric Laurent39b09b52018-06-29 12:24:40 -0700952 std::string tag("IAudioFlinger command " + std::to_string(code));
953 TimeCheck check(tag.c_str());
Eric Laurent3528c932018-02-23 17:17:22 -0800954
Glenn Kastene53b9ea2012-03-12 16:29:55 -0700955 switch (code) {
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800956 case CREATE_TRACK: {
957 CHECK_INTERFACE(IAudioFlinger, data, reply);
Eric Laurent21da6472017-11-09 16:29:26 -0800958
959 CreateTrackInput input;
960 if (input.readFromParcel((Parcel*)&data) != NO_ERROR) {
961 reply->writeInt32(DEAD_OBJECT);
962 return NO_ERROR;
Eric Laurent3d00aa62013-09-24 09:53:27 -0700963 }
Eric Laurent21da6472017-11-09 16:29:26 -0800964
965 status_t status;
966 CreateTrackOutput output;
967
968 sp<IAudioTrack> track= createTrack(input,
969 output,
970 &status);
971
972 LOG_ALWAYS_FATAL_IF((track != 0) != (status == NO_ERROR));
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800973 reply->writeInt32(status);
Eric Laurent21da6472017-11-09 16:29:26 -0800974 if (status != NO_ERROR) {
975 return NO_ERROR;
976 }
Marco Nelissen06b46062014-11-14 07:58:25 -0800977 reply->writeStrongBinder(IInterface::asBinder(track));
Eric Laurent21da6472017-11-09 16:29:26 -0800978 output.writeToParcel(reply);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800979 return NO_ERROR;
980 } break;
Eric Laurentf14db3c2017-12-08 14:20:36 -0800981 case CREATE_RECORD: {
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800982 CHECK_INTERFACE(IAudioFlinger, data, reply);
Eric Laurentf14db3c2017-12-08 14:20:36 -0800983
984 CreateRecordInput input;
985 if (input.readFromParcel((Parcel*)&data) != NO_ERROR) {
986 reply->writeInt32(DEAD_OBJECT);
987 return NO_ERROR;
988 }
989
990 status_t status;
991 CreateRecordOutput output;
992
993 sp<media::IAudioRecord> record = createRecord(input,
994 output,
995 &status);
996
Glenn Kastene93cf2c2013-09-24 11:52:37 -0700997 LOG_ALWAYS_FATAL_IF((record != 0) != (status == NO_ERROR));
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800998 reply->writeInt32(status);
Eric Laurentf14db3c2017-12-08 14:20:36 -0800999 if (status != NO_ERROR) {
1000 return NO_ERROR;
1001 }
Marco Nelissen06b46062014-11-14 07:58:25 -08001002 reply->writeStrongBinder(IInterface::asBinder(record));
Eric Laurentf14db3c2017-12-08 14:20:36 -08001003 output.writeToParcel(reply);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001004 return NO_ERROR;
1005 } break;
1006 case SAMPLE_RATE: {
1007 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001008 reply->writeInt32( sampleRate((audio_io_handle_t) data.readInt32()) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001009 return NO_ERROR;
1010 } break;
Glenn Kasten4a8308b2016-04-18 14:10:01 -07001011
1012 // RESERVED for channelCount()
1013
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001014 case FORMAT: {
1015 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001016 reply->writeInt32( format((audio_io_handle_t) data.readInt32()) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001017 return NO_ERROR;
1018 } break;
1019 case FRAME_COUNT: {
1020 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastene03dd222014-01-28 11:04:39 -08001021 reply->writeInt64( frameCount((audio_io_handle_t) data.readInt32()) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001022 return NO_ERROR;
1023 } break;
1024 case LATENCY: {
1025 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001026 reply->writeInt32( latency((audio_io_handle_t) data.readInt32()) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001027 return NO_ERROR;
1028 } break;
Glenn Kastene53b9ea2012-03-12 16:29:55 -07001029 case SET_MASTER_VOLUME: {
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001030 CHECK_INTERFACE(IAudioFlinger, data, reply);
1031 reply->writeInt32( setMasterVolume(data.readFloat()) );
1032 return NO_ERROR;
1033 } break;
1034 case SET_MASTER_MUTE: {
1035 CHECK_INTERFACE(IAudioFlinger, data, reply);
1036 reply->writeInt32( setMasterMute(data.readInt32()) );
1037 return NO_ERROR;
1038 } break;
1039 case MASTER_VOLUME: {
1040 CHECK_INTERFACE(IAudioFlinger, data, reply);
1041 reply->writeFloat( masterVolume() );
1042 return NO_ERROR;
1043 } break;
1044 case MASTER_MUTE: {
1045 CHECK_INTERFACE(IAudioFlinger, data, reply);
1046 reply->writeInt32( masterMute() );
1047 return NO_ERROR;
1048 } break;
1049 case SET_STREAM_VOLUME: {
1050 CHECK_INTERFACE(IAudioFlinger, data, reply);
1051 int stream = data.readInt32();
Eric Laurentc2f1f072009-07-17 12:17:14 -07001052 float volume = data.readFloat();
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001053 audio_io_handle_t output = (audio_io_handle_t) data.readInt32();
Glenn Kastenfff6d712012-01-12 16:38:12 -08001054 reply->writeInt32( setStreamVolume((audio_stream_type_t) stream, volume, output) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001055 return NO_ERROR;
1056 } break;
1057 case SET_STREAM_MUTE: {
1058 CHECK_INTERFACE(IAudioFlinger, data, reply);
1059 int stream = data.readInt32();
Glenn Kastenfff6d712012-01-12 16:38:12 -08001060 reply->writeInt32( setStreamMute((audio_stream_type_t) stream, data.readInt32()) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001061 return NO_ERROR;
1062 } break;
1063 case STREAM_VOLUME: {
1064 CHECK_INTERFACE(IAudioFlinger, data, reply);
1065 int stream = data.readInt32();
Eric Laurentfa2877b2009-07-28 08:44:33 -07001066 int output = data.readInt32();
Glenn Kastenfff6d712012-01-12 16:38:12 -08001067 reply->writeFloat( streamVolume((audio_stream_type_t) stream, output) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001068 return NO_ERROR;
1069 } break;
1070 case STREAM_MUTE: {
1071 CHECK_INTERFACE(IAudioFlinger, data, reply);
1072 int stream = data.readInt32();
Glenn Kastenfff6d712012-01-12 16:38:12 -08001073 reply->writeInt32( streamMute((audio_stream_type_t) stream) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001074 return NO_ERROR;
1075 } break;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001076 case SET_MODE: {
1077 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastenf78aee72012-01-04 11:00:47 -08001078 audio_mode_t mode = (audio_mode_t) data.readInt32();
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001079 reply->writeInt32( setMode(mode) );
1080 return NO_ERROR;
1081 } break;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001082 case SET_MIC_MUTE: {
1083 CHECK_INTERFACE(IAudioFlinger, data, reply);
1084 int state = data.readInt32();
1085 reply->writeInt32( setMicMute(state) );
1086 return NO_ERROR;
1087 } break;
1088 case GET_MIC_MUTE: {
1089 CHECK_INTERFACE(IAudioFlinger, data, reply);
1090 reply->writeInt32( getMicMute() );
1091 return NO_ERROR;
1092 } break;
Svet Ganovf4ddfef2018-01-16 07:37:58 -08001093 case SET_RECORD_SILENCED: {
1094 CHECK_INTERFACE(IAudioFlinger, data, reply);
1095 uid_t uid = data.readInt32();
1096 audio_source_t source;
1097 data.read(&source, sizeof(audio_source_t));
1098 bool silenced = data.readInt32() == 1;
1099 setRecordSilenced(uid, silenced);
1100 return NO_ERROR;
1101 } break;
Eric Laurentc2f1f072009-07-17 12:17:14 -07001102 case SET_PARAMETERS: {
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001103 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001104 audio_io_handle_t ioHandle = (audio_io_handle_t) data.readInt32();
Eric Laurentc2f1f072009-07-17 12:17:14 -07001105 String8 keyValuePairs(data.readString8());
1106 reply->writeInt32(setParameters(ioHandle, keyValuePairs));
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001107 return NO_ERROR;
Glenn Kastene53b9ea2012-03-12 16:29:55 -07001108 } break;
Eric Laurentc2f1f072009-07-17 12:17:14 -07001109 case GET_PARAMETERS: {
1110 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001111 audio_io_handle_t ioHandle = (audio_io_handle_t) data.readInt32();
Eric Laurentc2f1f072009-07-17 12:17:14 -07001112 String8 keys(data.readString8());
1113 reply->writeString8(getParameters(ioHandle, keys));
1114 return NO_ERROR;
Glenn Kastene53b9ea2012-03-12 16:29:55 -07001115 } break;
Eric Laurentc2f1f072009-07-17 12:17:14 -07001116
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001117 case REGISTER_CLIENT: {
1118 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten85ab62c2012-11-01 11:11:38 -07001119 sp<IAudioFlingerClient> client = interface_cast<IAudioFlingerClient>(
1120 data.readStrongBinder());
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001121 registerClient(client);
1122 return NO_ERROR;
1123 } break;
1124 case GET_INPUTBUFFERSIZE: {
1125 CHECK_INTERFACE(IAudioFlinger, data, reply);
1126 uint32_t sampleRate = data.readInt32();
Glenn Kasten58f30212012-01-12 12:27:51 -08001127 audio_format_t format = (audio_format_t) data.readInt32();
Glenn Kastendd8104c2012-07-02 12:42:44 -07001128 audio_channel_mask_t channelMask = data.readInt32();
Glenn Kastene03dd222014-01-28 11:04:39 -08001129 reply->writeInt64( getInputBufferSize(sampleRate, format, channelMask) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001130 return NO_ERROR;
1131 } break;
Eric Laurentc2f1f072009-07-17 12:17:14 -07001132 case OPEN_OUTPUT: {
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001133 CHECK_INTERFACE(IAudioFlinger, data, reply);
Eric Laurenta4c5a552012-03-29 10:12:40 -07001134 audio_module_handle_t module = (audio_module_handle_t)data.readInt32();
Wei Jiae995e472015-09-09 09:48:34 -07001135 audio_config_t config = {};
1136 if (data.read(&config, sizeof(audio_config_t)) != NO_ERROR) {
1137 ALOGE("b/23905951");
1138 }
Eric Laurenta4c5a552012-03-29 10:12:40 -07001139 audio_devices_t devices = (audio_devices_t)data.readInt32();
Eric Laurentcf2c0212014-07-25 16:20:43 -07001140 String8 address(data.readString8());
Eric Laurent0ca3cf92012-04-18 09:24:29 -07001141 audio_output_flags_t flags = (audio_output_flags_t) data.readInt32();
Wei Jia983dca32015-09-10 09:47:29 -07001142 uint32_t latencyMs = 0;
Wei Jia4cac44b2015-09-16 15:01:16 -07001143 audio_io_handle_t output = AUDIO_IO_HANDLE_NONE;
Eric Laurentcf2c0212014-07-25 16:20:43 -07001144 status_t status = openOutput(module, &output, &config,
1145 &devices, address, &latencyMs, flags);
Glenn Kasten70742962014-02-18 08:00:47 -08001146 ALOGV("OPEN_OUTPUT output, %d", output);
Eric Laurentcf2c0212014-07-25 16:20:43 -07001147 reply->writeInt32((int32_t)status);
1148 if (status == NO_ERROR) {
1149 reply->writeInt32((int32_t)output);
1150 reply->write(&config, sizeof(audio_config_t));
1151 reply->writeInt32(devices);
1152 reply->writeInt32(latencyMs);
1153 }
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001154 return NO_ERROR;
1155 } break;
Eric Laurentc2f1f072009-07-17 12:17:14 -07001156 case OPEN_DUPLICATE_OUTPUT: {
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001157 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001158 audio_io_handle_t output1 = (audio_io_handle_t) data.readInt32();
1159 audio_io_handle_t output2 = (audio_io_handle_t) data.readInt32();
1160 reply->writeInt32((int32_t) openDuplicateOutput(output1, output2));
Eric Laurentc2f1f072009-07-17 12:17:14 -07001161 return NO_ERROR;
1162 } break;
1163 case CLOSE_OUTPUT: {
1164 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001165 reply->writeInt32(closeOutput((audio_io_handle_t) data.readInt32()));
Eric Laurentc2f1f072009-07-17 12:17:14 -07001166 return NO_ERROR;
1167 } break;
1168 case SUSPEND_OUTPUT: {
1169 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001170 reply->writeInt32(suspendOutput((audio_io_handle_t) data.readInt32()));
Eric Laurentc2f1f072009-07-17 12:17:14 -07001171 return NO_ERROR;
1172 } break;
1173 case RESTORE_OUTPUT: {
1174 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001175 reply->writeInt32(restoreOutput((audio_io_handle_t) data.readInt32()));
Eric Laurentc2f1f072009-07-17 12:17:14 -07001176 return NO_ERROR;
1177 } break;
1178 case OPEN_INPUT: {
1179 CHECK_INTERFACE(IAudioFlinger, data, reply);
Eric Laurenta4c5a552012-03-29 10:12:40 -07001180 audio_module_handle_t module = (audio_module_handle_t)data.readInt32();
Eric Laurentcf2c0212014-07-25 16:20:43 -07001181 audio_io_handle_t input = (audio_io_handle_t)data.readInt32();
Wei Jiae995e472015-09-09 09:48:34 -07001182 audio_config_t config = {};
1183 if (data.read(&config, sizeof(audio_config_t)) != NO_ERROR) {
1184 ALOGE("b/23905951");
1185 }
Eric Laurentcf2c0212014-07-25 16:20:43 -07001186 audio_devices_t device = (audio_devices_t)data.readInt32();
1187 String8 address(data.readString8());
1188 audio_source_t source = (audio_source_t)data.readInt32();
Glenn Kastenec40d282014-07-15 15:31:26 -07001189 audio_input_flags_t flags = (audio_input_flags_t) data.readInt32();
Eric Laurentc2f1f072009-07-17 12:17:14 -07001190
Eric Laurentcf2c0212014-07-25 16:20:43 -07001191 status_t status = openInput(module, &input, &config,
1192 &device, address, source, flags);
1193 reply->writeInt32((int32_t) status);
1194 if (status == NO_ERROR) {
1195 reply->writeInt32((int32_t) input);
1196 reply->write(&config, sizeof(audio_config_t));
1197 reply->writeInt32(device);
1198 }
Eric Laurentc2f1f072009-07-17 12:17:14 -07001199 return NO_ERROR;
1200 } break;
1201 case CLOSE_INPUT: {
1202 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001203 reply->writeInt32(closeInput((audio_io_handle_t) data.readInt32()));
Eric Laurentc2f1f072009-07-17 12:17:14 -07001204 return NO_ERROR;
1205 } break;
Glenn Kastend2304db2014-02-03 07:40:31 -08001206 case INVALIDATE_STREAM: {
Eric Laurentc2f1f072009-07-17 12:17:14 -07001207 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastend2304db2014-02-03 07:40:31 -08001208 audio_stream_type_t stream = (audio_stream_type_t) data.readInt32();
1209 reply->writeInt32(invalidateStream(stream));
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001210 return NO_ERROR;
1211 } break;
Eric Laurentf0ee6f42009-10-21 08:14:22 -07001212 case SET_VOICE_VOLUME: {
1213 CHECK_INTERFACE(IAudioFlinger, data, reply);
1214 float volume = data.readFloat();
1215 reply->writeInt32( setVoiceVolume(volume) );
1216 return NO_ERROR;
1217 } break;
Eric Laurent342e9cf2010-01-19 17:37:09 -08001218 case GET_RENDER_POSITION: {
1219 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001220 audio_io_handle_t output = (audio_io_handle_t) data.readInt32();
Wei Jia983dca32015-09-10 09:47:29 -07001221 uint32_t halFrames = 0;
1222 uint32_t dspFrames = 0;
Eric Laurent342e9cf2010-01-19 17:37:09 -08001223 status_t status = getRenderPosition(&halFrames, &dspFrames, output);
1224 reply->writeInt32(status);
1225 if (status == NO_ERROR) {
1226 reply->writeInt32(halFrames);
1227 reply->writeInt32(dspFrames);
1228 }
1229 return NO_ERROR;
1230 }
Eric Laurent05bca2f2010-02-26 02:47:27 -08001231 case GET_INPUT_FRAMES_LOST: {
1232 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001233 audio_io_handle_t ioHandle = (audio_io_handle_t) data.readInt32();
Glenn Kasten5f972c02014-01-13 09:59:31 -08001234 reply->writeInt32((int32_t) getInputFramesLost(ioHandle));
Eric Laurent05bca2f2010-02-26 02:47:27 -08001235 return NO_ERROR;
1236 } break;
Glenn Kasten9eae0362016-04-19 09:09:14 -07001237 case NEW_AUDIO_UNIQUE_ID: {
Eric Laurentbe916aa2010-06-01 23:49:17 -07001238 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasteneeecb982016-02-26 10:44:04 -08001239 reply->writeInt32(newAudioUniqueId((audio_unique_id_use_t) data.readInt32()));
Eric Laurentbe916aa2010-06-01 23:49:17 -07001240 return NO_ERROR;
1241 } break;
Marco Nelissen3a34bef2011-08-02 13:33:41 -07001242 case ACQUIRE_AUDIO_SESSION_ID: {
1243 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastend848eb42016-03-08 13:42:11 -08001244 audio_session_t audioSession = (audio_session_t) data.readInt32();
Marco Nelissend457c972014-02-11 08:47:07 -08001245 int pid = data.readInt32();
1246 acquireAudioSessionId(audioSession, pid);
Marco Nelissen3a34bef2011-08-02 13:33:41 -07001247 return NO_ERROR;
1248 } break;
1249 case RELEASE_AUDIO_SESSION_ID: {
1250 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastend848eb42016-03-08 13:42:11 -08001251 audio_session_t audioSession = (audio_session_t) data.readInt32();
Marco Nelissend457c972014-02-11 08:47:07 -08001252 int pid = data.readInt32();
1253 releaseAudioSessionId(audioSession, pid);
Marco Nelissen3a34bef2011-08-02 13:33:41 -07001254 return NO_ERROR;
1255 } break;
Eric Laurentbe916aa2010-06-01 23:49:17 -07001256 case QUERY_NUM_EFFECTS: {
1257 CHECK_INTERFACE(IAudioFlinger, data, reply);
Wei Jia983dca32015-09-10 09:47:29 -07001258 uint32_t numEffects = 0;
Eric Laurentbe916aa2010-06-01 23:49:17 -07001259 status_t status = queryNumberEffects(&numEffects);
1260 reply->writeInt32(status);
1261 if (status == NO_ERROR) {
1262 reply->writeInt32((int32_t)numEffects);
1263 }
1264 return NO_ERROR;
1265 }
Eric Laurentffe9c252010-06-23 17:38:20 -07001266 case QUERY_EFFECT: {
Eric Laurentbe916aa2010-06-01 23:49:17 -07001267 CHECK_INTERFACE(IAudioFlinger, data, reply);
Wei Jia983dca32015-09-10 09:47:29 -07001268 effect_descriptor_t desc = {};
Eric Laurentffe9c252010-06-23 17:38:20 -07001269 status_t status = queryEffect(data.readInt32(), &desc);
Eric Laurentbe916aa2010-06-01 23:49:17 -07001270 reply->writeInt32(status);
1271 if (status == NO_ERROR) {
1272 reply->write(&desc, sizeof(effect_descriptor_t));
1273 }
1274 return NO_ERROR;
1275 }
1276 case GET_EFFECT_DESCRIPTOR: {
1277 CHECK_INTERFACE(IAudioFlinger, data, reply);
1278 effect_uuid_t uuid;
1279 data.read(&uuid, sizeof(effect_uuid_t));
Wei Jia983dca32015-09-10 09:47:29 -07001280 effect_descriptor_t desc = {};
Eric Laurentbe916aa2010-06-01 23:49:17 -07001281 status_t status = getEffectDescriptor(&uuid, &desc);
1282 reply->writeInt32(status);
1283 if (status == NO_ERROR) {
1284 reply->write(&desc, sizeof(effect_descriptor_t));
1285 }
1286 return NO_ERROR;
1287 }
1288 case CREATE_EFFECT: {
1289 CHECK_INTERFACE(IAudioFlinger, data, reply);
Wei Jiae995e472015-09-09 09:48:34 -07001290 effect_descriptor_t desc = {};
1291 if (data.read(&desc, sizeof(effect_descriptor_t)) != NO_ERROR) {
1292 ALOGE("b/23905951");
1293 }
Eric Laurentbe916aa2010-06-01 23:49:17 -07001294 sp<IEffectClient> client = interface_cast<IEffectClient>(data.readStrongBinder());
1295 int32_t priority = data.readInt32();
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001296 audio_io_handle_t output = (audio_io_handle_t) data.readInt32();
Glenn Kastend848eb42016-03-08 13:42:11 -08001297 audio_session_t sessionId = (audio_session_t) data.readInt32();
Svet Ganovbe71aa22015-04-28 12:06:02 -07001298 const String16 opPackageName = data.readString16();
Eric Laurentb6436272016-12-07 19:24:50 -08001299 pid_t pid = (pid_t)data.readInt32();
1300
Wei Jia983dca32015-09-10 09:47:29 -07001301 status_t status = NO_ERROR;
1302 int id = 0;
1303 int enabled = 0;
Eric Laurent05bca2f2010-02-26 02:47:27 -08001304
Glenn Kasten8d6cc842012-02-03 11:06:53 -08001305 sp<IEffect> effect = createEffect(&desc, client, priority, output, sessionId,
Eric Laurentb6436272016-12-07 19:24:50 -08001306 opPackageName, pid, &status, &id, &enabled);
Eric Laurentbe916aa2010-06-01 23:49:17 -07001307 reply->writeInt32(status);
1308 reply->writeInt32(id);
1309 reply->writeInt32(enabled);
Marco Nelissen06b46062014-11-14 07:58:25 -08001310 reply->writeStrongBinder(IInterface::asBinder(effect));
Eric Laurentbe916aa2010-06-01 23:49:17 -07001311 reply->write(&desc, sizeof(effect_descriptor_t));
1312 return NO_ERROR;
1313 } break;
Eric Laurentde070132010-07-13 04:45:46 -07001314 case MOVE_EFFECTS: {
1315 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastend848eb42016-03-08 13:42:11 -08001316 audio_session_t session = (audio_session_t) data.readInt32();
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001317 audio_io_handle_t srcOutput = (audio_io_handle_t) data.readInt32();
1318 audio_io_handle_t dstOutput = (audio_io_handle_t) data.readInt32();
Eric Laurentde070132010-07-13 04:45:46 -07001319 reply->writeInt32(moveEffects(session, srcOutput, dstOutput));
1320 return NO_ERROR;
1321 } break;
Eric Laurenta4c5a552012-03-29 10:12:40 -07001322 case LOAD_HW_MODULE: {
1323 CHECK_INTERFACE(IAudioFlinger, data, reply);
1324 reply->writeInt32(loadHwModule(data.readCString()));
1325 return NO_ERROR;
1326 } break;
Glenn Kastencc0f1cf2012-09-24 11:27:18 -07001327 case GET_PRIMARY_OUTPUT_SAMPLING_RATE: {
1328 CHECK_INTERFACE(IAudioFlinger, data, reply);
1329 reply->writeInt32(getPrimaryOutputSamplingRate());
1330 return NO_ERROR;
1331 } break;
1332 case GET_PRIMARY_OUTPUT_FRAME_COUNT: {
1333 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastene03dd222014-01-28 11:04:39 -08001334 reply->writeInt64(getPrimaryOutputFrameCount());
Glenn Kastencc0f1cf2012-09-24 11:27:18 -07001335 return NO_ERROR;
1336 } break;
Glenn Kasten4182c4e2013-07-15 14:45:07 -07001337 case SET_LOW_RAM_DEVICE: {
1338 CHECK_INTERFACE(IAudioFlinger, data, reply);
Andy Hung6f248bb2018-01-23 14:04:37 -08001339 int32_t isLowRamDevice;
1340 int64_t totalMemory;
1341 const status_t status =
1342 data.readInt32(&isLowRamDevice) ?:
1343 data.readInt64(&totalMemory) ?:
1344 setLowRamDevice(isLowRamDevice != 0, totalMemory);
1345 (void)reply->writeInt32(status);
Glenn Kasten4182c4e2013-07-15 14:45:07 -07001346 return NO_ERROR;
1347 } break;
Eric Laurent4b123402014-04-11 09:22:20 -07001348 case LIST_AUDIO_PORTS: {
1349 CHECK_INTERFACE(IAudioFlinger, data, reply);
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001350 unsigned int numPortsReq = data.readInt32();
1351 if (numPortsReq > MAX_ITEMS_PER_LIST) {
1352 numPortsReq = MAX_ITEMS_PER_LIST;
1353 }
1354 unsigned int numPorts = numPortsReq;
Eric Laurent4b123402014-04-11 09:22:20 -07001355 struct audio_port *ports =
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001356 (struct audio_port *)calloc(numPortsReq,
Eric Laurent4b123402014-04-11 09:22:20 -07001357 sizeof(struct audio_port));
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001358 if (ports == NULL) {
1359 reply->writeInt32(NO_MEMORY);
1360 reply->writeInt32(0);
1361 return NO_ERROR;
1362 }
1363 status_t status = listAudioPorts(&numPorts, ports);
Eric Laurent4b123402014-04-11 09:22:20 -07001364 reply->writeInt32(status);
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001365 reply->writeInt32(numPorts);
Eric Laurent4b123402014-04-11 09:22:20 -07001366 if (status == NO_ERROR) {
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001367 if (numPortsReq > numPorts) {
1368 numPortsReq = numPorts;
1369 }
1370 reply->write(ports, numPortsReq * sizeof(struct audio_port));
Eric Laurent4b123402014-04-11 09:22:20 -07001371 }
1372 free(ports);
1373 return NO_ERROR;
1374 } break;
1375 case GET_AUDIO_PORT: {
1376 CHECK_INTERFACE(IAudioFlinger, data, reply);
Wei Jiae995e472015-09-09 09:48:34 -07001377 struct audio_port port = {};
1378 if (data.read(&port, sizeof(struct audio_port)) != NO_ERROR) {
1379 ALOGE("b/23905951");
1380 }
Eric Laurent4b123402014-04-11 09:22:20 -07001381 status_t status = getAudioPort(&port);
1382 reply->writeInt32(status);
1383 if (status == NO_ERROR) {
1384 reply->write(&port, sizeof(struct audio_port));
1385 }
1386 return NO_ERROR;
1387 } break;
1388 case CREATE_AUDIO_PATCH: {
1389 CHECK_INTERFACE(IAudioFlinger, data, reply);
1390 struct audio_patch patch;
1391 data.read(&patch, sizeof(struct audio_patch));
Glenn Kastena13cde92016-03-28 15:26:02 -07001392 audio_patch_handle_t handle = AUDIO_PATCH_HANDLE_NONE;
Wei Jiae995e472015-09-09 09:48:34 -07001393 if (data.read(&handle, sizeof(audio_patch_handle_t)) != NO_ERROR) {
1394 ALOGE("b/23905951");
1395 }
Eric Laurent4b123402014-04-11 09:22:20 -07001396 status_t status = createAudioPatch(&patch, &handle);
1397 reply->writeInt32(status);
1398 if (status == NO_ERROR) {
1399 reply->write(&handle, sizeof(audio_patch_handle_t));
1400 }
1401 return NO_ERROR;
1402 } break;
1403 case RELEASE_AUDIO_PATCH: {
1404 CHECK_INTERFACE(IAudioFlinger, data, reply);
1405 audio_patch_handle_t handle;
1406 data.read(&handle, sizeof(audio_patch_handle_t));
1407 status_t status = releaseAudioPatch(handle);
1408 reply->writeInt32(status);
1409 return NO_ERROR;
1410 } break;
1411 case LIST_AUDIO_PATCHES: {
1412 CHECK_INTERFACE(IAudioFlinger, data, reply);
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001413 unsigned int numPatchesReq = data.readInt32();
1414 if (numPatchesReq > MAX_ITEMS_PER_LIST) {
1415 numPatchesReq = MAX_ITEMS_PER_LIST;
1416 }
1417 unsigned int numPatches = numPatchesReq;
Eric Laurent4b123402014-04-11 09:22:20 -07001418 struct audio_patch *patches =
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001419 (struct audio_patch *)calloc(numPatchesReq,
Eric Laurent4b123402014-04-11 09:22:20 -07001420 sizeof(struct audio_patch));
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001421 if (patches == NULL) {
1422 reply->writeInt32(NO_MEMORY);
1423 reply->writeInt32(0);
1424 return NO_ERROR;
1425 }
1426 status_t status = listAudioPatches(&numPatches, patches);
Eric Laurent4b123402014-04-11 09:22:20 -07001427 reply->writeInt32(status);
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001428 reply->writeInt32(numPatches);
Eric Laurent4b123402014-04-11 09:22:20 -07001429 if (status == NO_ERROR) {
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001430 if (numPatchesReq > numPatches) {
1431 numPatchesReq = numPatches;
1432 }
1433 reply->write(patches, numPatchesReq * sizeof(struct audio_patch));
Eric Laurent4b123402014-04-11 09:22:20 -07001434 }
1435 free(patches);
1436 return NO_ERROR;
1437 } break;
1438 case SET_AUDIO_PORT_CONFIG: {
1439 CHECK_INTERFACE(IAudioFlinger, data, reply);
1440 struct audio_port_config config;
1441 data.read(&config, sizeof(struct audio_port_config));
1442 status_t status = setAudioPortConfig(&config);
1443 reply->writeInt32(status);
1444 return NO_ERROR;
1445 } break;
Glenn Kasten9eae0362016-04-19 09:09:14 -07001446 case GET_AUDIO_HW_SYNC_FOR_SESSION: {
Eric Laurent93c3d412014-08-01 14:48:35 -07001447 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastend848eb42016-03-08 13:42:11 -08001448 reply->writeInt32(getAudioHwSyncForSession((audio_session_t) data.readInt32()));
Eric Laurent93c3d412014-08-01 14:48:35 -07001449 return NO_ERROR;
1450 } break;
Eric Laurent72e3f392015-05-20 14:43:50 -07001451 case SYSTEM_READY: {
1452 CHECK_INTERFACE(IAudioFlinger, data, reply);
1453 systemReady();
1454 return NO_ERROR;
1455 } break;
Glenn Kasten4a8308b2016-04-18 14:10:01 -07001456 case FRAME_COUNT_HAL: {
1457 CHECK_INTERFACE(IAudioFlinger, data, reply);
1458 reply->writeInt64( frameCountHAL((audio_io_handle_t) data.readInt32()) );
1459 return NO_ERROR;
1460 } break;
jiabin9ff780e2018-03-19 18:19:52 -07001461 case GET_MICROPHONES: {
jiabin46a76fa2018-01-05 10:18:21 -08001462 CHECK_INTERFACE(IAudioFlinger, data, reply);
1463 std::vector<media::MicrophoneInfo> microphones;
1464 status_t status = getMicrophones(&microphones);
1465 reply->writeInt32(status);
1466 if (status == NO_ERROR) {
1467 reply->writeParcelableVector(microphones);
1468 }
1469 return NO_ERROR;
1470 }
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001471 default:
1472 return BBinder::onTransact(code, data, reply, flags);
1473 }
1474}
1475
1476// ----------------------------------------------------------------------------
1477
Glenn Kasten40bc9062015-03-20 09:09:33 -07001478} // namespace android