mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-16 18:36:38 +00:00

This reverts commit aec6a04b8e99b42eca431fc0b56947937d3a14c2. (google/benchmark still at hash 1576991177ba97a4b2ff6c45950f1fa6e9aa678c as it was in #83488. Also reapplied same extra local diffs) Verified locally.
52 lines
1.2 KiB
C++
52 lines
1.2 KiB
C++
|
|
#include <cassert>
|
|
#include <memory>
|
|
|
|
#include "benchmark/benchmark.h"
|
|
|
|
#define FIXTURE_BECHMARK_NAME MyFixture
|
|
|
|
class FIXTURE_BECHMARK_NAME : public ::benchmark::Fixture {
|
|
public:
|
|
void SetUp(const ::benchmark::State& state) override {
|
|
if (state.thread_index() == 0) {
|
|
assert(data.get() == nullptr);
|
|
data.reset(new int(42));
|
|
}
|
|
}
|
|
|
|
void TearDown(const ::benchmark::State& state) override {
|
|
if (state.thread_index() == 0) {
|
|
assert(data.get() != nullptr);
|
|
data.reset();
|
|
}
|
|
}
|
|
|
|
~FIXTURE_BECHMARK_NAME() override { assert(data == nullptr); }
|
|
|
|
std::unique_ptr<int> data;
|
|
};
|
|
|
|
BENCHMARK_F(FIXTURE_BECHMARK_NAME, Foo)(benchmark::State& st) {
|
|
assert(data.get() != nullptr);
|
|
assert(*data == 42);
|
|
for (auto _ : st) {
|
|
}
|
|
}
|
|
|
|
BENCHMARK_DEFINE_F(FIXTURE_BECHMARK_NAME, Bar)(benchmark::State& st) {
|
|
if (st.thread_index() == 0) {
|
|
assert(data.get() != nullptr);
|
|
assert(*data == 42);
|
|
}
|
|
for (auto _ : st) {
|
|
assert(data.get() != nullptr);
|
|
assert(*data == 42);
|
|
}
|
|
st.SetItemsProcessed(st.range(0));
|
|
}
|
|
BENCHMARK_REGISTER_F(FIXTURE_BECHMARK_NAME, Bar)->Arg(42);
|
|
BENCHMARK_REGISTER_F(FIXTURE_BECHMARK_NAME, Bar)->Arg(42)->ThreadPerCpu();
|
|
|
|
BENCHMARK_MAIN();
|