1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/tests/gnrc_mac_timeout/main.c
zhuoshuguo 79e5586d0c gnrc_mac: add timeout module.
Co-Authored-By: zhuoshuguo <zhuosgzju@gmail.com>
2019-01-21 22:46:10 +08:00

120 lines
4.0 KiB
C

/*
* Copyright (C) 2017 INRIA
*
* 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 gnrc_mac timeout test application
*
* @author Shuguo Zhuo <shuguo.zhuo@inria.fr>
*
* @}
*/
#include <stdio.h>
#include "net/gnrc/mac/timeout.h"
#include "thread.h"
#include "msg.h"
#include "xtimer.h"
#define TIMEOUT_COUNT 3
#define TIMEOUT_1_DURATION 1000
#define TIMEOUT_2_DURATION 2538
#define TIMEOUT_3_DURATION 3471
static gnrc_mac_timeout_t mac_timeout;
static gnrc_mac_timeout_event_t test_timeouts[TIMEOUT_COUNT];
static gnrc_mac_timeout_type_t timeout_1;
static gnrc_mac_timeout_type_t timeout_2;
static gnrc_mac_timeout_type_t timeout_3;
static uint32_t start_time;
static char worker_stack[THREAD_STACKSIZE_MAIN];
/* This thread will print the drift to stdout once per second */
void *worker_thread(void *arg)
{
int count = 1;
(void) arg;
while (1) {
msg_t m;
uint32_t now;
msg_receive(&m);
now = xtimer_now_usec() / US_PER_MS;
if (gnrc_mac_timeout_is_expired(&mac_timeout, timeout_1)) {
printf("At %6" PRIu32 " ms received msg %i: timeout_1 (set at %" PRIu32 " ms) expired, "
"supposed to be %" PRIu32 " ms!\n", now, count++, start_time, (TIMEOUT_1_DURATION + start_time));
}
if (gnrc_mac_timeout_is_expired(&mac_timeout, timeout_2)) {
printf("At %6" PRIu32 " ms received msg %i: timeout_2 (set at %" PRIu32 " ms) expired, "
"supposed to be %" PRIu32 " ms!\n", now, count++, start_time, (TIMEOUT_2_DURATION + start_time));
}
if (gnrc_mac_timeout_is_expired(&mac_timeout, timeout_3)) {
printf("At %6" PRIu32 " ms received msg %i: timeout_3 (set at %" PRIu32 " ms) expired, "
"supposed to be %" PRIu32 " ms!\n", now, count++, start_time, (TIMEOUT_3_DURATION + start_time));
}
if (gnrc_mac_timeout_is_running(&mac_timeout, timeout_1)) {
printf("At %6" PRIu32 " ms: timeout_1 is running.\n", now);
}
else {
printf("At %6" PRIu32 " ms: timeout_1 is not running.\n", now);
}
if (gnrc_mac_timeout_is_running(&mac_timeout, timeout_2)) {
printf("At %6" PRIu32 " ms: timeout_2 is running.\n", now);
}
else {
printf("At %6" PRIu32 " ms: timeout_2 is not running.\n", now);
}
if (gnrc_mac_timeout_is_running(&mac_timeout, timeout_3)) {
printf("At %6" PRIu32 " ms: timeout_3 is running.\n", now);
}
else {
printf("At %6" PRIu32 " ms: timeout_3 is not running.\n", now);
}
}
}
int main(void)
{
/* create worker thread */
kernel_pid_t pid = thread_create(worker_stack, sizeof(worker_stack),
THREAD_PRIORITY_MAIN - 1,
THREAD_CREATE_STACKTEST,
worker_thread, NULL, "worker");
timeout_1 = -1;
timeout_2 = -2;
timeout_3 = -3;
start_time = xtimer_now_usec() / US_PER_MS;
gnrc_mac_init_timeouts(&mac_timeout, test_timeouts, TIMEOUT_COUNT);
gnrc_mac_set_timeout(&mac_timeout, timeout_1, TIMEOUT_1_DURATION, pid);
gnrc_mac_set_timeout(&mac_timeout, timeout_2, TIMEOUT_2_DURATION, pid);
gnrc_mac_set_timeout(&mac_timeout, timeout_3, TIMEOUT_3_DURATION, pid);
printf("Testing gnrc_mac timeout module (start time = %" PRIu32 " ms)\n", start_time);
printf("Set timeout_1, should be expired at %" PRIu32 " ms)\n", TIMEOUT_1_DURATION + start_time);
printf("Set timeout_2, should be expired at %" PRIu32 " ms)\n", TIMEOUT_2_DURATION + start_time);
printf("Set timeout_3, should be expired at %" PRIu32 " ms)\n", TIMEOUT_3_DURATION + start_time);
puts("Are the reception times of all 3 msgs close to the supposed values?\n");
puts("If yes, the tests were successful");
}