3469e7df9b
We can (and should) use `inline` in C++ but not in C headers that need to support ANSI/C89/C90. `__inline__` works everywhere, but traditionally we've used the BSD `__inline` in public headers. Change-Id: I920e0a1f5fcd01cf8ddd89240ef66b25c50378d7
80 lines
2.6 KiB
C++
80 lines
2.6 KiB
C++
/*
|
|
* Copyright (C) 2017 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.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <map>
|
|
#include <mutex>
|
|
#include <string>
|
|
#include <utility>
|
|
#include <vector>
|
|
|
|
typedef void (*benchmark_func_t) (void);
|
|
|
|
extern std::mutex g_map_lock;
|
|
|
|
extern std::map<std::string, std::pair<benchmark_func_t, std::string>> g_str_to_func;
|
|
|
|
static int __attribute__((unused)) EmplaceBenchmark(const std::string& fn_name, benchmark_func_t fn_ptr, const std::string& arg = "") {
|
|
g_map_lock.lock();
|
|
g_str_to_func.emplace(std::string(fn_name), std::make_pair(fn_ptr, arg));
|
|
g_map_lock.unlock();
|
|
return 0;
|
|
}
|
|
|
|
#define BIONIC_BENCHMARK(n) \
|
|
int _bionic_benchmark_##n __attribute__((unused)) = EmplaceBenchmark(std::string(#n), reinterpret_cast<benchmark_func_t>(n))
|
|
|
|
#define BIONIC_BENCHMARK_WITH_ARG(n, arg) \
|
|
int _bionic_benchmark_##n __attribute__((unused)) = EmplaceBenchmark(std::string(#n), reinterpret_cast<benchmark_func_t>(n), arg)
|
|
|
|
#define BIONIC_TRIVIAL_BENCHMARK(__name, __expression) \
|
|
static void __name(benchmark::State& state) { \
|
|
for (auto _ : state) { \
|
|
benchmark::DoNotOptimize(__expression); \
|
|
} \
|
|
} \
|
|
BIONIC_BENCHMARK(__name)
|
|
|
|
constexpr auto KB = 1024;
|
|
|
|
typedef struct {
|
|
int cpu_to_lock = -1;
|
|
long num_iterations = 0;
|
|
std::string xmlpath;
|
|
std::vector<std::string> extra_benchmarks;
|
|
} bench_opts_t;
|
|
|
|
// This function returns a pointer less than 2 * alignment + or_mask bytes into the array.
|
|
char* GetAlignedMemory(char* orig_ptr, size_t alignment, size_t or_mask);
|
|
|
|
char* GetAlignedPtr(std::vector<char>* buf, size_t alignment, size_t nbytes);
|
|
|
|
wchar_t* GetAlignedPtr(std::vector<wchar_t>* buf, size_t alignment, size_t nbytes);
|
|
|
|
char* GetAlignedPtrFilled(std::vector<char>* buf, size_t alignment, size_t nbytes, char fill_byte);
|
|
|
|
bool LockToCPU(int cpu_to_lock);
|
|
|
|
static inline __attribute__((__always_inline__)) void MakeAllocationResident(
|
|
void* ptr, size_t nbytes, int pagesize) {
|
|
uint8_t* data = reinterpret_cast<uint8_t*>(ptr);
|
|
for (size_t i = 0; i < nbytes; i += pagesize) {
|
|
data[i] = 1;
|
|
}
|
|
}
|