/* * Copyright (C) 2014 Freie Universität Berlin * * This file is subject to the terms and conditions of the GNU Lesser General * Public License. See the file LICENSE in the top level directory for more * details. */ /** * @ingroup tests * @{ * @file * @brief Test if the queue used for messaging is fair. * @author René Kijewski * @} */ #include #include "msg.h" #include "sched.h" #include "thread.h" #include "vtimer.h" #define STACK_SIZE (KERNEL_CONF_STACKSIZE_DEFAULT + KERNEL_CONF_STACKSIZE_MAIN) #define NUM_CHILDREN (3) #define NUM_ITERATIONS (10) static char stacks[NUM_CHILDREN][STACK_SIZE]; static int pids[NUM_CHILDREN]; static char names[NUM_CHILDREN][8]; static int parent_pid; static void *child_fun(void *arg) { (void) arg; printf("Start of %s.\n", sched_active_thread->name); for (int i = 0; i < NUM_ITERATIONS; ++i) { msg_t m; m.type = i + 1; m.content.ptr = (void *) sched_active_thread->name; msg_send(&m, parent_pid, true); } printf("End of %s.\n", sched_active_thread->name); return NULL; } int main(void) { puts("Start."); parent_pid = sched_active_pid; for (int i = 0; i < NUM_CHILDREN; ++i) { snprintf(names[i], sizeof(names[i]), "child%2u", i + 1); pids[i] = thread_create(stacks[i], sizeof(stacks[i]), PRIORITY_MAIN + 1, CREATE_WOUT_YIELD | CREATE_STACKTEST, child_fun, NULL, names[i]); } int last_iteration = 0; for (int i = 0; i < NUM_ITERATIONS * NUM_CHILDREN; ++i) { msg_t m; msg_receive(&m); int cur_iteration = (int) m.type; char *child = (char *) m.content.ptr; printf("Received message from %s, iteration %d / %u: %s\n", child, cur_iteration, NUM_ITERATIONS, cur_iteration >= last_iteration ? "okay" : "ERROR"); last_iteration = cur_iteration; vtimer_usleep(25 * 1000); } puts("Done."); return 0; }