49 lines
1.4 KiB
Diff
49 lines
1.4 KiB
Diff
|
From d94cd024be7da876a356fff16f375a562b406beb Mon Sep 17 00:00:00 2001
|
||
|
From: Jeffy Chen <jeffy.chen@rock-chips.com>
|
||
|
Date: Mon, 3 Oct 2022 21:03:04 +0800
|
||
|
Subject: [PATCH 78/92] desktop-shell: Fix crash when hotplugging screens
|
||
|
|
||
|
1/ Force allowing respawn.
|
||
|
2/ Panel's output might not be available when committing.
|
||
|
|
||
|
Signed-off-by: Jeffy Chen <jeffy.chen@rock-chips.com>
|
||
|
---
|
||
|
desktop-shell/shell.c | 7 +++++++
|
||
|
1 file changed, 7 insertions(+)
|
||
|
|
||
|
diff --git a/desktop-shell/shell.c b/desktop-shell/shell.c
|
||
|
index 08c84c5..25d9525 100644
|
||
|
--- a/desktop-shell/shell.c
|
||
|
+++ b/desktop-shell/shell.c
|
||
|
@@ -2631,6 +2631,10 @@ panel_committed(struct weston_surface *es, int32_t sx, int32_t sy)
|
||
|
|
||
|
view = container_of(es->views.next, struct weston_view, surface_link);
|
||
|
|
||
|
+ /* The output might be unavaiable */
|
||
|
+ if (!view->output)
|
||
|
+ return;
|
||
|
+
|
||
|
get_panel_size(shell, view, &width, &height);
|
||
|
switch (shell->panel_position) {
|
||
|
case WESTON_DESKTOP_SHELL_PANEL_POSITION_TOP:
|
||
|
@@ -3947,6 +3951,8 @@ check_desktop_shell_crash_too_early(struct desktop_shell *shell)
|
||
|
if (clock_gettime(CLOCK_MONOTONIC, &now) < 0)
|
||
|
return false;
|
||
|
|
||
|
+ /* HACK: The shell might be crashed too early when hotplugging */
|
||
|
+#if 0
|
||
|
/*
|
||
|
* If the shell helper client dies before the session has been
|
||
|
* up for roughly 30 seconds, better just make Weston shut down,
|
||
|
@@ -3962,6 +3968,7 @@ check_desktop_shell_crash_too_early(struct desktop_shell *shell)
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
+#endif
|
||
|
|
||
|
return false;
|
||
|
}
|
||
|
--
|
||
|
2.20.1
|
||
|
|