1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/sys/shell/cmds/nice.c
Dylan Laduranty f78a41f1b3 treewide: replace shell_commands module in documentation
Signed-off-by: Dylan Laduranty <dylan.laduranty@mesotic.com>
2024-03-19 15:12:02 +01:00

58 lines
1.5 KiB
C

/*
* Copyright (C) 2021 Otto-von-Guericke-Universität Magdeburg
*
* 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 sys_shell_commands
* @{
*
* @file
* @brief A shell command to change the niceness (inverse priority) of a thread
*
* @note Enable this by using the modules shell_cmds_default and
* shell_cmd_nice
*
* @author Marian Buschsieweke <marian.buschsieweke@ovgu.de>
*
* @}
*/
#include <stdio.h>
#include <stdlib.h>
#include "sched.h"
#include "shell.h"
#include "thread.h"
static int _sc_nice(int argc, char **argv)
{
if (argc != 3) {
printf("Usage: %s <THREAD_ID> <PRIORITY>\n"
"Note: Lower number means higher priority (niceness)\n",
argv[0]);
return EXIT_FAILURE;
}
/* Note: thread_get() does bounds checking and returns NULL on out of bounds PID */
thread_t *thread = thread_get(atoi(argv[1]));
if (!thread) {
printf("No active thread found for ID \"%s\"\n", argv[1]);
return EXIT_FAILURE;
}
uint8_t prio = atoi(argv[2]);
if (prio >= SCHED_PRIO_LEVELS) {
printf("Priority \"%s\" is invalid (try 0..%u)\n",
argv[2], (unsigned)SCHED_PRIO_LEVELS - 1);
}
sched_change_priority(thread, prio);
return EXIT_SUCCESS;
}
SHELL_COMMAND(nice, "Change priority of an active thread", _sc_nice);