Merge "Fix timeout issue for bcradio worker thread" into main

This commit is contained in:
Weilin Xu
2024-01-09 01:35:37 +00:00
committed by Android (Google) Code Review
3 changed files with 12 additions and 4 deletions

View File

@@ -86,4 +86,7 @@ cc_test {
],
static_libs: ["android.hardware.broadcastradio@common-utils-lib"],
test_suites: ["general-tests"],
shared_libs: [
"libbase",
],
}

View File

@@ -69,8 +69,11 @@ void WorkerThread::cancelAll() {
}
void WorkerThread::threadLoop() {
while (!mIsTerminating) {
while (true) {
unique_lock<mutex> lk(mMut);
if (mIsTerminating) {
return;
}
if (mTasks.empty()) {
mCond.wait(lk);
continue;

View File

@@ -20,6 +20,8 @@
#include <queue>
#include <thread>
#include <android-base/thread_annotations.h>
namespace android {
class WorkerThread {
@@ -40,11 +42,11 @@ class WorkerThread {
};
friend bool operator<(const Task& lhs, const Task& rhs);
std::atomic<bool> mIsTerminating;
std::mutex mMut;
std::condition_variable mCond;
bool mIsTerminating GUARDED_BY(mMut);
std::condition_variable mCond GUARDED_BY(mMut);
std::thread mThread;
std::priority_queue<Task> mTasks;
std::priority_queue<Task> mTasks GUARDED_BY(mMut);
void threadLoop();
};