2015-01-13 00:04:08 -08:00
|
|
|
// 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.
|
|
|
|
|
2015-01-28 13:42:40 -08:00
|
|
|
#include <atomic>
|
|
|
|
|
2015-01-13 00:04:08 -08:00
|
|
|
#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.
|
2015-01-28 13:42:40 -08:00
|
|
|
static std::atomic<int> operations_delay[ThreadStatus::NUM_OP_TYPES];
|
|
|
|
static std::atomic<int> states_delay[ThreadStatus::NUM_STATE_TYPES];
|
2015-01-13 00:04:08 -08:00
|
|
|
|
|
|
|
void ThreadStatusUtil::TEST_SetStateDelay(
|
|
|
|
const ThreadStatus::StateType state, int micro) {
|
2015-01-28 13:42:40 -08:00
|
|
|
states_delay[state].store(micro, std::memory_order_relaxed);
|
2015-01-13 00:04:08 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
void ThreadStatusUtil::TEST_StateDelay(
|
|
|
|
const ThreadStatus::StateType state) {
|
|
|
|
Env::Default()->SleepForMicroseconds(
|
2015-01-28 13:42:40 -08:00
|
|
|
states_delay[state].load(std::memory_order_relaxed));
|
2015-01-13 00:04:08 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
void ThreadStatusUtil::TEST_SetOperationDelay(
|
|
|
|
const ThreadStatus::OperationType operation, int micro) {
|
2015-01-28 13:42:40 -08:00
|
|
|
operations_delay[operation].store(micro, std::memory_order_relaxed);
|
2015-01-13 00:04:08 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
void ThreadStatusUtil::TEST_OperationDelay(
|
|
|
|
const ThreadStatus::OperationType operation) {
|
|
|
|
Env::Default()->SleepForMicroseconds(
|
2015-01-28 13:42:40 -08:00
|
|
|
operations_delay[operation].load(std::memory_order_relaxed));
|
2015-01-13 00:04:08 -08:00
|
|
|
}
|
|
|
|
#endif // !NDEBUG
|
|
|
|
|
|
|
|
} // namespace rocksdb
|