From 4d21ec47b0137dfb13a62055ee5f47553baf4dfb Mon Sep 17 00:00:00 2001 From: "Baohe.Wang" Date: Sun, 30 Jun 2019 22:15:24 +0800 Subject: [PATCH] Add mutual exclusion access for addOrUpdateStream and removeStream Added locks to avoid race condition when accessing addOrUpdateStream and removeStream Bug: 136411965 --- services/core/jni/com_android_server_tv_TvInputHal.cpp | 3 +++ 1 file changed, 3 insertions(+) diff --git a/services/core/jni/com_android_server_tv_TvInputHal.cpp b/services/core/jni/com_android_server_tv_TvInputHal.cpp index 098b2ef6439dd..4e1a234163309 100644 --- a/services/core/jni/com_android_server_tv_TvInputHal.cpp +++ b/services/core/jni/com_android_server_tv_TvInputHal.cpp @@ -301,6 +301,7 @@ private: JTvInputHal(JNIEnv* env, jobject thiz, sp tvInput, const sp& looper); Mutex mLock; + Mutex mStreamLock; jweak mThiz; sp mLooper; @@ -338,6 +339,7 @@ JTvInputHal* JTvInputHal::createInstance(JNIEnv* env, jobject thiz, const sp& surface) { + Mutex::Autolock autoLock(&mStreamLock); KeyedVector& connections = mConnections.editValueFor(deviceId); if (connections.indexOfKey(streamId) < 0) { connections.add(streamId, Connection()); @@ -412,6 +414,7 @@ int JTvInputHal::addOrUpdateStream(int deviceId, int streamId, const sp } int JTvInputHal::removeStream(int deviceId, int streamId) { + Mutex::Autolock autoLock(&mStreamLock); KeyedVector& connections = mConnections.editValueFor(deviceId); if (connections.indexOfKey(streamId) < 0) { return BAD_VALUE;