Add a memmove(3) benchmark.

Change-Id: I9c0ffae0b5aae29521b7e68e5ce2318b5a401cba
This commit is contained in:
Elliott Hughes 2012-11-09 14:59:21 -08:00
parent 49677deca2
commit fbe44ec043

View File

@ -62,6 +62,22 @@ static void BM_memcpy(int iters, int nbytes) {
}
BENCHMARK(BM_memcpy)->AT_COMMON_SIZES;
static void BM_memmove(int iters, int nbytes) {
StopBenchmarkTiming();
char* buf = new char[nbytes + 64];
memset(buf, 'x', nbytes + 64);
StartBenchmarkTiming();
for (int i = 0; i < iters; i++) {
memmove(buf, buf + 1, nbytes); // Worst-case overlap.
}
StopBenchmarkTiming();
SetBenchmarkBytesProcessed(int64_t(iters) * int64_t(nbytes));
delete[] buf;
}
BENCHMARK(BM_memmove)->AT_COMMON_SIZES;
static void BM_memset(int iters, int nbytes) {
StopBenchmarkTiming();
char* dst = new char[nbytes];