2017-12-20 11:32:16 +01:00
|
|
|
/*
|
2018-06-14 13:24:50 +02:00
|
|
|
* Copyright (C) 2017,2018 Freie Universität Berlin
|
2017-12-20 11:32:16 +01:00
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
|
|
* Public License v2.1. See the file LICENSE in the top level directory for more
|
|
|
|
* details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup sys_benchmark
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Utility functions for the benchmark module
|
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
2021-11-03 13:04:54 +01:00
|
|
|
#include "timex.h"
|
2017-12-20 11:32:16 +01:00
|
|
|
|
|
|
|
#include "benchmark.h"
|
|
|
|
|
|
|
|
void benchmark_print_time(uint32_t time, unsigned long runs, const char *name)
|
|
|
|
{
|
|
|
|
uint32_t full = (time / runs);
|
2022-02-08 12:52:48 +01:00
|
|
|
uint32_t div = (time - (full * runs)) * 1000 / runs;
|
2017-12-20 11:32:16 +01:00
|
|
|
|
2021-11-03 13:04:54 +01:00
|
|
|
uint32_t per_sec = (uint32_t)(((uint64_t)US_PER_SEC * runs) / time);
|
2018-06-14 13:24:50 +02:00
|
|
|
|
|
|
|
printf("%25s: %9" PRIu32 "us"
|
|
|
|
" --- %2" PRIu32 ".%03" PRIu32 "us per call"
|
|
|
|
" --- %9" PRIu32 " calls per sec\n",
|
|
|
|
name, time, full, div, per_sec);
|
2017-12-20 11:32:16 +01:00
|
|
|
}
|