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

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since fe656783 was fe656783, checked in by Vojtech Horky <vojtech.horky@…>, 6 years ago

Rename perf to hbench

The main reason for the rename is that perf (and performance measuring
tool description) suggests that perf is a generic tool for measuring
performance of other applications. But it is actually a set of
benchmarks for measuring internal parts of HelenOS (libc, IPC, etc.).

Furthermore, perf is a well-known program in GNU/Linux world with
completely different purpose and there really is no reason why to
confuse the users.

The new name hopefully better suggests that the tool is a set of
benchmarks for HelenOS (hence the name (H)elenOS (bench)marks).

  • 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 "csv.h"
38
39static FILE *csv_output = NULL;
40
41/** Open CSV benchmark report.
42 *
43 * @param filename Filename where to store the CSV.
44 * @return Whether it was possible to open the file.
45 */
46errno_t csv_report_open(const char *filename)
47{
48 csv_output = fopen(filename, "w");
49 if (csv_output == NULL) {
50 return errno;
51 }
52
53 fprintf(csv_output, "benchmark,run,size,duration_nanos\n");
54
55 return EOK;
56}
57
58/** Add one entry to the report.
59 *
60 * When csv_report_open() was not called or failed, the function does
61 * nothing.
62 *
63 * @param stopwatch Performance data of the entry.
64 * @param run_index Run index, use negative values for warm-up.
65 * @param bench Benchmark information.
66 * @param workload_size Workload size.
67 */
68void csv_report_add_entry(stopwatch_t *stopwatch, int run_index,
69 benchmark_t *bench, uint64_t workload_size)
70{
71 if (csv_output == NULL) {
72 return;
73 }
74
75 fprintf(csv_output, "%s,%d,%" PRIu64 ",%lld\n",
76 bench->name, run_index, workload_size,
77 (long long) stopwatch_get_nanos(stopwatch));
78}
79
80/** Close CSV report.
81 *
82 * When csv_report_open() was not called or failed, the function does
83 * nothing.
84 */
85void csv_report_close(void)
86{
87 if (csv_output != NULL) {
88 fclose(csv_output);
89 }
90}
91
92/** @}
93 */
Note: See TracBrowser for help on using the repository browser.