| /* |
| * Copyright 2021 The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| #include "EffectTestHelper.h" |
| extern audio_effect_library_t AUDIO_EFFECT_LIBRARY_INFO_SYM; |
| |
| void EffectTestHelper::createEffect() { |
| int status = AUDIO_EFFECT_LIBRARY_INFO_SYM.create_effect(mUuid, 1, 1, &mEffectHandle); |
| ASSERT_EQ(status, 0) << "create_effect returned an error " << status; |
| } |
| |
| void EffectTestHelper::releaseEffect() { |
| int status = AUDIO_EFFECT_LIBRARY_INFO_SYM.release_effect(mEffectHandle); |
| ASSERT_EQ(status, 0) << "release_effect returned an error " << status; |
| } |
| |
| void EffectTestHelper::setConfig(bool configReverse) { |
| effect_config_t config{}; |
| config.inputCfg.samplingRate = config.outputCfg.samplingRate = mSampleRate; |
| config.inputCfg.channels = config.outputCfg.channels = mChMask; |
| config.inputCfg.format = config.outputCfg.format = AUDIO_FORMAT_PCM_16_BIT; |
| |
| int reply = 0; |
| uint32_t replySize = sizeof(reply); |
| |
| int status = (*mEffectHandle) |
| ->command(mEffectHandle, EFFECT_CMD_SET_CONFIG, sizeof(effect_config_t), |
| &config, &replySize, &reply); |
| ASSERT_EQ(status, 0) << "set_config returned an error " << status; |
| ASSERT_EQ(reply, 0) << "set_config reply non zero " << reply; |
| |
| if (configReverse) { |
| int status = (*mEffectHandle) |
| ->command(mEffectHandle, EFFECT_CMD_SET_CONFIG_REVERSE, |
| sizeof(effect_config_t), &config, &replySize, &reply); |
| ASSERT_EQ(status, 0) << "set_config_reverse returned an error " << status; |
| ASSERT_EQ(reply, 0) << "set_config_reverse reply non zero " << reply; |
| } |
| |
| status = (*mEffectHandle) |
| ->command(mEffectHandle, EFFECT_CMD_ENABLE, 0, nullptr, &replySize, &reply); |
| ASSERT_EQ(status, 0) << "cmd_enable returned an error " << status; |
| ASSERT_EQ(reply, 0) << "cmd_enable reply non zero " << reply; |
| } |
| |
| void EffectTestHelper::setParam(uint32_t type, uint32_t value) { |
| int reply = 0; |
| uint32_t replySize = sizeof(reply); |
| uint32_t paramData[2] = {type, value}; |
| auto effectParam = (effect_param_t*)malloc(sizeof(effect_param_t) + sizeof(paramData)); |
| memcpy(&effectParam->data[0], ¶mData[0], sizeof(paramData)); |
| effectParam->psize = sizeof(paramData[0]); |
| effectParam->vsize = sizeof(paramData[1]); |
| int status = (*mEffectHandle) |
| ->command(mEffectHandle, EFFECT_CMD_SET_PARAM, |
| sizeof(effect_param_t) + sizeof(paramData), effectParam, |
| &replySize, &reply); |
| free(effectParam); |
| ASSERT_EQ(status, 0) << "set_param returned an error " << status; |
| ASSERT_EQ(reply, 0) << "set_param reply non zero " << reply; |
| } |
| |
| void EffectTestHelper::process(int16_t* input, int16_t* output, bool setAecEchoDelay) { |
| audio_buffer_t inBuffer = {.frameCount = mFrameCount, .s16 = input}; |
| audio_buffer_t outBuffer = {.frameCount = mFrameCount, .s16 = output}; |
| for (size_t i = 0; i < mLoopCount; i++) { |
| if (setAecEchoDelay) ASSERT_NO_FATAL_FAILURE(setParam(AEC_PARAM_ECHO_DELAY, kAECDelay)); |
| int status = (*mEffectHandle)->process(mEffectHandle, &inBuffer, &outBuffer); |
| ASSERT_EQ(status, 0) << "process returned an error " << status; |
| |
| inBuffer.s16 += mFrameCount * mChannelCount; |
| outBuffer.s16 += mFrameCount * mChannelCount; |
| } |
| } |
| |
| void EffectTestHelper::process_reverse(int16_t* farInput, int16_t* output) { |
| audio_buffer_t farInBuffer = {.frameCount = mFrameCount, .s16 = farInput}; |
| audio_buffer_t outBuffer = {.frameCount = mFrameCount, .s16 = output}; |
| for (size_t i = 0; i < mLoopCount; i++) { |
| int status = (*mEffectHandle)->process_reverse(mEffectHandle, &farInBuffer, &outBuffer); |
| ASSERT_EQ(status, 0) << "process returned an error " << status; |
| |
| farInBuffer.s16 += mFrameCount * mChannelCount; |
| outBuffer.s16 += mFrameCount * mChannelCount; |
| } |
| } |