2014-04-22 18:12:58 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Ludwig Ortmann <ludwig.ortmann@fu-berlin.de>
|
|
|
|
*
|
2014-07-31 19:45:27 +02: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.
|
2014-04-22 18:12:58 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup tests
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Hwtimer test application
|
|
|
|
*
|
|
|
|
* @author Ludwig Ortmann <ludwig.ortmann@fu-berlin.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
2014-08-28 12:39:58 +02:00
|
|
|
#include <math.h>
|
2014-04-22 18:12:58 +02:00
|
|
|
|
|
|
|
#include "hwtimer.h"
|
2014-08-01 09:02:21 +02:00
|
|
|
#include "board.h"
|
2014-04-22 18:12:58 +02:00
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
puts("This is a regression test for a race condition in hwtimer_wait.");
|
2014-08-28 12:39:58 +02:00
|
|
|
puts("When the race condition is hit, the timer will wait for a very very long time.");
|
2014-04-22 18:12:58 +02:00
|
|
|
|
2015-07-09 16:09:59 +02:00
|
|
|
long iterations = 1000;
|
2014-11-28 13:48:25 +01:00
|
|
|
long start_duration = (HWTIMER_SPIN_BARRIER + 1) << 5;
|
2014-08-29 18:45:55 +02:00
|
|
|
long duration = iterations * start_duration * 2L;
|
|
|
|
|
2014-08-28 12:39:58 +02:00
|
|
|
printf("The test should take about %li sec.\n", (HWTIMER_TICKS_TO_US(duration)/1000000));
|
|
|
|
|
|
|
|
for (unsigned long r = iterations; r > 0; r--) {
|
2014-08-01 09:02:21 +02:00
|
|
|
for (unsigned long i = start_duration; i > HWTIMER_SPIN_BARRIER; i = i >> 1) {
|
2014-04-22 18:12:58 +02:00
|
|
|
hwtimer_wait(i);
|
|
|
|
}
|
|
|
|
}
|
2014-05-12 13:03:47 +02:00
|
|
|
puts("success");
|
2014-08-28 12:39:58 +02:00
|
|
|
|
2014-05-12 13:03:47 +02:00
|
|
|
return 0;
|
2014-04-22 18:12:58 +02:00
|
|
|
}
|