diff options
| author | 2022-02-07 17:59:43 +0000 | |
|---|---|---|
| committer | 2022-02-07 17:59:43 +0000 | |
| commit | b40813fb700f455441ff149f9ef7e2e4aaca1e83 (patch) | |
| tree | a8ad372f6afdb29e803d8b5759150163373b4b22 /libs/gui/BLASTBufferQueue.cpp | |
| parent | 3fe93b90cac0a4abe3c38ccd960210998f863578 (diff) | |
| parent | 09fe4d2cc07beb8f776a6967fe3ae69d248c5fb1 (diff) | |
Merge "BlastBufferQueue: Fix async worker deadlock" am: 09fe4d2cc0
Original change: https://android-review.googlesource.com/c/platform/frameworks/native/+/1973102
Change-Id: I32ca7a1a993acd299197373e39adce3f7f910733
Diffstat (limited to 'libs/gui/BLASTBufferQueue.cpp')
| -rw-r--r-- | libs/gui/BLASTBufferQueue.cpp | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/libs/gui/BLASTBufferQueue.cpp b/libs/gui/BLASTBufferQueue.cpp index 5b59c592df..9baf79b443 100644 --- a/libs/gui/BLASTBufferQueue.cpp +++ b/libs/gui/BLASTBufferQueue.cpp @@ -731,14 +731,26 @@ private: std::unique_lock<std::mutex> lock(mMutex); while (!mDone) { while (!mRunnables.empty()) { - std::function<void()> runnable = mRunnables.front(); - mRunnables.pop_front(); - runnable(); + std::deque<std::function<void()>> runnables = std::move(mRunnables); + mRunnables.clear(); + lock.unlock(); + // Run outside the lock since the runnable might trigger another + // post to the async worker. + execute(runnables); + lock.lock(); } mCv.wait(lock); } } + void execute(std::deque<std::function<void()>>& runnables) { + while (!runnables.empty()) { + std::function<void()> runnable = runnables.front(); + runnables.pop_front(); + runnable(); + } + } + public: AsyncWorker() : Singleton<AsyncWorker>() { mThread = std::thread(&AsyncWorker::run, this); } |