summaryrefslogtreecommitdiff
path: root/benchtests/bench-memmove-walk.c
diff options
context:
space:
mode:
Diffstat (limited to 'benchtests/bench-memmove-walk.c')
-rw-r--r--benchtests/bench-memmove-walk.c15
1 files changed, 5 insertions, 10 deletions
diff --git a/benchtests/bench-memmove-walk.c b/benchtests/bench-memmove-walk.c
index 54dcd64292..969ddd94a2 100644
--- a/benchtests/bench-memmove-walk.c
+++ b/benchtests/bench-memmove-walk.c
@@ -47,26 +47,22 @@ static void
do_one_test (json_ctx_t *json_ctx, impl_t *impl, char *dst, char *src,
size_t len)
{
- size_t i, iters = MIN_PAGE_SIZE / len;
+ size_t i = 0;
timing_t start, stop, cur;
char *dst_end = dst + MIN_PAGE_SIZE - len;
char *src_end = src + MIN_PAGE_SIZE - len;
TIMING_NOW (start);
- /* Copy the entire buffer back and forth, LEN at a time. */
- for (i = 0; i < iters && dst_end >= dst && src <= src_end; src++, dst_end--)
- {
- CALL (impl, dst_end, src, len);
- CALL (impl, src, dst_end, len);
- i += 2;
- }
+ /* Copy the entire buffer backwards, LEN at a time. */
+ for (; src_end >= src && dst <= dst_end; dst += len, src_end -= len, i++)
+ CALL (impl, dst, src_end, len);
TIMING_NOW (stop);
TIMING_DIFF (cur, start, stop);
/* Get time taken per function call. */
- json_element_double (json_ctx, (double) cur * len / i);
+ json_element_double (json_ctx, (double) cur / i);
}
static void
@@ -79,7 +75,6 @@ do_test (json_ctx_t *json_ctx, size_t len, bool overlap)
if (overlap)
buf2 = buf1;
- /* First the non-overlapping moves. */
FOR_EACH_IMPL (impl, 0)
do_one_test (json_ctx, impl, (char *) buf2, (char *) buf1, len);