blob: 57142b0347ea3b4a4b97b635748c6151d1c91885 [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 Laurent4dacbc32020-10-07 13:48:21 -070027#include <media/AudioSanitizer.h>
Eric Laurent14dc3cb2020-09-16 18:42:23 -070028#include <media/IAudioPolicyService.h>
Andy Hung4ef19fa2018-05-15 19:35:29 -070029#include <mediautils/ServiceUtilities.h>
Marco Nelissencf90b492019-09-26 11:20:54 -070030#include <mediautils/TimeCheck.h>
Steven Moreland25a9e552017-04-17 14:30:39 -070031#include "IAudioFlinger.h"
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080032
33namespace android {
34
35enum {
36 CREATE_TRACK = IBinder::FIRST_CALL_TRANSACTION,
Eric Laurentf14db3c2017-12-08 14:20:36 -080037 CREATE_RECORD,
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080038 SAMPLE_RATE,
Glenn Kasten5876f2f2012-11-30 10:52:16 -080039 RESERVED, // obsolete, was CHANNEL_COUNT
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080040 FORMAT,
41 FRAME_COUNT,
42 LATENCY,
43 SET_MASTER_VOLUME,
44 SET_MASTER_MUTE,
45 MASTER_VOLUME,
46 MASTER_MUTE,
47 SET_STREAM_VOLUME,
48 SET_STREAM_MUTE,
49 STREAM_VOLUME,
50 STREAM_MUTE,
51 SET_MODE,
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080052 SET_MIC_MUTE,
53 GET_MIC_MUTE,
Svet Ganovf4ddfef2018-01-16 07:37:58 -080054 SET_RECORD_SILENCED,
Eric Laurentc2f1f072009-07-17 12:17:14 -070055 SET_PARAMETERS,
56 GET_PARAMETERS,
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080057 REGISTER_CLIENT,
58 GET_INPUTBUFFERSIZE,
Eric Laurentc2f1f072009-07-17 12:17:14 -070059 OPEN_OUTPUT,
60 OPEN_DUPLICATE_OUTPUT,
61 CLOSE_OUTPUT,
62 SUSPEND_OUTPUT,
63 RESTORE_OUTPUT,
64 OPEN_INPUT,
65 CLOSE_INPUT,
Glenn Kastend2304db2014-02-03 07:40:31 -080066 INVALIDATE_STREAM,
Eric Laurent342e9cf2010-01-19 17:37:09 -080067 SET_VOICE_VOLUME,
Eric Laurent05bca2f2010-02-26 02:47:27 -080068 GET_RENDER_POSITION,
Eric Laurentbe916aa2010-06-01 23:49:17 -070069 GET_INPUT_FRAMES_LOST,
Glenn Kasten9eae0362016-04-19 09:09:14 -070070 NEW_AUDIO_UNIQUE_ID,
Marco Nelissen3a34bef2011-08-02 13:33:41 -070071 ACQUIRE_AUDIO_SESSION_ID,
72 RELEASE_AUDIO_SESSION_ID,
Eric Laurentbe916aa2010-06-01 23:49:17 -070073 QUERY_NUM_EFFECTS,
Eric Laurentffe9c252010-06-23 17:38:20 -070074 QUERY_EFFECT,
Eric Laurentbe916aa2010-06-01 23:49:17 -070075 GET_EFFECT_DESCRIPTOR,
Eric Laurentde070132010-07-13 04:45:46 -070076 CREATE_EFFECT,
Eric Laurenta4c5a552012-03-29 10:12:40 -070077 MOVE_EFFECTS,
Glenn Kastencc0f1cf2012-09-24 11:27:18 -070078 LOAD_HW_MODULE,
79 GET_PRIMARY_OUTPUT_SAMPLING_RATE,
80 GET_PRIMARY_OUTPUT_FRAME_COUNT,
Glenn Kasten4182c4e2013-07-15 14:45:07 -070081 SET_LOW_RAM_DEVICE,
Eric Laurent4b123402014-04-11 09:22:20 -070082 LIST_AUDIO_PORTS,
83 GET_AUDIO_PORT,
84 CREATE_AUDIO_PATCH,
85 RELEASE_AUDIO_PATCH,
86 LIST_AUDIO_PATCHES,
Eric Laurent93c3d412014-08-01 14:48:35 -070087 SET_AUDIO_PORT_CONFIG,
Glenn Kasten9eae0362016-04-19 09:09:14 -070088 GET_AUDIO_HW_SYNC_FOR_SESSION,
Glenn Kasten4a8308b2016-04-18 14:10:01 -070089 SYSTEM_READY,
90 FRAME_COUNT_HAL,
jiabin9ff780e2018-03-19 18:19:52 -070091 GET_MICROPHONES,
Richard Folke Tullberg3fae0372017-01-13 09:04:25 +010092 SET_MASTER_BALANCE,
93 GET_MASTER_BALANCE,
Eric Laurentb20cf7d2019-04-05 19:37:34 -070094 SET_EFFECT_SUSPENDED,
Eric Laurent42896a02019-09-27 15:40:33 -070095 SET_AUDIO_HAL_PIDS
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080096};
97
Eric Laurentf75c2fe2015-04-02 13:49:15 -070098#define MAX_ITEMS_PER_LIST 1024
99
Ytai Ben-Tsvi4dfeb622020-11-02 12:47:30 -0800100ConversionResult<media::CreateTrackRequest> IAudioFlinger::CreateTrackInput::toAidl() const {
101 media::CreateTrackRequest aidl;
102 aidl.attr = VALUE_OR_RETURN(legacy2aidl_audio_attributes_t_AudioAttributesInternal(attr));
103 aidl.config = VALUE_OR_RETURN(legacy2aidl_audio_config_t_AudioConfig(config));
104 aidl.clientInfo = VALUE_OR_RETURN(legacy2aidl_AudioClient(clientInfo));
105 aidl.sharedBuffer = VALUE_OR_RETURN(legacy2aidl_NullableIMemory_SharedFileRegion(sharedBuffer));
106 aidl.notificationsPerBuffer = VALUE_OR_RETURN(convertIntegral<int32_t>(notificationsPerBuffer));
107 aidl.speed = speed;
108 aidl.audioTrackCallback = audioTrackCallback;
109 aidl.opPackageName = opPackageName;
110 aidl.flags = VALUE_OR_RETURN(legacy2aidl_audio_output_flags_mask(flags));
111 aidl.frameCount = VALUE_OR_RETURN(convertIntegral<int64_t>(frameCount));
112 aidl.notificationFrameCount = VALUE_OR_RETURN(convertIntegral<int64_t>(notificationFrameCount));
113 aidl.selectedDeviceId = VALUE_OR_RETURN(
114 legacy2aidl_audio_port_handle_t_int32_t(selectedDeviceId));
115 aidl.sessionId = VALUE_OR_RETURN(legacy2aidl_audio_session_t_int32_t(sessionId));
116 return aidl;
117}
118
119ConversionResult<IAudioFlinger::CreateTrackInput>
120IAudioFlinger::CreateTrackInput::fromAidl(const media::CreateTrackRequest& aidl) {
121 IAudioFlinger::CreateTrackInput legacy;
122 legacy.attr = VALUE_OR_RETURN(aidl2legacy_AudioAttributesInternal_audio_attributes_t(aidl.attr));
123 legacy.config = VALUE_OR_RETURN(aidl2legacy_AudioConfig_audio_config_t(aidl.config));
124 legacy.clientInfo = VALUE_OR_RETURN(aidl2legacy_AudioClient(aidl.clientInfo));
125 legacy.sharedBuffer = VALUE_OR_RETURN(aidl2legacy_NullableSharedFileRegion_IMemory(aidl.sharedBuffer));
126 legacy.notificationsPerBuffer = VALUE_OR_RETURN(
127 convertIntegral<uint32_t>(aidl.notificationsPerBuffer));
128 legacy.speed = aidl.speed;
129 legacy.audioTrackCallback = aidl.audioTrackCallback;
130 legacy.opPackageName = aidl.opPackageName;
131 legacy.flags = VALUE_OR_RETURN(aidl2legacy_audio_output_flags_mask(aidl.flags));
132 legacy.frameCount = VALUE_OR_RETURN(convertIntegral<size_t>(aidl.frameCount));
133 legacy.notificationFrameCount = VALUE_OR_RETURN(
134 convertIntegral<size_t>(aidl.notificationFrameCount));
135 legacy.selectedDeviceId = VALUE_OR_RETURN(
136 aidl2legacy_int32_t_audio_port_handle_t(aidl.selectedDeviceId));
137 legacy.sessionId = VALUE_OR_RETURN(aidl2legacy_int32_t_audio_session_t(aidl.sessionId));
138 return legacy;
139}
140
141ConversionResult<media::CreateTrackResponse>
142IAudioFlinger::CreateTrackOutput::toAidl() const {
143 media::CreateTrackResponse aidl;
144 aidl.flags = VALUE_OR_RETURN(legacy2aidl_audio_output_flags_mask(flags));
145 aidl.frameCount = VALUE_OR_RETURN(convertIntegral<int64_t>(frameCount));
146 aidl.notificationFrameCount = VALUE_OR_RETURN(convertIntegral<int64_t>(notificationFrameCount));
147 aidl.selectedDeviceId = VALUE_OR_RETURN(
148 legacy2aidl_audio_port_handle_t_int32_t(selectedDeviceId));
149 aidl.sessionId = VALUE_OR_RETURN(legacy2aidl_audio_session_t_int32_t(sessionId));
150 aidl.sampleRate = VALUE_OR_RETURN(convertIntegral<int32_t>(sampleRate));
151 aidl.afFrameCount = VALUE_OR_RETURN(convertIntegral<int64_t>(afFrameCount));
152 aidl.afSampleRate = VALUE_OR_RETURN(convertIntegral<int32_t>(afSampleRate));
153 aidl.afLatencyMs = VALUE_OR_RETURN(convertIntegral<int32_t>(afLatencyMs));
154 aidl.outputId = VALUE_OR_RETURN(legacy2aidl_audio_io_handle_t_int32_t(outputId));
155 aidl.portId = VALUE_OR_RETURN(legacy2aidl_audio_port_handle_t_int32_t(portId));
156 return aidl;
157}
158
159ConversionResult<IAudioFlinger::CreateTrackOutput>
160IAudioFlinger::CreateTrackOutput::fromAidl(
161 const media::CreateTrackResponse& aidl) {
162 IAudioFlinger::CreateTrackOutput legacy;
163 legacy.flags = VALUE_OR_RETURN(aidl2legacy_audio_output_flags_mask(aidl.flags));
164 legacy.frameCount = VALUE_OR_RETURN(convertIntegral<size_t>(aidl.frameCount));
165 legacy.notificationFrameCount = VALUE_OR_RETURN(
166 convertIntegral<size_t>(aidl.notificationFrameCount));
167 legacy.selectedDeviceId = VALUE_OR_RETURN(
168 aidl2legacy_int32_t_audio_port_handle_t(aidl.selectedDeviceId));
169 legacy.sessionId = VALUE_OR_RETURN(aidl2legacy_int32_t_audio_session_t(aidl.sessionId));
170 legacy.sampleRate = VALUE_OR_RETURN(convertIntegral<uint32_t>(aidl.sampleRate));
171 legacy.afFrameCount = VALUE_OR_RETURN(convertIntegral<size_t>(aidl.afFrameCount));
172 legacy.afSampleRate = VALUE_OR_RETURN(convertIntegral<uint32_t>(aidl.afSampleRate));
173 legacy.afLatencyMs = VALUE_OR_RETURN(convertIntegral<uint32_t>(aidl.afLatencyMs));
174 legacy.outputId = VALUE_OR_RETURN(aidl2legacy_int32_t_audio_io_handle_t(aidl.outputId));
175 legacy.portId = VALUE_OR_RETURN(aidl2legacy_int32_t_audio_port_handle_t(aidl.portId));
176 return legacy;
177}
178
179ConversionResult<media::CreateRecordRequest>
180IAudioFlinger::CreateRecordInput::toAidl() const {
181 media::CreateRecordRequest aidl;
182 aidl.attr = VALUE_OR_RETURN(legacy2aidl_audio_attributes_t_AudioAttributesInternal(attr));
183 aidl.config = VALUE_OR_RETURN(legacy2aidl_audio_config_base_t_AudioConfigBase(config));
184 aidl.clientInfo = VALUE_OR_RETURN(legacy2aidl_AudioClient(clientInfo));
185 aidl.opPackageName = VALUE_OR_RETURN(legacy2aidl_String16_string(opPackageName));
186 aidl.riid = VALUE_OR_RETURN(legacy2aidl_audio_unique_id_t_int32_t(riid));
187 aidl.flags = VALUE_OR_RETURN(legacy2aidl_audio_input_flags_mask(flags));
188 aidl.frameCount = VALUE_OR_RETURN(convertIntegral<int64_t>(frameCount));
189 aidl.notificationFrameCount = VALUE_OR_RETURN(convertIntegral<int64_t>(notificationFrameCount));
190 aidl.selectedDeviceId = VALUE_OR_RETURN(
191 legacy2aidl_audio_port_handle_t_int32_t(selectedDeviceId));
192 aidl.sessionId = VALUE_OR_RETURN(legacy2aidl_audio_session_t_int32_t(sessionId));
193 return aidl;
194}
195
196ConversionResult<IAudioFlinger::CreateRecordInput>
197IAudioFlinger::CreateRecordInput::fromAidl(
198 const media::CreateRecordRequest& aidl) {
199 IAudioFlinger::CreateRecordInput legacy;
200 legacy.attr = VALUE_OR_RETURN(aidl2legacy_AudioAttributesInternal_audio_attributes_t(aidl.attr));
201 legacy.config = VALUE_OR_RETURN(aidl2legacy_AudioConfigBase_audio_config_base_t(aidl.config));
202 legacy.clientInfo = VALUE_OR_RETURN(aidl2legacy_AudioClient(aidl.clientInfo));
203 legacy.opPackageName = VALUE_OR_RETURN(aidl2legacy_string_view_String16(aidl.opPackageName));
204 legacy.riid = VALUE_OR_RETURN(aidl2legacy_int32_t_audio_unique_id_t(aidl.riid));
205 legacy.flags = VALUE_OR_RETURN(aidl2legacy_audio_input_flags_mask(aidl.flags));
206 legacy.frameCount = VALUE_OR_RETURN(convertIntegral<size_t>(aidl.frameCount));
207 legacy.notificationFrameCount = VALUE_OR_RETURN(
208 convertIntegral<size_t>(aidl.notificationFrameCount));
209 legacy.selectedDeviceId = VALUE_OR_RETURN(
210 aidl2legacy_int32_t_audio_port_handle_t(aidl.selectedDeviceId));
211 legacy.sessionId = VALUE_OR_RETURN(aidl2legacy_int32_t_audio_session_t(aidl.sessionId));
212 return legacy;
213}
214
215ConversionResult<media::CreateRecordResponse>
216IAudioFlinger::CreateRecordOutput::toAidl() const {
217 media::CreateRecordResponse aidl;
218 aidl.flags = VALUE_OR_RETURN(legacy2aidl_audio_input_flags_mask(flags));
219 aidl.frameCount = VALUE_OR_RETURN(convertIntegral<int64_t>(frameCount));
220 aidl.notificationFrameCount = VALUE_OR_RETURN(convertIntegral<int64_t>(notificationFrameCount));
221 aidl.selectedDeviceId = VALUE_OR_RETURN(
222 legacy2aidl_audio_port_handle_t_int32_t(selectedDeviceId));
223 aidl.sessionId = VALUE_OR_RETURN(legacy2aidl_audio_session_t_int32_t(sessionId));
224 aidl.sampleRate = VALUE_OR_RETURN(convertIntegral<int32_t>(sampleRate));
225 aidl.inputId = VALUE_OR_RETURN(legacy2aidl_audio_io_handle_t_int32_t(inputId));
226 aidl.cblk = VALUE_OR_RETURN(legacy2aidl_NullableIMemory_SharedFileRegion(cblk));
227 aidl.buffers = VALUE_OR_RETURN(legacy2aidl_NullableIMemory_SharedFileRegion(buffers));
228 aidl.portId = VALUE_OR_RETURN(legacy2aidl_audio_port_handle_t_int32_t(portId));
229 return aidl;
230}
231
232ConversionResult<IAudioFlinger::CreateRecordOutput>
233IAudioFlinger::CreateRecordOutput::fromAidl(
234 const media::CreateRecordResponse& aidl) {
235 IAudioFlinger::CreateRecordOutput legacy;
236 legacy.flags = VALUE_OR_RETURN(aidl2legacy_audio_input_flags_mask(aidl.flags));
237 legacy.frameCount = VALUE_OR_RETURN(convertIntegral<size_t>(aidl.frameCount));
238 legacy.notificationFrameCount = VALUE_OR_RETURN(
239 convertIntegral<size_t>(aidl.notificationFrameCount));
240 legacy.selectedDeviceId = VALUE_OR_RETURN(
241 aidl2legacy_int32_t_audio_port_handle_t(aidl.selectedDeviceId));
242 legacy.sessionId = VALUE_OR_RETURN(aidl2legacy_int32_t_audio_session_t(aidl.sessionId));
243 legacy.sampleRate = VALUE_OR_RETURN(convertIntegral<uint32_t>(aidl.sampleRate));
244 legacy.inputId = VALUE_OR_RETURN(aidl2legacy_int32_t_audio_io_handle_t(aidl.inputId));
245 legacy.cblk = VALUE_OR_RETURN(aidl2legacy_NullableSharedFileRegion_IMemory(aidl.cblk));
246 legacy.buffers = VALUE_OR_RETURN(aidl2legacy_NullableSharedFileRegion_IMemory(aidl.buffers));
247 legacy.portId = VALUE_OR_RETURN(aidl2legacy_int32_t_audio_port_handle_t(aidl.portId));
248 return legacy;
249}
Eric Laurent42896a02019-09-27 15:40:33 -0700250
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800251class BpAudioFlinger : public BpInterface<IAudioFlinger>
252{
253public:
Chih-Hung Hsieh090ef602016-04-27 10:39:54 -0700254 explicit BpAudioFlinger(const sp<IBinder>& impl)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800255 : BpInterface<IAudioFlinger>(impl)
256 {
257 }
258
Ytai Ben-Tsvi4dfeb622020-11-02 12:47:30 -0800259 virtual sp<IAudioTrack> createTrack(const media::CreateTrackRequest& input,
260 media::CreateTrackResponse& output,
261 status_t* status)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800262 {
263 Parcel data, reply;
Eric Laurent5841db72009-09-09 05:16:08 -0700264 sp<IAudioTrack> track;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800265 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurent21da6472017-11-09 16:29:26 -0800266
267 if (status == nullptr) {
268 return track;
Eric Laurent3d00aa62013-09-24 09:53:27 -0700269 }
Eric Laurent21da6472017-11-09 16:29:26 -0800270
Ytai Ben-Tsvi4dfeb622020-11-02 12:47:30 -0800271 data.writeParcelable(input);
Eric Laurent21da6472017-11-09 16:29:26 -0800272
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800273 status_t lStatus = remote()->transact(CREATE_TRACK, data, &reply);
274 if (lStatus != NO_ERROR) {
Eric Laurent21da6472017-11-09 16:29:26 -0800275 ALOGE("createTrack transaction error %d", lStatus);
276 *status = DEAD_OBJECT;
277 return track;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800278 }
Eric Laurent21da6472017-11-09 16:29:26 -0800279 *status = reply.readInt32();
280 if (*status != NO_ERROR) {
281 ALOGE("createTrack returned error %d", *status);
282 return track;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800283 }
Eric Laurent21da6472017-11-09 16:29:26 -0800284 track = interface_cast<IAudioTrack>(reply.readStrongBinder());
285 if (track == 0) {
286 ALOGE("createTrack returned an NULL IAudioTrack with status OK");
287 *status = DEAD_OBJECT;
288 return track;
289 }
290 output.readFromParcel(&reply);
Eric Laurent5841db72009-09-09 05:16:08 -0700291 return track;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800292 }
293
Ytai Ben-Tsvi4dfeb622020-11-02 12:47:30 -0800294 virtual sp<media::IAudioRecord> createRecord(const media::CreateRecordRequest& input,
295 media::CreateRecordResponse& output,
296 status_t* status)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800297 {
298 Parcel data, reply;
Ivan Lozanoff6900d2017-08-01 15:47:38 -0700299 sp<media::IAudioRecord> record;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800300 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurentf14db3c2017-12-08 14:20:36 -0800301
302 if (status == nullptr) {
303 return record;
Eric Laurentbe916aa2010-06-01 23:49:17 -0700304 }
Eric Laurentf14db3c2017-12-08 14:20:36 -0800305
Ytai Ben-Tsvi4dfeb622020-11-02 12:47:30 -0800306 data.writeParcelable(input);
Eric Laurentf14db3c2017-12-08 14:20:36 -0800307
308 status_t lStatus = remote()->transact(CREATE_RECORD, data, &reply);
Eric Laurent5841db72009-09-09 05:16:08 -0700309 if (lStatus != NO_ERROR) {
Eric Laurentf14db3c2017-12-08 14:20:36 -0800310 ALOGE("createRecord transaction error %d", lStatus);
311 *status = DEAD_OBJECT;
312 return record;
Eric Laurent5841db72009-09-09 05:16:08 -0700313 }
Eric Laurentf14db3c2017-12-08 14:20:36 -0800314 *status = reply.readInt32();
315 if (*status != NO_ERROR) {
316 ALOGE("createRecord returned error %d", *status);
317 return record;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800318 }
Eric Laurentf14db3c2017-12-08 14:20:36 -0800319
320 record = interface_cast<media::IAudioRecord>(reply.readStrongBinder());
321 if (record == 0) {
322 ALOGE("createRecord returned a NULL IAudioRecord with status OK");
323 *status = DEAD_OBJECT;
324 return record;
325 }
326 output.readFromParcel(&reply);
Eric Laurent5841db72009-09-09 05:16:08 -0700327 return record;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800328 }
329
Glenn Kasten2c073da2016-02-26 09:14:08 -0800330 virtual uint32_t sampleRate(audio_io_handle_t ioHandle) const
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800331 {
332 Parcel data, reply;
333 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten2c073da2016-02-26 09:14:08 -0800334 data.writeInt32((int32_t) ioHandle);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800335 remote()->transact(SAMPLE_RATE, data, &reply);
336 return reply.readInt32();
337 }
338
Glenn Kasten4a8308b2016-04-18 14:10:01 -0700339 // RESERVED for channelCount()
340
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800341 virtual audio_format_t format(audio_io_handle_t output) const
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800342 {
343 Parcel data, reply;
344 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800345 data.writeInt32((int32_t) output);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800346 remote()->transact(FORMAT, data, &reply);
Glenn Kasten58f30212012-01-12 12:27:51 -0800347 return (audio_format_t) reply.readInt32();
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800348 }
349
Glenn Kasten2c073da2016-02-26 09:14:08 -0800350 virtual size_t frameCount(audio_io_handle_t ioHandle) const
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800351 {
352 Parcel data, reply;
353 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten2c073da2016-02-26 09:14:08 -0800354 data.writeInt32((int32_t) ioHandle);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800355 remote()->transact(FRAME_COUNT, data, &reply);
Glenn Kastene03dd222014-01-28 11:04:39 -0800356 return reply.readInt64();
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800357 }
358
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800359 virtual uint32_t latency(audio_io_handle_t output) const
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800360 {
361 Parcel data, reply;
362 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800363 data.writeInt32((int32_t) output);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800364 remote()->transact(LATENCY, data, &reply);
365 return reply.readInt32();
366 }
367
368 virtual status_t setMasterVolume(float value)
369 {
370 Parcel data, reply;
371 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
372 data.writeFloat(value);
373 remote()->transact(SET_MASTER_VOLUME, data, &reply);
374 return reply.readInt32();
375 }
376
377 virtual status_t setMasterMute(bool muted)
378 {
379 Parcel data, reply;
380 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
381 data.writeInt32(muted);
382 remote()->transact(SET_MASTER_MUTE, data, &reply);
383 return reply.readInt32();
384 }
385
386 virtual float masterVolume() const
387 {
388 Parcel data, reply;
389 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
390 remote()->transact(MASTER_VOLUME, data, &reply);
391 return reply.readFloat();
392 }
393
394 virtual bool masterMute() const
395 {
396 Parcel data, reply;
397 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
398 remote()->transact(MASTER_MUTE, data, &reply);
399 return reply.readInt32();
400 }
401
Richard Folke Tullberg3fae0372017-01-13 09:04:25 +0100402 status_t setMasterBalance(float balance) override
403 {
404 Parcel data, reply;
405 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
406 data.writeFloat(balance);
407 status_t status = remote()->transact(SET_MASTER_BALANCE, data, &reply);
408 if (status != NO_ERROR) {
409 return status;
410 }
411 return reply.readInt32();
412 }
413
414 status_t getMasterBalance(float *balance) const override
415 {
416 Parcel data, reply;
417 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
418 status_t status = remote()->transact(GET_MASTER_BALANCE, data, &reply);
419 if (status != NO_ERROR) {
420 return status;
421 }
422 status = (status_t)reply.readInt32();
423 if (status != NO_ERROR) {
424 return status;
425 }
426 *balance = reply.readFloat();
427 return NO_ERROR;
428 }
429
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800430 virtual status_t setStreamVolume(audio_stream_type_t stream, float value,
431 audio_io_handle_t output)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800432 {
433 Parcel data, reply;
434 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kastenfff6d712012-01-12 16:38:12 -0800435 data.writeInt32((int32_t) stream);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800436 data.writeFloat(value);
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800437 data.writeInt32((int32_t) output);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800438 remote()->transact(SET_STREAM_VOLUME, data, &reply);
439 return reply.readInt32();
440 }
441
Glenn Kastenfff6d712012-01-12 16:38:12 -0800442 virtual status_t setStreamMute(audio_stream_type_t stream, bool muted)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800443 {
444 Parcel data, reply;
445 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kastenfff6d712012-01-12 16:38:12 -0800446 data.writeInt32((int32_t) stream);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800447 data.writeInt32(muted);
448 remote()->transact(SET_STREAM_MUTE, data, &reply);
449 return reply.readInt32();
450 }
451
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800452 virtual float streamVolume(audio_stream_type_t stream, audio_io_handle_t output) const
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800453 {
454 Parcel data, reply;
455 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kastenfff6d712012-01-12 16:38:12 -0800456 data.writeInt32((int32_t) stream);
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800457 data.writeInt32((int32_t) output);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800458 remote()->transact(STREAM_VOLUME, data, &reply);
459 return reply.readFloat();
460 }
461
Glenn Kastenfff6d712012-01-12 16:38:12 -0800462 virtual bool streamMute(audio_stream_type_t stream) const
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800463 {
464 Parcel data, reply;
465 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kastenfff6d712012-01-12 16:38:12 -0800466 data.writeInt32((int32_t) stream);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800467 remote()->transact(STREAM_MUTE, data, &reply);
468 return reply.readInt32();
469 }
470
Glenn Kastenf78aee72012-01-04 11:00:47 -0800471 virtual status_t setMode(audio_mode_t mode)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800472 {
473 Parcel data, reply;
474 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
475 data.writeInt32(mode);
476 remote()->transact(SET_MODE, data, &reply);
477 return reply.readInt32();
478 }
479
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800480 virtual status_t setMicMute(bool state)
481 {
482 Parcel data, reply;
483 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
484 data.writeInt32(state);
485 remote()->transact(SET_MIC_MUTE, data, &reply);
486 return reply.readInt32();
487 }
488
489 virtual bool getMicMute() const
490 {
491 Parcel data, reply;
492 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
493 remote()->transact(GET_MIC_MUTE, data, &reply);
494 return reply.readInt32();
495 }
496
Eric Laurent5ada82e2019-08-29 17:53:54 -0700497 virtual void setRecordSilenced(audio_port_handle_t portId, bool silenced)
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800498 {
499 Parcel data, reply;
500 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurent5ada82e2019-08-29 17:53:54 -0700501 data.writeInt32(portId);
Svet Ganovf4ddfef2018-01-16 07:37:58 -0800502 data.writeInt32(silenced ? 1 : 0);
503 remote()->transact(SET_RECORD_SILENCED, data, &reply);
504 }
505
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800506 virtual status_t setParameters(audio_io_handle_t ioHandle, const String8& keyValuePairs)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800507 {
508 Parcel data, reply;
509 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800510 data.writeInt32((int32_t) ioHandle);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700511 data.writeString8(keyValuePairs);
512 remote()->transact(SET_PARAMETERS, data, &reply);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800513 return reply.readInt32();
514 }
Eric Laurentc2f1f072009-07-17 12:17:14 -0700515
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800516 virtual String8 getParameters(audio_io_handle_t ioHandle, const String8& keys) const
Eric Laurentc2f1f072009-07-17 12:17:14 -0700517 {
518 Parcel data, reply;
519 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800520 data.writeInt32((int32_t) ioHandle);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700521 data.writeString8(keys);
522 remote()->transact(GET_PARAMETERS, data, &reply);
523 return reply.readString8();
524 }
525
Ytai Ben-Tsvi10dc0a62020-09-18 11:31:55 -0700526 virtual void registerClient(const sp<media::IAudioFlingerClient>& client)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800527 {
528 Parcel data, reply;
529 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Marco Nelissen06b46062014-11-14 07:58:25 -0800530 data.writeStrongBinder(IInterface::asBinder(client));
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800531 remote()->transact(REGISTER_CLIENT, data, &reply);
532 }
Eric Laurentc2f1f072009-07-17 12:17:14 -0700533
Glenn Kastendd8104c2012-07-02 12:42:44 -0700534 virtual size_t getInputBufferSize(uint32_t sampleRate, audio_format_t format,
535 audio_channel_mask_t channelMask) const
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800536 {
537 Parcel data, reply;
538 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
539 data.writeInt32(sampleRate);
540 data.writeInt32(format);
Glenn Kastendd8104c2012-07-02 12:42:44 -0700541 data.writeInt32(channelMask);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800542 remote()->transact(GET_INPUTBUFFERSIZE, data, &reply);
Glenn Kastene03dd222014-01-28 11:04:39 -0800543 return reply.readInt64();
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800544 }
Eric Laurentc2f1f072009-07-17 12:17:14 -0700545
Eric Laurentcf2c0212014-07-25 16:20:43 -0700546 virtual status_t openOutput(audio_module_handle_t module,
547 audio_io_handle_t *output,
548 audio_config_t *config,
jiabin43810402019-10-24 14:58:31 -0700549 const sp<DeviceDescriptorBase>& device,
Eric Laurentcf2c0212014-07-25 16:20:43 -0700550 uint32_t *latencyMs,
551 audio_output_flags_t flags)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800552 {
jiabin43810402019-10-24 14:58:31 -0700553 if (output == nullptr || config == nullptr || device == nullptr || latencyMs == nullptr) {
Eric Laurentcf2c0212014-07-25 16:20:43 -0700554 return BAD_VALUE;
555 }
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800556 Parcel data, reply;
557 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurenta4c5a552012-03-29 10:12:40 -0700558 data.writeInt32(module);
Eric Laurentcf2c0212014-07-25 16:20:43 -0700559 data.write(config, sizeof(audio_config_t));
jiabin43810402019-10-24 14:58:31 -0700560 data.writeParcelable(*device);
Glenn Kasten18868c52012-03-07 09:15:37 -0800561 data.writeInt32((int32_t) flags);
Eric Laurentcf2c0212014-07-25 16:20:43 -0700562 status_t status = remote()->transact(OPEN_OUTPUT, data, &reply);
563 if (status != NO_ERROR) {
564 *output = AUDIO_IO_HANDLE_NONE;
565 return status;
Richard Fitzgeraldb1a270d2013-05-14 12:12:21 +0100566 }
Eric Laurentcf2c0212014-07-25 16:20:43 -0700567 status = (status_t)reply.readInt32();
568 if (status != NO_ERROR) {
569 *output = AUDIO_IO_HANDLE_NONE;
570 return status;
Glenn Kasten507b2862013-07-31 16:12:13 -0700571 }
Eric Laurentcf2c0212014-07-25 16:20:43 -0700572 *output = (audio_io_handle_t)reply.readInt32();
573 ALOGV("openOutput() returned output, %d", *output);
574 reply.read(config, sizeof(audio_config_t));
Eric Laurentcf2c0212014-07-25 16:20:43 -0700575 *latencyMs = reply.readInt32();
576 return NO_ERROR;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800577 }
578
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800579 virtual audio_io_handle_t openDuplicateOutput(audio_io_handle_t output1,
580 audio_io_handle_t output2)
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800581 {
582 Parcel data, reply;
583 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800584 data.writeInt32((int32_t) output1);
585 data.writeInt32((int32_t) output2);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700586 remote()->transact(OPEN_DUPLICATE_OUTPUT, data, &reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800587 return (audio_io_handle_t) reply.readInt32();
Eric Laurentc2f1f072009-07-17 12:17:14 -0700588 }
589
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800590 virtual status_t closeOutput(audio_io_handle_t output)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700591 {
592 Parcel data, reply;
593 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800594 data.writeInt32((int32_t) output);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700595 remote()->transact(CLOSE_OUTPUT, data, &reply);
596 return reply.readInt32();
597 }
598
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800599 virtual status_t suspendOutput(audio_io_handle_t output)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700600 {
601 Parcel data, reply;
602 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800603 data.writeInt32((int32_t) output);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700604 remote()->transact(SUSPEND_OUTPUT, data, &reply);
605 return reply.readInt32();
606 }
607
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800608 virtual status_t restoreOutput(audio_io_handle_t output)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700609 {
610 Parcel data, reply;
611 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800612 data.writeInt32((int32_t) output);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700613 remote()->transact(RESTORE_OUTPUT, data, &reply);
614 return reply.readInt32();
615 }
616
Eric Laurentcf2c0212014-07-25 16:20:43 -0700617 virtual status_t openInput(audio_module_handle_t module,
618 audio_io_handle_t *input,
619 audio_config_t *config,
620 audio_devices_t *device,
621 const String8& address,
622 audio_source_t source,
623 audio_input_flags_t flags)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700624 {
Eric Laurentcf2c0212014-07-25 16:20:43 -0700625 if (input == NULL || config == NULL || device == NULL) {
626 return BAD_VALUE;
627 }
Eric Laurentc2f1f072009-07-17 12:17:14 -0700628 Parcel data, reply;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700629 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurenta4c5a552012-03-29 10:12:40 -0700630 data.writeInt32(module);
Eric Laurentcf2c0212014-07-25 16:20:43 -0700631 data.writeInt32(*input);
632 data.write(config, sizeof(audio_config_t));
633 data.writeInt32(*device);
634 data.writeString8(address);
635 data.writeInt32(source);
Glenn Kastenec40d282014-07-15 15:31:26 -0700636 data.writeInt32(flags);
Eric Laurentcf2c0212014-07-25 16:20:43 -0700637 status_t status = remote()->transact(OPEN_INPUT, data, &reply);
638 if (status != NO_ERROR) {
639 *input = AUDIO_IO_HANDLE_NONE;
640 return status;
Glenn Kasten507b2862013-07-31 16:12:13 -0700641 }
Eric Laurentcf2c0212014-07-25 16:20:43 -0700642 status = (status_t)reply.readInt32();
643 if (status != NO_ERROR) {
644 *input = AUDIO_IO_HANDLE_NONE;
645 return status;
Glenn Kasten507b2862013-07-31 16:12:13 -0700646 }
Eric Laurentcf2c0212014-07-25 16:20:43 -0700647 *input = (audio_io_handle_t)reply.readInt32();
648 reply.read(config, sizeof(audio_config_t));
649 *device = (audio_devices_t)reply.readInt32();
650 return NO_ERROR;
Eric Laurentc2f1f072009-07-17 12:17:14 -0700651 }
652
Eric Laurentfa2877b2009-07-28 08:44:33 -0700653 virtual status_t closeInput(int input)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700654 {
655 Parcel data, reply;
656 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurentfa2877b2009-07-28 08:44:33 -0700657 data.writeInt32(input);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700658 remote()->transact(CLOSE_INPUT, data, &reply);
659 return reply.readInt32();
660 }
661
Glenn Kastend2304db2014-02-03 07:40:31 -0800662 virtual status_t invalidateStream(audio_stream_type_t stream)
Eric Laurentc2f1f072009-07-17 12:17:14 -0700663 {
664 Parcel data, reply;
665 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kastenfff6d712012-01-12 16:38:12 -0800666 data.writeInt32((int32_t) stream);
Glenn Kastend2304db2014-02-03 07:40:31 -0800667 remote()->transact(INVALIDATE_STREAM, data, &reply);
Eric Laurentc2f1f072009-07-17 12:17:14 -0700668 return reply.readInt32();
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -0800669 }
Eric Laurentf0ee6f42009-10-21 08:14:22 -0700670
671 virtual status_t setVoiceVolume(float volume)
672 {
673 Parcel data, reply;
674 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
675 data.writeFloat(volume);
676 remote()->transact(SET_VOICE_VOLUME, data, &reply);
677 return reply.readInt32();
678 }
Eric Laurent342e9cf2010-01-19 17:37:09 -0800679
Kévin PETIT377b2ec2014-02-03 12:35:36 +0000680 virtual status_t getRenderPosition(uint32_t *halFrames, uint32_t *dspFrames,
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800681 audio_io_handle_t output) const
Eric Laurent342e9cf2010-01-19 17:37:09 -0800682 {
683 Parcel data, reply;
684 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800685 data.writeInt32((int32_t) output);
Eric Laurent342e9cf2010-01-19 17:37:09 -0800686 remote()->transact(GET_RENDER_POSITION, data, &reply);
687 status_t status = reply.readInt32();
688 if (status == NO_ERROR) {
689 uint32_t tmp = reply.readInt32();
Glenn Kasten507b2862013-07-31 16:12:13 -0700690 if (halFrames != NULL) {
Eric Laurent342e9cf2010-01-19 17:37:09 -0800691 *halFrames = tmp;
692 }
693 tmp = reply.readInt32();
Glenn Kasten507b2862013-07-31 16:12:13 -0700694 if (dspFrames != NULL) {
Eric Laurent342e9cf2010-01-19 17:37:09 -0800695 *dspFrames = tmp;
696 }
697 }
698 return status;
699 }
Eric Laurent05bca2f2010-02-26 02:47:27 -0800700
Glenn Kasten5f972c02014-01-13 09:59:31 -0800701 virtual uint32_t getInputFramesLost(audio_io_handle_t ioHandle) const
Eric Laurent05bca2f2010-02-26 02:47:27 -0800702 {
703 Parcel data, reply;
704 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800705 data.writeInt32((int32_t) ioHandle);
Glenn Kasten5f972c02014-01-13 09:59:31 -0800706 status_t status = remote()->transact(GET_INPUT_FRAMES_LOST, data, &reply);
707 if (status != NO_ERROR) {
708 return 0;
709 }
710 return (uint32_t) reply.readInt32();
Eric Laurent05bca2f2010-02-26 02:47:27 -0800711 }
Eric Laurentbe916aa2010-06-01 23:49:17 -0700712
Glenn Kasteneeecb982016-02-26 10:44:04 -0800713 virtual audio_unique_id_t newAudioUniqueId(audio_unique_id_use_t use)
Eric Laurentbe916aa2010-06-01 23:49:17 -0700714 {
715 Parcel data, reply;
716 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Glenn Kasteneeecb982016-02-26 10:44:04 -0800717 data.writeInt32((int32_t) use);
Glenn Kasten9eae0362016-04-19 09:09:14 -0700718 status_t status = remote()->transact(NEW_AUDIO_UNIQUE_ID, data, &reply);
719 audio_unique_id_t id = AUDIO_UNIQUE_ID_ALLOCATE;
Eric Laurentbe916aa2010-06-01 23:49:17 -0700720 if (status == NO_ERROR) {
721 id = reply.readInt32();
722 }
723 return id;
724 }
725
Andy Hung8b0bfd92019-12-23 13:11:11 -0800726 void acquireAudioSessionId(audio_session_t audioSession, pid_t pid, uid_t uid) override
Marco Nelissen3a34bef2011-08-02 13:33:41 -0700727 {
728 Parcel data, reply;
729 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
730 data.writeInt32(audioSession);
Andy Hung8b0bfd92019-12-23 13:11:11 -0800731 data.writeInt32((int32_t)pid);
732 data.writeInt32((int32_t)uid);
Marco Nelissen3a34bef2011-08-02 13:33:41 -0700733 remote()->transact(ACQUIRE_AUDIO_SESSION_ID, data, &reply);
734 }
735
Glenn Kastend848eb42016-03-08 13:42:11 -0800736 virtual void releaseAudioSessionId(audio_session_t audioSession, int pid)
Marco Nelissen3a34bef2011-08-02 13:33:41 -0700737 {
738 Parcel data, reply;
739 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
740 data.writeInt32(audioSession);
Marco Nelissend457c972014-02-11 08:47:07 -0800741 data.writeInt32(pid);
Marco Nelissen3a34bef2011-08-02 13:33:41 -0700742 remote()->transact(RELEASE_AUDIO_SESSION_ID, data, &reply);
743 }
744
Glenn Kastenf587ba52012-01-26 16:25:10 -0800745 virtual status_t queryNumberEffects(uint32_t *numEffects) const
Eric Laurentbe916aa2010-06-01 23:49:17 -0700746 {
747 Parcel data, reply;
748 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
749 status_t status = remote()->transact(QUERY_NUM_EFFECTS, data, &reply);
750 if (status != NO_ERROR) {
751 return status;
752 }
753 status = reply.readInt32();
754 if (status != NO_ERROR) {
755 return status;
756 }
Glenn Kasten9d1f02d2012-02-08 17:47:58 -0800757 if (numEffects != NULL) {
Eric Laurentbe916aa2010-06-01 23:49:17 -0700758 *numEffects = (uint32_t)reply.readInt32();
759 }
760 return NO_ERROR;
761 }
762
Glenn Kastenf587ba52012-01-26 16:25:10 -0800763 virtual status_t queryEffect(uint32_t index, effect_descriptor_t *pDescriptor) const
Eric Laurentbe916aa2010-06-01 23:49:17 -0700764 {
765 if (pDescriptor == NULL) {
766 return BAD_VALUE;
767 }
768 Parcel data, reply;
769 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurentffe9c252010-06-23 17:38:20 -0700770 data.writeInt32(index);
771 status_t status = remote()->transact(QUERY_EFFECT, data, &reply);
Eric Laurentbe916aa2010-06-01 23:49:17 -0700772 if (status != NO_ERROR) {
773 return status;
774 }
775 status = reply.readInt32();
776 if (status != NO_ERROR) {
777 return status;
778 }
779 reply.read(pDescriptor, sizeof(effect_descriptor_t));
780 return NO_ERROR;
781 }
782
Glenn Kasten5e92a782012-01-30 07:40:52 -0800783 virtual status_t getEffectDescriptor(const effect_uuid_t *pUuid,
Ari Hausman-Cohen2046ec72018-04-24 14:00:55 -0700784 const effect_uuid_t *pType,
785 uint32_t preferredTypeFlag,
786 effect_descriptor_t *pDescriptor) const
Eric Laurentbe916aa2010-06-01 23:49:17 -0700787 {
Ari Hausman-Cohen2046ec72018-04-24 14:00:55 -0700788 if (pUuid == NULL || pType == NULL || pDescriptor == NULL) {
Eric Laurentbe916aa2010-06-01 23:49:17 -0700789 return BAD_VALUE;
790 }
791 Parcel data, reply;
792 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
793 data.write(pUuid, sizeof(effect_uuid_t));
Ari Hausman-Cohen2046ec72018-04-24 14:00:55 -0700794 data.write(pType, sizeof(effect_uuid_t));
795 data.writeUint32(preferredTypeFlag);
Eric Laurentbe916aa2010-06-01 23:49:17 -0700796 status_t status = remote()->transact(GET_EFFECT_DESCRIPTOR, data, &reply);
797 if (status != NO_ERROR) {
798 return status;
799 }
800 status = reply.readInt32();
801 if (status != NO_ERROR) {
802 return status;
803 }
804 reply.read(pDescriptor, sizeof(effect_descriptor_t));
805 return NO_ERROR;
806 }
807
Ytai Ben-Tsvi9cd89812020-07-01 17:12:06 -0700808 virtual sp<media::IEffect> createEffect(
Eric Laurentbe916aa2010-06-01 23:49:17 -0700809 effect_descriptor_t *pDesc,
Ytai Ben-Tsvi9cd89812020-07-01 17:12:06 -0700810 const sp<media::IEffectClient>& client,
Eric Laurentbe916aa2010-06-01 23:49:17 -0700811 int32_t priority,
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800812 audio_io_handle_t output,
Glenn Kastend848eb42016-03-08 13:42:11 -0800813 audio_session_t sessionId,
Eric Laurent94876032019-11-13 12:45:28 -0800814 const AudioDeviceTypeAddr& device,
Svet Ganovbe71aa22015-04-28 12:06:02 -0700815 const String16& opPackageName,
Eric Laurentb6436272016-12-07 19:24:50 -0800816 pid_t pid,
Eric Laurent2fe0acd2020-03-13 14:30:46 -0700817 bool probe,
Eric Laurentbe916aa2010-06-01 23:49:17 -0700818 status_t *status,
819 int *id,
820 int *enabled)
821 {
822 Parcel data, reply;
Ytai Ben-Tsvi9cd89812020-07-01 17:12:06 -0700823 sp<media::IEffect> effect;
Eric Laurentbe916aa2010-06-01 23:49:17 -0700824 if (pDesc == NULL) {
Glenn Kasten507b2862013-07-31 16:12:13 -0700825 if (status != NULL) {
Glenn Kastene53b9ea2012-03-12 16:29:55 -0700826 *status = BAD_VALUE;
827 }
Eric Laurent94876032019-11-13 12:45:28 -0800828 return nullptr;
Glenn Kastene53b9ea2012-03-12 16:29:55 -0700829 }
Eric Laurentbe916aa2010-06-01 23:49:17 -0700830
831 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Eric Laurentbe916aa2010-06-01 23:49:17 -0700832 data.write(pDesc, sizeof(effect_descriptor_t));
Marco Nelissen06b46062014-11-14 07:58:25 -0800833 data.writeStrongBinder(IInterface::asBinder(client));
Eric Laurentbe916aa2010-06-01 23:49:17 -0700834 data.writeInt32(priority);
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800835 data.writeInt32((int32_t) output);
Eric Laurentbe916aa2010-06-01 23:49:17 -0700836 data.writeInt32(sessionId);
Eric Laurent94876032019-11-13 12:45:28 -0800837 if (data.writeParcelable(device) != NO_ERROR) {
838 if (status != NULL) {
839 *status = NO_INIT;
840 }
841 return nullptr;
842 }
Svet Ganovbe71aa22015-04-28 12:06:02 -0700843 data.writeString16(opPackageName);
Eric Laurentb6436272016-12-07 19:24:50 -0800844 data.writeInt32((int32_t) pid);
Eric Laurent2fe0acd2020-03-13 14:30:46 -0700845 data.writeInt32(probe ? 1 : 0);
Eric Laurentbe916aa2010-06-01 23:49:17 -0700846
847 status_t lStatus = remote()->transact(CREATE_EFFECT, data, &reply);
848 if (lStatus != NO_ERROR) {
Steve Block29357bc2012-01-06 19:20:56 +0000849 ALOGE("createEffect error: %s", strerror(-lStatus));
Eric Laurentbe916aa2010-06-01 23:49:17 -0700850 } else {
851 lStatus = reply.readInt32();
852 int tmp = reply.readInt32();
Glenn Kasten507b2862013-07-31 16:12:13 -0700853 if (id != NULL) {
Eric Laurentbe916aa2010-06-01 23:49:17 -0700854 *id = tmp;
855 }
856 tmp = reply.readInt32();
Glenn Kastena0d68332012-01-27 16:47:15 -0800857 if (enabled != NULL) {
Eric Laurentbe916aa2010-06-01 23:49:17 -0700858 *enabled = tmp;
859 }
Ytai Ben-Tsvi9cd89812020-07-01 17:12:06 -0700860 effect = interface_cast<media::IEffect>(reply.readStrongBinder());
Eric Laurentbe916aa2010-06-01 23:49:17 -0700861 reply.read(pDesc, sizeof(effect_descriptor_t));
862 }
Glenn Kasten507b2862013-07-31 16:12:13 -0700863 if (status != NULL) {
Eric Laurentbe916aa2010-06-01 23:49:17 -0700864 *status = lStatus;
865 }
866
867 return effect;
868 }
Eric Laurentde070132010-07-13 04:45:46 -0700869
Glenn Kastend848eb42016-03-08 13:42:11 -0800870 virtual status_t moveEffects(audio_session_t session, audio_io_handle_t srcOutput,
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800871 audio_io_handle_t dstOutput)
Eric Laurentde070132010-07-13 04:45:46 -0700872 {
873 Parcel data, reply;
874 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
875 data.writeInt32(session);
Glenn Kasten72ef00d2012-01-17 11:09:42 -0800876 data.writeInt32((int32_t) srcOutput);
877 data.writeInt32((int32_t) dstOutput);
Eric Laurentde070132010-07-13 04:45:46 -0700878 remote()->transact(MOVE_EFFECTS, data, &reply);
879 return reply.readInt32();
880 }
Eric Laurenta4c5a552012-03-29 10:12:40 -0700881
Eric Laurentb20cf7d2019-04-05 19:37:34 -0700882 virtual void setEffectSuspended(int effectId,
883 audio_session_t sessionId,
884 bool suspended)
885 {
886 Parcel data, reply;
887 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
888 data.writeInt32(effectId);
889 data.writeInt32(sessionId);
890 data.writeInt32(suspended ? 1 : 0);
891 remote()->transact(SET_EFFECT_SUSPENDED, data, &reply);
892 }
893
Eric Laurenta4c5a552012-03-29 10:12:40 -0700894 virtual audio_module_handle_t loadHwModule(const char *name)
895 {
896 Parcel data, reply;
897 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
898 data.writeCString(name);
899 remote()->transact(LOAD_HW_MODULE, data, &reply);
900 return (audio_module_handle_t) reply.readInt32();
901 }
Glenn Kastencc0f1cf2012-09-24 11:27:18 -0700902
Glenn Kasten3b16c762012-11-14 08:44:39 -0800903 virtual uint32_t getPrimaryOutputSamplingRate()
Glenn Kastencc0f1cf2012-09-24 11:27:18 -0700904 {
905 Parcel data, reply;
906 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
907 remote()->transact(GET_PRIMARY_OUTPUT_SAMPLING_RATE, data, &reply);
908 return reply.readInt32();
909 }
910
Glenn Kastene33054e2012-11-14 12:54:39 -0800911 virtual size_t getPrimaryOutputFrameCount()
Glenn Kastencc0f1cf2012-09-24 11:27:18 -0700912 {
913 Parcel data, reply;
914 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
915 remote()->transact(GET_PRIMARY_OUTPUT_FRAME_COUNT, data, &reply);
Glenn Kastene03dd222014-01-28 11:04:39 -0800916 return reply.readInt64();
Glenn Kastencc0f1cf2012-09-24 11:27:18 -0700917 }
918
Andy Hung6f248bb2018-01-23 14:04:37 -0800919 virtual status_t setLowRamDevice(bool isLowRamDevice, int64_t totalMemory) override
Glenn Kasten4182c4e2013-07-15 14:45:07 -0700920 {
921 Parcel data, reply;
Andy Hung6f248bb2018-01-23 14:04:37 -0800922
923 static_assert(NO_ERROR == 0, "NO_ERROR must be 0");
924 return data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor())
925 ?: data.writeInt32((int) isLowRamDevice)
926 ?: data.writeInt64(totalMemory)
927 ?: remote()->transact(SET_LOW_RAM_DEVICE, data, &reply)
928 ?: reply.readInt32();
Glenn Kasten4182c4e2013-07-15 14:45:07 -0700929 }
Andy Hung6f248bb2018-01-23 14:04:37 -0800930
Eric Laurent4b123402014-04-11 09:22:20 -0700931 virtual status_t listAudioPorts(unsigned int *num_ports,
932 struct audio_port *ports)
933 {
934 if (num_ports == NULL || *num_ports == 0 || ports == NULL) {
935 return BAD_VALUE;
936 }
937 Parcel data, reply;
938 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
939 data.writeInt32(*num_ports);
940 status_t status = remote()->transact(LIST_AUDIO_PORTS, data, &reply);
941 if (status != NO_ERROR ||
942 (status = (status_t)reply.readInt32()) != NO_ERROR) {
943 return status;
944 }
945 *num_ports = (unsigned int)reply.readInt32();
946 reply.read(ports, *num_ports * sizeof(struct audio_port));
947 return status;
948 }
Jiabin Huang3a0cf472020-11-03 17:29:35 +0000949 virtual status_t getAudioPort(struct audio_port *port)
Eric Laurent4b123402014-04-11 09:22:20 -0700950 {
Jiabin Huang3a0cf472020-11-03 17:29:35 +0000951 if (port == NULL) {
Eric Laurent4b123402014-04-11 09:22:20 -0700952 return BAD_VALUE;
953 }
954 Parcel data, reply;
955 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
Jiabin Huang3a0cf472020-11-03 17:29:35 +0000956 data.write(port, sizeof(struct audio_port));
Eric Laurent4b123402014-04-11 09:22:20 -0700957 status_t status = remote()->transact(GET_AUDIO_PORT, data, &reply);
958 if (status != NO_ERROR ||
959 (status = (status_t)reply.readInt32()) != NO_ERROR) {
960 return status;
961 }
962 reply.read(port, sizeof(struct audio_port));
963 return status;
964 }
965 virtual status_t createAudioPatch(const struct audio_patch *patch,
966 audio_patch_handle_t *handle)
967 {
968 if (patch == NULL || handle == NULL) {
969 return BAD_VALUE;
970 }
971 Parcel data, reply;
972 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
973 data.write(patch, sizeof(struct audio_patch));
974 data.write(handle, sizeof(audio_patch_handle_t));
975 status_t status = remote()->transact(CREATE_AUDIO_PATCH, data, &reply);
976 if (status != NO_ERROR ||
977 (status = (status_t)reply.readInt32()) != NO_ERROR) {
978 return status;
979 }
980 reply.read(handle, sizeof(audio_patch_handle_t));
981 return status;
982 }
983 virtual status_t releaseAudioPatch(audio_patch_handle_t handle)
984 {
985 Parcel data, reply;
986 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
987 data.write(&handle, sizeof(audio_patch_handle_t));
988 status_t status = remote()->transact(RELEASE_AUDIO_PATCH, data, &reply);
989 if (status != NO_ERROR) {
990 status = (status_t)reply.readInt32();
991 }
992 return status;
993 }
994 virtual status_t listAudioPatches(unsigned int *num_patches,
995 struct audio_patch *patches)
996 {
997 if (num_patches == NULL || *num_patches == 0 || patches == NULL) {
998 return BAD_VALUE;
999 }
1000 Parcel data, reply;
1001 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
1002 data.writeInt32(*num_patches);
1003 status_t status = remote()->transact(LIST_AUDIO_PATCHES, data, &reply);
1004 if (status != NO_ERROR ||
1005 (status = (status_t)reply.readInt32()) != NO_ERROR) {
1006 return status;
1007 }
1008 *num_patches = (unsigned int)reply.readInt32();
1009 reply.read(patches, *num_patches * sizeof(struct audio_patch));
1010 return status;
1011 }
1012 virtual status_t setAudioPortConfig(const struct audio_port_config *config)
1013 {
1014 if (config == NULL) {
1015 return BAD_VALUE;
1016 }
1017 Parcel data, reply;
1018 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
1019 data.write(config, sizeof(struct audio_port_config));
1020 status_t status = remote()->transact(SET_AUDIO_PORT_CONFIG, data, &reply);
1021 if (status != NO_ERROR) {
1022 status = (status_t)reply.readInt32();
1023 }
1024 return status;
1025 }
Eric Laurent93c3d412014-08-01 14:48:35 -07001026 virtual audio_hw_sync_t getAudioHwSyncForSession(audio_session_t sessionId)
1027 {
1028 Parcel data, reply;
1029 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
1030 data.writeInt32(sessionId);
Glenn Kasten9eae0362016-04-19 09:09:14 -07001031 status_t status = remote()->transact(GET_AUDIO_HW_SYNC_FOR_SESSION, data, &reply);
Eric Laurent93c3d412014-08-01 14:48:35 -07001032 if (status != NO_ERROR) {
1033 return AUDIO_HW_SYNC_INVALID;
1034 }
1035 return (audio_hw_sync_t)reply.readInt32();
1036 }
Eric Laurent72e3f392015-05-20 14:43:50 -07001037 virtual status_t systemReady()
1038 {
1039 Parcel data, reply;
1040 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
1041 return remote()->transact(SYSTEM_READY, data, &reply, IBinder::FLAG_ONEWAY);
1042 }
Glenn Kasten4a8308b2016-04-18 14:10:01 -07001043 virtual size_t frameCountHAL(audio_io_handle_t ioHandle) const
1044 {
1045 Parcel data, reply;
1046 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
1047 data.writeInt32((int32_t) ioHandle);
1048 status_t status = remote()->transact(FRAME_COUNT_HAL, data, &reply);
1049 if (status != NO_ERROR) {
1050 return 0;
1051 }
1052 return reply.readInt64();
1053 }
jiabin46a76fa2018-01-05 10:18:21 -08001054 virtual status_t getMicrophones(std::vector<media::MicrophoneInfo> *microphones)
1055 {
1056 Parcel data, reply;
1057 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
jiabin9ff780e2018-03-19 18:19:52 -07001058 status_t status = remote()->transact(GET_MICROPHONES, data, &reply);
jiabin46a76fa2018-01-05 10:18:21 -08001059 if (status != NO_ERROR ||
1060 (status = (status_t)reply.readInt32()) != NO_ERROR) {
1061 return status;
1062 }
1063 status = reply.readParcelableVector(microphones);
1064 return status;
1065 }
Eric Laurent42896a02019-09-27 15:40:33 -07001066 virtual status_t setAudioHalPids(const std::vector<pid_t>& pids)
1067 {
1068 Parcel data, reply;
1069 data.writeInterfaceToken(IAudioFlinger::getInterfaceDescriptor());
1070 data.writeInt32(pids.size());
1071 for (auto pid : pids) {
1072 data.writeInt32(pid);
1073 }
1074 status_t status = remote()->transact(SET_AUDIO_HAL_PIDS, data, &reply);
1075 if (status != NO_ERROR) {
1076 return status;
1077 }
1078 return static_cast <status_t> (reply.readInt32());
1079 }
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001080};
1081
1082IMPLEMENT_META_INTERFACE(AudioFlinger, "android.media.IAudioFlinger");
1083
1084// ----------------------------------------------------------------------
1085
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001086status_t BnAudioFlinger::onTransact(
1087 uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags)
1088{
Eric Laurentb1cc36b2017-12-11 12:14:16 -08001089 // make sure transactions reserved to AudioPolicyManager do not come from other processes
1090 switch (code) {
1091 case SET_STREAM_VOLUME:
1092 case SET_STREAM_MUTE:
Eric Laurentb1cc36b2017-12-11 12:14:16 -08001093 case OPEN_OUTPUT:
1094 case OPEN_DUPLICATE_OUTPUT:
1095 case CLOSE_OUTPUT:
1096 case SUSPEND_OUTPUT:
1097 case RESTORE_OUTPUT:
1098 case OPEN_INPUT:
1099 case CLOSE_INPUT:
1100 case INVALIDATE_STREAM:
1101 case SET_VOICE_VOLUME:
1102 case MOVE_EFFECTS:
Eric Laurentb20cf7d2019-04-05 19:37:34 -07001103 case SET_EFFECT_SUSPENDED:
Eric Laurentb1cc36b2017-12-11 12:14:16 -08001104 case LOAD_HW_MODULE:
1105 case LIST_AUDIO_PORTS:
1106 case GET_AUDIO_PORT:
1107 case CREATE_AUDIO_PATCH:
1108 case RELEASE_AUDIO_PATCH:
1109 case LIST_AUDIO_PATCHES:
1110 case SET_AUDIO_PORT_CONFIG:
Svet Ganovf4ddfef2018-01-16 07:37:58 -08001111 case SET_RECORD_SILENCED:
Eric Laurentb1cc36b2017-12-11 12:14:16 -08001112 ALOGW("%s: transaction %d received from PID %d",
1113 __func__, code, IPCThreadState::self()->getCallingPid());
Eric Laurentef92bff2018-04-26 10:44:50 -07001114 // return status only for non void methods
1115 switch (code) {
1116 case SET_RECORD_SILENCED:
Eric Laurentb20cf7d2019-04-05 19:37:34 -07001117 case SET_EFFECT_SUSPENDED:
Eric Laurentef92bff2018-04-26 10:44:50 -07001118 break;
1119 default:
1120 reply->writeInt32(static_cast<int32_t> (INVALID_OPERATION));
1121 break;
1122 }
1123 return OK;
Eric Laurentb1cc36b2017-12-11 12:14:16 -08001124 default:
1125 break;
1126 }
1127
Eric Laurent4980df22018-01-26 18:04:09 -08001128 // make sure the following transactions come from system components
1129 switch (code) {
1130 case SET_MASTER_VOLUME:
1131 case SET_MASTER_MUTE:
1132 case SET_MODE:
1133 case SET_MIC_MUTE:
1134 case SET_LOW_RAM_DEVICE:
Eric Laurent42896a02019-09-27 15:40:33 -07001135 case SYSTEM_READY:
1136 case SET_AUDIO_HAL_PIDS: {
Andy Hung4ef19fa2018-05-15 19:35:29 -07001137 if (!isServiceUid(IPCThreadState::self()->getCallingUid())) {
Eric Laurent4980df22018-01-26 18:04:09 -08001138 ALOGW("%s: transaction %d received from PID %d unauthorized UID %d",
1139 __func__, code, IPCThreadState::self()->getCallingPid(),
1140 IPCThreadState::self()->getCallingUid());
Eric Laurentef92bff2018-04-26 10:44:50 -07001141 // return status only for non void methods
1142 switch (code) {
1143 case SYSTEM_READY:
1144 break;
1145 default:
1146 reply->writeInt32(static_cast<int32_t> (INVALID_OPERATION));
1147 break;
1148 }
1149 return OK;
Eric Laurent4980df22018-01-26 18:04:09 -08001150 }
Eric Laurent96c7eed2018-03-26 17:57:01 -07001151 } break;
Eric Laurent4980df22018-01-26 18:04:09 -08001152 default:
1153 break;
1154 }
1155
Glenn Kasten67f95702020-06-22 16:42:52 -07001156 // List of relevant events that trigger log merging.
Nicolas Rouletdcdfaec2017-02-14 10:18:39 -08001157 // Log merging should activate during audio activity of any kind. This are considered the
1158 // most relevant events.
1159 // TODO should select more wisely the items from the list
1160 switch (code) {
1161 case CREATE_TRACK:
Eric Laurentf14db3c2017-12-08 14:20:36 -08001162 case CREATE_RECORD:
Nicolas Rouletdcdfaec2017-02-14 10:18:39 -08001163 case SET_MASTER_VOLUME:
1164 case SET_MASTER_MUTE:
Nicolas Rouletdcdfaec2017-02-14 10:18:39 -08001165 case SET_MIC_MUTE:
1166 case SET_PARAMETERS:
Nicolas Rouletdcdfaec2017-02-14 10:18:39 -08001167 case CREATE_EFFECT:
1168 case SYSTEM_READY: {
1169 requestLogMerge();
1170 break;
1171 }
1172 default:
1173 break;
1174 }
Eric Laurentb1cc36b2017-12-11 12:14:16 -08001175
Eric Laurent39b09b52018-06-29 12:24:40 -07001176 std::string tag("IAudioFlinger command " + std::to_string(code));
1177 TimeCheck check(tag.c_str());
Eric Laurent3528c932018-02-23 17:17:22 -08001178
Eric Laurent14dc3cb2020-09-16 18:42:23 -07001179 // Make sure we connect to Audio Policy Service before calling into AudioFlinger:
1180 // - AudioFlinger can call into Audio Policy Service with its global mutex held
1181 // - If this is the first time Audio Policy Service is queried from inside audioserver process
1182 // this will trigger Audio Policy Manager initialization.
1183 // - Audio Policy Manager initialization calls into AudioFlinger which will try to lock
1184 // its global mutex and a deadlock will occur.
1185 if (IPCThreadState::self()->getCallingPid() != getpid()) {
1186 AudioSystem::get_audio_policy_service();
1187 }
1188
Glenn Kastene53b9ea2012-03-12 16:29:55 -07001189 switch (code) {
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001190 case CREATE_TRACK: {
1191 CHECK_INTERFACE(IAudioFlinger, data, reply);
Eric Laurent21da6472017-11-09 16:29:26 -08001192
Ytai Ben-Tsvi4dfeb622020-11-02 12:47:30 -08001193 media::CreateTrackRequest input;
1194 if (data.readParcelable(&input) != NO_ERROR) {
Eric Laurent21da6472017-11-09 16:29:26 -08001195 reply->writeInt32(DEAD_OBJECT);
1196 return NO_ERROR;
Eric Laurent3d00aa62013-09-24 09:53:27 -07001197 }
Eric Laurent21da6472017-11-09 16:29:26 -08001198
1199 status_t status;
Ytai Ben-Tsvi4dfeb622020-11-02 12:47:30 -08001200 media::CreateTrackResponse output;
Eric Laurent21da6472017-11-09 16:29:26 -08001201
1202 sp<IAudioTrack> track= createTrack(input,
1203 output,
1204 &status);
1205
1206 LOG_ALWAYS_FATAL_IF((track != 0) != (status == NO_ERROR));
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001207 reply->writeInt32(status);
Eric Laurent21da6472017-11-09 16:29:26 -08001208 if (status != NO_ERROR) {
1209 return NO_ERROR;
1210 }
Marco Nelissen06b46062014-11-14 07:58:25 -08001211 reply->writeStrongBinder(IInterface::asBinder(track));
Eric Laurent21da6472017-11-09 16:29:26 -08001212 output.writeToParcel(reply);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001213 return NO_ERROR;
1214 } break;
Eric Laurentf14db3c2017-12-08 14:20:36 -08001215 case CREATE_RECORD: {
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001216 CHECK_INTERFACE(IAudioFlinger, data, reply);
Eric Laurentf14db3c2017-12-08 14:20:36 -08001217
Ytai Ben-Tsvi4dfeb622020-11-02 12:47:30 -08001218 media::CreateRecordRequest input;
1219 if (data.readParcelable(&input) != NO_ERROR) {
Eric Laurentf14db3c2017-12-08 14:20:36 -08001220 reply->writeInt32(DEAD_OBJECT);
1221 return NO_ERROR;
1222 }
1223
1224 status_t status;
Ytai Ben-Tsvi4dfeb622020-11-02 12:47:30 -08001225 media::CreateRecordResponse output;
Eric Laurentf14db3c2017-12-08 14:20:36 -08001226
1227 sp<media::IAudioRecord> record = createRecord(input,
1228 output,
1229 &status);
1230
Glenn Kastene93cf2c2013-09-24 11:52:37 -07001231 LOG_ALWAYS_FATAL_IF((record != 0) != (status == NO_ERROR));
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001232 reply->writeInt32(status);
Eric Laurentf14db3c2017-12-08 14:20:36 -08001233 if (status != NO_ERROR) {
1234 return NO_ERROR;
1235 }
Marco Nelissen06b46062014-11-14 07:58:25 -08001236 reply->writeStrongBinder(IInterface::asBinder(record));
Eric Laurentf14db3c2017-12-08 14:20:36 -08001237 output.writeToParcel(reply);
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001238 return NO_ERROR;
1239 } break;
1240 case SAMPLE_RATE: {
1241 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001242 reply->writeInt32( sampleRate((audio_io_handle_t) data.readInt32()) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001243 return NO_ERROR;
1244 } break;
Glenn Kasten4a8308b2016-04-18 14:10:01 -07001245
1246 // RESERVED for channelCount()
1247
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001248 case FORMAT: {
1249 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001250 reply->writeInt32( format((audio_io_handle_t) data.readInt32()) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001251 return NO_ERROR;
1252 } break;
1253 case FRAME_COUNT: {
1254 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastene03dd222014-01-28 11:04:39 -08001255 reply->writeInt64( frameCount((audio_io_handle_t) data.readInt32()) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001256 return NO_ERROR;
1257 } break;
1258 case LATENCY: {
1259 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001260 reply->writeInt32( latency((audio_io_handle_t) data.readInt32()) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001261 return NO_ERROR;
1262 } break;
Glenn Kastene53b9ea2012-03-12 16:29:55 -07001263 case SET_MASTER_VOLUME: {
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001264 CHECK_INTERFACE(IAudioFlinger, data, reply);
1265 reply->writeInt32( setMasterVolume(data.readFloat()) );
1266 return NO_ERROR;
1267 } break;
1268 case SET_MASTER_MUTE: {
1269 CHECK_INTERFACE(IAudioFlinger, data, reply);
1270 reply->writeInt32( setMasterMute(data.readInt32()) );
1271 return NO_ERROR;
1272 } break;
1273 case MASTER_VOLUME: {
1274 CHECK_INTERFACE(IAudioFlinger, data, reply);
1275 reply->writeFloat( masterVolume() );
1276 return NO_ERROR;
1277 } break;
1278 case MASTER_MUTE: {
1279 CHECK_INTERFACE(IAudioFlinger, data, reply);
1280 reply->writeInt32( masterMute() );
1281 return NO_ERROR;
1282 } break;
Richard Folke Tullberg3fae0372017-01-13 09:04:25 +01001283 case SET_MASTER_BALANCE: {
1284 CHECK_INTERFACE(IAudioFlinger, data, reply);
1285 reply->writeInt32( setMasterBalance(data.readFloat()) );
1286 return NO_ERROR;
1287 } break;
1288 case GET_MASTER_BALANCE: {
1289 CHECK_INTERFACE(IAudioFlinger, data, reply);
1290 float f;
1291 const status_t status = getMasterBalance(&f);
1292 reply->writeInt32((int32_t)status);
1293 if (status == NO_ERROR) {
1294 (void)reply->writeFloat(f);
1295 }
1296 return NO_ERROR;
1297 } break;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001298 case SET_STREAM_VOLUME: {
1299 CHECK_INTERFACE(IAudioFlinger, data, reply);
1300 int stream = data.readInt32();
Eric Laurentc2f1f072009-07-17 12:17:14 -07001301 float volume = data.readFloat();
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001302 audio_io_handle_t output = (audio_io_handle_t) data.readInt32();
Glenn Kastenfff6d712012-01-12 16:38:12 -08001303 reply->writeInt32( setStreamVolume((audio_stream_type_t) stream, volume, output) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001304 return NO_ERROR;
1305 } break;
1306 case SET_STREAM_MUTE: {
1307 CHECK_INTERFACE(IAudioFlinger, data, reply);
1308 int stream = data.readInt32();
Glenn Kastenfff6d712012-01-12 16:38:12 -08001309 reply->writeInt32( setStreamMute((audio_stream_type_t) stream, data.readInt32()) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001310 return NO_ERROR;
1311 } break;
1312 case STREAM_VOLUME: {
1313 CHECK_INTERFACE(IAudioFlinger, data, reply);
1314 int stream = data.readInt32();
Eric Laurentfa2877b2009-07-28 08:44:33 -07001315 int output = data.readInt32();
Glenn Kastenfff6d712012-01-12 16:38:12 -08001316 reply->writeFloat( streamVolume((audio_stream_type_t) stream, output) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001317 return NO_ERROR;
1318 } break;
1319 case STREAM_MUTE: {
1320 CHECK_INTERFACE(IAudioFlinger, data, reply);
1321 int stream = data.readInt32();
Glenn Kastenfff6d712012-01-12 16:38:12 -08001322 reply->writeInt32( streamMute((audio_stream_type_t) stream) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001323 return NO_ERROR;
1324 } break;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001325 case SET_MODE: {
1326 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastenf78aee72012-01-04 11:00:47 -08001327 audio_mode_t mode = (audio_mode_t) data.readInt32();
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001328 reply->writeInt32( setMode(mode) );
1329 return NO_ERROR;
1330 } break;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001331 case SET_MIC_MUTE: {
1332 CHECK_INTERFACE(IAudioFlinger, data, reply);
1333 int state = data.readInt32();
1334 reply->writeInt32( setMicMute(state) );
1335 return NO_ERROR;
1336 } break;
1337 case GET_MIC_MUTE: {
1338 CHECK_INTERFACE(IAudioFlinger, data, reply);
1339 reply->writeInt32( getMicMute() );
1340 return NO_ERROR;
1341 } break;
Svet Ganovf4ddfef2018-01-16 07:37:58 -08001342 case SET_RECORD_SILENCED: {
1343 CHECK_INTERFACE(IAudioFlinger, data, reply);
Eric Laurent5ada82e2019-08-29 17:53:54 -07001344 audio_port_handle_t portId = data.readInt32();
Svet Ganovf4ddfef2018-01-16 07:37:58 -08001345 bool silenced = data.readInt32() == 1;
Eric Laurent5ada82e2019-08-29 17:53:54 -07001346 setRecordSilenced(portId, silenced);
Svet Ganovf4ddfef2018-01-16 07:37:58 -08001347 return NO_ERROR;
1348 } break;
Eric Laurentc2f1f072009-07-17 12:17:14 -07001349 case SET_PARAMETERS: {
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001350 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001351 audio_io_handle_t ioHandle = (audio_io_handle_t) data.readInt32();
Eric Laurentc2f1f072009-07-17 12:17:14 -07001352 String8 keyValuePairs(data.readString8());
1353 reply->writeInt32(setParameters(ioHandle, keyValuePairs));
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001354 return NO_ERROR;
Glenn Kastene53b9ea2012-03-12 16:29:55 -07001355 } break;
Eric Laurentc2f1f072009-07-17 12:17:14 -07001356 case GET_PARAMETERS: {
1357 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001358 audio_io_handle_t ioHandle = (audio_io_handle_t) data.readInt32();
Eric Laurentc2f1f072009-07-17 12:17:14 -07001359 String8 keys(data.readString8());
1360 reply->writeString8(getParameters(ioHandle, keys));
1361 return NO_ERROR;
Glenn Kastene53b9ea2012-03-12 16:29:55 -07001362 } break;
Eric Laurentc2f1f072009-07-17 12:17:14 -07001363
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001364 case REGISTER_CLIENT: {
1365 CHECK_INTERFACE(IAudioFlinger, data, reply);
Ytai Ben-Tsvi10dc0a62020-09-18 11:31:55 -07001366 sp<media::IAudioFlingerClient> client = interface_cast<media::IAudioFlingerClient>(
Glenn Kasten85ab62c2012-11-01 11:11:38 -07001367 data.readStrongBinder());
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001368 registerClient(client);
1369 return NO_ERROR;
1370 } break;
1371 case GET_INPUTBUFFERSIZE: {
1372 CHECK_INTERFACE(IAudioFlinger, data, reply);
1373 uint32_t sampleRate = data.readInt32();
Glenn Kasten58f30212012-01-12 12:27:51 -08001374 audio_format_t format = (audio_format_t) data.readInt32();
Mikhail Naganov55773032020-10-01 15:08:13 -07001375 audio_channel_mask_t channelMask = (audio_channel_mask_t) data.readInt32();
Glenn Kastene03dd222014-01-28 11:04:39 -08001376 reply->writeInt64( getInputBufferSize(sampleRate, format, channelMask) );
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001377 return NO_ERROR;
1378 } break;
Eric Laurentc2f1f072009-07-17 12:17:14 -07001379 case OPEN_OUTPUT: {
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001380 CHECK_INTERFACE(IAudioFlinger, data, reply);
Eric Laurenta4c5a552012-03-29 10:12:40 -07001381 audio_module_handle_t module = (audio_module_handle_t)data.readInt32();
Wei Jiae995e472015-09-09 09:48:34 -07001382 audio_config_t config = {};
1383 if (data.read(&config, sizeof(audio_config_t)) != NO_ERROR) {
1384 ALOGE("b/23905951");
1385 }
jiabin43810402019-10-24 14:58:31 -07001386 sp<DeviceDescriptorBase> device = new DeviceDescriptorBase(AUDIO_DEVICE_NONE);
1387 status_t status = NO_ERROR;
1388 if ((status = data.readParcelable(device.get())) != NO_ERROR) {
1389 reply->writeInt32((int32_t)status);
1390 return NO_ERROR;
1391 }
Eric Laurent0ca3cf92012-04-18 09:24:29 -07001392 audio_output_flags_t flags = (audio_output_flags_t) data.readInt32();
Wei Jia983dca32015-09-10 09:47:29 -07001393 uint32_t latencyMs = 0;
Wei Jia4cac44b2015-09-16 15:01:16 -07001394 audio_io_handle_t output = AUDIO_IO_HANDLE_NONE;
jiabin43810402019-10-24 14:58:31 -07001395 status = openOutput(module, &output, &config, device, &latencyMs, flags);
Glenn Kasten70742962014-02-18 08:00:47 -08001396 ALOGV("OPEN_OUTPUT output, %d", output);
Eric Laurentcf2c0212014-07-25 16:20:43 -07001397 reply->writeInt32((int32_t)status);
1398 if (status == NO_ERROR) {
1399 reply->writeInt32((int32_t)output);
1400 reply->write(&config, sizeof(audio_config_t));
Eric Laurentcf2c0212014-07-25 16:20:43 -07001401 reply->writeInt32(latencyMs);
1402 }
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001403 return NO_ERROR;
1404 } break;
Eric Laurentc2f1f072009-07-17 12:17:14 -07001405 case OPEN_DUPLICATE_OUTPUT: {
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001406 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001407 audio_io_handle_t output1 = (audio_io_handle_t) data.readInt32();
1408 audio_io_handle_t output2 = (audio_io_handle_t) data.readInt32();
1409 reply->writeInt32((int32_t) openDuplicateOutput(output1, output2));
Eric Laurentc2f1f072009-07-17 12:17:14 -07001410 return NO_ERROR;
1411 } break;
1412 case CLOSE_OUTPUT: {
1413 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001414 reply->writeInt32(closeOutput((audio_io_handle_t) data.readInt32()));
Eric Laurentc2f1f072009-07-17 12:17:14 -07001415 return NO_ERROR;
1416 } break;
1417 case SUSPEND_OUTPUT: {
1418 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001419 reply->writeInt32(suspendOutput((audio_io_handle_t) data.readInt32()));
Eric Laurentc2f1f072009-07-17 12:17:14 -07001420 return NO_ERROR;
1421 } break;
1422 case RESTORE_OUTPUT: {
1423 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001424 reply->writeInt32(restoreOutput((audio_io_handle_t) data.readInt32()));
Eric Laurentc2f1f072009-07-17 12:17:14 -07001425 return NO_ERROR;
1426 } break;
1427 case OPEN_INPUT: {
1428 CHECK_INTERFACE(IAudioFlinger, data, reply);
Eric Laurenta4c5a552012-03-29 10:12:40 -07001429 audio_module_handle_t module = (audio_module_handle_t)data.readInt32();
Eric Laurentcf2c0212014-07-25 16:20:43 -07001430 audio_io_handle_t input = (audio_io_handle_t)data.readInt32();
Wei Jiae995e472015-09-09 09:48:34 -07001431 audio_config_t config = {};
1432 if (data.read(&config, sizeof(audio_config_t)) != NO_ERROR) {
1433 ALOGE("b/23905951");
1434 }
Eric Laurentcf2c0212014-07-25 16:20:43 -07001435 audio_devices_t device = (audio_devices_t)data.readInt32();
1436 String8 address(data.readString8());
1437 audio_source_t source = (audio_source_t)data.readInt32();
Glenn Kastenec40d282014-07-15 15:31:26 -07001438 audio_input_flags_t flags = (audio_input_flags_t) data.readInt32();
Eric Laurentc2f1f072009-07-17 12:17:14 -07001439
Eric Laurentcf2c0212014-07-25 16:20:43 -07001440 status_t status = openInput(module, &input, &config,
1441 &device, address, source, flags);
1442 reply->writeInt32((int32_t) status);
1443 if (status == NO_ERROR) {
1444 reply->writeInt32((int32_t) input);
1445 reply->write(&config, sizeof(audio_config_t));
1446 reply->writeInt32(device);
1447 }
Eric Laurentc2f1f072009-07-17 12:17:14 -07001448 return NO_ERROR;
1449 } break;
1450 case CLOSE_INPUT: {
1451 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001452 reply->writeInt32(closeInput((audio_io_handle_t) data.readInt32()));
Eric Laurentc2f1f072009-07-17 12:17:14 -07001453 return NO_ERROR;
1454 } break;
Glenn Kastend2304db2014-02-03 07:40:31 -08001455 case INVALIDATE_STREAM: {
Eric Laurentc2f1f072009-07-17 12:17:14 -07001456 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastend2304db2014-02-03 07:40:31 -08001457 audio_stream_type_t stream = (audio_stream_type_t) data.readInt32();
1458 reply->writeInt32(invalidateStream(stream));
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001459 return NO_ERROR;
1460 } break;
Eric Laurentf0ee6f42009-10-21 08:14:22 -07001461 case SET_VOICE_VOLUME: {
1462 CHECK_INTERFACE(IAudioFlinger, data, reply);
1463 float volume = data.readFloat();
1464 reply->writeInt32( setVoiceVolume(volume) );
1465 return NO_ERROR;
1466 } break;
Eric Laurent342e9cf2010-01-19 17:37:09 -08001467 case GET_RENDER_POSITION: {
1468 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001469 audio_io_handle_t output = (audio_io_handle_t) data.readInt32();
Wei Jia983dca32015-09-10 09:47:29 -07001470 uint32_t halFrames = 0;
1471 uint32_t dspFrames = 0;
Eric Laurent342e9cf2010-01-19 17:37:09 -08001472 status_t status = getRenderPosition(&halFrames, &dspFrames, output);
1473 reply->writeInt32(status);
1474 if (status == NO_ERROR) {
1475 reply->writeInt32(halFrames);
1476 reply->writeInt32(dspFrames);
1477 }
1478 return NO_ERROR;
1479 }
Eric Laurent05bca2f2010-02-26 02:47:27 -08001480 case GET_INPUT_FRAMES_LOST: {
1481 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001482 audio_io_handle_t ioHandle = (audio_io_handle_t) data.readInt32();
Glenn Kasten5f972c02014-01-13 09:59:31 -08001483 reply->writeInt32((int32_t) getInputFramesLost(ioHandle));
Eric Laurent05bca2f2010-02-26 02:47:27 -08001484 return NO_ERROR;
1485 } break;
Glenn Kasten9eae0362016-04-19 09:09:14 -07001486 case NEW_AUDIO_UNIQUE_ID: {
Eric Laurentbe916aa2010-06-01 23:49:17 -07001487 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kasteneeecb982016-02-26 10:44:04 -08001488 reply->writeInt32(newAudioUniqueId((audio_unique_id_use_t) data.readInt32()));
Eric Laurentbe916aa2010-06-01 23:49:17 -07001489 return NO_ERROR;
1490 } break;
Marco Nelissen3a34bef2011-08-02 13:33:41 -07001491 case ACQUIRE_AUDIO_SESSION_ID: {
1492 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastend848eb42016-03-08 13:42:11 -08001493 audio_session_t audioSession = (audio_session_t) data.readInt32();
Andy Hung8b0bfd92019-12-23 13:11:11 -08001494 const pid_t pid = (pid_t)data.readInt32();
1495 const uid_t uid = (uid_t)data.readInt32();
1496 acquireAudioSessionId(audioSession, pid, uid);
Marco Nelissen3a34bef2011-08-02 13:33:41 -07001497 return NO_ERROR;
1498 } break;
1499 case RELEASE_AUDIO_SESSION_ID: {
1500 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastend848eb42016-03-08 13:42:11 -08001501 audio_session_t audioSession = (audio_session_t) data.readInt32();
Marco Nelissend457c972014-02-11 08:47:07 -08001502 int pid = data.readInt32();
1503 releaseAudioSessionId(audioSession, pid);
Marco Nelissen3a34bef2011-08-02 13:33:41 -07001504 return NO_ERROR;
1505 } break;
Eric Laurentbe916aa2010-06-01 23:49:17 -07001506 case QUERY_NUM_EFFECTS: {
1507 CHECK_INTERFACE(IAudioFlinger, data, reply);
Wei Jia983dca32015-09-10 09:47:29 -07001508 uint32_t numEffects = 0;
Eric Laurentbe916aa2010-06-01 23:49:17 -07001509 status_t status = queryNumberEffects(&numEffects);
1510 reply->writeInt32(status);
1511 if (status == NO_ERROR) {
1512 reply->writeInt32((int32_t)numEffects);
1513 }
1514 return NO_ERROR;
1515 }
Eric Laurentffe9c252010-06-23 17:38:20 -07001516 case QUERY_EFFECT: {
Eric Laurentbe916aa2010-06-01 23:49:17 -07001517 CHECK_INTERFACE(IAudioFlinger, data, reply);
Wei Jia983dca32015-09-10 09:47:29 -07001518 effect_descriptor_t desc = {};
Eric Laurentffe9c252010-06-23 17:38:20 -07001519 status_t status = queryEffect(data.readInt32(), &desc);
Eric Laurentbe916aa2010-06-01 23:49:17 -07001520 reply->writeInt32(status);
1521 if (status == NO_ERROR) {
1522 reply->write(&desc, sizeof(effect_descriptor_t));
1523 }
1524 return NO_ERROR;
1525 }
1526 case GET_EFFECT_DESCRIPTOR: {
1527 CHECK_INTERFACE(IAudioFlinger, data, reply);
Andy Hungf85d1292019-08-21 14:45:41 -07001528 effect_uuid_t uuid = {};
1529 if (data.read(&uuid, sizeof(effect_uuid_t)) != NO_ERROR) {
1530 android_errorWriteLog(0x534e4554, "139417189");
1531 }
1532 effect_uuid_t type = {};
1533 if (data.read(&type, sizeof(effect_uuid_t)) != NO_ERROR) {
1534 android_errorWriteLog(0x534e4554, "139417189");
1535 }
Ari Hausman-Cohen2046ec72018-04-24 14:00:55 -07001536 uint32_t preferredTypeFlag = data.readUint32();
Wei Jia983dca32015-09-10 09:47:29 -07001537 effect_descriptor_t desc = {};
Ari Hausman-Cohen2046ec72018-04-24 14:00:55 -07001538 status_t status = getEffectDescriptor(&uuid, &type, preferredTypeFlag, &desc);
Eric Laurentbe916aa2010-06-01 23:49:17 -07001539 reply->writeInt32(status);
1540 if (status == NO_ERROR) {
1541 reply->write(&desc, sizeof(effect_descriptor_t));
1542 }
1543 return NO_ERROR;
1544 }
1545 case CREATE_EFFECT: {
1546 CHECK_INTERFACE(IAudioFlinger, data, reply);
Wei Jiae995e472015-09-09 09:48:34 -07001547 effect_descriptor_t desc = {};
1548 if (data.read(&desc, sizeof(effect_descriptor_t)) != NO_ERROR) {
1549 ALOGE("b/23905951");
1550 }
Ytai Ben-Tsvi9cd89812020-07-01 17:12:06 -07001551 sp<media::IEffectClient> client =
1552 interface_cast<media::IEffectClient>(data.readStrongBinder());
Eric Laurentbe916aa2010-06-01 23:49:17 -07001553 int32_t priority = data.readInt32();
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001554 audio_io_handle_t output = (audio_io_handle_t) data.readInt32();
Glenn Kastend848eb42016-03-08 13:42:11 -08001555 audio_session_t sessionId = (audio_session_t) data.readInt32();
Eric Laurent94876032019-11-13 12:45:28 -08001556 AudioDeviceTypeAddr device;
1557 status_t status = NO_ERROR;
1558 if ((status = data.readParcelable(&device)) != NO_ERROR) {
1559 return status;
1560 }
Svet Ganovbe71aa22015-04-28 12:06:02 -07001561 const String16 opPackageName = data.readString16();
Eric Laurentb6436272016-12-07 19:24:50 -08001562 pid_t pid = (pid_t)data.readInt32();
Eric Laurent2fe0acd2020-03-13 14:30:46 -07001563 bool probe = data.readInt32() == 1;
Eric Laurentb6436272016-12-07 19:24:50 -08001564
Wei Jia983dca32015-09-10 09:47:29 -07001565 int id = 0;
1566 int enabled = 0;
Eric Laurent05bca2f2010-02-26 02:47:27 -08001567
Ytai Ben-Tsvi9cd89812020-07-01 17:12:06 -07001568 sp<media::IEffect> effect = createEffect(&desc, client, priority, output, sessionId,
1569 device, opPackageName, pid, probe, &status, &id, &enabled);
Eric Laurentbe916aa2010-06-01 23:49:17 -07001570 reply->writeInt32(status);
1571 reply->writeInt32(id);
1572 reply->writeInt32(enabled);
Marco Nelissen06b46062014-11-14 07:58:25 -08001573 reply->writeStrongBinder(IInterface::asBinder(effect));
Eric Laurentbe916aa2010-06-01 23:49:17 -07001574 reply->write(&desc, sizeof(effect_descriptor_t));
1575 return NO_ERROR;
1576 } break;
Eric Laurentde070132010-07-13 04:45:46 -07001577 case MOVE_EFFECTS: {
1578 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastend848eb42016-03-08 13:42:11 -08001579 audio_session_t session = (audio_session_t) data.readInt32();
Glenn Kasten72ef00d2012-01-17 11:09:42 -08001580 audio_io_handle_t srcOutput = (audio_io_handle_t) data.readInt32();
1581 audio_io_handle_t dstOutput = (audio_io_handle_t) data.readInt32();
Eric Laurentde070132010-07-13 04:45:46 -07001582 reply->writeInt32(moveEffects(session, srcOutput, dstOutput));
1583 return NO_ERROR;
1584 } break;
Eric Laurentb20cf7d2019-04-05 19:37:34 -07001585 case SET_EFFECT_SUSPENDED: {
1586 CHECK_INTERFACE(IAudioFlinger, data, reply);
1587 int effectId = data.readInt32();
1588 audio_session_t sessionId = (audio_session_t) data.readInt32();
1589 bool suspended = data.readInt32() == 1;
1590 setEffectSuspended(effectId, sessionId, suspended);
1591 return NO_ERROR;
1592 } break;
Eric Laurenta4c5a552012-03-29 10:12:40 -07001593 case LOAD_HW_MODULE: {
1594 CHECK_INTERFACE(IAudioFlinger, data, reply);
1595 reply->writeInt32(loadHwModule(data.readCString()));
1596 return NO_ERROR;
1597 } break;
Glenn Kastencc0f1cf2012-09-24 11:27:18 -07001598 case GET_PRIMARY_OUTPUT_SAMPLING_RATE: {
1599 CHECK_INTERFACE(IAudioFlinger, data, reply);
1600 reply->writeInt32(getPrimaryOutputSamplingRate());
1601 return NO_ERROR;
1602 } break;
1603 case GET_PRIMARY_OUTPUT_FRAME_COUNT: {
1604 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastene03dd222014-01-28 11:04:39 -08001605 reply->writeInt64(getPrimaryOutputFrameCount());
Glenn Kastencc0f1cf2012-09-24 11:27:18 -07001606 return NO_ERROR;
1607 } break;
Glenn Kasten4182c4e2013-07-15 14:45:07 -07001608 case SET_LOW_RAM_DEVICE: {
1609 CHECK_INTERFACE(IAudioFlinger, data, reply);
Andy Hung6f248bb2018-01-23 14:04:37 -08001610 int32_t isLowRamDevice;
1611 int64_t totalMemory;
1612 const status_t status =
1613 data.readInt32(&isLowRamDevice) ?:
1614 data.readInt64(&totalMemory) ?:
1615 setLowRamDevice(isLowRamDevice != 0, totalMemory);
1616 (void)reply->writeInt32(status);
Glenn Kasten4182c4e2013-07-15 14:45:07 -07001617 return NO_ERROR;
1618 } break;
Eric Laurent4b123402014-04-11 09:22:20 -07001619 case LIST_AUDIO_PORTS: {
1620 CHECK_INTERFACE(IAudioFlinger, data, reply);
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001621 unsigned int numPortsReq = data.readInt32();
1622 if (numPortsReq > MAX_ITEMS_PER_LIST) {
1623 numPortsReq = MAX_ITEMS_PER_LIST;
1624 }
1625 unsigned int numPorts = numPortsReq;
Eric Laurent4b123402014-04-11 09:22:20 -07001626 struct audio_port *ports =
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001627 (struct audio_port *)calloc(numPortsReq,
Eric Laurent4b123402014-04-11 09:22:20 -07001628 sizeof(struct audio_port));
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001629 if (ports == NULL) {
1630 reply->writeInt32(NO_MEMORY);
1631 reply->writeInt32(0);
1632 return NO_ERROR;
1633 }
1634 status_t status = listAudioPorts(&numPorts, ports);
Eric Laurent4b123402014-04-11 09:22:20 -07001635 reply->writeInt32(status);
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001636 reply->writeInt32(numPorts);
Eric Laurent4b123402014-04-11 09:22:20 -07001637 if (status == NO_ERROR) {
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001638 if (numPortsReq > numPorts) {
1639 numPortsReq = numPorts;
1640 }
1641 reply->write(ports, numPortsReq * sizeof(struct audio_port));
Eric Laurent4b123402014-04-11 09:22:20 -07001642 }
1643 free(ports);
1644 return NO_ERROR;
1645 } break;
1646 case GET_AUDIO_PORT: {
1647 CHECK_INTERFACE(IAudioFlinger, data, reply);
Jiabin Huang3a0cf472020-11-03 17:29:35 +00001648 struct audio_port port = {};
Eric Laurent4dacbc32020-10-07 13:48:21 -07001649 status_t status = data.read(&port, sizeof(struct audio_port));
1650 if (status != NO_ERROR) {
Wei Jiae995e472015-09-09 09:48:34 -07001651 ALOGE("b/23905951");
Eric Laurent4dacbc32020-10-07 13:48:21 -07001652 return status;
Wei Jiae995e472015-09-09 09:48:34 -07001653 }
Eric Laurent4dacbc32020-10-07 13:48:21 -07001654 status = AudioSanitizer::sanitizeAudioPort(&port);
1655 if (status == NO_ERROR) {
1656 status = getAudioPort(&port);
1657 }
Eric Laurent4b123402014-04-11 09:22:20 -07001658 reply->writeInt32(status);
1659 if (status == NO_ERROR) {
Jiabin Huang3a0cf472020-11-03 17:29:35 +00001660 reply->write(&port, sizeof(struct audio_port));
Eric Laurent4b123402014-04-11 09:22:20 -07001661 }
1662 return NO_ERROR;
1663 } break;
1664 case CREATE_AUDIO_PATCH: {
1665 CHECK_INTERFACE(IAudioFlinger, data, reply);
1666 struct audio_patch patch;
Eric Laurent4dacbc32020-10-07 13:48:21 -07001667 status_t status = data.read(&patch, sizeof(struct audio_patch));
1668 if (status != NO_ERROR) {
1669 return status;
Wei Jiae995e472015-09-09 09:48:34 -07001670 }
Eric Laurent4dacbc32020-10-07 13:48:21 -07001671 audio_patch_handle_t handle = AUDIO_PATCH_HANDLE_NONE;
1672 status = data.read(&handle, sizeof(audio_patch_handle_t));
1673 if (status != NO_ERROR) {
1674 ALOGE("b/23905951");
1675 return status;
1676 }
1677 status = AudioSanitizer::sanitizeAudioPatch(&patch);
1678 if (status == NO_ERROR) {
1679 status = createAudioPatch(&patch, &handle);
1680 }
Eric Laurent4b123402014-04-11 09:22:20 -07001681 reply->writeInt32(status);
1682 if (status == NO_ERROR) {
1683 reply->write(&handle, sizeof(audio_patch_handle_t));
1684 }
1685 return NO_ERROR;
1686 } break;
1687 case RELEASE_AUDIO_PATCH: {
1688 CHECK_INTERFACE(IAudioFlinger, data, reply);
1689 audio_patch_handle_t handle;
1690 data.read(&handle, sizeof(audio_patch_handle_t));
1691 status_t status = releaseAudioPatch(handle);
1692 reply->writeInt32(status);
1693 return NO_ERROR;
1694 } break;
1695 case LIST_AUDIO_PATCHES: {
1696 CHECK_INTERFACE(IAudioFlinger, data, reply);
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001697 unsigned int numPatchesReq = data.readInt32();
1698 if (numPatchesReq > MAX_ITEMS_PER_LIST) {
1699 numPatchesReq = MAX_ITEMS_PER_LIST;
1700 }
1701 unsigned int numPatches = numPatchesReq;
Eric Laurent4b123402014-04-11 09:22:20 -07001702 struct audio_patch *patches =
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001703 (struct audio_patch *)calloc(numPatchesReq,
Eric Laurent4b123402014-04-11 09:22:20 -07001704 sizeof(struct audio_patch));
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001705 if (patches == NULL) {
1706 reply->writeInt32(NO_MEMORY);
1707 reply->writeInt32(0);
1708 return NO_ERROR;
1709 }
1710 status_t status = listAudioPatches(&numPatches, patches);
Eric Laurent4b123402014-04-11 09:22:20 -07001711 reply->writeInt32(status);
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001712 reply->writeInt32(numPatches);
Eric Laurent4b123402014-04-11 09:22:20 -07001713 if (status == NO_ERROR) {
Eric Laurentf75c2fe2015-04-02 13:49:15 -07001714 if (numPatchesReq > numPatches) {
1715 numPatchesReq = numPatches;
1716 }
1717 reply->write(patches, numPatchesReq * sizeof(struct audio_patch));
Eric Laurent4b123402014-04-11 09:22:20 -07001718 }
1719 free(patches);
1720 return NO_ERROR;
1721 } break;
1722 case SET_AUDIO_PORT_CONFIG: {
1723 CHECK_INTERFACE(IAudioFlinger, data, reply);
1724 struct audio_port_config config;
Eric Laurent4dacbc32020-10-07 13:48:21 -07001725 status_t status = data.read(&config, sizeof(struct audio_port_config));
1726 if (status != NO_ERROR) {
1727 return status;
1728 }
1729 status = AudioSanitizer::sanitizeAudioPortConfig(&config);
1730 if (status == NO_ERROR) {
1731 status = setAudioPortConfig(&config);
1732 }
Eric Laurent4b123402014-04-11 09:22:20 -07001733 reply->writeInt32(status);
1734 return NO_ERROR;
1735 } break;
Glenn Kasten9eae0362016-04-19 09:09:14 -07001736 case GET_AUDIO_HW_SYNC_FOR_SESSION: {
Eric Laurent93c3d412014-08-01 14:48:35 -07001737 CHECK_INTERFACE(IAudioFlinger, data, reply);
Glenn Kastend848eb42016-03-08 13:42:11 -08001738 reply->writeInt32(getAudioHwSyncForSession((audio_session_t) data.readInt32()));
Eric Laurent93c3d412014-08-01 14:48:35 -07001739 return NO_ERROR;
1740 } break;
Eric Laurent72e3f392015-05-20 14:43:50 -07001741 case SYSTEM_READY: {
1742 CHECK_INTERFACE(IAudioFlinger, data, reply);
1743 systemReady();
1744 return NO_ERROR;
1745 } break;
Glenn Kasten4a8308b2016-04-18 14:10:01 -07001746 case FRAME_COUNT_HAL: {
1747 CHECK_INTERFACE(IAudioFlinger, data, reply);
1748 reply->writeInt64( frameCountHAL((audio_io_handle_t) data.readInt32()) );
1749 return NO_ERROR;
1750 } break;
jiabin9ff780e2018-03-19 18:19:52 -07001751 case GET_MICROPHONES: {
jiabin46a76fa2018-01-05 10:18:21 -08001752 CHECK_INTERFACE(IAudioFlinger, data, reply);
1753 std::vector<media::MicrophoneInfo> microphones;
1754 status_t status = getMicrophones(&microphones);
1755 reply->writeInt32(status);
1756 if (status == NO_ERROR) {
1757 reply->writeParcelableVector(microphones);
1758 }
1759 return NO_ERROR;
1760 }
Eric Laurent42896a02019-09-27 15:40:33 -07001761 case SET_AUDIO_HAL_PIDS: {
1762 CHECK_INTERFACE(IAudioFlinger, data, reply);
1763 std::vector<pid_t> pids;
1764 int32_t size;
1765 status_t status = data.readInt32(&size);
1766 if (status != NO_ERROR) {
1767 return status;
1768 }
1769 if (size < 0) {
1770 return BAD_VALUE;
1771 }
1772 if (size > MAX_ITEMS_PER_LIST) {
1773 size = MAX_ITEMS_PER_LIST;
1774 }
1775 for (int32_t i = 0; i < size; i++) {
1776 int32_t pid;
1777 status = data.readInt32(&pid);
1778 if (status != NO_ERROR) {
1779 return status;
1780 }
1781 pids.push_back(pid);
1782 }
1783 reply->writeInt32(setAudioHalPids(pids));
1784 return NO_ERROR;
1785 }
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001786 default:
1787 return BBinder::onTransact(code, data, reply, flags);
1788 }
1789}
1790
1791// ----------------------------------------------------------------------------
1792
Glenn Kasten40bc9062015-03-20 09:09:33 -07001793} // namespace android