2017-05-11 10:04:05 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2017 OTA keys S.A.
|
2017-06-01 10:38:36 +02:00
|
|
|
* 2017 HAW Hamburg
|
2017-05-11 10:04:05 +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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup tests
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief ps schedstatistics test app
|
|
|
|
*
|
|
|
|
* @author Vincent Dupont <vincent@otakeys.com>
|
2017-06-01 10:38:36 +02:00
|
|
|
* @author Sebastian Meiling <s@mlng.net>
|
2017-05-11 10:04:05 +02:00
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <inttypes.h>
|
|
|
|
|
|
|
|
#include <shell.h>
|
|
|
|
#include <thread.h>
|
|
|
|
#include <xtimer.h>
|
|
|
|
|
2019-10-10 01:10:41 +02:00
|
|
|
#include "test_utils/interactive_sync.h"
|
|
|
|
|
2017-06-01 10:38:36 +02:00
|
|
|
#define NB_THREADS (5U)
|
2017-05-11 10:04:05 +02:00
|
|
|
|
|
|
|
static char stacks[NB_THREADS][THREAD_STACKSIZE_DEFAULT];
|
|
|
|
static kernel_pid_t pids[NB_THREADS];
|
|
|
|
|
|
|
|
static void *_thread_fn(void *arg)
|
|
|
|
{
|
2017-06-01 10:38:36 +02:00
|
|
|
int next = ((int)arg + 1) % NB_THREADS;
|
2017-05-11 10:04:05 +02:00
|
|
|
|
|
|
|
printf("Creating thread #%d, next=%d\n", (int)arg, next);
|
|
|
|
|
|
|
|
while (1) {
|
2017-06-01 10:38:36 +02:00
|
|
|
msg_t m1, m2;
|
|
|
|
msg_receive(&m1);
|
2019-10-23 21:14:17 +02:00
|
|
|
/* generate different loads per thead */
|
2017-06-01 10:38:36 +02:00
|
|
|
for (int i = 0; i < (10 * (next + 1)); ++i) {
|
|
|
|
_xtimer_now64();
|
|
|
|
}
|
2019-11-28 08:05:00 +01:00
|
|
|
xtimer_usleep(XTIMER_BACKOFF * 10);
|
2017-06-01 10:38:36 +02:00
|
|
|
msg_send(&m2, pids[next]);
|
2017-05-11 10:04:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
2019-10-10 01:10:41 +02:00
|
|
|
test_utils_interactive_sync();
|
|
|
|
|
2017-06-01 10:38:36 +02:00
|
|
|
for (unsigned i = 0; i < NB_THREADS; ++i) {
|
2017-05-11 10:04:05 +02:00
|
|
|
pids[i] = thread_create(stacks[i], sizeof(stacks[i]),
|
2017-06-01 10:38:36 +02:00
|
|
|
THREAD_PRIORITY_MAIN - 1,
|
2017-05-11 10:04:05 +02:00
|
|
|
THREAD_CREATE_STACKTEST,
|
|
|
|
_thread_fn, (void *)i, "thread");
|
|
|
|
}
|
2017-06-01 10:38:36 +02:00
|
|
|
/* sleep for a second, so that `ps` shows some % on idle at the beginning */
|
|
|
|
xtimer_sleep(1);
|
2017-05-11 10:04:05 +02:00
|
|
|
|
|
|
|
msg_t msg;
|
|
|
|
msg_send(&msg, pids[0]);
|
|
|
|
|
|
|
|
char line_buf[SHELL_DEFAULT_BUFSIZE];
|
|
|
|
shell_run(NULL, line_buf, SHELL_DEFAULT_BUFSIZE);
|
|
|
|
}
|