From af1cfa7a6f8d8b2d45c98765f0d229ea708ab48f Mon Sep 17 00:00:00 2001 From: Todd Volkert Date: Sun, 18 Nov 2018 09:23:13 -0800 Subject: [PATCH] Revert "Guard the service protocol's global handlers list with a reader/writer lock (#6888) #6895" --- ci/licenses_golden/licenses_flutter | 6 --- fml/BUILD.gn | 8 ---- fml/platform/posix/shared_mutex_posix.cc | 30 --------------- fml/platform/posix/shared_mutex_posix.h | 28 -------------- fml/synchronization/atomic_object.h | 36 ----------------- fml/synchronization/shared_mutex.h | 49 ------------------------ fml/synchronization/shared_mutex_std.cc | 25 ------------ fml/synchronization/shared_mutex_std.h | 28 -------------- runtime/service_protocol.cc | 18 ++++----- runtime/service_protocol.h | 7 ++-- 10 files changed, 12 insertions(+), 223 deletions(-) delete mode 100644 fml/platform/posix/shared_mutex_posix.cc delete mode 100644 fml/platform/posix/shared_mutex_posix.h delete mode 100644 fml/synchronization/atomic_object.h delete mode 100644 fml/synchronization/shared_mutex.h delete mode 100644 fml/synchronization/shared_mutex_std.cc delete mode 100644 fml/synchronization/shared_mutex_std.h diff --git a/ci/licenses_golden/licenses_flutter b/ci/licenses_golden/licenses_flutter index 63b2ac899e260..2fc0c7a9f63e5 100644 --- a/ci/licenses_golden/licenses_flutter +++ b/ci/licenses_golden/licenses_flutter @@ -164,8 +164,6 @@ FILE: ../../../flutter/fml/platform/posix/file_posix.cc FILE: ../../../flutter/fml/platform/posix/mapping_posix.cc FILE: ../../../flutter/fml/platform/posix/native_library_posix.cc FILE: ../../../flutter/fml/platform/posix/paths_posix.cc -FILE: ../../../flutter/fml/platform/posix/shared_mutex_posix.cc -FILE: ../../../flutter/fml/platform/posix/shared_mutex_posix.h FILE: ../../../flutter/fml/platform/win/errors_win.cc FILE: ../../../flutter/fml/platform/win/errors_win.h FILE: ../../../flutter/fml/platform/win/file_win.cc @@ -178,13 +176,9 @@ FILE: ../../../flutter/fml/platform/win/wstring_conversion.h FILE: ../../../flutter/fml/string_view.cc FILE: ../../../flutter/fml/string_view.h FILE: ../../../flutter/fml/string_view_unittest.cc -FILE: ../../../flutter/fml/synchronization/atomic_object.h FILE: ../../../flutter/fml/synchronization/count_down_latch.cc FILE: ../../../flutter/fml/synchronization/count_down_latch.h FILE: ../../../flutter/fml/synchronization/count_down_latch_unittests.cc -FILE: ../../../flutter/fml/synchronization/shared_mutex.h -FILE: ../../../flutter/fml/synchronization/shared_mutex_std.cc -FILE: ../../../flutter/fml/synchronization/shared_mutex_std.h FILE: ../../../flutter/fml/synchronization/thread_annotations.h FILE: ../../../flutter/fml/synchronization/thread_annotations_unittest.cc FILE: ../../../flutter/fml/synchronization/thread_checker.h diff --git a/fml/BUILD.gn b/fml/BUILD.gn index 0f1a34dec369d..f73f7f40714c4 100644 --- a/fml/BUILD.gn +++ b/fml/BUILD.gn @@ -46,10 +46,8 @@ source_set("fml") { "paths.h", "string_view.cc", "string_view.h", - "synchronization/atomic_object.h", "synchronization/count_down_latch.cc", "synchronization/count_down_latch.h", - "synchronization/shared_mutex.h", "synchronization/thread_annotations.h", "synchronization/thread_checker.h", "synchronization/waitable_event.cc", @@ -85,12 +83,6 @@ source_set("fml") { libs = [] - if (is_ios || is_mac) { - sources += [ "platform/posix/shared_mutex_posix.cc" ] - } else { - sources += [ "synchronization/shared_mutex_std.cc" ] - } - if (is_ios || is_mac) { sources += [ "platform/darwin/cf_utils.cc", diff --git a/fml/platform/posix/shared_mutex_posix.cc b/fml/platform/posix/shared_mutex_posix.cc deleted file mode 100644 index dcbb2938308c5..0000000000000 --- a/fml/platform/posix/shared_mutex_posix.cc +++ /dev/null @@ -1,30 +0,0 @@ -// Copyright 2013 The Flutter Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "flutter/fml/platform/posix/shared_mutex_posix.h" -#include "flutter/fml/logging.h" - -namespace fml { - -SharedMutex* SharedMutex::Create() { - return new SharedMutexPosix(); -} - -SharedMutexPosix::SharedMutexPosix() { - FML_CHECK(pthread_rwlock_init(&rwlock_, nullptr) == 0); -} - -void SharedMutexPosix::Lock() { - pthread_rwlock_wrlock(&rwlock_); -} - -void SharedMutexPosix::LockShared() { - pthread_rwlock_rdlock(&rwlock_); -} - -void SharedMutexPosix::Unlock() { - pthread_rwlock_unlock(&rwlock_); -} - -} // namespace fml diff --git a/fml/platform/posix/shared_mutex_posix.h b/fml/platform/posix/shared_mutex_posix.h deleted file mode 100644 index 9364400015410..0000000000000 --- a/fml/platform/posix/shared_mutex_posix.h +++ /dev/null @@ -1,28 +0,0 @@ -// Copyright 2013 The Flutter Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef FLUTTER_FML_SYNCHRONIZATION_SHARED_MUTEX_POSIX_H_ -#define FLUTTER_FML_SYNCHRONIZATION_SHARED_MUTEX_POSIX_H_ - -#include -#include "flutter/fml/synchronization/shared_mutex.h" - -namespace fml { - -class SharedMutexPosix : public SharedMutex { - public: - virtual void Lock(); - virtual void LockShared(); - virtual void Unlock(); - - private: - friend SharedMutex* SharedMutex::Create(); - SharedMutexPosix(); - - pthread_rwlock_t rwlock_; -}; - -} // namespace fml - -#endif // FLUTTER_FML_SYNCHRONIZATION_SHARED_MUTEX_POSIX_H_ diff --git a/fml/synchronization/atomic_object.h b/fml/synchronization/atomic_object.h deleted file mode 100644 index 2a06792ff4a24..0000000000000 --- a/fml/synchronization/atomic_object.h +++ /dev/null @@ -1,36 +0,0 @@ -// Copyright 2013 The Flutter Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef FLUTTER_FML_SYNCHRONIZATION_ATOMIC_OBJECT_H_ -#define FLUTTER_FML_SYNCHRONIZATION_ATOMIC_OBJECT_H_ - -#include - -namespace fml { - -// A wrapper for an object instance that can be read or written atomically. -template -class AtomicObject { - public: - AtomicObject() = default; - AtomicObject(T object) : object_(object) {} - - T Load() const { - std::lock_guard lock(mutex_); - return object_; - } - - void Store(const T& object) { - std::lock_guard lock(mutex_); - object_ = object; - } - - private: - mutable std::mutex mutex_; - T object_; -}; - -} // namespace fml - -#endif // FLUTTER_FML_SYNCHRONIZATION_ATOMIC_OBJECT_H_ diff --git a/fml/synchronization/shared_mutex.h b/fml/synchronization/shared_mutex.h deleted file mode 100644 index 07acb43461bee..0000000000000 --- a/fml/synchronization/shared_mutex.h +++ /dev/null @@ -1,49 +0,0 @@ -// Copyright 2013 The Flutter Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef FLUTTER_FML_SYNCHRONIZATION_SHARED_MUTEX_H_ -#define FLUTTER_FML_SYNCHRONIZATION_SHARED_MUTEX_H_ - -namespace fml { - -// Interface for a reader/writer lock. -class SharedMutex { - public: - static SharedMutex* Create(); - virtual ~SharedMutex() = default; - - virtual void Lock() = 0; - virtual void LockShared() = 0; - virtual void Unlock() = 0; -}; - -// RAII wrapper that does a shared acquire of a SharedMutex. -class SharedLock { - public: - explicit SharedLock(SharedMutex& shared_mutex) : shared_mutex_(shared_mutex) { - shared_mutex_.LockShared(); - } - - ~SharedLock() { shared_mutex_.Unlock(); } - - private: - SharedMutex& shared_mutex_; -}; - -// RAII wrapper that does an exclusive acquire of a SharedMutex. -class UniqueLock { - public: - explicit UniqueLock(SharedMutex& shared_mutex) : shared_mutex_(shared_mutex) { - shared_mutex_.Lock(); - } - - ~UniqueLock() { shared_mutex_.Unlock(); } - - private: - SharedMutex& shared_mutex_; -}; - -} // namespace fml - -#endif // FLUTTER_FML_SYNCHRONIZATION_SHARED_MUTEX_H_ diff --git a/fml/synchronization/shared_mutex_std.cc b/fml/synchronization/shared_mutex_std.cc deleted file mode 100644 index 12509d6893bf1..0000000000000 --- a/fml/synchronization/shared_mutex_std.cc +++ /dev/null @@ -1,25 +0,0 @@ -// Copyright 2013 The Flutter Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "flutter/fml/synchronization/shared_mutex_std.h" - -namespace fml { - -SharedMutex* SharedMutex::Create() { - return new SharedMutexStd(); -} - -void SharedMutexStd::Lock() { - mutex_.lock(); -} - -void SharedMutexStd::LockShared() { - mutex_.lock_shared(); -} - -void SharedMutexStd::Unlock() { - mutex_.unlock(); -} - -} // namespace fml diff --git a/fml/synchronization/shared_mutex_std.h b/fml/synchronization/shared_mutex_std.h deleted file mode 100644 index 84ab270bd89ed..0000000000000 --- a/fml/synchronization/shared_mutex_std.h +++ /dev/null @@ -1,28 +0,0 @@ -// Copyright 2013 The Flutter Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef FLUTTER_FML_SYNCHRONIZATION_SHARED_MUTEX_STD_H_ -#define FLUTTER_FML_SYNCHRONIZATION_SHARED_MUTEX_STD_H_ - -#include -#include "flutter/fml/synchronization/shared_mutex.h" - -namespace fml { - -class SharedMutexStd : public SharedMutex { - public: - virtual void Lock(); - virtual void LockShared(); - virtual void Unlock(); - - private: - friend SharedMutex* SharedMutex::Create(); - SharedMutexStd() = default; - - std::shared_timed_mutex mutex_; -}; - -} // namespace fml - -#endif // FLUTTER_FML_SYNCHRONIZATION_SHARED_MUTEX_STD_H_ diff --git a/runtime/service_protocol.cc b/runtime/service_protocol.cc index ea93a120facc7..602ebccf645f2 100644 --- a/runtime/service_protocol.cc +++ b/runtime/service_protocol.cc @@ -45,8 +45,7 @@ ServiceProtocol::ServiceProtocol() kRunInViewExtensionName, kFlushUIThreadTasksExtensionName, kSetAssetBundlePathExtensionName, - }), - handlers_mutex_(fml::SharedMutex::Create()) {} + }) {} ServiceProtocol::~ServiceProtocol() { ToggleHooks(false); @@ -54,21 +53,21 @@ ServiceProtocol::~ServiceProtocol() { void ServiceProtocol::AddHandler(Handler* handler, Handler::Description description) { - fml::UniqueLock lock(*handlers_mutex_); + std::lock_guard lock(handlers_mutex_); handlers_.emplace(handler, description); } void ServiceProtocol::RemoveHandler(Handler* handler) { - fml::UniqueLock lock(*handlers_mutex_); + std::lock_guard lock(handlers_mutex_); handlers_.erase(handler); } void ServiceProtocol::SetHandlerDescription(Handler* handler, Handler::Description description) { - fml::SharedLock lock(*handlers_mutex_); + std::lock_guard lock(handlers_mutex_); auto it = handlers_.find(handler); if (it != handlers_.end()) - it->second.Store(description); + it->second = description; } void ServiceProtocol::ToggleHooks(bool set) { @@ -176,7 +175,7 @@ bool ServiceProtocol::HandleMessage(fml::StringView method, return HandleListViewsMethod(response); } - fml::SharedLock lock(*handlers_mutex_); + std::lock_guard lock(handlers_mutex_); if (handlers_.size() == 0) { WriteServerErrorResponse(response, @@ -247,11 +246,12 @@ void ServiceProtocol::Handler::Description::Write( bool ServiceProtocol::HandleListViewsMethod( rapidjson::Document& response) const { - fml::SharedLock lock(*handlers_mutex_); + // Collect handler descriptions on their respective task runners. + std::lock_guard lock(handlers_mutex_); std::vector> descriptions; for (const auto& handler : handlers_) { descriptions.emplace_back(reinterpret_cast(handler.first), - handler.second.Load()); + handler.second); } auto& allocator = response.GetAllocator(); diff --git a/runtime/service_protocol.h b/runtime/service_protocol.h index 1ab1f9183d208..401702e5d5be3 100644 --- a/runtime/service_protocol.h +++ b/runtime/service_protocol.h @@ -6,14 +6,13 @@ #define FLUTTER_RUNTIME_SERVICE_PROTOCOL_H_ #include +#include #include #include #include "flutter/fml/compiler_specific.h" #include "flutter/fml/macros.h" #include "flutter/fml/string_view.h" -#include "flutter/fml/synchronization/atomic_object.h" -#include "flutter/fml/synchronization/shared_mutex.h" #include "flutter/fml/synchronization/thread_annotations.h" #include "flutter/fml/task_runner.h" #include "rapidjson/document.h" @@ -73,8 +72,8 @@ class ServiceProtocol { private: const std::set endpoints_; - std::unique_ptr handlers_mutex_; - std::map> handlers_; + mutable std::mutex handlers_mutex_; + std::map handlers_; FML_WARN_UNUSED_RESULT static bool HandleMessage(const char* method,