2015-09-12 14:31:19 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
*
|
|
|
|
* 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 tests
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief timer test application
|
|
|
|
*
|
|
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include "xtimer.h"
|
|
|
|
#include "periph_conf.h"
|
|
|
|
|
|
|
|
#define ITERATIONS 128
|
|
|
|
#define MAXSHIFT 8
|
|
|
|
|
|
|
|
unsigned min[MAXSHIFT];
|
|
|
|
unsigned max[MAXSHIFT];
|
|
|
|
unsigned avg[MAXSHIFT];
|
|
|
|
unsigned total[MAXSHIFT];
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
puts("xtimer_shift_on_compare test application.\n");
|
|
|
|
|
|
|
|
printf("trying %u iterations\n", ITERATIONS);
|
|
|
|
|
|
|
|
uint32_t a, b;
|
|
|
|
unsigned i = 0;
|
|
|
|
|
|
|
|
for (int shift = 0; shift < MAXSHIFT; shift++) {
|
|
|
|
min[shift] = (unsigned)0xffffffff;
|
|
|
|
max[shift] = 0;
|
|
|
|
total[shift] = 0;
|
|
|
|
avg[shift] = 0;
|
|
|
|
|
|
|
|
for (int j=0; j < ITERATIONS; j++) {
|
|
|
|
i = 0;
|
|
|
|
do {
|
|
|
|
i++;
|
|
|
|
if (i >= 0xF) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
}
|
|
|
|
|
2015-10-28 07:56:04 +01:00
|
|
|
a = _lltimer_now() | _high_cnt;
|
|
|
|
b = _lltimer_now() | _high_cnt;
|
2015-09-12 14:31:19 +02:00
|
|
|
} while ((a>>shift) != (b>>shift));
|
|
|
|
|
|
|
|
min[shift] = i < min[shift] ? i : min[shift];
|
|
|
|
max[shift] = i > max[shift] ? i : max[shift];
|
|
|
|
if (i != 0xF) {
|
|
|
|
total[shift]++;
|
|
|
|
avg[shift] += i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (int i=0; i < MAXSHIFT; i++) {
|
|
|
|
if (min[i] >= 0xF) {
|
|
|
|
printf("shift %i is too little.\n", i);
|
|
|
|
} else {
|
|
|
|
printf("shift %i min=%u max=%u n_success=%u avg=%u\n", i, min[i], max[i], total[i], avg[i]/total[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
printf("\nTest complete.\n");
|
|
|
|
return 0;
|
|
|
|
}
|