2015-02-04 01:47:32 -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-03-10 14:51:28 -07:00
|
|
|
#include "rocksdb/env.h"
|
2015-02-04 01:47:32 -08:00
|
|
|
#include "rocksdb/thread_status.h"
|
2015-03-23 16:35:04 -07:00
|
|
|
#include "util/logging.h"
|
2015-02-04 01:47:32 -08:00
|
|
|
#include "util/thread_operation.h"
|
|
|
|
|
|
|
|
namespace rocksdb {
|
|
|
|
|
|
|
|
#if ROCKSDB_USING_THREAD_STATUS
|
2015-03-06 11:22:06 -08:00
|
|
|
const std::string& ThreadStatus::GetThreadTypeName(
|
|
|
|
ThreadStatus::ThreadType thread_type) {
|
|
|
|
static std::string thread_type_names[NUM_THREAD_TYPES + 1] = {
|
|
|
|
"High Pri", "Low Pri", "User", "Unknown"};
|
|
|
|
return thread_type_names[thread_type];
|
|
|
|
}
|
|
|
|
|
2015-02-04 01:47:32 -08:00
|
|
|
const std::string& ThreadStatus::GetOperationName(
|
|
|
|
ThreadStatus::OperationType op_type) {
|
|
|
|
return global_operation_table[op_type].name;
|
|
|
|
}
|
|
|
|
|
2015-03-13 10:45:40 -07:00
|
|
|
const std::string& ThreadStatus::GetOperationStageName(
|
|
|
|
ThreadStatus::OperationStage stage) {
|
|
|
|
return global_op_stage_table[stage].name;
|
|
|
|
}
|
|
|
|
|
2015-02-04 01:47:32 -08:00
|
|
|
const std::string& ThreadStatus::GetStateName(
|
|
|
|
ThreadStatus::StateType state_type) {
|
|
|
|
return global_state_table[state_type].name;
|
|
|
|
}
|
|
|
|
|
2015-03-23 16:35:04 -07:00
|
|
|
const std::string ThreadStatus::MicrosToString(uint64_t micros) {
|
|
|
|
if (micros == 0) {
|
2015-03-10 14:51:28 -07:00
|
|
|
return "";
|
|
|
|
}
|
2015-03-23 16:35:04 -07:00
|
|
|
const int kBufferLen = 100;
|
|
|
|
char buffer[kBufferLen];
|
2015-03-30 11:28:25 -07:00
|
|
|
AppendHumanMicros(micros, buffer, kBufferLen, false);
|
2015-03-23 16:35:04 -07:00
|
|
|
return std::string(buffer);
|
2015-03-10 14:51:28 -07:00
|
|
|
}
|
|
|
|
|
2015-02-04 01:47:32 -08:00
|
|
|
#else
|
|
|
|
|
2015-03-06 11:22:06 -08:00
|
|
|
const std::string& ThreadStatus::GetThreadTypeName(
|
|
|
|
ThreadStatus::ThreadType thread_type) {
|
|
|
|
static std::string dummy_str = "";
|
|
|
|
return dummy_str;
|
|
|
|
}
|
|
|
|
|
2015-02-04 01:47:32 -08:00
|
|
|
const std::string& ThreadStatus::GetOperationName(
|
|
|
|
ThreadStatus::OperationType op_type) {
|
|
|
|
static std::string dummy_str = "";
|
|
|
|
return dummy_str;
|
|
|
|
}
|
|
|
|
|
2015-03-13 10:45:40 -07:00
|
|
|
const std::string& ThreadStatus::GetOperationStageName(
|
|
|
|
ThreadStatus::OperationStage stage) {
|
|
|
|
static std::string dummy_str = "";
|
|
|
|
return dummy_str;
|
|
|
|
}
|
|
|
|
|
2015-02-04 01:47:32 -08:00
|
|
|
const std::string& ThreadStatus::GetStateName(
|
|
|
|
ThreadStatus::StateType state_type) {
|
|
|
|
static std::string dummy_str = "";
|
|
|
|
return dummy_str;
|
|
|
|
}
|
|
|
|
|
2015-03-24 14:50:32 -07:00
|
|
|
const std::string ThreadStatus::MicrosToString(
|
|
|
|
uint64_t op_elapsed_time) {
|
2015-03-11 13:02:46 -07:00
|
|
|
static std::string dummy_str = "";
|
|
|
|
return dummy_str;
|
|
|
|
}
|
|
|
|
|
2015-02-04 01:47:32 -08:00
|
|
|
#endif // ROCKSDB_USING_THREAD_STATUS
|
|
|
|
} // namespace rocksdb
|