blob: 347dc3571c5a5aa4a00af6fc371b73c95359889c [file] [log] [blame]
Anders Lewisf4447b92017-06-23 15:53:59 -07001/*
2 * Copyright (C) 2017 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Elliott Hughescbc80ba2018-02-13 14:26:29 -080017#pragma once
Anders Lewisf4447b92017-06-23 15:53:59 -070018
Christopher Ferris5a3c9202019-12-04 15:57:07 -080019#include <stdint.h>
20
Anders Lewisa7b0f882017-07-24 20:01:13 -070021#include <map>
22#include <mutex>
23#include <string>
Christopher Ferris858e3362017-11-30 08:53:15 -080024#include <utility>
Anders Lewisf4447b92017-06-23 15:53:59 -070025#include <vector>
26
Anders Lewisa7b0f882017-07-24 20:01:13 -070027typedef void (*benchmark_func_t) (void);
28
29extern std::mutex g_map_lock;
30
Christopher Ferris858e3362017-11-30 08:53:15 -080031extern std::map<std::string, std::pair<benchmark_func_t, std::string>> g_str_to_func;
Anders Lewisa7b0f882017-07-24 20:01:13 -070032
Elliott Hughes5cec3772018-01-19 15:45:23 -080033static int __attribute__((unused)) EmplaceBenchmark(const std::string& fn_name, benchmark_func_t fn_ptr, const std::string& arg = "") {
Anders Lewisa7b0f882017-07-24 20:01:13 -070034 g_map_lock.lock();
Christopher Ferris858e3362017-11-30 08:53:15 -080035 g_str_to_func.emplace(std::string(fn_name), std::make_pair(fn_ptr, arg));
Anders Lewisa7b0f882017-07-24 20:01:13 -070036 g_map_lock.unlock();
37 return 0;
38}
39
40#define BIONIC_BENCHMARK(n) \
41 int _bionic_benchmark_##n __attribute__((unused)) = EmplaceBenchmark(std::string(#n), reinterpret_cast<benchmark_func_t>(n))
42
Christopher Ferris858e3362017-11-30 08:53:15 -080043#define BIONIC_BENCHMARK_WITH_ARG(n, arg) \
44 int _bionic_benchmark_##n __attribute__((unused)) = EmplaceBenchmark(std::string(#n), reinterpret_cast<benchmark_func_t>(n), arg)
45
Elliott Hughes96705e32019-09-26 07:42:23 -070046#define BIONIC_TRIVIAL_BENCHMARK(__name, __expression) \
47 static void __name(benchmark::State& state) { \
48 for (auto _ : state) { \
49 benchmark::DoNotOptimize(__expression); \
50 } \
51 } \
52 BIONIC_BENCHMARK(__name)
Christopher Ferris858e3362017-11-30 08:53:15 -080053
Anders Lewisa7b0f882017-07-24 20:01:13 -070054constexpr auto KB = 1024;
55
56typedef struct {
Christopher Ferrisbfb7c762018-05-04 13:27:47 -070057 int cpu_to_lock = -1;
58 long num_iterations = 0;
Anders Lewisa7b0f882017-07-24 20:01:13 -070059 std::string xmlpath;
60 std::vector<std::string> extra_benchmarks;
61} bench_opts_t;
62
Anders Lewisf4447b92017-06-23 15:53:59 -070063// This function returns a pointer less than 2 * alignment + or_mask bytes into the array.
Anders Lewisa7b0f882017-07-24 20:01:13 -070064char* GetAlignedMemory(char* orig_ptr, size_t alignment, size_t or_mask);
Anders Lewisf4447b92017-06-23 15:53:59 -070065
Anders Lewisa7b0f882017-07-24 20:01:13 -070066char* GetAlignedPtr(std::vector<char>* buf, size_t alignment, size_t nbytes);
Anders Lewisf4447b92017-06-23 15:53:59 -070067
Anders Lewisac4f4b42017-08-08 18:29:51 -070068wchar_t* GetAlignedPtr(std::vector<wchar_t>* buf, size_t alignment, size_t nbytes);
69
Anders Lewisa7b0f882017-07-24 20:01:13 -070070char* GetAlignedPtrFilled(std::vector<char>* buf, size_t alignment, size_t nbytes, char fill_byte);
Anders Lewisf4447b92017-06-23 15:53:59 -070071
Christopher Ferrisbfb7c762018-05-04 13:27:47 -070072bool LockToCPU(int cpu_to_lock);
Christopher Ferris5a3c9202019-12-04 15:57:07 -080073
Elliott Hughes3469e7d2024-05-15 16:06:07 +000074static inline __attribute__((__always_inline__)) void MakeAllocationResident(
Christopher Ferris5a3c9202019-12-04 15:57:07 -080075 void* ptr, size_t nbytes, int pagesize) {
76 uint8_t* data = reinterpret_cast<uint8_t*>(ptr);
77 for (size_t i = 0; i < nbytes; i += pagesize) {
78 data[i] = 1;
79 }
80}