From 12aeddf5ad41902a180f8108623f356642b3e911 Mon Sep 17 00:00:00 2001 From: Maarten Maathuis Date: Thu, 19 Mar 2009 19:07:59 +0100 Subject: [PATCH] exa: Accept scratch pixmaps with offscreen memory as such. --- exa/exa.c | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/exa/exa.c b/exa/exa.c index ecb2117cf..10abf06c9 100644 --- a/exa/exa.c +++ b/exa/exa.c @@ -427,11 +427,19 @@ exaModifyPixmapHeader(PixmapPtr pPixmap, int width, int height, int depth, if (devKind > 0) pExaPixmap->sys_pitch = devKind; - /* Is this the framebuffer (for classic exa)? */ - if (pPixData && pPixData == pExaScr->info->memoryBase) { - pExaPixmap->fb_ptr = pPixData; - pExaPixmap->fb_pitch = devKind; - pExaPixmap->offscreen = TRUE; + /* Classic EXA: + * - Framebuffer. + * - Scratch pixmap with offscreen memory. + */ + if (!(pExaScr->info->flags & EXA_HANDLES_PIXMAPS) && + pExaScr->info->memoryBase && pPixData) { + if ((CARD8 *)pPixData >= pExaScr->info->memoryBase && + ((CARD8 *)pPixData - pExaScr->info->memoryBase) < + pExaScr->info->memorySize) { + pExaPixmap->fb_ptr = pPixData; + pExaPixmap->fb_pitch = devKind; + pExaPixmap->offscreen = TRUE; + } } if (width > 0 && height > 0 && bitsPerPixel > 0) {