blob: 03a0d862fe52e2907e6d9dfd6f2669db8f77bf3d [file] [log] [blame]
Kevin Rocard4bcd67f2018-02-28 14:33:38 -08001/*
2 * Copyright (C) 2016 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include <stdio.h>
18
19#define LOG_TAG "DeviceHalHidl"
20//#define LOG_NDEBUG 0
21
Kevin Rocard4bcd67f2018-02-28 14:33:38 -080022#include <cutils/native_handle.h>
23#include <hwbinder/IPCThreadState.h>
jiabindaf49952019-11-22 14:10:57 -080024#include <media/AudioContainers.h>
Kevin Rocard4bcd67f2018-02-28 14:33:38 -080025#include <utils/Log.h>
26
Mikhail Naganov247b5f92021-01-15 19:16:12 +000027#include PATH(android/hardware/audio/FILE_VERSION/IPrimaryDevice.h)
28#include <HidlUtils.h>
Kevin Rocardb9cfbf12018-02-23 19:11:06 -080029#include <common/all-versions/VersionUtils.h>
Mikhail Naganov247b5f92021-01-15 19:16:12 +000030#include <util/CoreUtils.h>
Kevin Rocardb9cfbf12018-02-23 19:11:06 -080031
Kevin Rocard4bcd67f2018-02-28 14:33:38 -080032#include "DeviceHalHidl.h"
Eric Laurentb82e6b72019-11-22 17:25:04 -080033#include "EffectHalHidl.h"
Mikhail Naganov247b5f92021-01-15 19:16:12 +000034#include "ParameterUtils.h"
Kevin Rocard4bcd67f2018-02-28 14:33:38 -080035#include "StreamHalHidl.h"
36
Mikhail Naganov9ccaa162018-12-12 10:27:29 -080037using ::android::hardware::audio::common::CPP_VERSION::implementation::HidlUtils;
Kevin Rocard7a9f05a2018-11-28 16:52:25 -080038using ::android::hardware::audio::common::utils::EnumBitfield;
Mikhail Naganov247b5f92021-01-15 19:16:12 +000039using ::android::hardware::audio::CPP_VERSION::implementation::CoreUtils;
Kevin Rocard4bcd67f2018-02-28 14:33:38 -080040using ::android::hardware::hidl_string;
41using ::android::hardware::hidl_vec;
42
43namespace android {
Kevin Rocard070e7512018-05-22 09:29:13 -070044namespace CPP_VERSION {
Kevin Rocard4bcd67f2018-02-28 14:33:38 -080045
Mikhail Naganov9ccaa162018-12-12 10:27:29 -080046using namespace ::android::hardware::audio::common::CPP_VERSION;
47using namespace ::android::hardware::audio::CPP_VERSION;
48
Eric Laurentb82e6b72019-11-22 17:25:04 -080049using EffectHalHidl = ::android::effect::CPP_VERSION::EffectHalHidl;
50
Kevin Rocard4bcd67f2018-02-28 14:33:38 -080051DeviceHalHidl::DeviceHalHidl(const sp<IDevice>& device)
52 : ConversionHelperHidl("Device"), mDevice(device),
53 mPrimaryDevice(IPrimaryDevice::castFrom(device)) {
54}
55
56DeviceHalHidl::~DeviceHalHidl() {
57 if (mDevice != 0) {
Mikhail Naganov3355e442019-11-20 14:20:01 -080058#if MAJOR_VERSION <= 5
Kevin Rocard4bcd67f2018-02-28 14:33:38 -080059 mDevice.clear();
60 hardware::IPCThreadState::self()->flushCommands();
Mikhail Naganov3355e442019-11-20 14:20:01 -080061#elif MAJOR_VERSION >= 6
62 mDevice->close();
63#endif
Kevin Rocard4bcd67f2018-02-28 14:33:38 -080064 }
65}
66
67status_t DeviceHalHidl::getSupportedDevices(uint32_t*) {
68 // Obsolete.
69 return INVALID_OPERATION;
70}
71
72status_t DeviceHalHidl::initCheck() {
73 if (mDevice == 0) return NO_INIT;
74 return processReturn("initCheck", mDevice->initCheck());
75}
76
77status_t DeviceHalHidl::setVoiceVolume(float volume) {
78 if (mDevice == 0) return NO_INIT;
79 if (mPrimaryDevice == 0) return INVALID_OPERATION;
80 return processReturn("setVoiceVolume", mPrimaryDevice->setVoiceVolume(volume));
81}
82
83status_t DeviceHalHidl::setMasterVolume(float volume) {
84 if (mDevice == 0) return NO_INIT;
Mikhail Naganovae1f6622019-02-21 15:20:05 -080085 return processReturn("setMasterVolume", mDevice->setMasterVolume(volume));
Kevin Rocard4bcd67f2018-02-28 14:33:38 -080086}
87
88status_t DeviceHalHidl::getMasterVolume(float *volume) {
89 if (mDevice == 0) return NO_INIT;
Kevin Rocard4bcd67f2018-02-28 14:33:38 -080090 Result retval;
Mikhail Naganovae1f6622019-02-21 15:20:05 -080091 Return<void> ret = mDevice->getMasterVolume(
Kevin Rocard4bcd67f2018-02-28 14:33:38 -080092 [&](Result r, float v) {
93 retval = r;
94 if (retval == Result::OK) {
95 *volume = v;
96 }
97 });
98 return processReturn("getMasterVolume", ret, retval);
99}
100
101status_t DeviceHalHidl::setMode(audio_mode_t mode) {
102 if (mDevice == 0) return NO_INIT;
103 if (mPrimaryDevice == 0) return INVALID_OPERATION;
104 return processReturn("setMode", mPrimaryDevice->setMode(AudioMode(mode)));
105}
106
107status_t DeviceHalHidl::setMicMute(bool state) {
108 if (mDevice == 0) return NO_INIT;
109 return processReturn("setMicMute", mDevice->setMicMute(state));
110}
111
112status_t DeviceHalHidl::getMicMute(bool *state) {
113 if (mDevice == 0) return NO_INIT;
114 Result retval;
115 Return<void> ret = mDevice->getMicMute(
116 [&](Result r, bool mute) {
117 retval = r;
118 if (retval == Result::OK) {
119 *state = mute;
120 }
121 });
122 return processReturn("getMicMute", ret, retval);
123}
124
125status_t DeviceHalHidl::setMasterMute(bool state) {
126 if (mDevice == 0) return NO_INIT;
127 return processReturn("setMasterMute", mDevice->setMasterMute(state));
128}
129
130status_t DeviceHalHidl::getMasterMute(bool *state) {
131 if (mDevice == 0) return NO_INIT;
132 Result retval;
133 Return<void> ret = mDevice->getMasterMute(
134 [&](Result r, bool mute) {
135 retval = r;
136 if (retval == Result::OK) {
137 *state = mute;
138 }
139 });
140 return processReturn("getMasterMute", ret, retval);
141}
142
143status_t DeviceHalHidl::setParameters(const String8& kvPairs) {
144 if (mDevice == 0) return NO_INIT;
145 hidl_vec<ParameterValue> hidlParams;
146 status_t status = parametersFromHal(kvPairs, &hidlParams);
147 if (status != OK) return status;
Kevin Rocardb9cfbf12018-02-23 19:11:06 -0800148 // TODO: change the API so that context and kvPairs are separated
149 return processReturn("setParameters",
150 utils::setParameters(mDevice, {} /* context */, hidlParams));
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800151}
152
153status_t DeviceHalHidl::getParameters(const String8& keys, String8 *values) {
154 values->clear();
155 if (mDevice == 0) return NO_INIT;
156 hidl_vec<hidl_string> hidlKeys;
157 status_t status = keysFromHal(keys, &hidlKeys);
158 if (status != OK) return status;
159 Result retval;
Kevin Rocardb9cfbf12018-02-23 19:11:06 -0800160 Return<void> ret = utils::getParameters(mDevice,
161 {} /* context */,
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800162 hidlKeys,
163 [&](Result r, const hidl_vec<ParameterValue>& parameters) {
164 retval = r;
165 if (retval == Result::OK) {
166 parametersToHal(parameters, values);
167 }
168 });
169 return processReturn("getParameters", ret, retval);
170}
171
172status_t DeviceHalHidl::getInputBufferSize(
173 const struct audio_config *config, size_t *size) {
174 if (mDevice == 0) return NO_INIT;
175 AudioConfig hidlConfig;
Mikhail Naganov05e03192020-12-14 23:19:54 +0000176 HidlUtils::audioConfigFromHal(*config, true /*isInput*/, &hidlConfig);
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800177 Result retval;
178 Return<void> ret = mDevice->getInputBufferSize(
179 hidlConfig,
180 [&](Result r, uint64_t bufferSize) {
181 retval = r;
182 if (retval == Result::OK) {
183 *size = static_cast<size_t>(bufferSize);
184 }
185 });
186 return processReturn("getInputBufferSize", ret, retval);
187}
188
189status_t DeviceHalHidl::openOutputStream(
190 audio_io_handle_t handle,
jiabin43810402019-10-24 14:58:31 -0700191 audio_devices_t deviceType,
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800192 audio_output_flags_t flags,
193 struct audio_config *config,
194 const char *address,
195 sp<StreamOutHalInterface> *outStream) {
196 if (mDevice == 0) return NO_INIT;
197 DeviceAddress hidlDevice;
Mikhail Naganov247b5f92021-01-15 19:16:12 +0000198 if (status_t status = CoreUtils::deviceAddressFromHal(deviceType, address, &hidlDevice);
199 status != OK) {
200 return status;
201 }
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800202 AudioConfig hidlConfig;
Mikhail Naganov247b5f92021-01-15 19:16:12 +0000203 if (status_t status = HidlUtils::audioConfigFromHal(*config, false /*isInput*/, &hidlConfig);
204 status != OK) {
205 return status;
206 }
207 CoreUtils::AudioOutputFlags hidlFlags;
208 if (status_t status = CoreUtils::audioOutputFlagsFromHal(flags, &hidlFlags); status != OK) {
209 return status;
210 }
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800211 Result retval = Result::NOT_INITIALIZED;
212 Return<void> ret = mDevice->openOutputStream(
Mikhail Naganov247b5f92021-01-15 19:16:12 +0000213 handle, hidlDevice, hidlConfig, hidlFlags,
Kevin Rocard3d48dce2018-11-08 17:16:57 -0800214#if MAJOR_VERSION >= 4
Kevin Rocardb9cfbf12018-02-23 19:11:06 -0800215 {} /* metadata */,
Kevin Rocard070e7512018-05-22 09:29:13 -0700216#endif
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800217 [&](Result r, const sp<IStreamOut>& result, const AudioConfig& suggestedConfig) {
218 retval = r;
219 if (retval == Result::OK) {
220 *outStream = new StreamOutHalHidl(result);
221 }
222 HidlUtils::audioConfigToHal(suggestedConfig, config);
223 });
224 return processReturn("openOutputStream", ret, retval);
225}
226
227status_t DeviceHalHidl::openInputStream(
228 audio_io_handle_t handle,
229 audio_devices_t devices,
230 struct audio_config *config,
231 audio_input_flags_t flags,
232 const char *address,
233 audio_source_t source,
Mikhail Naganovb4e037e2019-01-14 15:56:33 -0800234 audio_devices_t outputDevice,
235 const char *outputDeviceAddress,
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800236 sp<StreamInHalInterface> *inStream) {
237 if (mDevice == 0) return NO_INIT;
238 DeviceAddress hidlDevice;
Mikhail Naganov247b5f92021-01-15 19:16:12 +0000239 if (status_t status = CoreUtils::deviceAddressFromHal(devices, address, &hidlDevice);
240 status != OK) {
241 return status;
242 }
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800243 AudioConfig hidlConfig;
Mikhail Naganov247b5f92021-01-15 19:16:12 +0000244 if (status_t status = HidlUtils::audioConfigFromHal(*config, true /*isInput*/, &hidlConfig);
245 status != OK) {
246 return status;
247 }
248 CoreUtils::AudioInputFlags hidlFlags;
Dean Wheatleyea186342021-03-12 16:49:47 +1100249#if MAJOR_VERSION <= 5
250 // Some flags were specific to framework and must not leak to the HAL.
251 flags = static_cast<audio_input_flags_t>(flags & ~AUDIO_INPUT_FLAG_DIRECT);
252#endif
Mikhail Naganov247b5f92021-01-15 19:16:12 +0000253 if (status_t status = CoreUtils::audioInputFlagsFromHal(flags, &hidlFlags); status != OK) {
254 return status;
255 }
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800256 Result retval = Result::NOT_INITIALIZED;
Kevin Rocard070e7512018-05-22 09:29:13 -0700257#if MAJOR_VERSION == 2
Mikhail Naganovd9499eb2018-12-17 16:23:22 -0800258 auto sinkMetadata = AudioSource(source);
Kevin Rocard3d48dce2018-11-08 17:16:57 -0800259#elif MAJOR_VERSION >= 4
Kevin Rocardb9cfbf12018-02-23 19:11:06 -0800260 // TODO: correctly propagate the tracks sources and volume
261 // for now, only send the main source at 1dbfs
Mikhail Naganov247b5f92021-01-15 19:16:12 +0000262 AudioSource hidlSource;
263 if (status_t status = HidlUtils::audioSourceFromHal(source, &hidlSource); status != OK) {
264 return status;
265 }
266 SinkMetadata sinkMetadata = {{{ .source = std::move(hidlSource), .gain = 1 }}};
Kevin Rocard070e7512018-05-22 09:29:13 -0700267#endif
Mikhail Naganovb4e037e2019-01-14 15:56:33 -0800268#if MAJOR_VERSION < 5
269 (void)outputDevice;
270 (void)outputDeviceAddress;
271#else
Mikhail Naganovc4258802021-02-08 17:14:17 -0800272#if MAJOR_VERSION >= 7
273 (void)HidlUtils::audioChannelMaskFromHal(
274 AUDIO_CHANNEL_NONE, true /*isInput*/, &sinkMetadata.tracks[0].channelMask);
275#endif
Mikhail Naganovb4e037e2019-01-14 15:56:33 -0800276 if (outputDevice != AUDIO_DEVICE_NONE) {
277 DeviceAddress hidlOutputDevice;
Mikhail Naganov247b5f92021-01-15 19:16:12 +0000278 if (status_t status = CoreUtils::deviceAddressFromHal(
279 outputDevice, outputDeviceAddress, &hidlOutputDevice); status != OK) {
280 return status;
281 }
Mikhail Naganovb4e037e2019-01-14 15:56:33 -0800282 sinkMetadata.tracks[0].destination.device(std::move(hidlOutputDevice));
283 }
284#endif
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800285 Return<void> ret = mDevice->openInputStream(
Mikhail Naganov247b5f92021-01-15 19:16:12 +0000286 handle, hidlDevice, hidlConfig, hidlFlags, sinkMetadata,
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800287 [&](Result r, const sp<IStreamIn>& result, const AudioConfig& suggestedConfig) {
288 retval = r;
289 if (retval == Result::OK) {
290 *inStream = new StreamInHalHidl(result);
291 }
292 HidlUtils::audioConfigToHal(suggestedConfig, config);
293 });
294 return processReturn("openInputStream", ret, retval);
295}
296
297status_t DeviceHalHidl::supportsAudioPatches(bool *supportsPatches) {
298 if (mDevice == 0) return NO_INIT;
299 return processReturn("supportsAudioPatches", mDevice->supportsAudioPatches(), supportsPatches);
300}
301
302status_t DeviceHalHidl::createAudioPatch(
303 unsigned int num_sources,
304 const struct audio_port_config *sources,
305 unsigned int num_sinks,
306 const struct audio_port_config *sinks,
307 audio_patch_handle_t *patch) {
308 if (mDevice == 0) return NO_INIT;
Eric Laurent8711cfd2019-06-10 18:06:33 -0700309 if (patch == nullptr) return BAD_VALUE;
310
Mikhail Naganov73bdf572019-12-11 12:34:15 -0800311#if MAJOR_VERSION < 6
Eric Laurent8711cfd2019-06-10 18:06:33 -0700312 if (*patch != AUDIO_PATCH_HANDLE_NONE) {
313 status_t status = releaseAudioPatch(*patch);
314 ALOGW_IF(status != NO_ERROR, "%s error %d releasing patch handle %d",
315 __func__, status, *patch);
Mikhail Naganov73bdf572019-12-11 12:34:15 -0800316 *patch = AUDIO_PATCH_HANDLE_NONE;
Eric Laurent8711cfd2019-06-10 18:06:33 -0700317 }
Mikhail Naganov73bdf572019-12-11 12:34:15 -0800318#endif
Eric Laurent8711cfd2019-06-10 18:06:33 -0700319
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800320 hidl_vec<AudioPortConfig> hidlSources, hidlSinks;
321 HidlUtils::audioPortConfigsFromHal(num_sources, sources, &hidlSources);
322 HidlUtils::audioPortConfigsFromHal(num_sinks, sinks, &hidlSinks);
Mikhail Naganov73bdf572019-12-11 12:34:15 -0800323 Result retval = Result::OK;
324 Return<void> ret;
325 std::string methodName = "createAudioPatch";
326 if (*patch == AUDIO_PATCH_HANDLE_NONE) { // always true for MAJOR_VERSION < 6
327 ret = mDevice->createAudioPatch(
328 hidlSources, hidlSinks,
329 [&](Result r, AudioPatchHandle hidlPatch) {
330 retval = r;
331 if (retval == Result::OK) {
332 *patch = static_cast<audio_patch_handle_t>(hidlPatch);
333 }
334 });
335 } else {
336#if MAJOR_VERSION >= 6
337 ret = mDevice->updateAudioPatch(
338 *patch,
339 hidlSources, hidlSinks,
340 [&](Result r, AudioPatchHandle hidlPatch) {
341 retval = r;
342 if (retval == Result::OK) {
343 *patch = static_cast<audio_patch_handle_t>(hidlPatch);
344 }
345 });
346 methodName = "updateAudioPatch";
347#endif
348 }
349 return processReturn(methodName.c_str(), ret, retval);
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800350}
351
352status_t DeviceHalHidl::releaseAudioPatch(audio_patch_handle_t patch) {
353 if (mDevice == 0) return NO_INIT;
354 return processReturn("releaseAudioPatch", mDevice->releaseAudioPatch(patch));
355}
356
357status_t DeviceHalHidl::getAudioPort(struct audio_port *port) {
358 if (mDevice == 0) return NO_INIT;
359 AudioPort hidlPort;
360 HidlUtils::audioPortFromHal(*port, &hidlPort);
361 Result retval;
362 Return<void> ret = mDevice->getAudioPort(
363 hidlPort,
364 [&](Result r, const AudioPort& p) {
365 retval = r;
366 if (retval == Result::OK) {
367 HidlUtils::audioPortToHal(p, port);
368 }
369 });
370 return processReturn("getAudioPort", ret, retval);
371}
372
jiabinb4fed192020-09-22 14:45:40 -0700373status_t DeviceHalHidl::getAudioPort(struct audio_port_v7 *port) {
374 if (mDevice == 0) return NO_INIT;
375 status_t status = NO_ERROR;
376#if MAJOR_VERSION >= 7
377 AudioPort hidlPort;
378 HidlUtils::audioPortFromHal(*port, &hidlPort);
379 Result retval;
380 Return<void> ret = mDevice->getAudioPort(
381 hidlPort,
382 [&](Result r, const AudioPort& p) {
383 retval = r;
384 if (retval == Result::OK) {
385 HidlUtils::audioPortToHal(p, port);
386 }
387 });
388 status = processReturn("getAudioPort", ret, retval);
389#else
390 struct audio_port audioPort = {};
391 audio_populate_audio_port(port, &audioPort);
392 status = getAudioPort(&audioPort);
393 if (status == NO_ERROR) {
394 audio_populate_audio_port_v7(&audioPort, port);
395 }
396#endif
397 return status;
398}
399
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800400status_t DeviceHalHidl::setAudioPortConfig(const struct audio_port_config *config) {
401 if (mDevice == 0) return NO_INIT;
402 AudioPortConfig hidlConfig;
403 HidlUtils::audioPortConfigFromHal(*config, &hidlConfig);
404 return processReturn("setAudioPortConfig", mDevice->setAudioPortConfig(hidlConfig));
405}
406
Kevin Rocard070e7512018-05-22 09:29:13 -0700407#if MAJOR_VERSION == 2
408status_t DeviceHalHidl::getMicrophones(
409 std::vector<media::MicrophoneInfo> *microphonesInfo __unused) {
410 if (mDevice == 0) return NO_INIT;
411 return INVALID_OPERATION;
412}
Kevin Rocard3d48dce2018-11-08 17:16:57 -0800413#elif MAJOR_VERSION >= 4
jiabin9ff780e2018-03-19 18:19:52 -0700414status_t DeviceHalHidl::getMicrophones(std::vector<media::MicrophoneInfo> *microphonesInfo) {
415 if (mDevice == 0) return NO_INIT;
416 Result retval;
417 Return<void> ret = mDevice->getMicrophones(
418 [&](Result r, hidl_vec<MicrophoneInfo> micArrayHal) {
419 retval = r;
420 for (size_t k = 0; k < micArrayHal.size(); k++) {
421 audio_microphone_characteristic_t dst;
422 //convert
Mikhail Naganov247b5f92021-01-15 19:16:12 +0000423 (void)CoreUtils::microphoneInfoToHal(micArrayHal[k], &dst);
jiabin9ff780e2018-03-19 18:19:52 -0700424 media::MicrophoneInfo microphone = media::MicrophoneInfo(dst);
425 microphonesInfo->push_back(microphone);
426 }
427 });
428 return processReturn("getMicrophones", ret, retval);
429}
Kevin Rocard070e7512018-05-22 09:29:13 -0700430#endif
jiabin9ff780e2018-03-19 18:19:52 -0700431
Eric Laurentb82e6b72019-11-22 17:25:04 -0800432#if MAJOR_VERSION >= 6
433status_t DeviceHalHidl::addDeviceEffect(
434 audio_port_handle_t device, sp<EffectHalInterface> effect) {
435 if (mDevice == 0) return NO_INIT;
436 return processReturn("addDeviceEffect", mDevice->addDeviceEffect(
437 static_cast<AudioPortHandle>(device),
438 static_cast<EffectHalHidl*>(effect.get())->effectId()));
439}
440#else
441status_t DeviceHalHidl::addDeviceEffect(
442 audio_port_handle_t device __unused, sp<EffectHalInterface> effect __unused) {
443 return INVALID_OPERATION;
444}
445#endif
446
447#if MAJOR_VERSION >= 6
448status_t DeviceHalHidl::removeDeviceEffect(
449 audio_port_handle_t device, sp<EffectHalInterface> effect) {
450 if (mDevice == 0) return NO_INIT;
451 return processReturn("removeDeviceEffect", mDevice->removeDeviceEffect(
452 static_cast<AudioPortHandle>(device),
453 static_cast<EffectHalHidl*>(effect.get())->effectId()));
454}
455#else
456status_t DeviceHalHidl::removeDeviceEffect(
457 audio_port_handle_t device __unused, sp<EffectHalInterface> effect __unused) {
458 return INVALID_OPERATION;
459}
460#endif
461
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800462status_t DeviceHalHidl::dump(int fd) {
463 if (mDevice == 0) return NO_INIT;
464 native_handle_t* hidlHandle = native_handle_create(1, 0);
465 hidlHandle->data[0] = fd;
Kevin Rocardb9cfbf12018-02-23 19:11:06 -0800466 Return<void> ret = mDevice->debug(hidlHandle, {} /* options */);
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800467 native_handle_delete(hidlHandle);
468 return processReturn("dump", ret);
469}
470
Kevin Rocard070e7512018-05-22 09:29:13 -0700471} // namespace CPP_VERSION
Kevin Rocard4bcd67f2018-02-28 14:33:38 -0800472} // namespace android