Files
filament/libs/utils/benchmark/benchmark_calls.cpp
2018-11-27 15:07:45 -08:00

142 lines
3.5 KiB
C++

/*
* Copyright (C) 2018 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "PerformanceCounters.h"
#include <benchmark/benchmark.h>
#include <utils/compiler.h>
// ------------------------------------------------------------------------------------------------
//
// Running benchmarks on Android
//
// adb push out/cmake-android-release-aarch64/libs/utils/benchmark_utils /data/local/tmp
// adb push out/cmake-android-release-aarch64/libs/utils/libbenchmark_utils_callee.so /data/local/tmp
// adb shell LD_LIBRARY_PATH=/data/local/tmp /data/local/tmp/benchmark_utils --benchmark_color=true --benchmark_counters_tabular=true
// ------------------------------------------------------------------------------------------------
#define REPEAT 128
extern void bar() noexcept;
UTILS_NOINLINE
void foo() noexcept {
benchmark::ClobberMemory();
}
class VirtualizerInterface {
public:
virtual void baz() noexcept = 0;
void bazz() noexcept;
};
UTILS_NOINLINE
void VirtualizerInterface::bazz() noexcept {
baz();
}
class Virtualizer : public VirtualizerInterface {
public:
void baz() noexcept override;
};
UTILS_NOINLINE
void Virtualizer::baz() noexcept {
benchmark::ClobberMemory();
}
static void BM_call_local(benchmark::State& state) {
PerformanceCounters pc(state);
#pragma unroll(REPEAT)
for (auto _ : state) {
foo();
}
}
static void BM_call_library(benchmark::State& state) {
PerformanceCounters pc(state);
#pragma unroll(REPEAT)
for (auto _ : state) {
bar();
}
}
static void BM_call_virtual(benchmark::State& state) {
Virtualizer base;
VirtualizerInterface* v = &base;
benchmark::ClobberMemory();
benchmark::DoNotOptimize(base);
benchmark::DoNotOptimize(v);
PerformanceCounters pc(state);
#pragma unroll(REPEAT)
for (auto _ : state) {
v->baz();
}
}
static void BM_call_virtual_no_unroll(benchmark::State& state) {
Virtualizer base;
VirtualizerInterface* v = &base;
benchmark::ClobberMemory();
benchmark::DoNotOptimize(base);
benchmark::DoNotOptimize(v);
PerformanceCounters pc(state);
#pragma unroll(8)
for (auto _ : state) {
v->baz();
}
}
static void BM_call_virtual_trampoline(benchmark::State& state) {
Virtualizer base;
VirtualizerInterface* v = &base;
benchmark::ClobberMemory();
benchmark::DoNotOptimize(base);
benchmark::DoNotOptimize(v);
PerformanceCounters pc(state);
#pragma unroll(REPEAT)
for (auto _ : state) {
v->bazz();
}
}
static void BM_call_function_ptr(benchmark::State& state) {
using PFN = void(*)();
PFN pfn = foo;
benchmark::DoNotOptimize(pfn);
PerformanceCounters pc(state);
#pragma unroll(REPEAT)
for (auto _ : state) {
pfn();
}
}
BENCHMARK(BM_call_local);
BENCHMARK(BM_call_library);
BENCHMARK(BM_call_virtual);
BENCHMARK(BM_call_virtual_no_unroll);
BENCHMARK(BM_call_virtual_trampoline);
BENCHMARK(BM_call_function_ptr);