- u_record-fix-sig11.patch

* If you aren't using the Record extension (and you aren't), you
    can work around the bug by moving the code which accesses the
    (non-existant) request buffer inside the loop looking at the
    recording contexts (of which there should be none). 
    (bnc #728964, fdo #36930)

OBS-URL: https://build.opensuse.org/package/show/X11:XOrg/xorg-x11-server?expand=0&rev=359
This commit is contained in:
Stefan Dirsch 2011-11-09 17:52:18 +00:00 committed by Git OBS Bridge
parent 3d3d212928
commit 11c2d2bd16
3 changed files with 48 additions and 0 deletions

36
u_record-fix-sig11.patch Normal file
View File

@ -0,0 +1,36 @@
Date: Mon, 07 Nov 2011 22:09:34 -0800
From: Keith Packard <keithp@keithp.com>
Subject: Re: X server SIGSEGV?
If you aren't using the Record extension (and you aren't), you can work
around the bug by moving the code which accesses the (non-existant)
request buffer inside the loop looking at the recording contexts (of
which there should be none):
diff --git a/record/record.c b/record/record.c
index 68311ac..9e36103 100644
--- a/record/record.c
+++ b/record/record.c
@@ -603,12 +603,10 @@ RecordAReply(CallbackListPtr *pcbl, pointer nulldata, pointer calldata)
RecordContextPtr pContext;
RecordClientsAndProtocolPtr pRCAP;
int eci;
- int majorop;
ReplyInfoRec *pri = (ReplyInfoRec *)calldata;
ClientPtr client = pri->client;
REQUEST(xReq);
- majorop = stuff->reqType;
for (eci = 0; eci < numEnabledContexts; eci++)
{
pContext = ppAllContexts[eci];
@@ -616,6 +614,7 @@ RecordAReply(CallbackListPtr *pcbl, pointer nulldata, pointer calldata)
NULL);
if (pRCAP)
{
+ int majorop = stuff->reqType;
if (pContext->continuedReply)
{
RecordAProtocolElement(pContext, client, XRecordFromServer,
I'll see if I can't get someone to fix this for real...

View File

@ -1,3 +1,13 @@
-------------------------------------------------------------------
Wed Nov 9 17:40:42 UTC 2011 - sndirsch@suse.com
- u_record-fix-sig11.patch
* If you aren't using the Record extension (and you aren't), you
can work around the bug by moving the code which accesses the
(non-existant) request buffer inside the loop looking at the
recording contexts (of which there should be none).
(bnc #728964, fdo #36930)
-------------------------------------------------------------------
Tue Oct 18 18:38:41 UTC 2011 - eich@suse.com

View File

@ -94,6 +94,7 @@ Patch213: xorg-server-xdmcp.patch
Patch220: Use-external-tool-for-creating-backtraces-on-crashes.patch
Patch222: sync-fix.patch
Patch223: U_Don-t-call-deleted-Block-WakeupHandler.patch
Patch224: u_record-fix-sig11.patch
%description
This package contains the X.Org Server.
@ -202,6 +203,7 @@ popd
#%patch220 -p1
%patch222 -p1
%patch223 -p2
%patch224 -p1
%build
pushd xorg-docs-*