summaryrefslogtreecommitdiffstats
path: root/lib/libcxx/benchmarks/string.bench.cpp
diff options
context:
space:
mode:
authorpatrick <patrick@openbsd.org>2019-02-04 16:55:44 +0000
committerpatrick <patrick@openbsd.org>2019-02-04 16:55:44 +0000
commit76c648e7a477ffb2a882ad5ffe523269bd9a3f6a (patch)
tree29d319d598650bab04e4f58e5e8769567e33091e /lib/libcxx/benchmarks/string.bench.cpp
parentImport libc++abi 7.0.1. (diff)
downloadwireguard-openbsd-76c648e7a477ffb2a882ad5ffe523269bd9a3f6a.tar.xz
wireguard-openbsd-76c648e7a477ffb2a882ad5ffe523269bd9a3f6a.zip
Import libc++ 7.0.1.
Diffstat (limited to 'lib/libcxx/benchmarks/string.bench.cpp')
-rw-r--r--lib/libcxx/benchmarks/string.bench.cpp25
1 files changed, 23 insertions, 2 deletions
diff --git a/lib/libcxx/benchmarks/string.bench.cpp b/lib/libcxx/benchmarks/string.bench.cpp
index ef892391688..8a09e738d9b 100644
--- a/lib/libcxx/benchmarks/string.bench.cpp
+++ b/lib/libcxx/benchmarks/string.bench.cpp
@@ -2,7 +2,7 @@
#include <vector>
#include <cstdint>
-#include "benchmark/benchmark_api.h"
+#include "benchmark/benchmark.h"
#include "GenerateInput.hpp"
constexpr std::size_t MAX_STRING_LEN = 8 << 14;
@@ -46,4 +46,25 @@ static void BM_StringFindMatch2(benchmark::State &state) {
}
BENCHMARK(BM_StringFindMatch2)->Range(1, MAX_STRING_LEN / 4);
-BENCHMARK_MAIN()
+static void BM_StringCtorDefault(benchmark::State &state) {
+ while (state.KeepRunning()) {
+ for (unsigned I=0; I < 1000; ++I) {
+ std::string Default;
+ benchmark::DoNotOptimize(Default.c_str());
+ }
+ }
+}
+BENCHMARK(BM_StringCtorDefault);
+
+static void BM_StringCtorCStr(benchmark::State &state) {
+ std::string Input = getRandomString(state.range(0));
+ const char *Str = Input.c_str();
+ benchmark::DoNotOptimize(Str);
+ while (state.KeepRunning()) {
+ std::string Tmp(Str);
+ benchmark::DoNotOptimize(Tmp.c_str());
+ }
+}
+BENCHMARK(BM_StringCtorCStr)->Arg(1)->Arg(8)->Range(16, MAX_STRING_LEN / 4);
+
+BENCHMARK_MAIN();