source: mainline/uspace/app/hbench/csv.c

Last change on this file was e7f9a09, checked in by Vojtech Horky <vojtech.horky@…>, 6 years ago

hbench: less parameters to benchmark runners

Merge stopwatch as well as error message buffer into one structure to
simplify benchmark runner signature.

  • Property mode set to 100644
File size: 2.7 KB
Line 
1/*
2 * Copyright (c) 2019 Vojtech Horky
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup hbench
30 * @{
31 */
32/**
33 * @file
34 */
35
36#include <stdlib.h>
37#include <stdio.h>
38#include "hbench.h"
39
40static FILE *csv_output = NULL;
41
42/** Open CSV benchmark report.
43 *
44 * @param filename Filename where to store the CSV.
45 * @return Whether it was possible to open the file.
46 */
47errno_t csv_report_open(const char *filename)
48{
49 csv_output = fopen(filename, "w");
50 if (csv_output == NULL) {
51 return errno;
52 }
53
54 fprintf(csv_output, "benchmark,run,size,duration_nanos\n");
55
56 return EOK;
57}
58
59/** Add one entry to the report.
60 *
61 * When csv_report_open() was not called or failed, the function does
62 * nothing.
63 *
64 * @param run Performance data of the entry.
65 * @param run_index Run index, use negative values for warm-up.
66 * @param bench Benchmark information.
67 * @param workload_size Workload size.
68 */
69void csv_report_add_entry(bench_run_t *run, int run_index,
70 benchmark_t *bench, uint64_t workload_size)
71{
72 if (csv_output == NULL) {
73 return;
74 }
75
76 fprintf(csv_output, "%s,%d,%" PRIu64 ",%lld\n",
77 bench->name, run_index, workload_size,
78 (long long) stopwatch_get_nanos(&run->stopwatch));
79}
80
81/** Close CSV report.
82 *
83 * When csv_report_open() was not called or failed, the function does
84 * nothing.
85 */
86void csv_report_close(void)
87{
88 if (csv_output != NULL) {
89 fclose(csv_output);
90 }
91}
92
93/** @}
94 */
Note: See TracBrowser for help on using the repository browser.