mirror of
https://github.com/RPCS3/llvm.git
synced 2026-01-31 01:25:19 +01:00
This patch pulls google/benchmark v1.4.1 into the LLVM tree so that any project could use it for benchmark generation. A dummy benchmark is added to `llvm/benchmarks/DummyYAML.cpp` to validate the correctness of the build process. The current version does not utilize LLVM LNT and LLVM CMake infrastructure, but that might be sufficient for most users. Two introduced CMake variables: * `LLVM_INCLUDE_BENCHMARKS` (`ON` by default) generates benchmark targets * `LLVM_BUILD_BENCHMARKS` (`OFF` by default) adds generated benchmark targets to the list of default LLVM targets (i.e. if `ON` benchmarks will be built upon standard build invocation, e.g. `ninja` or `make` with no specific targets) List of modifications: * `BENCHMARK_ENABLE_TESTING` is disabled * `BENCHMARK_ENABLE_EXCEPTIONS` is disabled * `BENCHMARK_ENABLE_INSTALL` is disabled * `BENCHMARK_ENABLE_GTEST_TESTS` is disabled * `BENCHMARK_DOWNLOAD_DEPENDENCIES` is disabled Original discussion can be found here: http://lists.llvm.org/pipermail/llvm-dev/2018-August/125023.html Reviewed by: dberris, lebedev.ri Subscribers: ilya-biryukov, ioeric, EricWF, lebedev.ri, srhines, dschuff, mgorny, krytarowski, fedor.sergeev, mgrang, jfb, llvm-commits Differential Revision: https://reviews.llvm.org/D50894 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@340809 91177308-0d34-0410-b5e6-96231b3b80d8
70 lines
1.7 KiB
C++
70 lines
1.7 KiB
C++
#ifndef BENCHMARK_THREAD_TIMER_H
|
|
#define BENCHMARK_THREAD_TIMER_H
|
|
|
|
#include "check.h"
|
|
#include "timers.h"
|
|
|
|
namespace benchmark {
|
|
namespace internal {
|
|
|
|
class ThreadTimer {
|
|
public:
|
|
ThreadTimer() = default;
|
|
|
|
// Called by each thread
|
|
void StartTimer() {
|
|
running_ = true;
|
|
start_real_time_ = ChronoClockNow();
|
|
start_cpu_time_ = ThreadCPUUsage();
|
|
}
|
|
|
|
// Called by each thread
|
|
void StopTimer() {
|
|
CHECK(running_);
|
|
running_ = false;
|
|
real_time_used_ += ChronoClockNow() - start_real_time_;
|
|
// Floating point error can result in the subtraction producing a negative
|
|
// time. Guard against that.
|
|
cpu_time_used_ += std::max<double>(ThreadCPUUsage() - start_cpu_time_, 0);
|
|
}
|
|
|
|
// Called by each thread
|
|
void SetIterationTime(double seconds) { manual_time_used_ += seconds; }
|
|
|
|
bool running() const { return running_; }
|
|
|
|
// REQUIRES: timer is not running
|
|
double real_time_used() {
|
|
CHECK(!running_);
|
|
return real_time_used_;
|
|
}
|
|
|
|
// REQUIRES: timer is not running
|
|
double cpu_time_used() {
|
|
CHECK(!running_);
|
|
return cpu_time_used_;
|
|
}
|
|
|
|
// REQUIRES: timer is not running
|
|
double manual_time_used() {
|
|
CHECK(!running_);
|
|
return manual_time_used_;
|
|
}
|
|
|
|
private:
|
|
bool running_ = false; // Is the timer running
|
|
double start_real_time_ = 0; // If running_
|
|
double start_cpu_time_ = 0; // If running_
|
|
|
|
// Accumulated time so far (does not contain current slice if running_)
|
|
double real_time_used_ = 0;
|
|
double cpu_time_used_ = 0;
|
|
// Manually set iteration time. User sets this with SetIterationTime(seconds).
|
|
double manual_time_used_ = 0;
|
|
};
|
|
|
|
} // namespace internal
|
|
} // namespace benchmark
|
|
|
|
#endif // BENCHMARK_THREAD_TIMER_H
|