blob: 1a52c1390a852cc3a0a1377026de98fde5e1b372 [file] [log] [blame]
Shunkai Yaoea24c1a2022-09-28 17:39:23 +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
Shunkai Yao41888a22023-04-10 17:13:30 +000017#include <cstddef>
Shraddha Basantwanif627d802022-11-08 14:45:07 +053018#include <memory>
Shunkai Yao41888a22023-04-10 17:13:30 +000019
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000020#define LOG_TAG "AHAL_EffectThread"
21#include <android-base/logging.h>
22#include <pthread.h>
23#include <sys/resource.h>
24
25#include "effect-impl/EffectThread.h"
Shunkai Yao41888a22023-04-10 17:13:30 +000026#include "effect-impl/EffectTypes.h"
27
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000028namespace aidl::android::hardware::audio::effect {
29
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000030EffectThread::~EffectThread() {
Shunkai Yaoa4ab38c2022-10-14 01:07:47 +000031 destroyThread();
Shunkai Yao41888a22023-04-10 17:13:30 +000032}
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000033
Shunkai Yao81bfcda2024-01-09 20:50:53 +000034RetCode EffectThread::createThread(const std::string& name, int priority) {
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000035 if (mThread.joinable()) {
Shunkai Yao41888a22023-04-10 17:13:30 +000036 LOG(WARNING) << mName << __func__ << " thread already created, no-op";
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000037 return RetCode::SUCCESS;
38 }
Shunkai Yao81bfcda2024-01-09 20:50:53 +000039
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000040 mName = name;
41 mPriority = priority;
Shraddha Basantwanif627d802022-11-08 14:45:07 +053042 {
43 std::lock_guard lg(mThreadMutex);
Jaideep Sharma632b1cd2023-09-20 11:43:17 +053044 mStop = true;
45 mExit = false;
Shraddha Basantwanif627d802022-11-08 14:45:07 +053046 }
Shunkai Yao41888a22023-04-10 17:13:30 +000047
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000048 mThread = std::thread(&EffectThread::threadLoop, this);
Shunkai Yaodd43b562024-03-14 22:04:02 +000049 LOG(VERBOSE) << mName << __func__ << " priority " << mPriority << " done";
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000050 return RetCode::SUCCESS;
51}
52
Shunkai Yaoa4ab38c2022-10-14 01:07:47 +000053RetCode EffectThread::destroyThread() {
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000054 {
Shraddha Basantwanif627d802022-11-08 14:45:07 +053055 std::lock_guard lg(mThreadMutex);
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000056 mStop = mExit = true;
57 }
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000058
Shunkai Yao81bfcda2024-01-09 20:50:53 +000059 mCv.notify_one();
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000060 if (mThread.joinable()) {
61 mThread.join();
62 }
Shraddha Basantwanif627d802022-11-08 14:45:07 +053063
Shunkai Yaodd43b562024-03-14 22:04:02 +000064 LOG(VERBOSE) << mName << __func__;
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000065 return RetCode::SUCCESS;
66}
67
Shunkai Yaoa4ab38c2022-10-14 01:07:47 +000068RetCode EffectThread::startThread() {
Shunkai Yao41888a22023-04-10 17:13:30 +000069 {
70 std::lock_guard lg(mThreadMutex);
Shunkai Yao16b799f2024-11-24 18:40:58 +000071 if (mDraining) {
72 mDraining = false;
73 } else {
74 mStop = false;
75 }
Shunkai Yao41888a22023-04-10 17:13:30 +000076 mCv.notify_one();
77 }
78
Shunkai Yaodd43b562024-03-14 22:04:02 +000079 LOG(VERBOSE) << mName << __func__;
Shunkai Yao41888a22023-04-10 17:13:30 +000080 return RetCode::SUCCESS;
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000081}
82
Shunkai Yaoa4ab38c2022-10-14 01:07:47 +000083RetCode EffectThread::stopThread() {
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000084 {
Shraddha Basantwanif627d802022-11-08 14:45:07 +053085 std::lock_guard lg(mThreadMutex);
Shunkai Yao41888a22023-04-10 17:13:30 +000086 mStop = true;
87 mCv.notify_one();
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000088 }
Shunkai Yaob49631f2023-02-03 01:44:32 +000089
Shunkai Yaodd43b562024-03-14 22:04:02 +000090 LOG(VERBOSE) << mName << __func__;
Shunkai Yaoea24c1a2022-09-28 17:39:23 +000091 return RetCode::SUCCESS;
92}
93
Shunkai Yao16b799f2024-11-24 18:40:58 +000094RetCode EffectThread::startDraining() {
95 std::lock_guard lg(mThreadMutex);
96 mDraining = true;
97 mCv.notify_one();
98
99 LOG(VERBOSE) << mName << __func__;
100 return RetCode::SUCCESS;
101}
102
103RetCode EffectThread::finishDraining() {
104 std::lock_guard lg(mThreadMutex);
105 mDraining = false;
106 mStop = true;
107 mCv.notify_one();
108
109 LOG(VERBOSE) << mName << __func__;
110 return RetCode::SUCCESS;
111}
112
Shunkai Yaoea24c1a2022-09-28 17:39:23 +0000113void EffectThread::threadLoop() {
Shraddha Basantwanif627d802022-11-08 14:45:07 +0530114 pthread_setname_np(pthread_self(), mName.substr(0, kMaxTaskNameLen - 1).c_str());
Shunkai Yaoea24c1a2022-09-28 17:39:23 +0000115 setpriority(PRIO_PROCESS, 0, mPriority);
116 while (true) {
Shunkai Yao41888a22023-04-10 17:13:30 +0000117 {
118 std::unique_lock l(mThreadMutex);
119 ::android::base::ScopedLockAssertion lock_assertion(mThreadMutex);
120 mCv.wait(l, [&]() REQUIRES(mThreadMutex) { return mExit || !mStop; });
121 if (mExit) {
Shunkai Yaodd43b562024-03-14 22:04:02 +0000122 LOG(VERBOSE) << mName << " threadLoop EXIT!";
Shunkai Yao41888a22023-04-10 17:13:30 +0000123 return;
124 }
Shunkai Yaoea24c1a2022-09-28 17:39:23 +0000125 }
Shunkai Yao81bfcda2024-01-09 20:50:53 +0000126 process();
Shraddha Basantwanif627d802022-11-08 14:45:07 +0530127 }
128}
129
Shunkai Yaoea24c1a2022-09-28 17:39:23 +0000130} // namespace aidl::android::hardware::audio::effect