blob: ca81204823c08e82df9bb22f19619aa0e0e53903 [file] [log] [blame]
Shunkai Yaoc23916b2022-07-13 04:59:37 +00001/*
2 * Copyright (C) 2022 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 "effectFactory-impl/EffectFactory.h"
18
19#include <android-base/logging.h>
20#include <android/binder_manager.h>
21#include <android/binder_process.h>
Shunkai Yao60b34b72022-11-10 17:16:50 +000022#include <system/audio_config.h>
23
24/** Default name of effect configuration file. */
25static const char* kDefaultConfigName = "audio_effects_config.xml";
Shunkai Yaoc23916b2022-07-13 04:59:37 +000026
27int main() {
28 // This is a debug implementation, always enable debug logging.
29 android::base::SetMinimumLogSeverity(::android::base::DEBUG);
Shunkai Yao121c6dd2022-09-21 23:42:08 +000030 ABinderProcess_setThreadPoolMaxThreadCount(0);
Shunkai Yaoc23916b2022-07-13 04:59:37 +000031
Shunkai Yao60b34b72022-11-10 17:16:50 +000032 auto configFile = android::audio_find_readable_configuration_file(kDefaultConfigName);
33 if (configFile == "") {
34 LOG(ERROR) << __func__ << ": config file " << kDefaultConfigName << " not found!";
35 return EXIT_FAILURE;
36 }
37 LOG(DEBUG) << __func__ << ": start factory with configFile:" << configFile;
Shunkai Yaoc23916b2022-07-13 04:59:37 +000038 auto effectFactory =
Shunkai Yao60b34b72022-11-10 17:16:50 +000039 ndk::SharedRefBase::make<aidl::android::hardware::audio::effect::Factory>(configFile);
Shunkai Yao45905172022-08-24 18:14:02 +000040
Shunkai Yaoc23916b2022-07-13 04:59:37 +000041 std::string serviceName = std::string() + effectFactory->descriptor + "/default";
42 binder_status_t status =
43 AServiceManager_addService(effectFactory->asBinder().get(), serviceName.c_str());
44 CHECK_EQ(STATUS_OK, status);
Shunkai Yaoc23916b2022-07-13 04:59:37 +000045
Shunkai Yao60b34b72022-11-10 17:16:50 +000046 LOG(DEBUG) << __func__ << ": effectFactory: " << serviceName << " start";
Shunkai Yaoc23916b2022-07-13 04:59:37 +000047 ABinderProcess_joinThreadPool();
48 return EXIT_FAILURE; // should not reach
49}