/* * piHiPri: * Simple way to get your program running at high priority * with realtime schedulling. * * Copyright (c) 2012 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://github.com/WiringPi/WiringPi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "wiringPi.h" /* * piHiPri: * Attempt to set a high priority schedulling for the running program. * A lower priority number = higher priority in the system. * On linux, this range is 1 through 99. * Returns result of sched_setscheduler() call: 0 on success, -1 on error. ********************************************************************************* * @NOTE: This could be done using "int nice(int inc);" in * nice() adds inc to the nice value for the calling thread. * A higher inc value means a lower priority. * A negative inc value means higher priority. ********************************************************************************* */ int piHiPri (const int pri) { struct sched_param sched; int max_pri = sched_get_priority_max (SCHED_RR); memset (&sched, 0, sizeof(sched)); if (pri > max_pri) sched.sched_priority = max_pri; else sched.sched_priority = pri; // PID = 0 means the current running program. // SCHED_RR = round-robin scheduling policy. return sched_setscheduler (0, SCHED_RR, &sched); }