1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 06:52:44 +01:00
RIOT/sys/benchmark/benchmark.c

38 lines
948 B
C
Raw Normal View History

2017-12-20 11:32:16 +01: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);
uint32_t div = (uint32_t)(((uint64_t)(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);
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
}