2014-03-29 Siddhesh Poyarekar <siddhesh@redhat.com>
+ * benchtests/Makefile (DETAILED_OPT): New make option.
+ (bench-func): Run benchmark program with -d if DETAILED_OPT is
+ set.
+ * benchtests/bench-skeleton.c: Include stdbool.h.
+ (main): Store and print timings per input.
+ * benchtests/scripts/bench.py (STRUCT_TEMPLATE): Add timing
+ member to each argument value.
+ (EPILOGUE): Define new macros RESULT and RESULT_ACCUM.
+ (_print_arg_data): Initialize per-input timing to 0.
+
* benchtests/Makefile (timing-type): New binary.
(bench-clean): Also remove bench-timing-type.
(bench): New target for timing-type.
CPPFLAGS-nonlib += -DUSE_CLOCK_GETTIME
endif
+DETAILED_OPT :=
+
+ifdef DETAILED
+DETAILED_OPT := -d
+endif
+
# This makes sure CPPFLAGS-nonlib and CFLAGS-nonlib are passed
# for all these modules.
cpp-srcs-left := $(binaries-benchset:=.c) $(binaries-bench:=.c)
echo ","; \
fi; \
echo "Running $${run}" >&2; \
- $(run-bench); \
+ $(run-bench) $(DETAILED_OPT); \
done; \
echo " }"; \
echo "}"; } > $(objpfx)bench.out-tmp; \
#include <string.h>
#include <stdint.h>
+#include <stdbool.h>
#include <stdio.h>
#include <time.h>
#include <inttypes.h>
unsigned long i, k;
struct timespec runtime;
timing_t start, end;
+ bool detailed = false;
+
+ if (argc == 2 && !strcmp (argv[1], "-d"))
+ detailed = true;
startup();
double d_total_i = 0;
timing_t total = 0, max = 0, min = 0x7fffffffffffffff;
+ int64_t c = 0;
while (1)
{
for (i = 0; i < NUM_SAMPLES (v); i++)
min = cur;
TIMING_ACCUM (total, cur);
+ /* Accumulate timings for the value. In the end we will divide
+ by the total iterations. */
+ RESULT_ACCUM (cur, v, i, c * iters, (c + 1) * iters);
+
d_total_i += iters;
}
+ c++;
struct timespec curtime;
memset (&curtime, 0, sizeof (curtime));
d_total_s, d_total_i, max / d_iters, min / d_iters,
d_total_s / d_total_i);
+ if (detailed)
+ {
+ printf (",\n\"timings\": [");
+ for (int i = 0; i < NUM_SAMPLES (v); i++)
+ {
+ if (i > 0)
+ putc (',', stdout);
+ printf ("%g", RESULT (v, i));
+ }
+ puts ("]");
+ }
puts ("}");
}
struct args
{
%(args)s
+ double timing;
};
struct _variants
# Epilogue for the generated source file.
EPILOGUE = '''
+#define RESULT(__v, __i) (variants[(__v)].in[(__i)].timing)
+#define RESULT_ACCUM(r, v, i, old, new) \\
+ ((RESULT ((v), (i))) = (RESULT ((v), (i)) * (old) + (r)) / ((new) + 1))
#define BENCH_FUNC(i, j) ({%(getret)s CALL_BENCH_FUNC (i, j);})
#define FUNCNAME "%(func)s"
#include "bench-skeleton.c"'''
# Now print the values.
variants = []
for (k, vals), i in zip(all_vals.items(), itertools.count()):
- out = [' {%s},' % v for v in vals]
+ out = [' {%s, 0},' % v for v in vals]
# Members for the variants structure list that we will
# print later.