-
Notifications
You must be signed in to change notification settings - Fork 1.7k
/
Copy pathharness.h
120 lines (96 loc) · 3.79 KB
/
harness.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/*
* Copyright (c) 2019, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* The Universal Permissive License (UPL), Version 1.0
*
* Subject to the condition set forth below, permission is hereby granted to any
* person obtaining a copy of this software, associated documentation and/or
* data (collectively the "Software"), free of charge and under any and all
* copyright rights in the Software, and any and all patent rights owned or
* freely licensable by each licensor hereunder covering either (i) the
* unmodified Software as contributed to or provided by such licensor, or (ii)
* the Larger Works (as defined below), to deal in both
*
* (a) the Software, and
*
* (b) any piece of software and/or hardware listed in the lrgrwrks.txt file if
* one is included with the Software each a "Larger Work" to which the Software
* is contributed by such licensors),
*
* without restriction, including without limitation the rights to copy, create
* derivative works of, display, perform, and distribute the Software and make,
* use, sell, offer for sale, import, export, have made, and have sold the
* Software and the Larger Work(s), and to sublicense the foregoing rights on
* either these or other terms.
*
* This license is subject to the following condition:
*
* The above copyright notice and either this complete permission notice or at a
* minimum a reference to the UPL must be included in all copies or substantial
* portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
#include <stdio.h>
#include <stdlib.h>
#include <sys/time.h>
// ------------------------
// The following methods
// must be implemented
// by the benchmarks.
// ------------------------
int benchmarkIterationsCount();
void benchmarkSetupOnce();
void benchmarkSetupEach();
void benchmarkTeardownEach(char* outputFile);
int benchmarkRun();
// -------------------------
// Function pointer list.
//
// This is done to prevent the optimization of these functions.
// They need to be called by the harness programmatically,
// which means that it must be possible to look them up.
// -------------------------
int (*functionIterationsCount)() = benchmarkIterationsCount;
void (*functionSetupOnce)() = benchmarkSetupOnce;
void (*functionSetupEach)() = benchmarkSetupEach;
void (*functionTeardownEach)(char* outputFile) = benchmarkTeardownEach;
int (*functionRun)() = benchmarkRun;
// -------------------------
// End of the function pointer list.
// -------------------------
int main(int argc, char* argv[]) {
int iterations = functionIterationsCount();
if (argc > 1) {
iterations = atoi(argv[1]);
}
printf("Will run %d iterations.\n", iterations);
char* outputFile = NULL;
if (argc > 2) {
outputFile = argv[2];
}
if (iterations == 0) {
return 0;
}
functionSetupOnce();
for (int i = 0; i != iterations; ++i) {
functionSetupEach();
struct timeval start, end;
gettimeofday(&start, NULL);
int result = functionRun();
gettimeofday(&end, NULL);
long start_t = start.tv_sec * 1000000 + start.tv_usec;
long end_t = end.tv_sec * 1000000 + end.tv_usec;
double time = (end_t - start_t) / 1000000.0;
printf("Iteration %d, result = %d, sec = %.3f, ops / sec = %.3f\n", i, result, time, 1.0 / time);
functionTeardownEach(outputFile);
}
return 0;
}