mirror of
https://github.com/swaywm/sway.git
synced 2024-11-28 19:01:29 +00:00
realtime: request SCHED_RR using CAP_SYS_NICE
Try to gain SCHED_RR (round-robin) realtime scheduling privileges before starting the server. This requires CAP_SYS_NICE on Linux systems. We additionally register a pthread_atfork callback which resets the scheduling class back to SCHED_OTHER (the Linux system default). Due to CAP_SYS_NICE, setting RLIMIT_RTPRIO has no effect on the process as documented within man 7 sched (from Linux): Privileged (CAP_SYS_NICE) threads ignore the RLIMIT_RTPRIO limit; as with older kernels, they can make arbitrary changes to scheduling policy and priority. See getrlimit(2) for further information on RLIMIT_RTPRIO Note that this requires the sway distribution packagers to set the CAP_SYS_NICE capability on the sway binary. Supersedes #6992
This commit is contained in:
parent
3f600565e4
commit
a3a82efbf6
|
@ -173,4 +173,6 @@ void handle_pointer_constraint(struct wl_listener *listener, void *data);
|
||||||
void xdg_activation_v1_handle_request_activate(struct wl_listener *listener,
|
void xdg_activation_v1_handle_request_activate(struct wl_listener *listener,
|
||||||
void *data);
|
void *data);
|
||||||
|
|
||||||
|
void set_rr_scheduling(void);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -413,6 +413,8 @@ int main(int argc, char **argv) {
|
||||||
goto shutdown;
|
goto shutdown;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
set_rr_scheduling();
|
||||||
|
|
||||||
if (!server_start(&server)) {
|
if (!server_start(&server)) {
|
||||||
sway_terminate(EXIT_FAILURE);
|
sway_terminate(EXIT_FAILURE);
|
||||||
goto shutdown;
|
goto shutdown;
|
||||||
|
|
|
@ -7,6 +7,7 @@ sway_sources = files(
|
||||||
'ipc-server.c',
|
'ipc-server.c',
|
||||||
'lock.c',
|
'lock.c',
|
||||||
'main.c',
|
'main.c',
|
||||||
|
'realtime.c',
|
||||||
'server.c',
|
'server.c',
|
||||||
'swaynag.c',
|
'swaynag.c',
|
||||||
'xdg_activation_v1.c',
|
'xdg_activation_v1.c',
|
||||||
|
|
40
sway/realtime.c
Normal file
40
sway/realtime.c
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
#include <sys/resource.h>
|
||||||
|
#include <sched.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <pthread.h>
|
||||||
|
#include "sway/server.h"
|
||||||
|
#include "log.h"
|
||||||
|
|
||||||
|
static void child_fork_callback(void) {
|
||||||
|
struct sched_param param;
|
||||||
|
|
||||||
|
param.sched_priority = 0;
|
||||||
|
|
||||||
|
int ret = pthread_setschedparam(pthread_self(), SCHED_OTHER, ¶m);
|
||||||
|
if (ret != 0) {
|
||||||
|
sway_log(SWAY_ERROR, "Failed to reset scheduler policy on fork");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void set_rr_scheduling(void) {
|
||||||
|
int prio = sched_get_priority_min(SCHED_RR);
|
||||||
|
int old_policy;
|
||||||
|
int ret;
|
||||||
|
struct sched_param param;
|
||||||
|
|
||||||
|
ret = pthread_getschedparam(pthread_self(), &old_policy, ¶m);
|
||||||
|
if (ret != 0) {
|
||||||
|
sway_log(SWAY_DEBUG, "Failed to get old scheduling priority");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
param.sched_priority = prio;
|
||||||
|
|
||||||
|
ret = pthread_setschedparam(pthread_self(), SCHED_RR, ¶m);
|
||||||
|
if (ret != 0) {
|
||||||
|
sway_log(SWAY_INFO, "Failed to set scheduling priority to %d", prio);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
pthread_atfork(NULL, NULL, child_fork_callback);
|
||||||
|
}
|
Loading…
Reference in a new issue