2006-08-28 23:00:23 +00:00
|
|
|
--- ./hw/xfree86/xaa/xaaInit.c.offscreen-pixmaps 2006-07-05 14:31:42.000000000 -0400
|
2006-08-31 00:41:14 +00:00
|
|
|
+++ ./hw/xfree86/xaa/xaaInit.c 2006-08-30 16:47:29.000000000 -0400
|
|
|
|
@@ -98,6 +98,30 @@
|
2006-08-08 16:33:11 +00:00
|
|
|
xfree(infoRec);
|
|
|
|
}
|
|
|
|
|
2006-08-31 00:41:14 +00:00
|
|
|
+void
|
|
|
|
+XAAEvictPixmaps(void)
|
2006-08-08 16:33:11 +00:00
|
|
|
+{
|
2006-08-31 00:41:14 +00:00
|
|
|
+ XAAScreenPtr pScreenPriv;
|
|
|
|
+ XAAInfoRecPtr infoRec;
|
|
|
|
+ ScreenPtr pScreen;
|
|
|
|
+ int i;
|
2006-08-08 16:33:11 +00:00
|
|
|
+
|
2006-08-31 00:41:14 +00:00
|
|
|
+ xf86MsgVerb(X_INFO, 3, "XAA: Evicting pixmaps\n");
|
2006-08-08 16:33:11 +00:00
|
|
|
+
|
2006-08-31 00:41:14 +00:00
|
|
|
+ for (i = 0; i < screenInfo.numScreens; i++) {
|
|
|
|
+ pScreen = screenInfo.screens[i];
|
|
|
|
+ infoRec = GET_XAAINFORECPTR_FROM_SCREEN(pScreen);
|
|
|
|
+
|
|
|
|
+ pScreenPriv = pScreen->devPrivates[XAAScreenIndex].ptr;
|
|
|
|
+ infoRec = pScreenPriv->AccelInfoRec;
|
2006-08-28 23:00:23 +00:00
|
|
|
+
|
2006-08-08 16:33:11 +00:00
|
|
|
+ infoRec->offscreenDepths = 0;
|
|
|
|
+ infoRec->Flags &= ~OFFSCREEN_PIXMAPS;
|
|
|
|
+
|
|
|
|
+ XAAMoveOutOffscreenPixmaps(pScreen);
|
|
|
|
+ XAAInvalidatePixmapCache(pScreen);
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
|
|
|
|
Bool
|
|
|
|
XAAInit(ScreenPtr pScreen, XAAInfoRecPtr infoRec)
|
2006-08-31 00:41:14 +00:00
|
|
|
--- ./GL/glx/glxdri.c.offscreen-pixmaps 2006-08-30 16:46:45.000000000 -0400
|
|
|
|
+++ ./GL/glx/glxdri.c 2006-08-30 16:45:52.000000000 -0400
|
|
|
|
@@ -367,6 +367,19 @@
|
|
|
|
int bpp;
|
|
|
|
GLenum target, format, type;
|
|
|
|
|
|
|
|
+ /* When the GLX_EXT_texture_from_pixmap is used, as it's
|
|
|
|
+ * implemented here, we want to pull pixmap out of video memory
|
|
|
|
+ * and into host memory. */
|
|
|
|
+ {
|
|
|
|
+ extern void XAAEvictPixmaps(void);
|
|
|
|
+ static int evictedPixmaps;
|
2006-08-08 16:33:11 +00:00
|
|
|
+
|
2006-08-31 00:41:14 +00:00
|
|
|
+ if (!evictedPixmaps) {
|
|
|
|
+ XAAEvictPixmaps();
|
|
|
|
+ evictedPixmaps = TRUE;
|
|
|
|
+ }
|
|
|
|
+ }
|
2006-08-08 16:33:11 +00:00
|
|
|
+
|
2006-08-31 00:41:14 +00:00
|
|
|
pixmap = (PixmapPtr) glxPixmap->pDraw;
|
|
|
|
if (!glxPixmap->pDamage) {
|
|
|
|
glxPixmap->pDamage = DamageCreate(NULL, NULL, DamageReportNone,
|