summary refs log tree commit diff
path: root/pkgs/development/libraries/wlroots/0001-backend-wayland-downgrade-to-wl_compositor-v3.patch
blob: e6d934419f053629ce0ee46e791208a2865df83f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
From fae720321c2e8e4d57c9c6554d4f025b1808747c Mon Sep 17 00:00:00 2001
From: Alyssa Ross <hi@alyssa.is>
Date: Tue, 25 Aug 2020 17:34:48 +0000
Subject: [PATCH 1/2] backend/wayland: downgrade to wl_compositor v3

Sommelier does not support v4.

Rather than calculating exact surface-relative damage regions instead
of the previous buffer-relative ones, just damage the whole surface.
It'll do for now.
---
 backend/wayland/backend.c |  6 +++++-
 backend/wayland/output.c  | 11 +++++++++--
 include/backend/wayland.h |  1 +
 3 files changed, 15 insertions(+), 3 deletions(-)

diff --git a/backend/wayland/backend.c b/backend/wayland/backend.c
index 771f4405..fc798292 100644
--- a/backend/wayland/backend.c
+++ b/backend/wayland/backend.c
@@ -210,7 +210,7 @@ static void registry_global(void *data, struct wl_registry *registry,
 
 	if (strcmp(iface, wl_compositor_interface.name) == 0) {
 		wl->compositor = wl_registry_bind(registry, name,
-			&wl_compositor_interface, 4);
+			&wl_compositor_interface, wl_compositor_version());
 	} else if (strcmp(iface, wl_seat_interface.name) == 0) {
 		struct wl_seat *wl_seat = wl_registry_bind(registry, name,
 			&wl_seat_interface, 5);
@@ -373,6 +373,10 @@ bool wlr_backend_is_wl(struct wlr_backend *b) {
 	return b->impl == &backend_impl;
 }
 
+uint32_t wl_compositor_version(void) {
+	return getenv("SOMMELIER_VERSION") ? 3 : 4;
+}
+
 static void handle_display_destroy(struct wl_listener *listener, void *data) {
 	struct wlr_wl_backend *wl =
 		wl_container_of(listener, wl, local_display_destroy);
diff --git a/backend/wayland/output.c b/backend/wayland/output.c
index 542185ce..5c5ff93d 100644
--- a/backend/wayland/output.c
+++ b/backend/wayland/output.c
@@ -319,7 +319,9 @@ static bool output_commit(struct wlr_output *wlr_output) {
 
 		wl_surface_attach(output->surface, buffer->wl_buffer, 0, 0);
 
-		if (damage == NULL) {
+		if (wl_compositor_version() < 4) {
+			wl_surface_damage(output->surface, 0, 0, INT32_MAX, INT32_MAX);
+		} else if (damage == NULL) {
 			wl_surface_damage_buffer(output->surface,
 				0, 0, INT32_MAX, INT32_MAX);
 		} else {
@@ -381,7 +383,12 @@ static bool output_set_cursor(struct wlr_output *wlr_output,
 		}
 
 		wl_surface_attach(surface, buffer->wl_buffer, 0, 0);
-		wl_surface_damage_buffer(surface, 0, 0, INT32_MAX, INT32_MAX);
+
+		if (wl_compositor_version() < 4)
+			wl_surface_damage(surface, 0, 0, INT32_MAX, INT32_MAX);
+		else
+			wl_surface_damage_buffer(surface, 0, 0, INT32_MAX, INT32_MAX);
+
 		wl_surface_commit(surface);
 	} else {
 		wl_surface_attach(surface, NULL, 0, 0);
diff --git a/include/backend/wayland.h b/include/backend/wayland.h
index 5d69c248..344dffb1 100644
--- a/include/backend/wayland.h
+++ b/include/backend/wayland.h
@@ -131,6 +131,7 @@ struct wlr_wl_input_device *create_wl_input_device(
 bool create_wl_seat(struct wl_seat *wl_seat, struct wlr_wl_backend *wl);
 void destroy_wl_seats(struct wlr_wl_backend *wl);
 void destroy_wl_buffer(struct wlr_wl_buffer *buffer);
+uint32_t wl_compositor_version(void);
 
 extern const struct wl_seat_listener seat_listener;
 
-- 
2.31.1