mirror of
https://github.com/Ardour/ardour.git
synced 2025-12-10 16:46:35 +01:00
Add API to set thread-priority (for ctrl-surfaces)
This commit is contained in:
parent
c125cd2647
commit
8374e23014
2 changed files with 34 additions and 0 deletions
|
|
@ -28,6 +28,9 @@
|
|||
#include <cerrno>
|
||||
#include <cstring>
|
||||
|
||||
#include <pthread.h>
|
||||
#include <sched.h>
|
||||
|
||||
#include "pbd/base_ui.h"
|
||||
#include "pbd/debug.h"
|
||||
#include "pbd/pthread_utils.h"
|
||||
|
|
@ -76,6 +79,35 @@ BaseUI::new_request_type ()
|
|||
return rt;
|
||||
}
|
||||
|
||||
int
|
||||
BaseUI::set_thread_priority (const int policy, int priority) const
|
||||
{
|
||||
struct sched_param param;
|
||||
memset (¶m, 0, sizeof (param));
|
||||
|
||||
/* POSIX requires a spread of at least 32 steps between min..max */
|
||||
const int p_min = sched_get_priority_min (policy); // Linux: 1
|
||||
const int p_max = sched_get_priority_max (policy); // Linux: 99
|
||||
|
||||
if (priority == 0) {
|
||||
/* use default. XXX this should be relative to audio (JACK) thread,
|
||||
* internal backends use -20 (Audio), -21 (MIDI), -22 (compuation)
|
||||
*/
|
||||
priority = 7;
|
||||
}
|
||||
|
||||
if (priority > 0) {
|
||||
priority += p_min;
|
||||
} else {
|
||||
priority += p_max;
|
||||
}
|
||||
if (priority > p_max) priority = p_max;
|
||||
if (priority < p_min) priority = p_min;
|
||||
param.sched_priority = priority;
|
||||
|
||||
return pthread_setschedparam (pthread_self(), SCHED_FIFO, ¶m);
|
||||
}
|
||||
|
||||
void
|
||||
BaseUI::main_thread ()
|
||||
{
|
||||
|
|
|
|||
|
|
@ -91,6 +91,8 @@ class LIBPBD_API BaseUI : public sigc::trackable, public PBD::EventLoop
|
|||
|
||||
virtual void thread_init () {};
|
||||
|
||||
int set_thread_priority (const int policy = SCHED_FIFO, int priority = 0) const;
|
||||
|
||||
/** Called when there input ready on the request_channel
|
||||
*/
|
||||
bool request_handler (Glib::IOCondition);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue