Split the various attempts at accelerating Composite into separate
functions. Along with making things more readable, it fixes a problem
    where the coordinates would get messed up if acceleration failed due to
    things like pixmaps being in the wrong locations.
			
			
This commit is contained in:
		
							parent
							
								
									1e1a35e20c
								
							
						
					
					
						commit
						d15acfa79b
					
				|  | @ -214,31 +214,17 @@ kaaGetRGBAFromPixel(CARD32	pixel, | ||||||
|     return TRUE; |     return TRUE; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | static int | ||||||
| kaaComposite(CARD8	op, | kaaTryDriverSolidFill(PicturePtr	pSrc, | ||||||
| 	     PicturePtr pSrc, |  | ||||||
| 	     PicturePtr pMask, |  | ||||||
| 		      PicturePtr	pDst, | 		      PicturePtr	pDst, | ||||||
| 		      INT16		xSrc, | 		      INT16		xSrc, | ||||||
| 		      INT16		ySrc, | 		      INT16		ySrc, | ||||||
| 	     INT16	xMask, |  | ||||||
| 	     INT16	yMask, |  | ||||||
| 		      INT16		xDst, | 		      INT16		xDst, | ||||||
| 		      INT16		yDst, | 		      INT16		yDst, | ||||||
| 		      CARD16		width, | 		      CARD16		width, | ||||||
| 		      CARD16		height) | 		      CARD16		height) | ||||||
| { | { | ||||||
|     KdScreenPriv (pDst->pDrawable->pScreen); |  | ||||||
|     KaaScreenPriv (pDst->pDrawable->pScreen); |     KaaScreenPriv (pDst->pDrawable->pScreen); | ||||||
|      |  | ||||||
|     if (!pMask) |  | ||||||
|     { |  | ||||||
| 	if (op == PictOpSrc) |  | ||||||
| 	{ |  | ||||||
| 	    if (pSrc->pDrawable->width == 1 && pSrc->pDrawable->height == 1 && |  | ||||||
| 		pSrc->repeat) |  | ||||||
| 	    { |  | ||||||
| 		/* Solid fill case */ |  | ||||||
|     RegionRec region; |     RegionRec region; | ||||||
|     BoxPtr pbox; |     BoxPtr pbox; | ||||||
|     int nbox; |     int nbox; | ||||||
|  | @ -252,10 +238,10 @@ kaaComposite(CARD8	op, | ||||||
|     xSrc += pSrc->pDrawable->x; |     xSrc += pSrc->pDrawable->x; | ||||||
|     ySrc += pSrc->pDrawable->y; |     ySrc += pSrc->pDrawable->y; | ||||||
| 
 | 
 | ||||||
| 		if (!miComputeCompositeRegion (®ion, pSrc, pMask, pDst, |     if (!miComputeCompositeRegion (®ion, pSrc, NULL, pDst, | ||||||
| 					       xSrc, ySrc, xMask, yMask, xDst, yDst, | 				   xSrc, ySrc, 0, 0, xDst, yDst, | ||||||
| 				   width, height)) | 				   width, height)) | ||||||
| 		    return; | 	return 1; | ||||||
| 
 | 
 | ||||||
|     if (pSrc->pDrawable->type == DRAWABLE_PIXMAP) |     if (pSrc->pDrawable->type == DRAWABLE_PIXMAP) | ||||||
| 	kaaPixmapUseMemory ((PixmapPtr) pSrc->pDrawable); | 	kaaPixmapUseMemory ((PixmapPtr) pSrc->pDrawable); | ||||||
|  | @ -265,7 +251,7 @@ kaaComposite(CARD8	op, | ||||||
|     pDstPix = kaaGetOffscreenPixmap (pDst->pDrawable, &dst_off_x, |     pDstPix = kaaGetOffscreenPixmap (pDst->pDrawable, &dst_off_x, | ||||||
| 				 &dst_off_y); | 				 &dst_off_y); | ||||||
|     if (!pDstPix) |     if (!pDstPix) | ||||||
| 		   goto software2; | 	return 0; | ||||||
| 
 | 
 | ||||||
|     if (pSrc->pDrawable->type == DRAWABLE_WINDOW) |     if (pSrc->pDrawable->type == DRAWABLE_WINDOW) | ||||||
| 	pSrcPix = (*pSrc->pDrawable->pScreen->GetWindowPixmap)( | 	pSrcPix = (*pSrc->pDrawable->pScreen->GetWindowPixmap)( | ||||||
|  | @ -283,15 +269,13 @@ kaaComposite(CARD8	op, | ||||||
|     pixel = *(CARD32 *)(pSrcPix->devPrivate.ptr); |     pixel = *(CARD32 *)(pSrcPix->devPrivate.ptr); | ||||||
|     if (!kaaGetRGBAFromPixel(pixel, &red, &green, &blue, &alpha, |     if (!kaaGetRGBAFromPixel(pixel, &red, &green, &blue, &alpha, | ||||||
| 			 pSrc->format)) | 			 pSrc->format)) | ||||||
| 		    goto software; | 	return -1; | ||||||
|     kaaGetPixelFromRGBA(&pixel, red, green, blue, alpha, |     kaaGetPixelFromRGBA(&pixel, red, green, blue, alpha, | ||||||
| 			pDst->format); | 			pDst->format); | ||||||
| 
 | 
 | ||||||
|     if (!(*pKaaScr->info->PrepareSolid) (pDstPix, GXcopy, 0xffffff, |     if (!(*pKaaScr->info->PrepareSolid) (pDstPix, GXcopy, 0xffffff, | ||||||
| 					 pixel)) | 					 pixel)) | ||||||
| 		{ | 	return -1; | ||||||
| 		    goto software; |  | ||||||
| 		} |  | ||||||
| 
 | 
 | ||||||
|     nbox = REGION_NUM_RECTS(®ion); |     nbox = REGION_NUM_RECTS(®ion); | ||||||
|     pbox = REGION_RECTS(®ion); |     pbox = REGION_RECTS(®ion); | ||||||
|  | @ -307,11 +291,200 @@ kaaComposite(CARD8	op, | ||||||
|     (*pKaaScr->info->DoneSolid) (); |     (*pKaaScr->info->DoneSolid) (); | ||||||
|     KdMarkSync(pDst->pDrawable->pScreen); |     KdMarkSync(pDst->pDrawable->pScreen); | ||||||
| 
 | 
 | ||||||
|  |     return 1; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static int | ||||||
|  | kaaTryDriverBlend(CARD8		op, | ||||||
|  | 		  PicturePtr	pSrc, | ||||||
|  | 		  PicturePtr	pDst, | ||||||
|  | 		  INT16		xSrc, | ||||||
|  | 		  INT16		ySrc, | ||||||
|  | 		  INT16		xDst, | ||||||
|  | 		  INT16		yDst, | ||||||
|  | 		  CARD16	width, | ||||||
|  | 		  CARD16	height) | ||||||
|  | { | ||||||
|  |     KaaScreenPriv (pDst->pDrawable->pScreen); | ||||||
|  |     RegionRec region; | ||||||
|  |     BoxPtr pbox; | ||||||
|  |     int nbox; | ||||||
|  |     int src_off_x, src_off_y, dst_off_x, dst_off_y; | ||||||
|  |     PixmapPtr pSrcPix, pDstPix; | ||||||
|  | 
 | ||||||
|  |     xDst += pDst->pDrawable->x; | ||||||
|  |     yDst += pDst->pDrawable->y; | ||||||
|  | 
 | ||||||
|  |     xSrc += pSrc->pDrawable->x; | ||||||
|  |     ySrc += pSrc->pDrawable->y; | ||||||
|  | 
 | ||||||
|  |     if (!miComputeCompositeRegion (®ion, pSrc, NULL, pDst, | ||||||
|  | 				   xSrc, ySrc, 0, 0, xDst, yDst, | ||||||
|  | 				   width, height)) | ||||||
|  | 	return 1; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     if (pSrc->pDrawable->type == DRAWABLE_PIXMAP) | ||||||
|  | 	kaaPixmapUseScreen ((PixmapPtr) pSrc->pDrawable); | ||||||
|  |     if (pDst->pDrawable->type == DRAWABLE_PIXMAP) | ||||||
|  | 	kaaPixmapUseScreen ((PixmapPtr) pDst->pDrawable); | ||||||
|  |      | ||||||
|  |     pSrcPix = kaaGetOffscreenPixmap (pSrc->pDrawable, &src_off_x, | ||||||
|  | 				     &src_off_y); | ||||||
|  |     pDstPix = kaaGetOffscreenPixmap (pDst->pDrawable, &dst_off_x, | ||||||
|  | 				     &dst_off_y); | ||||||
|  |     if (!pSrcPix || !pDstPix) | ||||||
|  | 	return 0; | ||||||
|  | 
 | ||||||
|  |     if (!(*pKaaScr->info->PrepareBlend) (op, pSrc, pDst, pSrcPix, | ||||||
|  | 					 pDstPix)) | ||||||
|  | 	return -1; | ||||||
|  |      | ||||||
|  |     nbox = REGION_NUM_RECTS(®ion); | ||||||
|  |     pbox = REGION_RECTS(®ion); | ||||||
|  | 
 | ||||||
|  |     xSrc -= xDst; | ||||||
|  |     ySrc -= yDst; | ||||||
|  | 
 | ||||||
|  |     while (nbox--) | ||||||
|  |     { | ||||||
|  | 	(*pKaaScr->info->Blend) (pbox->x1 + xSrc + src_off_x, | ||||||
|  | 				 pbox->y1 + ySrc + src_off_y, | ||||||
|  | 				 pbox->x1 + dst_off_x, | ||||||
|  | 				 pbox->y1 + dst_off_y, | ||||||
|  | 				 pbox->x2 - pbox->x1, | ||||||
|  | 				 pbox->y2 - pbox->y1); | ||||||
|  | 	pbox++; | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     (*pKaaScr->info->DoneBlend) (); | ||||||
|  |     KdMarkSync(pDst->pDrawable->pScreen); | ||||||
|  | 
 | ||||||
|  |     return 1; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static int | ||||||
|  | kaaTryDriverComposite(CARD8		op, | ||||||
|  | 		      PicturePtr	pSrc, | ||||||
|  | 		      PicturePtr	pMask, | ||||||
|  | 		      PicturePtr	pDst, | ||||||
|  | 		      INT16		xSrc, | ||||||
|  | 		      INT16		ySrc, | ||||||
|  | 		      INT16		xMask, | ||||||
|  | 		      INT16		yMask, | ||||||
|  | 		      INT16		xDst, | ||||||
|  | 		      INT16		yDst, | ||||||
|  | 		      CARD16		width, | ||||||
|  | 		      CARD16		height) | ||||||
|  | { | ||||||
|  |     KaaScreenPriv (pDst->pDrawable->pScreen); | ||||||
|  |     RegionRec region; | ||||||
|  |     BoxPtr pbox; | ||||||
|  |     int nbox; | ||||||
|  |     int src_off_x, src_off_y, mask_off_x, mask_off_y, dst_off_x, dst_off_y; | ||||||
|  |     PixmapPtr pSrcPix, pMaskPix = NULL, pDstPix; | ||||||
|  | 
 | ||||||
|  |     xDst += pDst->pDrawable->x; | ||||||
|  |     yDst += pDst->pDrawable->y; | ||||||
|  | 
 | ||||||
|  |     if (pMask) { | ||||||
|  | 	xMask += pMask->pDrawable->x; | ||||||
|  | 	yMask += pMask->pDrawable->y; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     xSrc += pSrc->pDrawable->x; | ||||||
|  |     ySrc += pSrc->pDrawable->y; | ||||||
|  | 
 | ||||||
|  |     if (!miComputeCompositeRegion (®ion, pSrc, pMask, pDst, | ||||||
|  | 				   xSrc, ySrc, xMask, yMask, xDst, yDst, | ||||||
|  | 				   width, height)) | ||||||
|  | 	return 1; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     if (pSrc->pDrawable->type == DRAWABLE_PIXMAP) | ||||||
|  | 	kaaPixmapUseScreen ((PixmapPtr) pSrc->pDrawable); | ||||||
|  |     if (pMask && pMask->pDrawable->type == DRAWABLE_PIXMAP) | ||||||
|  | 	kaaPixmapUseScreen ((PixmapPtr) pMask->pDrawable); | ||||||
|  |     if (pDst->pDrawable->type == DRAWABLE_PIXMAP) | ||||||
|  | 	kaaPixmapUseScreen ((PixmapPtr) pDst->pDrawable); | ||||||
|  | 
 | ||||||
|  |     pSrcPix = kaaGetOffscreenPixmap (pSrc->pDrawable, &src_off_x, | ||||||
|  | 				     &src_off_y); | ||||||
|  |     pDstPix = kaaGetOffscreenPixmap (pDst->pDrawable, &dst_off_x, | ||||||
|  | 				     &dst_off_y); | ||||||
|  |     if (!pSrcPix || !pDstPix) | ||||||
|  | 	return 0; | ||||||
|  |     if (pMask) { | ||||||
|  | 	pMaskPix = kaaGetOffscreenPixmap (pMask->pDrawable, &mask_off_x, | ||||||
|  | 					  &mask_off_y); | ||||||
|  | 	if (!pMaskPix) | ||||||
|  | 	    return 0; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     if (!(*pKaaScr->info->PrepareComposite) (op, pSrc, pMask, pDst, pSrcPix, | ||||||
|  | 					     pMaskPix, pDstPix)) | ||||||
|  | 	return -1; | ||||||
|  | 
 | ||||||
|  |     nbox = REGION_NUM_RECTS(®ion); | ||||||
|  |     pbox = REGION_RECTS(®ion); | ||||||
|  | 
 | ||||||
|  |     xMask -= xDst; | ||||||
|  |     yMask -= yDst; | ||||||
|  | 
 | ||||||
|  |     xSrc -= xDst; | ||||||
|  |     ySrc -= yDst; | ||||||
|  | 
 | ||||||
|  |     while (nbox--) | ||||||
|  |     { | ||||||
|  | 	(*pKaaScr->info->Composite) (pbox->x1 + xSrc + src_off_x, | ||||||
|  | 				     pbox->y1 + ySrc + src_off_y, | ||||||
|  | 				     pbox->x1 + xMask + mask_off_x, | ||||||
|  | 				     pbox->y1 + yMask + mask_off_y, | ||||||
|  | 				     pbox->x1 + dst_off_x, | ||||||
|  | 				     pbox->y1 + dst_off_y, | ||||||
|  | 				     pbox->x2 - pbox->x1, | ||||||
|  | 				     pbox->y2 - pbox->y1); | ||||||
|  | 	pbox++; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     (*pKaaScr->info->DoneBlend) (); | ||||||
|  |     KdMarkSync(pDst->pDrawable->pScreen); | ||||||
|  |     return 1; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | void | ||||||
|  | kaaComposite(CARD8	op, | ||||||
|  | 	     PicturePtr pSrc, | ||||||
|  | 	     PicturePtr pMask, | ||||||
|  | 	     PicturePtr pDst, | ||||||
|  | 	     INT16	xSrc, | ||||||
|  | 	     INT16	ySrc, | ||||||
|  | 	     INT16	xMask, | ||||||
|  | 	     INT16	yMask, | ||||||
|  | 	     INT16	xDst, | ||||||
|  | 	     INT16	yDst, | ||||||
|  | 	     CARD16	width, | ||||||
|  | 	     CARD16	height) | ||||||
|  | { | ||||||
|  |     KdScreenPriv (pDst->pDrawable->pScreen); | ||||||
|  |     KaaScreenPriv (pDst->pDrawable->pScreen); | ||||||
|  |     int ret = -1; | ||||||
|  | 
 | ||||||
|  |     if (!pMask) | ||||||
|  |     { | ||||||
|  | 	if (op == PictOpSrc) | ||||||
|  | 	{ | ||||||
|  | 	    if (pScreenPriv->enabled && pSrc->pDrawable->width == 1 && | ||||||
|  | 		pSrc->pDrawable->height == 1 && pSrc->repeat) | ||||||
|  | 	    { | ||||||
|  | 		ret = kaaTryDriverSolidFill(pSrc, pDst, xSrc, ySrc, xDst, yDst, | ||||||
|  | 					    width, height); | ||||||
|  | 		if (ret == 1) | ||||||
| 		    return; | 		    return; | ||||||
| 	    } | 	    } | ||||||
| 	    else if (!pSrc->repeat && pSrc->format == pDst->format) | 	    else if (!pSrc->repeat && pSrc->format == pDst->format) | ||||||
| 	    { | 	    { | ||||||
| 		/* Copy area case */ |  | ||||||
| 		RegionRec	region; | 		RegionRec	region; | ||||||
| 
 | 
 | ||||||
| 		xDst += pDst->pDrawable->x; | 		xDst += pDst->pDrawable->x; | ||||||
|  | @ -336,159 +509,34 @@ kaaComposite(CARD8	op, | ||||||
| 	if (pScreenPriv->enabled && pKaaScr->info->PrepareBlend && | 	if (pScreenPriv->enabled && pKaaScr->info->PrepareBlend && | ||||||
| 	    !pSrc->alphaMap && !pDst->alphaMap) | 	    !pSrc->alphaMap && !pDst->alphaMap) | ||||||
| 	{ | 	{ | ||||||
| 	    /* Blend case */ | 	ret = kaaTryDriverBlend(op, pSrc, pDst, xSrc, ySrc, xDst, yDst, width, | ||||||
| 	    RegionRec region; | 				height); | ||||||
| 	    BoxPtr pbox; | 	if (ret == 1) | ||||||
| 	    int nbox; |  | ||||||
| 	    int src_off_x, src_off_y, dst_off_x, dst_off_y; |  | ||||||
| 	    PixmapPtr pSrcPix, pDstPix; |  | ||||||
| 
 |  | ||||||
| 	    xDst += pDst->pDrawable->x; |  | ||||||
| 	    yDst += pDst->pDrawable->y; |  | ||||||
| 
 |  | ||||||
| 	    xSrc += pSrc->pDrawable->x; |  | ||||||
| 	    ySrc += pSrc->pDrawable->y; |  | ||||||
| 
 |  | ||||||
| 	    if (!miComputeCompositeRegion (®ion, pSrc, pMask, pDst, |  | ||||||
| 					   xSrc, ySrc, xMask, yMask, xDst, yDst, |  | ||||||
| 					   width, height)) |  | ||||||
| 		return; |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 	    /* Migrate pixmaps to same place as destination */ |  | ||||||
| 	    if (pSrc->pDrawable->type == DRAWABLE_PIXMAP) |  | ||||||
| 		kaaPixmapUseScreen ((PixmapPtr) pSrc->pDrawable); |  | ||||||
| 	    if (pDst->pDrawable->type == DRAWABLE_PIXMAP) |  | ||||||
| 		kaaPixmapUseScreen ((PixmapPtr) pDst->pDrawable); |  | ||||||
| 	     |  | ||||||
| 	    pSrcPix = kaaGetOffscreenPixmap (pSrc->pDrawable, &src_off_x, |  | ||||||
| 					     &src_off_y); |  | ||||||
| 	    pDstPix = kaaGetOffscreenPixmap (pDst->pDrawable, &dst_off_x, |  | ||||||
| 					     &dst_off_y); |  | ||||||
| 	    if (!pSrcPix || !pDstPix) |  | ||||||
| 		goto software2; |  | ||||||
| 	    if (!(*pKaaScr->info->PrepareBlend) (op, pSrc, pDst, pSrcPix, |  | ||||||
| 						 pDstPix)) |  | ||||||
| 	    { |  | ||||||
| 		goto software; |  | ||||||
| 	    } |  | ||||||
| 	     |  | ||||||
| 	    nbox = REGION_NUM_RECTS(®ion); |  | ||||||
| 	    pbox = REGION_RECTS(®ion); |  | ||||||
| 
 |  | ||||||
| 	    xSrc -= xDst; |  | ||||||
| 	    ySrc -= yDst; |  | ||||||
| 	 |  | ||||||
| 	    while (nbox--) |  | ||||||
| 	    { |  | ||||||
| 		(*pKaaScr->info->Blend) (pbox->x1 + xSrc + src_off_x, |  | ||||||
| 					 pbox->y1 + ySrc + src_off_y, |  | ||||||
| 					 pbox->x1 + dst_off_x, |  | ||||||
| 					 pbox->y1 + dst_off_y, |  | ||||||
| 					 pbox->x2 - pbox->x1, |  | ||||||
| 					 pbox->y2 - pbox->y1); |  | ||||||
| 		pbox++; |  | ||||||
| 	    } |  | ||||||
| 	     |  | ||||||
| 	    (*pKaaScr->info->DoneBlend) (); |  | ||||||
| 	    KdMarkSync(pDst->pDrawable->pScreen); |  | ||||||
| 
 |  | ||||||
| 	    return; | 	    return; | ||||||
| 	} | 	} | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|     if (pScreenPriv->enabled && pKaaScr->info->PrepareComposite && |     if (pScreenPriv->enabled && pKaaScr->info->PrepareComposite && | ||||||
| 	!pSrc->alphaMap && (!pMask || !pMask->alphaMap) && !pDst->alphaMap) | 	!pSrc->alphaMap && (!pMask || !pMask->alphaMap) && !pDst->alphaMap) | ||||||
|     { |     { | ||||||
| 	/* Catch-all Composite case */ | 	ret = kaaTryDriverComposite(op, pSrc, pMask, pDst, xSrc, ySrc, xMask, | ||||||
| 	RegionRec region; | 				    yMask, xDst, yDst, width, height); | ||||||
| 	BoxPtr pbox; | 	if (ret == 1) | ||||||
| 	int nbox; |  | ||||||
| 	int src_off_x, src_off_y, mask_off_x, mask_off_y, dst_off_x, dst_off_y; |  | ||||||
| 	PixmapPtr pSrcPix, pMaskPix = NULL, pDstPix; |  | ||||||
| 
 |  | ||||||
| 	xDst += pDst->pDrawable->x; |  | ||||||
| 	yDst += pDst->pDrawable->y; |  | ||||||
| 
 |  | ||||||
| 	if (pMask) { |  | ||||||
| 	    xMask += pMask->pDrawable->x; |  | ||||||
| 	    yMask += pMask->pDrawable->y; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	xSrc += pSrc->pDrawable->x; |  | ||||||
| 	ySrc += pSrc->pDrawable->y; |  | ||||||
| 
 |  | ||||||
| 	if (!miComputeCompositeRegion (®ion, pSrc, pMask, pDst, |  | ||||||
| 				       xSrc, ySrc, xMask, yMask, xDst, yDst, |  | ||||||
| 				       width, height)) |  | ||||||
| 		return; |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 	/* Migrate pixmaps to same place as destination */ |  | ||||||
| 	if (pSrc->pDrawable->type == DRAWABLE_PIXMAP) |  | ||||||
| 		kaaPixmapUseScreen ((PixmapPtr) pSrc->pDrawable); |  | ||||||
| 	if (pMask && pMask->pDrawable->type == DRAWABLE_PIXMAP) |  | ||||||
| 		kaaPixmapUseScreen ((PixmapPtr) pMask->pDrawable); |  | ||||||
| 	if (pDst->pDrawable->type == DRAWABLE_PIXMAP) |  | ||||||
| 		kaaPixmapUseScreen ((PixmapPtr) pDst->pDrawable); |  | ||||||
| 
 |  | ||||||
| 	pSrcPix = kaaGetOffscreenPixmap (pSrc->pDrawable, &src_off_x, |  | ||||||
| 				    	 &src_off_y); |  | ||||||
| 	pDstPix = kaaGetOffscreenPixmap (pDst->pDrawable, &dst_off_x, |  | ||||||
| 				    	 &dst_off_y); |  | ||||||
| 	if (!pSrcPix || !pDstPix) |  | ||||||
| 		goto software2; |  | ||||||
| 	if (pMask) { |  | ||||||
| 	    pMaskPix = kaaGetOffscreenPixmap (pMask->pDrawable, &mask_off_x, |  | ||||||
| 				    	     &mask_off_y); |  | ||||||
| 	    if (!pMaskPix) |  | ||||||
| 		goto software2; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
|     	if (!(*pKaaScr->info->PrepareComposite) (op, pSrc, pMask, pDst, pSrcPix, |  | ||||||
| 						 pMaskPix, pDstPix)) |  | ||||||
|     	{ |  | ||||||
| 		goto software; |  | ||||||
| 	} |  | ||||||
|     	 |  | ||||||
|     	nbox = REGION_NUM_RECTS(®ion); |  | ||||||
|     	pbox = REGION_RECTS(®ion); |  | ||||||
| 
 |  | ||||||
|     	xMask -= xDst; |  | ||||||
|     	yMask -= yDst; |  | ||||||
| 
 |  | ||||||
|     	xSrc -= xDst; |  | ||||||
|     	ySrc -= yDst; |  | ||||||
| 	 |  | ||||||
|     	while (nbox--) |  | ||||||
|     	{ |  | ||||||
| 		(*pKaaScr->info->Composite) (pbox->x1 + xSrc + src_off_x, |  | ||||||
| 					     pbox->y1 + ySrc + src_off_y, |  | ||||||
| 					     pbox->x1 + mask_off_x, |  | ||||||
| 					     pbox->y1 + mask_off_y, |  | ||||||
| 					     pbox->x1 + dst_off_x, |  | ||||||
| 					     pbox->y1 + dst_off_y, |  | ||||||
| 					     pbox->x2 - pbox->x1, |  | ||||||
| 					     pbox->y2 - pbox->y1); |  | ||||||
| 		pbox++; |  | ||||||
|     	} |  | ||||||
|     	 |  | ||||||
|     	(*pKaaScr->info->DoneBlend) (); |  | ||||||
|     	KdMarkSync(pDst->pDrawable->pScreen); |  | ||||||
| 
 |  | ||||||
| 	    return; | 	    return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| software: |     if (ret != 0) { | ||||||
|  | 	/* failure to accelerate was not due to pixmaps being in the wrong
 | ||||||
|  | 	 * locations. | ||||||
|  | 	 */ | ||||||
| 	if (pSrc->pDrawable->type == DRAWABLE_PIXMAP) | 	if (pSrc->pDrawable->type == DRAWABLE_PIXMAP) | ||||||
| 	    kaaPixmapUseMemory ((PixmapPtr) pSrc->pDrawable); | 	    kaaPixmapUseMemory ((PixmapPtr) pSrc->pDrawable); | ||||||
| 	if (pMask && pMask->pDrawable->type == DRAWABLE_PIXMAP) | 	if (pMask && pMask->pDrawable->type == DRAWABLE_PIXMAP) | ||||||
| 	    kaaPixmapUseMemory ((PixmapPtr) pMask->pDrawable); | 	    kaaPixmapUseMemory ((PixmapPtr) pMask->pDrawable); | ||||||
| #if 0 |  | ||||||
| 	if (pDst->pDrawable->type == DRAWABLE_PIXMAP) | 	if (pDst->pDrawable->type == DRAWABLE_PIXMAP) | ||||||
| 	    kaaPixmapUseMemory ((PixmapPtr) pDst->pDrawable); | 	    kaaPixmapUseMemory ((PixmapPtr) pDst->pDrawable); | ||||||
| #endif |     } | ||||||
| 
 | 
 | ||||||
| software2: |  | ||||||
| #if KAA_DEBUG_FALLBACKS | #if KAA_DEBUG_FALLBACKS | ||||||
|     kaaPrintCompositeFallback (op, pSrc, pMask, pDst); |     kaaPrintCompositeFallback (op, pSrc, pMask, pDst); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue