summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/sway/server.h2
-rw-r--r--sway/main.c5
-rw-r--r--sway/server.c13
3 files changed, 17 insertions, 3 deletions
diff --git a/include/sway/server.h b/include/sway/server.h
index 65d96e7a..963d4dc1 100644
--- a/include/sway/server.h
+++ b/include/sway/server.h
@@ -47,6 +47,8 @@ struct sway_server {
47 47
48struct sway_server server; 48struct sway_server server;
49 49
50/* Prepares an unprivileged server_init by performing all privileged operations in advance */
51bool server_privileged_prepare(struct sway_server *server);
50bool server_init(struct sway_server *server); 52bool server_init(struct sway_server *server);
51void server_fini(struct sway_server *server); 53void server_fini(struct sway_server *server);
52void server_run(struct sway_server *server); 54void server_run(struct sway_server *server);
diff --git a/sway/main.c b/sway/main.c
index a7e808ad..a325dc3a 100644
--- a/sway/main.c
+++ b/sway/main.c
@@ -359,6 +359,11 @@ int main(int argc, char **argv) {
359 359
360 executable_sanity_check(); 360 executable_sanity_check();
361 bool suid = false; 361 bool suid = false;
362
363 if (!server_privileged_prepare(&server)) {
364 return 1;
365 }
366
362#ifdef __linux__ 367#ifdef __linux__
363 if (getuid() != geteuid() || getgid() != getegid()) { 368 if (getuid() != geteuid() || getgid() != getegid()) {
364 // Retain capabilities after setuid() 369 // Retain capabilities after setuid()
diff --git a/sway/server.c b/sway/server.c
index 824b1d8e..a467283b 100644
--- a/sway/server.c
+++ b/sway/server.c
@@ -11,6 +11,7 @@
11#include <wlr/types/wlr_idle.h> 11#include <wlr/types/wlr_idle.h>
12#include <wlr/types/wlr_layer_shell.h> 12#include <wlr/types/wlr_layer_shell.h>
13#include <wlr/types/wlr_linux_dmabuf.h> 13#include <wlr/types/wlr_linux_dmabuf.h>
14#include <wlr/types/wlr_export_dmabuf_v1.h>
14#include <wlr/types/wlr_primary_selection.h> 15#include <wlr/types/wlr_primary_selection.h>
15#include <wlr/types/wlr_screenshooter.h> 16#include <wlr/types/wlr_screenshooter.h>
16#include <wlr/types/wlr_server_decoration.h> 17#include <wlr/types/wlr_server_decoration.h>
@@ -25,9 +26,8 @@
25#include "sway/tree/layout.h" 26#include "sway/tree/layout.h"
26 27
27 28
28bool server_init(struct sway_server *server) { 29bool server_privileged_prepare(struct sway_server *server) {
29 wlr_log(L_DEBUG, "Initializing Wayland server"); 30 wlr_log(L_DEBUG, "Preparing Wayland server initialization");
30
31 server->wl_display = wl_display_create(); 31 server->wl_display = wl_display_create();
32 server->wl_event_loop = wl_display_get_event_loop(server->wl_display); 32 server->wl_event_loop = wl_display_get_event_loop(server->wl_display);
33 server->backend = wlr_backend_autocreate(server->wl_display, NULL); 33 server->backend = wlr_backend_autocreate(server->wl_display, NULL);
@@ -36,6 +36,12 @@ bool server_init(struct sway_server *server) {
36 wlr_log(L_ERROR, "Unable to create backend"); 36 wlr_log(L_ERROR, "Unable to create backend");
37 return false; 37 return false;
38 } 38 }
39 return true;
40}
41
42bool server_init(struct sway_server *server) {
43 wlr_log(L_DEBUG, "Initializing Wayland server");
44
39 struct wlr_renderer *renderer = wlr_backend_get_renderer(server->backend); 45 struct wlr_renderer *renderer = wlr_backend_get_renderer(server->backend);
40 assert(renderer); 46 assert(renderer);
41 47
@@ -97,6 +103,7 @@ bool server_init(struct sway_server *server) {
97 deco_manager, WLR_SERVER_DECORATION_MANAGER_MODE_SERVER); 103 deco_manager, WLR_SERVER_DECORATION_MANAGER_MODE_SERVER);
98 104
99 wlr_linux_dmabuf_create(server->wl_display, renderer); 105 wlr_linux_dmabuf_create(server->wl_display, renderer);
106 wlr_export_dmabuf_manager_v1_create(server->wl_display);
100 107
101 server->socket = wl_display_add_socket_auto(server->wl_display); 108 server->socket = wl_display_add_socket_auto(server->wl_display);
102 if (!server->socket) { 109 if (!server->socket) {