1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/tests/mutex_unlock_and_sleep/main.c

75 lines
1.7 KiB
C
Raw Normal View History

2014-02-24 16:09:37 +01:00
/*
* Copyright (C) 2014 Hamburg University of Applied Siences (HAW)
*
* 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-02-24 16:09:37 +01:00
*/
/**
* @ingroup tests
* @{
*
* @file
* @brief simple test application for atomic mutex unlocking and sleeping
*
* @author Martin Landsmann <martin.landsmann@haw-hamburg.de>
*
* @}
*/
#include <stdio.h>
#include "thread.h"
#include "mutex.h"
static mutex_t mutex = MUTEX_INIT;
2014-02-24 16:09:37 +01:00
static volatile int indicator, count;
2014-10-01 03:57:54 +02:00
static kernel_pid_t main_pid;
2014-02-24 16:09:37 +01:00
static char stack[THREAD_STACKSIZE_MAIN];
static void *second_thread(void *arg)
2014-02-24 16:09:37 +01:00
{
(void) arg;
2014-02-24 16:09:37 +01:00
while (1) {
mutex_lock(&mutex);
2014-10-01 03:57:54 +02:00
thread_wakeup(main_pid);
2014-02-24 16:09:37 +01:00
indicator--;
mutex_unlock_and_sleep(&mutex);
}
return NULL;
2014-02-24 16:09:37 +01:00
}
int main(void)
{
indicator = 0;
count = 0;
2014-10-01 03:57:54 +02:00
main_pid = thread_getpid();
kernel_pid_t second_pid = thread_create(stack,
sizeof(stack),
THREAD_PRIORITY_MAIN - 1,
2014-02-24 16:09:37 +01:00
CREATE_WOUT_YIELD | CREATE_STACKTEST,
second_thread,
NULL,
2014-02-24 16:09:37 +01:00
"second_thread");
while (1) {
mutex_lock(&mutex);
2014-10-01 03:57:54 +02:00
thread_wakeup(second_pid);
2014-02-24 16:09:37 +01:00
indicator++;
count++;
if (indicator > 1 || indicator < -1) {
printf("Error, threads did not sleep properly. [indicator: %d]\n", indicator);
return -1;
}
if ((count % 100000) == 0) {
printf("Still alive alternated [count: %dk] times.\n", count / 1000);
}
mutex_unlock_and_sleep(&mutex);
}
}