summaryrefslogtreecommitdiff
path: root/miext
diff options
context:
space:
mode:
authorTorrey Lyons <torrey@mrcla.com>2004-09-18 00:38:30 +0000
committerTorrey Lyons <torrey@mrcla.com>2004-09-18 00:38:30 +0000
commit6344bb51e2a97d9678cec2ec1dab19abfe9d9e8d (patch)
treedac967ce48b061b2d8e64d7c0b7f1beed42f9dd9 /miext
parentcedb9a8d62df3391fd89a8b05a2dd64bd098a7df (diff)
Bugzilla #1032: Make rootless acceleration functions compatible with
Damage.
Diffstat (limited to 'miext')
-rw-r--r--miext/rootless/accel/rlAccel.c97
-rw-r--r--miext/rootless/accel/rlAccel.h2
-rw-r--r--miext/rootless/rootless.h7
-rw-r--r--miext/rootless/rootlessGC.c13
4 files changed, 107 insertions, 12 deletions
diff --git a/miext/rootless/accel/rlAccel.c b/miext/rootless/accel/rlAccel.c
new file mode 100644
index 000000000..7dedd8dbc
--- /dev/null
+++ b/miext/rootless/accel/rlAccel.c
@@ -0,0 +1,97 @@
+/*
+ * Support for accelerated rootless code
+ */
+/*
+ * Copyright (c) 2004 Torrey T. Lyons. All Rights Reserved.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+ * THE ABOVE LISTED COPYRIGHT HOLDER(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+ * DEALINGS IN THE SOFTWARE.
+ *
+ * Except as contained in this notice, the name(s) of the above copyright
+ * holders shall not be used in advertising or otherwise to promote the sale,
+ * use or other dealings in this Software without prior written authorization.
+ */
+/* $XdotOrg: $ */
+
+#include "rootless.h"
+#include "rlAccel.h"
+
+typedef struct _rlAccelScreenRec {
+ CreateGCProcPtr CreateGC;
+} rlAccelScreenRec, *rlAccelScreenPtr;
+
+static int rlAccelScreenPrivateIndex = -1;
+
+#define RLACCELREC(pScreen) \
+ ((rlAccelScreenRec *)(pScreen)->devPrivates[rlAccelScreenPrivateIndex].ptr)
+
+
+/*
+ * Screen function to create a graphics context
+ */
+static Bool
+rlCreateGC(GCPtr pGC)
+{
+ ScreenPtr pScreen = pGC->pScreen;
+ rlAccelScreenRec *s = RLACCELREC(pScreen);
+ Bool result;
+
+ // Unwrap and call
+ pScreen->CreateGC = s->CreateGC;
+ result = s->CreateGC(pGC);
+
+ // Accelerated GC ops replace some ops
+ pGC->ops->FillSpans = rlFillSpans;
+ pGC->ops->CopyArea = rlCopyArea;
+ pGC->ops->PolyFillRect = rlPolyFillRect;
+ pGC->ops->ImageGlyphBlt = rlImageGlyphBlt;
+
+ // Rewrap
+ s->CreateGC = pScreen->CreateGC;
+ pScreen->CreateGC = rlCreateGC;
+
+ return result;
+}
+
+
+/*
+ * RootlessAccelInit
+ * Called by the rootless implementation to initialize accelerated
+ * rootless drawing.
+ */
+Bool
+RootlessAccelInit(ScreenPtr pScreen)
+{
+ static unsigned long rlAccelGeneration = 0;
+ rlAccelScreenRec *s;
+
+ if (rlAccelGeneration != serverGeneration) {
+ rlAccelScreenPrivateIndex = AllocateScreenPrivateIndex();
+ if (rlAccelScreenPrivateIndex == -1) return FALSE;
+ }
+
+ s = xalloc(sizeof(rlAccelScreenRec));
+ if (!s) return FALSE;
+ RLACCELREC(pScreen) = s;
+
+ // Wrap the one screen function we need
+ s->CreateGC = pScreen->CreateGC;
+ pScreen->CreateGC = rlCreateGC;
+
+ return TRUE;
+}
diff --git a/miext/rootless/accel/rlAccel.h b/miext/rootless/accel/rlAccel.h
index dab0c6f46..b1488bdef 100644
--- a/miext/rootless/accel/rlAccel.h
+++ b/miext/rootless/accel/rlAccel.h
@@ -28,6 +28,8 @@
*/
/* $XFree86: xc/programs/Xserver/miext/rootless/rootlessCommon.c,v 1.4 2003/10/18 00:00:34 torrey Exp $ */
+#include "fb.h"
+
/*
* rlBlt.c
*/
diff --git a/miext/rootless/rootless.h b/miext/rootless/rootless.h
index 1bada3865..d87b08da1 100644
--- a/miext/rootless/rootless.h
+++ b/miext/rootless/rootless.h
@@ -369,6 +369,13 @@ typedef struct _RootlessFrameProcs {
Bool RootlessInit(ScreenPtr pScreen, RootlessFrameProcsPtr procs);
/*
+ * Initialize acceleration for rootless mode on a given screen.
+ * Note: RootlessAccelInit() must be called before DamageSetup()
+ * and RootlessInit() must be called afterwards.
+ */
+Bool RootlessAccelInit(ScreenPtr pScreen);
+
+/*
* Return the frame ID for the physical window displaying the given window.
*
* create If true and the window has no frame, attempt to create one
diff --git a/miext/rootless/rootlessGC.c b/miext/rootless/rootlessGC.c
index b370d2beb..fa10241f2 100644
--- a/miext/rootless/rootlessGC.c
+++ b/miext/rootless/rootlessGC.c
@@ -45,10 +45,6 @@
#include "rootlessCommon.h"
-#if ROOTLESS_ACCEL
-#include "rlAccel.h"
-#endif
-
// GC functions
static void RootlessValidateGC(GCPtr pGC, unsigned long changes,
@@ -165,7 +161,7 @@ static GCOps rootlessGCOps = {
...
- if (can_accel_xxx(..) && otherwise-suitable)
+ if (canAccelxxx(..) && otherwise-suitable)
GC_UNSET_PM(gc, dst);
gc->funcs->OP(gc, ...);
@@ -283,13 +279,6 @@ RootlessCreateGC(GCPtr pGC)
devPrivates[rootlessScreenPrivateIndex].ptr;
result = s->CreateGC(pGC);
-#if ROOTLESS_ACCEL
- pGC->ops->FillSpans = rlFillSpans;
- pGC->ops->CopyArea = rlCopyArea;
- pGC->ops->PolyFillRect = rlPolyFillRect;
- pGC->ops->ImageGlyphBlt = rlImageGlyphBlt;
-#endif
-
gcrec = (RootlessGCRec *) pGC->devPrivates[rootlessGCPrivateIndex].ptr;
gcrec->originalOps = NULL; // don't wrap ops yet
gcrec->originalFuncs = pGC->funcs;