[gnome-remote-desktop] session-rdp: Use trivial boolean value for condition in graphics thread
- From: Jonas Ådahl <jadahl src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-remote-desktop] session-rdp: Use trivial boolean value for condition in graphics thread
- Date: Thu, 9 Jun 2022 15:48:22 +0000 (UTC)
commit 188f4f6910be9e0a3d3f817c7fd7d2b142846b23
Author: Pascal Nowack <Pascal Nowack gmx de>
Date: Thu Jun 9 05:44:02 2022 +0200
session-rdp: Use trivial boolean value for condition in graphics thread
On a few systems, some WinPR events, but not all of them, are handled
in very unexpected manners.
While the cause for this issue is not yet known, reduce their usage and
simplify the conditions involving them.
https://errors.ubuntu.com/problem/797565ad6b046057aa5c7c21d86404a0935989b8
https://errors.ubuntu.com/problem/7da7b9d76648f53ed3806718217d177a1f4681d5
src/grd-session-rdp.c | 11 +++++------
1 file changed, 5 insertions(+), 6 deletions(-)
---
diff --git a/src/grd-session-rdp.c b/src/grd-session-rdp.c
index e9b5fe9f..7028338b 100644
--- a/src/grd-session-rdp.c
+++ b/src/grd-session-rdp.c
@@ -123,6 +123,7 @@ struct _GrdSessionRdp
GrdRdpSAMFile *sam_file;
uint32_t rdp_error_info;
GrdRdpScreenShareMode screen_share_mode;
+ gboolean session_stopped;
GMutex rdp_flags_mutex;
RdpPeerFlag rdp_flags;
@@ -2111,7 +2112,7 @@ graphics_thread_func (gpointer data)
if (session_rdp->hwaccel_nvidia)
grd_hwaccel_nvidia_push_cuda_context (session_rdp->hwaccel_nvidia);
- while (WaitForSingleObject (session_rdp->stop_event, 0) == WAIT_TIMEOUT)
+ while (!session_rdp->session_stopped)
g_main_context_iteration (session_rdp->graphics_context, TRUE);
if (session_rdp->hwaccel_nvidia)
@@ -2202,6 +2203,8 @@ grd_session_rdp_stop (GrdSession *session)
g_debug ("Stopping RDP session");
unset_rdp_peer_flag (session_rdp, RDP_PEER_ACTIVATED);
+ session_rdp->session_stopped = TRUE;
+
if (WaitForSingleObject (session_rdp->stop_event, 0) == WAIT_TIMEOUT)
{
freerdp_set_error_info (peer->context->rdp,
@@ -2222,12 +2225,8 @@ grd_session_rdp_stop (GrdSession *session)
if (session_rdp->graphics_thread)
{
- uint32_t status;
-
g_assert (session_rdp->graphics_context);
-
- status = WaitForSingleObject (session_rdp->stop_event, 0);
- g_assert (status != WAIT_TIMEOUT);
+ g_assert (session_rdp->session_stopped);
g_main_context_wakeup (session_rdp->graphics_context);
g_clear_pointer (&session_rdp->graphics_thread, g_thread_join);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]