From f0c36da6eea12a35ae97f07561eb3bf8e7f860a8 Mon Sep 17 00:00:00 2001 From: Yueh-Hsuan Chiang Date: Tue, 17 Feb 2015 11:29:36 -0800 Subject: [PATCH] Add thread_status_util_debug.cc back Summary: Add thread_status_util_debug.cc back as InstrumentedMutex related tests are using it to produce wait that can be reflected in the counter. Test Plan: ./perf_context_test export ROCKSDB_TESTS=MutexWaitStats ./db_test Reviewers: sdong, igor Reviewed By: igor Subscribers: dhruba, leveldb Differential Revision: https://reviews.facebook.net/D33525 --- util/thread_status_util.h | 6 ++++++ util/thread_status_util_debug.cc | 31 +++++++++++++++++++++++++++++++ 2 files changed, 37 insertions(+) create mode 100644 util/thread_status_util_debug.cc diff --git a/util/thread_status_util.h b/util/thread_status_util.h index 0e9d49db8..486e08b1d 100644 --- a/util/thread_status_util.h +++ b/util/thread_status_util.h @@ -60,6 +60,12 @@ class ThreadStatusUtil { static void ResetThreadStatus(); +#ifndef NDEBUG + static void TEST_SetStateDelay( + const ThreadStatus::StateType state, int micro); + static void TEST_StateDelay(const ThreadStatus::StateType state); +#endif + protected: // Initialize the thread-local ThreadStatusUpdater when it finds // the cached value is nullptr. Returns true if it has cached diff --git a/util/thread_status_util_debug.cc b/util/thread_status_util_debug.cc new file mode 100644 index 000000000..b91bc4ee3 --- /dev/null +++ b/util/thread_status_util_debug.cc @@ -0,0 +1,31 @@ +// Copyright (c) 2013, Facebook, Inc. All rights reserved. +// This source code is licensed under the BSD-style license found in the +// LICENSE file in the root directory of this source tree. An additional grant +// of patent rights can be found in the PATENTS file in the same directory. + +#include + +#include "rocksdb/env.h" +#include "util/thread_status_updater.h" +#include "util/thread_status_util.h" + +namespace rocksdb { + +#ifndef NDEBUG +// the delay for debugging purpose. +static std::atomic states_delay[ThreadStatus::NUM_STATE_TYPES]; + +void ThreadStatusUtil::TEST_SetStateDelay( + const ThreadStatus::StateType state, int micro) { + states_delay[state].store(micro, std::memory_order_relaxed); +} + +void ThreadStatusUtil::TEST_StateDelay( + const ThreadStatus::StateType state) { + Env::Default()->SleepForMicroseconds( + states_delay[state].load(std::memory_order_relaxed)); +} + +#endif // !NDEBUG + +} // namespace rocksdb