mirror of
https://git.yoctoproject.org/poky
synced 2026-05-07 16:59:22 +00:00
xserver-xorg: don't close already-closed connections
On shutdown xserver was closing connections that were already closed, resulting in a segfault. (From OE-Core rev: 04ffd02a14f5e0cd2ce0288b589d4c4a0120e2f4) Signed-off-by: Ross Burton <ross.burton@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
committed by
Richard Purdie
parent
38cdb72362
commit
dae9b5fb79
@@ -0,0 +1,38 @@
|
||||
Upstream-Status: Submitted
|
||||
Signed-off-by: Ross Burton <ross.burton@intel.com>
|
||||
|
||||
Since _XSERVTransClose frees the connection pointer passed to it,
|
||||
remove that pointer from the array, so we don't try to double free it
|
||||
if we come back into CloseWellKnownConnections again.
|
||||
|
||||
Should fix https://bugzilla.yoctoproject.org/show_bug.cgi?id=6665 in which
|
||||
the shutdown section of the main() loop called CloseWellKnownConnections()
|
||||
and then moved on to ddxGiveUp(), which failed to release the VT and thus
|
||||
called AbortServer(), which called CloseWellKnownConnections() again.
|
||||
|
||||
Signed-off-by: Alan Coopersmith <alan.coopersmith@oracle.com>
|
||||
Reviewed-by: Adam Jackson <ajax@redhat.com>
|
||||
---
|
||||
os/connection.c | 9 +++++++--
|
||||
1 file changed, 7 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/os/connection.c b/os/connection.c
|
||||
index ddfe50a..7ff44e1 100644
|
||||
--- a/os/connection.c
|
||||
+++ b/os/connection.c
|
||||
@@ -513,8 +513,13 @@ CloseWellKnownConnections(void)
|
||||
{
|
||||
int i;
|
||||
|
||||
- for (i = 0; i < ListenTransCount; i++)
|
||||
- _XSERVTransClose(ListenTransConns[i]);
|
||||
+ for (i = 0; i < ListenTransCount; i++) {
|
||||
+ if (ListenTransConns[i] != NULL) {
|
||||
+ _XSERVTransClose(ListenTransConns[i]);
|
||||
+ ListenTransConns[i] = NULL;
|
||||
+ }
|
||||
+ }
|
||||
+ ListenTransCount = 0;
|
||||
}
|
||||
|
||||
static void
|
||||
@@ -5,6 +5,7 @@ SRC_URI += "file://fix_open_max_preprocessor_error.patch \
|
||||
file://xorg-CVE-2013-6424.patch \
|
||||
file://xshmfence-option.patch \
|
||||
file://Fix-subwindow-in-Xi-emulated-events.patch \
|
||||
file://xtrans.patch \
|
||||
"
|
||||
|
||||
SRC_URI[md5sum] = "afd93977235584a9caa7528a737c1b52"
|
||||
|
||||
Reference in New Issue
Block a user