1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/tests/thread_cooperation/main.c

111 lines
2.4 KiB
C
Raw Normal View History

/*
* Copyright (C) 2014-2017 Hamburg University of Applied Sciences
2014-06-18 15:06:23 +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-06-18 15:06:23 +02:00
*/
/**
2014-06-18 15:06:23 +02:00
* @ingroup tests
* @{
*
* @file
* @brief riot thread test application
*
* @author Raphael Hiesgen <raphael.hiesgen@haw-hamburg.de>
* @author Sebastian Meiling <s@mlng.net>
2014-06-18 15:06:23 +02:00
*
* @}
*/
#include <stdio.h>
#include <inttypes.h>
#include "thread.h"
#include "mutex.h"
#include "test_utils/interactive_sync.h"
#ifndef PROBLEM
#define PROBLEM 12
#endif
mutex_t mtx = MUTEX_INIT;
volatile uint32_t storage = 1;
char stacks[PROBLEM][THREAD_STACKSIZE_DEFAULT];
void *run(void *arg)
{
(void) arg;
msg_t m, final;
kernel_pid_t me = thread_getpid();
printf("T-%02d: alive\n", me);
2014-07-25 08:17:06 +02:00
msg_receive(&m);
printf("T-%02d: got arg %" PRIu32 "\n", me, m.content.value);
2014-07-25 08:17:06 +02:00
mutex_lock(&mtx);
storage *= m.content.value;
mutex_unlock(&mtx);
final.content.value = me;
if (msg_send(&final, m.sender_pid) < 0) {
printf("T-%02d: send reply to main failed!\n", me);
}
return NULL;
}
int main(void)
{
msg_t args[PROBLEM];
kernel_pid_t ths;
uint32_t factorial = 1;
test_utils_interactive_sync();
printf("[START] compute %d! (factorial).\n", PROBLEM);
for (int i = 0; i < PROBLEM; ++i) {
int arg = i + 1;
factorial *= arg;
printf("MAIN: create thread, arg: %d\n", arg);
ths = thread_create(stacks[i], sizeof(stacks[i]),
2015-12-02 12:00:37 +01:00
THREAD_PRIORITY_MAIN - 1,
THREAD_CREATE_WOUT_YIELD | THREAD_CREATE_STACKTEST,
run, NULL, "thread");
if (ths < 0) {
puts("[ERROR]");
return 2;
}
printf("MAIN: msg to T-%d\n", ths);
args[i].content.value = arg;
if (msg_send(&args[i], ths) < 0) {
puts("[ERROR]");
return 3;
}
}
for (int i = 0; i < PROBLEM; ++i) {
msg_t msg;
msg_receive(&msg);
printf("MAIN: reply from T-%" PRIu32 "\n", msg.content.value);
}
printf("MAIN: %d! = %" PRIu32 "\n", PROBLEM, storage);
if (storage != factorial) {
printf("[ERROR] expected %" PRIu32 "\n", factorial);
return 1;
}
puts("[SUCCESS]");
return 0;
}