blob: 7d8222f91c53cab1ded61a0e1cd44639b0b231d3 [file] [log] [blame]
Eric Laurent801a1182010-06-09 00:17:29 -07001/*
2**
3** Copyright 2010, 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
19//#define LOG_NDEBUG 0
20#define LOG_TAG "AudioEffect"
21
22#include <stdint.h>
23#include <sys/types.h>
24#include <limits.h>
25
26#include <private/media/AudioEffectShared.h>
27#include <media/AudioEffect.h>
28
29#include <utils/Log.h>
Eric Laurent801a1182010-06-09 00:17:29 -070030#include <binder/IPCThreadState.h>
31
32
33
34namespace android {
35
36// ---------------------------------------------------------------------------
37
38AudioEffect::AudioEffect()
39 : mStatus(NO_INIT)
40{
41}
42
43
44AudioEffect::AudioEffect(const effect_uuid_t *type,
45 const effect_uuid_t *uuid,
46 int32_t priority,
47 effect_callback_t cbf,
48 void* user,
49 int sessionId,
Eric Laurent7c7f10b2011-06-17 21:29:58 -070050 audio_io_handle_t io
Eric Laurent801a1182010-06-09 00:17:29 -070051 )
52 : mStatus(NO_INIT)
53{
Eric Laurent7c7f10b2011-06-17 21:29:58 -070054 mStatus = set(type, uuid, priority, cbf, user, sessionId, io);
Eric Laurent801a1182010-06-09 00:17:29 -070055}
56
57AudioEffect::AudioEffect(const char *typeStr,
58 const char *uuidStr,
59 int32_t priority,
60 effect_callback_t cbf,
61 void* user,
62 int sessionId,
Eric Laurent7c7f10b2011-06-17 21:29:58 -070063 audio_io_handle_t io
Eric Laurent801a1182010-06-09 00:17:29 -070064 )
65 : mStatus(NO_INIT)
66{
67 effect_uuid_t type;
68 effect_uuid_t *pType = NULL;
69 effect_uuid_t uuid;
70 effect_uuid_t *pUuid = NULL;
71
Steve Block3856b092011-10-20 11:56:00 +010072 ALOGV("Constructor string\n - type: %s\n - uuid: %s", typeStr, uuidStr);
Eric Laurent801a1182010-06-09 00:17:29 -070073
74 if (typeStr != NULL) {
75 if (stringToGuid(typeStr, &type) == NO_ERROR) {
76 pType = &type;
77 }
78 }
79
80 if (uuidStr != NULL) {
81 if (stringToGuid(uuidStr, &uuid) == NO_ERROR) {
82 pUuid = &uuid;
83 }
84 }
85
Eric Laurent7c7f10b2011-06-17 21:29:58 -070086 mStatus = set(pType, pUuid, priority, cbf, user, sessionId, io);
Eric Laurent801a1182010-06-09 00:17:29 -070087}
88
89status_t AudioEffect::set(const effect_uuid_t *type,
90 const effect_uuid_t *uuid,
91 int32_t priority,
92 effect_callback_t cbf,
93 void* user,
94 int sessionId,
Eric Laurent7c7f10b2011-06-17 21:29:58 -070095 audio_io_handle_t io)
Eric Laurent801a1182010-06-09 00:17:29 -070096{
97 sp<IEffect> iEffect;
98 sp<IMemory> cblk;
99 int enabled;
100
Steve Block3856b092011-10-20 11:56:00 +0100101 ALOGV("set %p mUserData: %p uuid: %p timeLow %08x", this, user, type, type ? type->timeLow : 0);
Eric Laurent801a1182010-06-09 00:17:29 -0700102
103 if (mIEffect != 0) {
Steve Block5ff1dd52012-01-05 23:22:43 +0000104 ALOGW("Effect already in use");
Eric Laurent801a1182010-06-09 00:17:29 -0700105 return INVALID_OPERATION;
106 }
107
108 const sp<IAudioFlinger>& audioFlinger = AudioSystem::get_audio_flinger();
109 if (audioFlinger == 0) {
Steve Block29357bc2012-01-06 19:20:56 +0000110 ALOGE("set(): Could not get audioflinger");
Eric Laurent801a1182010-06-09 00:17:29 -0700111 return NO_INIT;
112 }
113
114 if (type == NULL && uuid == NULL) {
Steve Block5ff1dd52012-01-05 23:22:43 +0000115 ALOGW("Must specify at least type or uuid");
Eric Laurent801a1182010-06-09 00:17:29 -0700116 return BAD_VALUE;
117 }
118
119 mPriority = priority;
120 mCbf = cbf;
121 mUserData = user;
122 mSessionId = sessionId;
123
124 memset(&mDescriptor, 0, sizeof(effect_descriptor_t));
Glenn Kastena189a682012-02-20 12:16:30 -0800125 mDescriptor.type = *(type != NULL ? type : EFFECT_UUID_NULL);
126 mDescriptor.uuid = *(uuid != NULL ? uuid : EFFECT_UUID_NULL);
Eric Laurent801a1182010-06-09 00:17:29 -0700127
128 mIEffectClient = new EffectClient(this);
129
Glenn Kasten8d6cc842012-02-03 11:06:53 -0800130 iEffect = audioFlinger->createEffect((effect_descriptor_t *)&mDescriptor,
Eric Laurent7c7f10b2011-06-17 21:29:58 -0700131 mIEffectClient, priority, io, mSessionId, &mStatus, &mId, &enabled);
Eric Laurent801a1182010-06-09 00:17:29 -0700132
133 if (iEffect == 0 || (mStatus != NO_ERROR && mStatus != ALREADY_EXISTS)) {
Steve Block29357bc2012-01-06 19:20:56 +0000134 ALOGE("set(): AudioFlinger could not create effect, status: %d", mStatus);
Eric Laurent801a1182010-06-09 00:17:29 -0700135 return mStatus;
136 }
137
138 mEnabled = (volatile int32_t)enabled;
139
140 mIEffect = iEffect;
141 cblk = iEffect->getCblk();
142 if (cblk == 0) {
143 mStatus = NO_INIT;
Steve Block29357bc2012-01-06 19:20:56 +0000144 ALOGE("Could not get control block");
Eric Laurent801a1182010-06-09 00:17:29 -0700145 return mStatus;
146 }
147
Eric Laurent801a1182010-06-09 00:17:29 -0700148 mCblkMemory = cblk;
149 mCblk = static_cast<effect_param_cblk_t*>(cblk->pointer());
150 int bufOffset = ((sizeof(effect_param_cblk_t) - 1) / sizeof(int) + 1) * sizeof(int);
151 mCblk->buffer = (uint8_t *)mCblk + bufOffset;
152
Marco Nelissen06b46062014-11-14 07:58:25 -0800153 IInterface::asBinder(iEffect)->linkToDeath(mIEffectClient);
Jean-Michel Trivia0fd9ca2014-09-18 14:07:18 -0700154 mClientPid = IPCThreadState::self()->getCallingPid();
155 ALOGV("set() %p OK effect: %s id: %d status %d enabled %d pid %d", this, mDescriptor.name, mId,
156 mStatus, mEnabled, mClientPid);
157
158 if (mSessionId > AUDIO_SESSION_OUTPUT_MIX) {
159 AudioSystem::acquireAudioSessionId(mSessionId, mClientPid);
160 }
Eric Laurent801a1182010-06-09 00:17:29 -0700161
162 return mStatus;
163}
164
165
166AudioEffect::~AudioEffect()
167{
Steve Block3856b092011-10-20 11:56:00 +0100168 ALOGV("Destructor %p", this);
Eric Laurent801a1182010-06-09 00:17:29 -0700169
170 if (mStatus == NO_ERROR || mStatus == ALREADY_EXISTS) {
Jean-Michel Trivia0fd9ca2014-09-18 14:07:18 -0700171 if (mSessionId > AUDIO_SESSION_OUTPUT_MIX) {
172 AudioSystem::releaseAudioSessionId(mSessionId, mClientPid);
173 }
Eric Laurent801a1182010-06-09 00:17:29 -0700174 if (mIEffect != NULL) {
175 mIEffect->disconnect();
Marco Nelissen06b46062014-11-14 07:58:25 -0800176 IInterface::asBinder(mIEffect)->unlinkToDeath(mIEffectClient);
Eric Laurent801a1182010-06-09 00:17:29 -0700177 }
Glenn Kastene53b9ea2012-03-12 16:29:55 -0700178 IPCThreadState::self()->flushCommands();
Eric Laurent801a1182010-06-09 00:17:29 -0700179 }
180 mIEffect.clear();
181 mIEffectClient.clear();
182 mCblkMemory.clear();
183}
184
185
186status_t AudioEffect::initCheck() const
187{
188 return mStatus;
189}
190
191// -------------------------------------------------------------------------
192
193effect_descriptor_t AudioEffect::descriptor() const
194{
195 return mDescriptor;
196}
197
Eric Laurentda7581b2010-07-02 08:12:41 -0700198bool AudioEffect::getEnabled() const
Eric Laurent801a1182010-06-09 00:17:29 -0700199{
200 return (mEnabled != 0);
201}
202
Eric Laurentda7581b2010-07-02 08:12:41 -0700203status_t AudioEffect::setEnabled(bool enabled)
Eric Laurent801a1182010-06-09 00:17:29 -0700204{
205 if (mStatus != NO_ERROR) {
Glenn Kastenf063b492012-02-17 16:24:10 -0800206 return (mStatus == ALREADY_EXISTS) ? (status_t) INVALID_OPERATION : mStatus;
Eric Laurent801a1182010-06-09 00:17:29 -0700207 }
Eric Laurent801a1182010-06-09 00:17:29 -0700208
Eric Laurentf5aafb22010-11-18 08:40:16 -0800209 status_t status = NO_ERROR;
210
211 AutoMutex lock(mLock);
212 if (enabled != mEnabled) {
213 if (enabled) {
Steve Block3856b092011-10-20 11:56:00 +0100214 ALOGV("enable %p", this);
Eric Laurentf5aafb22010-11-18 08:40:16 -0800215 status = mIEffect->enable();
216 } else {
Steve Block3856b092011-10-20 11:56:00 +0100217 ALOGV("disable %p", this);
Eric Laurentf5aafb22010-11-18 08:40:16 -0800218 status = mIEffect->disable();
Eric Laurentda7581b2010-07-02 08:12:41 -0700219 }
Eric Laurentf5aafb22010-11-18 08:40:16 -0800220 if (status == NO_ERROR) {
221 mEnabled = enabled;
Eric Laurentda7581b2010-07-02 08:12:41 -0700222 }
Eric Laurent801a1182010-06-09 00:17:29 -0700223 }
Eric Laurentf5aafb22010-11-18 08:40:16 -0800224 return status;
Eric Laurent801a1182010-06-09 00:17:29 -0700225}
226
Eric Laurent25f43952010-07-28 05:40:18 -0700227status_t AudioEffect::command(uint32_t cmdCode,
228 uint32_t cmdSize,
229 void *cmdData,
230 uint32_t *replySize,
231 void *replyData)
Eric Laurent801a1182010-06-09 00:17:29 -0700232{
233 if (mStatus != NO_ERROR && mStatus != ALREADY_EXISTS) {
Steve Block3856b092011-10-20 11:56:00 +0100234 ALOGV("command() bad status %d", mStatus);
John Grossmanaf7d8182012-01-11 12:23:42 -0800235 return mStatus;
Eric Laurent801a1182010-06-09 00:17:29 -0700236 }
237
Eric Laurentf5aafb22010-11-18 08:40:16 -0800238 if (cmdCode == EFFECT_CMD_ENABLE || cmdCode == EFFECT_CMD_DISABLE) {
239 if (mEnabled == (cmdCode == EFFECT_CMD_ENABLE)) {
240 return NO_ERROR;
241 }
242 if (replySize == NULL || *replySize != sizeof(status_t) || replyData == NULL) {
243 return BAD_VALUE;
244 }
245 mLock.lock();
Eric Laurent0fa449c2010-09-24 11:52:04 -0700246 }
247
Eric Laurent8569f0d2010-07-29 23:43:43 -0700248 status_t status = mIEffect->command(cmdCode, cmdSize, cmdData, replySize, replyData);
Eric Laurent0fa449c2010-09-24 11:52:04 -0700249
250 if (cmdCode == EFFECT_CMD_ENABLE || cmdCode == EFFECT_CMD_DISABLE) {
Eric Laurentf5aafb22010-11-18 08:40:16 -0800251 if (status == NO_ERROR) {
252 status = *(status_t *)replyData;
Eric Laurent0fa449c2010-09-24 11:52:04 -0700253 }
Eric Laurentf5aafb22010-11-18 08:40:16 -0800254 if (status == NO_ERROR) {
255 mEnabled = (cmdCode == EFFECT_CMD_ENABLE);
Eric Laurent0fa449c2010-09-24 11:52:04 -0700256 }
Eric Laurentf5aafb22010-11-18 08:40:16 -0800257 mLock.unlock();
Eric Laurent8569f0d2010-07-29 23:43:43 -0700258 }
259
Eric Laurent8569f0d2010-07-29 23:43:43 -0700260 return status;
Eric Laurent801a1182010-06-09 00:17:29 -0700261}
262
263
264status_t AudioEffect::setParameter(effect_param_t *param)
265{
266 if (mStatus != NO_ERROR) {
Glenn Kastenf063b492012-02-17 16:24:10 -0800267 return (mStatus == ALREADY_EXISTS) ? (status_t) INVALID_OPERATION : mStatus;
Eric Laurent801a1182010-06-09 00:17:29 -0700268 }
269
270 if (param == NULL || param->psize == 0 || param->vsize == 0) {
271 return BAD_VALUE;
272 }
273
Eric Laurent25f43952010-07-28 05:40:18 -0700274 uint32_t size = sizeof(int);
275 uint32_t psize = ((param->psize - 1) / sizeof(int) + 1) * sizeof(int) + param->vsize;
Eric Laurent801a1182010-06-09 00:17:29 -0700276
Glenn Kasten85ab62c2012-11-01 11:11:38 -0700277 ALOGV("setParameter: param: %d, param2: %d", *(int *)param->data,
278 (param->psize == 8) ? *((int *)param->data + 1): -1);
Eric Laurent801a1182010-06-09 00:17:29 -0700279
Glenn Kasten85ab62c2012-11-01 11:11:38 -0700280 return mIEffect->command(EFFECT_CMD_SET_PARAM, sizeof (effect_param_t) + psize, param, &size,
281 &param->status);
Eric Laurent801a1182010-06-09 00:17:29 -0700282}
283
284status_t AudioEffect::setParameterDeferred(effect_param_t *param)
285{
286 if (mStatus != NO_ERROR) {
Glenn Kastenf063b492012-02-17 16:24:10 -0800287 return (mStatus == ALREADY_EXISTS) ? (status_t) INVALID_OPERATION : mStatus;
Eric Laurent801a1182010-06-09 00:17:29 -0700288 }
289
290 if (param == NULL || param->psize == 0 || param->vsize == 0) {
291 return BAD_VALUE;
292 }
293
294 Mutex::Autolock _l(mCblk->lock);
295
296 int psize = ((param->psize - 1) / sizeof(int) + 1) * sizeof(int) + param->vsize;
297 int size = ((sizeof(effect_param_t) + psize - 1) / sizeof(int) + 1) * sizeof(int);
298
299 if (mCblk->clientIndex + size > EFFECT_PARAM_BUFFER_SIZE) {
300 return NO_MEMORY;
301 }
302 int *p = (int *)(mCblk->buffer + mCblk->clientIndex);
303 *p++ = size;
304 memcpy(p, param, sizeof(effect_param_t) + psize);
305 mCblk->clientIndex += size;
306
307 return NO_ERROR;
308}
309
310status_t AudioEffect::setParameterCommit()
311{
312 if (mStatus != NO_ERROR) {
Glenn Kastenf063b492012-02-17 16:24:10 -0800313 return (mStatus == ALREADY_EXISTS) ? (status_t) INVALID_OPERATION : mStatus;
Eric Laurent801a1182010-06-09 00:17:29 -0700314 }
315
316 Mutex::Autolock _l(mCblk->lock);
317 if (mCblk->clientIndex == 0) {
318 return INVALID_OPERATION;
319 }
Eric Laurent25f43952010-07-28 05:40:18 -0700320 uint32_t size = 0;
Eric Laurent801a1182010-06-09 00:17:29 -0700321 return mIEffect->command(EFFECT_CMD_SET_PARAM_COMMIT, 0, NULL, &size, NULL);
322}
323
324status_t AudioEffect::getParameter(effect_param_t *param)
325{
326 if (mStatus != NO_ERROR && mStatus != ALREADY_EXISTS) {
John Grossmanaf7d8182012-01-11 12:23:42 -0800327 return mStatus;
Eric Laurent801a1182010-06-09 00:17:29 -0700328 }
329
330 if (param == NULL || param->psize == 0 || param->vsize == 0) {
331 return BAD_VALUE;
332 }
333
Glenn Kasten85ab62c2012-11-01 11:11:38 -0700334 ALOGV("getParameter: param: %d, param2: %d", *(int *)param->data,
335 (param->psize == 8) ? *((int *)param->data + 1): -1);
Eric Laurent801a1182010-06-09 00:17:29 -0700336
Glenn Kasten85ab62c2012-11-01 11:11:38 -0700337 uint32_t psize = sizeof(effect_param_t) + ((param->psize - 1) / sizeof(int) + 1) * sizeof(int) +
338 param->vsize;
Eric Laurent801a1182010-06-09 00:17:29 -0700339
Glenn Kasten85ab62c2012-11-01 11:11:38 -0700340 return mIEffect->command(EFFECT_CMD_GET_PARAM, sizeof(effect_param_t) + param->psize, param,
341 &psize, param);
Eric Laurent801a1182010-06-09 00:17:29 -0700342}
343
344
345// -------------------------------------------------------------------------
346
347void AudioEffect::binderDied()
348{
Steve Block5ff1dd52012-01-05 23:22:43 +0000349 ALOGW("IEffect died");
John Grossmanaf7d8182012-01-11 12:23:42 -0800350 mStatus = DEAD_OBJECT;
Glenn Kastena0d68332012-01-27 16:47:15 -0800351 if (mCbf != NULL) {
Eric Laurent801a1182010-06-09 00:17:29 -0700352 status_t status = DEAD_OBJECT;
353 mCbf(EVENT_ERROR, mUserData, &status);
354 }
355 mIEffect.clear();
356}
357
358// -------------------------------------------------------------------------
359
360void AudioEffect::controlStatusChanged(bool controlGranted)
361{
Glenn Kasten85ab62c2012-11-01 11:11:38 -0700362 ALOGV("controlStatusChanged %p control %d callback %p mUserData %p", this, controlGranted, mCbf,
363 mUserData);
Eric Laurent801a1182010-06-09 00:17:29 -0700364 if (controlGranted) {
365 if (mStatus == ALREADY_EXISTS) {
366 mStatus = NO_ERROR;
367 }
368 } else {
369 if (mStatus == NO_ERROR) {
370 mStatus = ALREADY_EXISTS;
371 }
372 }
Glenn Kastena0d68332012-01-27 16:47:15 -0800373 if (mCbf != NULL) {
Eric Laurent801a1182010-06-09 00:17:29 -0700374 mCbf(EVENT_CONTROL_STATUS_CHANGED, mUserData, &controlGranted);
375 }
376}
377
378void AudioEffect::enableStatusChanged(bool enabled)
379{
Steve Block3856b092011-10-20 11:56:00 +0100380 ALOGV("enableStatusChanged %p enabled %d mCbf %p", this, enabled, mCbf);
Eric Laurent801a1182010-06-09 00:17:29 -0700381 if (mStatus == ALREADY_EXISTS) {
Eric Laurentf5aafb22010-11-18 08:40:16 -0800382 mEnabled = enabled;
Glenn Kastena0d68332012-01-27 16:47:15 -0800383 if (mCbf != NULL) {
Eric Laurent801a1182010-06-09 00:17:29 -0700384 mCbf(EVENT_ENABLE_STATUS_CHANGED, mUserData, &enabled);
385 }
386 }
387}
388
Eric Laurent25f43952010-07-28 05:40:18 -0700389void AudioEffect::commandExecuted(uint32_t cmdCode,
Glenn Kasten0f11b512014-01-31 16:18:54 -0800390 uint32_t cmdSize __unused,
Eric Laurent25f43952010-07-28 05:40:18 -0700391 void *cmdData,
Glenn Kasten0f11b512014-01-31 16:18:54 -0800392 uint32_t replySize __unused,
Eric Laurent25f43952010-07-28 05:40:18 -0700393 void *replyData)
Eric Laurent801a1182010-06-09 00:17:29 -0700394{
395 if (cmdData == NULL || replyData == NULL) {
396 return;
397 }
398
Glenn Kastena0d68332012-01-27 16:47:15 -0800399 if (mCbf != NULL && cmdCode == EFFECT_CMD_SET_PARAM) {
Eric Laurent801a1182010-06-09 00:17:29 -0700400 effect_param_t *cmd = (effect_param_t *)cmdData;
401 cmd->status = *(int32_t *)replyData;
402 mCbf(EVENT_PARAMETER_CHANGED, mUserData, cmd);
403 }
404}
405
406// -------------------------------------------------------------------------
407
Eric Laurent801a1182010-06-09 00:17:29 -0700408status_t AudioEffect::queryNumberEffects(uint32_t *numEffects)
409{
410 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
411 if (af == 0) return PERMISSION_DENIED;
412 return af->queryNumberEffects(numEffects);
413}
414
Eric Laurentffe9c252010-06-23 17:38:20 -0700415status_t AudioEffect::queryEffect(uint32_t index, effect_descriptor_t *descriptor)
Eric Laurent801a1182010-06-09 00:17:29 -0700416{
417 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
418 if (af == 0) return PERMISSION_DENIED;
Eric Laurentffe9c252010-06-23 17:38:20 -0700419 return af->queryEffect(index, descriptor);
Eric Laurent801a1182010-06-09 00:17:29 -0700420}
421
Glenn Kasten5e92a782012-01-30 07:40:52 -0800422status_t AudioEffect::getEffectDescriptor(const effect_uuid_t *uuid,
Glenn Kastenf587ba52012-01-26 16:25:10 -0800423 effect_descriptor_t *descriptor) /*const*/
Eric Laurent801a1182010-06-09 00:17:29 -0700424{
425 const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger();
426 if (af == 0) return PERMISSION_DENIED;
427 return af->getEffectDescriptor(uuid, descriptor);
428}
429
Eric Laurent57dae992011-07-24 13:36:09 -0700430
431status_t AudioEffect::queryDefaultPreProcessing(int audioSession,
432 effect_descriptor_t *descriptors,
433 uint32_t *count)
434{
435 const sp<IAudioPolicyService>& aps = AudioSystem::get_audio_policy_service();
436 if (aps == 0) return PERMISSION_DENIED;
437 return aps->queryDefaultPreProcessing(audioSession, descriptors, count);
438}
Eric Laurent801a1182010-06-09 00:17:29 -0700439// -------------------------------------------------------------------------
440
441status_t AudioEffect::stringToGuid(const char *str, effect_uuid_t *guid)
442{
443 if (str == NULL || guid == NULL) {
444 return BAD_VALUE;
445 }
446
447 int tmp[10];
448
449 if (sscanf(str, "%08x-%04x-%04x-%04x-%02x%02x%02x%02x%02x%02x",
450 tmp, tmp+1, tmp+2, tmp+3, tmp+4, tmp+5, tmp+6, tmp+7, tmp+8, tmp+9) < 10) {
451 return BAD_VALUE;
452 }
453 guid->timeLow = (uint32_t)tmp[0];
454 guid->timeMid = (uint16_t)tmp[1];
455 guid->timeHiAndVersion = (uint16_t)tmp[2];
456 guid->clockSeq = (uint16_t)tmp[3];
457 guid->node[0] = (uint8_t)tmp[4];
458 guid->node[1] = (uint8_t)tmp[5];
459 guid->node[2] = (uint8_t)tmp[6];
460 guid->node[3] = (uint8_t)tmp[7];
461 guid->node[4] = (uint8_t)tmp[8];
462 guid->node[5] = (uint8_t)tmp[9];
463
464 return NO_ERROR;
465}
466
467status_t AudioEffect::guidToString(const effect_uuid_t *guid, char *str, size_t maxLen)
468{
469 if (guid == NULL || str == NULL) {
470 return BAD_VALUE;
471 }
472
473 snprintf(str, maxLen, "%08x-%04x-%04x-%04x-%02x%02x%02x%02x%02x%02x",
474 guid->timeLow,
475 guid->timeMid,
476 guid->timeHiAndVersion,
477 guid->clockSeq,
478 guid->node[0],
479 guid->node[1],
480 guid->node[2],
481 guid->node[3],
482 guid->node[4],
483 guid->node[5]);
484
485 return NO_ERROR;
486}
487
488
Glenn Kasten40bc9062015-03-20 09:09:33 -0700489} // namespace android