From 1c487e103618b7e4e3480f59375761e94ce80d2a Mon Sep 17 00:00:00 2001 From: Anders Lewis Date: Mon, 12 Jun 2017 12:33:06 -0700 Subject: [PATCH] Add benchmarks for strcpy and strcmp. Test: Ran benchmarks and verified that runtimes were sensible. Change-Id: I609e3261503a015bfd4982767fef3ce56141aebc --- benchmarks/string_benchmark.cpp | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/benchmarks/string_benchmark.cpp b/benchmarks/string_benchmark.cpp index e6c65703e..86a7c359f 100644 --- a/benchmarks/string_benchmark.cpp +++ b/benchmarks/string_benchmark.cpp @@ -173,3 +173,33 @@ static void BM_string_strcat_half_copy_half_seek(benchmark::State& state) { state.SetBytesProcessed(uint64_t(state.iterations()) * uint64_t(nbytes)); } BENCHMARK(BM_string_strcat_half_copy_half_seek)->AT_COMMON_SIZES; + +static void BM_string_strcpy(benchmark::State& state) { + const size_t nbytes = state.range(0); + std::vector src(nbytes, 'x'); + std::vector dst(nbytes); + src[nbytes - 1] = '\0'; + + while (state.KeepRunning()) { + strcpy(dst.data(), src.data()); + } + + state.SetBytesProcessed(uint64_t(state.iterations()) * uint64_t(nbytes)); +} +BENCHMARK(BM_string_strcpy)->AT_COMMON_SIZES; + +static void BM_string_strcmp(benchmark::State& state) { + const size_t nbytes = state.range(0); + std::vector s1(nbytes, 'x'); + std::vector s2(nbytes, 'x'); + s1[nbytes - 1] = '\0'; + s2[nbytes - 1] = '\0'; + + volatile int c __attribute__((unused)); + while (state.KeepRunning()) { + c = strcmp(s1.data(), s2.data()); + } + + state.SetBytesProcessed(uint64_t(state.iterations()) * uint64_t(nbytes)); +} +BENCHMARK(BM_string_strcmp)->AT_COMMON_SIZES; -- 2.11.0