diff options
| author | Michel Dänzer <daenzer@vmware.com> | 2009-11-30 13:17:51 +0100 | 
|---|---|---|
| committer | Keith Packard <keithp@keithp.com> | 2009-11-30 08:36:54 -0800 | 
| commit | 0e555a1033e5deed1db8582ca075455a6a2d4228 (patch) | |
| tree | c0615455bf2b89643ba06cc7720b046d3e3dfafc | |
| parent | 99d88ef69d5f7dbf99ca605eceb92f42230a89f4 (diff) | |
Revert "EXA: Accumulate arbitrary number of glyphs without flushing."
This reverts commit c11678cc189551f2a01eaa7a63969c16950739b4.
Not sure what I was thinking, turns out alloca() of a size derived from client
input is a bad idea.
Signed-off-by: Michel Dänzer <daenzer@vmware.com>
Signed-off-by: Keith Packard <keithp@keithp.com>
| -rw-r--r-- | exa/exa_glyphs.c | 47 | 
1 files changed, 25 insertions, 22 deletions
| diff --git a/exa/exa_glyphs.c b/exa/exa_glyphs.c index 4bc80ebcb..fd14e9b87 100644 --- a/exa/exa_glyphs.c +++ b/exa/exa_glyphs.c @@ -62,10 +62,15 @@   */  #define CACHE_PICTURE_WIDTH 1024 +/* Maximum number of glyphs we buffer on the stack before flushing + * rendering to the mask or destination surface. + */ +#define GLYPH_BUFFER_SIZE 256 +  typedef struct {      PicturePtr mask; +    ExaCompositeRectRec rects[GLYPH_BUFFER_SIZE];      int count; -    ExaCompositeRectRec rects[0];  } ExaGlyphBuffer, *ExaGlyphBufferPtr;  typedef enum { @@ -552,13 +557,16 @@ exaBufferGlyph(ScreenPtr         pScreen,  	       INT16             yDst)  {      ExaScreenPriv(pScreen); -    PicturePtr mask = GlyphPicture(pGlyph)[pScreen->myNum]; -    unsigned int format = mask->format; +    unsigned int format = (GlyphPicture(pGlyph)[pScreen->myNum])->format;      int width = pGlyph->info.width;      int height = pGlyph->info.height;      ExaCompositeRectPtr rect; +    PicturePtr mask;      int i; +    if (buffer->count == GLYPH_BUFFER_SIZE) +	return ExaGlyphNeedFlush; +      if (PICT_FORMAT_BPP(format) == 1)  	format = PICT_a8; @@ -589,6 +597,7 @@ exaBufferGlyph(ScreenPtr         pScreen,      /* Couldn't find the glyph in the cache, use the glyph picture directly */ +    mask = GlyphPicture(pGlyph)[pScreen->myNum];      if (buffer->mask && buffer->mask != mask)  	return ExaGlyphNeedFlush; @@ -702,18 +711,12 @@ exaGlyphs (CARD8 	 op,      int		width = 0, height = 0;      int		x, y;      int		first_xOff = list->xOff, first_yOff = list->yOff; -    int		i, n; +    int		n;      GlyphPtr	glyph;      int		error;      BoxRec	extents = {0, 0, 0, 0};      CARD32	component_alpha; -    ExaGlyphBufferPtr buffer; - -    for (i = 0, n = 0; i < nlist; i++) -	n += list[i].len; -    buffer = alloca(sizeof(ExaGlyphBuffer) + n * sizeof(ExaCompositeRectRec)); -    if (!buffer) -	return; +    ExaGlyphBuffer buffer;      if (maskFormat)      { @@ -793,8 +796,8 @@ exaGlyphs (CARD8 	 op,  	x = 0;  	y = 0;      } -    buffer->count = 0; -    buffer->mask = NULL; +    buffer.count = 0; +    buffer.mask = NULL;      while (nlist--)      {  	x += list->xOff; @@ -809,23 +812,23 @@ exaGlyphs (CARD8 	 op,  		/* pGlyph->info.{x,y} compensate for empty space in the glyph. */  		if (maskFormat)  		{ -		    if (exaBufferGlyph(pScreen, buffer, glyph, NULL, pMask, +		    if (exaBufferGlyph(pScreen, &buffer, glyph, NULL, pMask,  				       0, 0, 0, 0, x - glyph->info.x, y - glyph->info.y) == ExaGlyphNeedFlush)  		    { -			exaGlyphsToMask(pMask, buffer); -			exaBufferGlyph(pScreen, buffer, glyph, NULL, pMask, +			exaGlyphsToMask(pMask, &buffer); +			exaBufferGlyph(pScreen, &buffer, glyph, NULL, pMask,  				       0, 0, 0, 0, x - glyph->info.x, y - glyph->info.y);  		    }  		}  		else  		{ -		    if (exaBufferGlyph(pScreen, buffer, glyph, pSrc, pDst, +		    if (exaBufferGlyph(pScreen, &buffer, glyph, pSrc, pDst,  				       xSrc + (x - glyph->info.x) - first_xOff, ySrc + (y - glyph->info.y) - first_yOff,  				       0, 0, x - glyph->info.x, y - glyph->info.y)  			== ExaGlyphNeedFlush)  		    { -			exaGlyphsToDst(pSrc, pDst, buffer); -			exaBufferGlyph(pScreen, buffer, glyph, pSrc, pDst, +			exaGlyphsToDst(pSrc, pDst, &buffer); +			exaBufferGlyph(pScreen, &buffer, glyph, pSrc, pDst,  				       xSrc + (x - glyph->info.x) - first_xOff, ySrc + (y - glyph->info.y) - first_yOff,  				       0, 0, x - glyph->info.x, y - glyph->info.y);  		    } @@ -838,11 +841,11 @@ exaGlyphs (CARD8 	 op,  	list++;      } -    if (buffer->count) { +    if (buffer.count) {          if (maskFormat) -	    exaGlyphsToMask(pMask, buffer); +	    exaGlyphsToMask(pMask, &buffer);          else -	    exaGlyphsToDst(pSrc, pDst, buffer); +	    exaGlyphsToDst(pSrc, pDst, &buffer);      }      if (maskFormat) | 
