diff options
| author | marha <marha@users.sourceforge.net> | 2012-12-10 08:33:13 +0100 | 
|---|---|---|
| committer | marha <marha@users.sourceforge.net> | 2012-12-10 08:33:13 +0100 | 
| commit | 0328076efb5ff6e62152c09e38d0d11f7931d07b (patch) | |
| tree | ce71cf0fe95186671dc75862c2ced47f4735214f /mesalib/src/gallium | |
| parent | e82692e521240c5f8592f9ce56c9d5b3d68870ec (diff) | |
| download | vcxsrv-0328076efb5ff6e62152c09e38d0d11f7931d07b.tar.gz vcxsrv-0328076efb5ff6e62152c09e38d0d11f7931d07b.tar.bz2 vcxsrv-0328076efb5ff6e62152c09e38d0d11f7931d07b.zip | |
fontconfig libX11 mesa pixman git update 10 dec 2012
libX11 9833489e6c3829a1e835bc0a11f028fc180809e4
mesa 17f5dc57306b8f5079304701e455bf4b927d3cae
pixman 8ca4e144724ba2041bc5ef077ccf6d24e7cf4d1f
fontconfig 608c5b590bd3428dfcd30f3d68ee8b7131e2f019
Diffstat (limited to 'mesalib/src/gallium')
| -rw-r--r-- | mesalib/src/gallium/auxiliary/Makefile.sources | 1 | ||||
| -rw-r--r-- | mesalib/src/gallium/auxiliary/util/u_blitter.h | 6 | ||||
| -rw-r--r-- | mesalib/src/gallium/auxiliary/util/u_rect.c | 158 | ||||
| -rw-r--r-- | mesalib/src/gallium/auxiliary/util/u_rect.h | 30 | ||||
| -rw-r--r-- | mesalib/src/gallium/auxiliary/util/u_surface.c | 179 | ||||
| -rw-r--r-- | mesalib/src/gallium/auxiliary/util/u_surface.h | 24 | ||||
| -rw-r--r-- | mesalib/src/gallium/auxiliary/util/u_transfer.c | 28 | 
7 files changed, 209 insertions, 217 deletions
| diff --git a/mesalib/src/gallium/auxiliary/Makefile.sources b/mesalib/src/gallium/auxiliary/Makefile.sources index 6258861f0..724178535 100644 --- a/mesalib/src/gallium/auxiliary/Makefile.sources +++ b/mesalib/src/gallium/auxiliary/Makefile.sources @@ -124,7 +124,6 @@ C_SOURCES := \  	util/u_math.c \  	util/u_mm.c \  	util/u_pstipple.c \ -	util/u_rect.c \  	util/u_ringbuffer.c \  	util/u_sampler.c \  	util/u_simple_shaders.c \ diff --git a/mesalib/src/gallium/auxiliary/util/u_blitter.h b/mesalib/src/gallium/auxiliary/util/u_blitter.h index b96e68e93..99175409b 100644 --- a/mesalib/src/gallium/auxiliary/util/u_blitter.h +++ b/mesalib/src/gallium/auxiliary/util/u_blitter.h @@ -29,10 +29,14 @@  #include "util/u_framebuffer.h"  #include "util/u_inlines.h" -#include "util/u_memory.h"  #include "pipe/p_state.h" +/* u_memory.h conflicts with st/mesa */ +#ifndef Elements +#define Elements(x) (sizeof(x)/sizeof((x)[0])) +#endif +  #ifdef __cplusplus  extern "C" { diff --git a/mesalib/src/gallium/auxiliary/util/u_rect.c b/mesalib/src/gallium/auxiliary/util/u_rect.c deleted file mode 100644 index d00568f1f..000000000 --- a/mesalib/src/gallium/auxiliary/util/u_rect.c +++ /dev/null @@ -1,158 +0,0 @@ -/************************************************************************** - *  - * Copyright 2008 Tungsten Graphics, Inc., Cedar Park, Texas. - * 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, sub license, 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 (including the - * next paragraph) 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 NON-INFRINGEMENT. - * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS 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. - *  - **************************************************************************/ - -/** - * Rectangle-related helper functions. - */ - - -#include "util/u_format.h" -#include "util/u_rect.h" -#include "util/u_pack_color.h" - - -/** - * Copy 2D rect from one place to another. - * Position and sizes are in pixels. - * src_stride may be negative to do vertical flip of pixels from source. - */ -void -util_copy_rect(ubyte * dst, -               enum pipe_format format, -               unsigned dst_stride, -               unsigned dst_x, -               unsigned dst_y, -               unsigned width, -               unsigned height, -               const ubyte * src, -               int src_stride, -               unsigned src_x,  -               unsigned src_y) -{ -   unsigned i; -   int src_stride_pos = src_stride < 0 ? -src_stride : src_stride; -   int blocksize = util_format_get_blocksize(format); -   int blockwidth = util_format_get_blockwidth(format); -   int blockheight = util_format_get_blockheight(format); - -   assert(blocksize > 0); -   assert(blockwidth > 0); -   assert(blockheight > 0); - -   dst_x /= blockwidth; -   dst_y /= blockheight; -   width = (width + blockwidth - 1)/blockwidth; -   height = (height + blockheight - 1)/blockheight; -   src_x /= blockwidth; -   src_y /= blockheight; -    -   dst += dst_x * blocksize; -   src += src_x * blocksize; -   dst += dst_y * dst_stride; -   src += src_y * src_stride_pos; -   width *= blocksize; - -   if (width == dst_stride && width == src_stride) -      memcpy(dst, src, height * width); -   else { -      for (i = 0; i < height; i++) { -         memcpy(dst, src, width); -         dst += dst_stride; -         src += src_stride; -      } -   } -} - -void -util_fill_rect(ubyte * dst, -               enum pipe_format format, -               unsigned dst_stride, -               unsigned dst_x, -               unsigned dst_y, -               unsigned width, -               unsigned height, -               union util_color *uc) -{ -   const struct util_format_description *desc = util_format_description(format); -   unsigned i, j; -   unsigned width_size; -   int blocksize = desc->block.bits / 8; -   int blockwidth = desc->block.width; -   int blockheight = desc->block.height; - -   assert(blocksize > 0); -   assert(blockwidth > 0); -   assert(blockheight > 0); - -   dst_x /= blockwidth; -   dst_y /= blockheight; -   width = (width + blockwidth - 1)/blockwidth; -   height = (height + blockheight - 1)/blockheight; - -   dst += dst_x * blocksize; -   dst += dst_y * dst_stride; -   width_size = width * blocksize; - -   switch (blocksize) { -   case 1: -      if(dst_stride == width_size) -         memset(dst, uc->ub, height * width_size); -      else { -         for (i = 0; i < height; i++) { -            memset(dst, uc->ub, width_size); -            dst += dst_stride; -         } -      } -      break; -   case 2: -      for (i = 0; i < height; i++) { -         uint16_t *row = (uint16_t *)dst; -         for (j = 0; j < width; j++) -            *row++ = uc->us; -         dst += dst_stride; -      } -      break; -   case 4: -      for (i = 0; i < height; i++) { -         uint32_t *row = (uint32_t *)dst; -         for (j = 0; j < width; j++) -            *row++ = uc->ui; -         dst += dst_stride; -      } -      break; -   default: -      for (i = 0; i < height; i++) { -         ubyte *row = dst; -         for (j = 0; j < width; j++) { -            memcpy(row, uc, blocksize); -            row += blocksize; -         } -         dst += dst_stride; -      } -      break; -   } -} diff --git a/mesalib/src/gallium/auxiliary/util/u_rect.h b/mesalib/src/gallium/auxiliary/util/u_rect.h index 8fccae8c4..10909b202 100644 --- a/mesalib/src/gallium/auxiliary/util/u_rect.h +++ b/mesalib/src/gallium/auxiliary/util/u_rect.h @@ -83,36 +83,10 @@ u_rect_possible_intersection(const struct u_rect *a,  }  #endif -#include "pipe/p_format.h" -#include "util/u_pack_color.h" - - -/********************************************************************** - * Pipe copy/fill rect helpers. - */ - -/* These really should move to a different file: +/* Include pipe copy/fill rect helpers declarations for backwards compatibility   */ -#include "pipe/p_format.h" +#include "util/u_surface.h" -#ifdef __cplusplus -extern "C" { -#endif - -extern void -util_copy_rect(ubyte * dst, enum pipe_format format, -               unsigned dst_stride, unsigned dst_x, unsigned dst_y, -               unsigned width, unsigned height, const ubyte * src, -               int src_stride, unsigned src_x, unsigned src_y); - -extern void -util_fill_rect(ubyte * dst, enum pipe_format format, -               unsigned dst_stride, unsigned dst_x, unsigned dst_y, -               unsigned width, unsigned height, union util_color *uc); - -#ifdef __cplusplus -} -#endif  #endif /* U_RECT_H */ diff --git a/mesalib/src/gallium/auxiliary/util/u_surface.c b/mesalib/src/gallium/auxiliary/util/u_surface.c index 5b42afd0d..2c197c3df 100644 --- a/mesalib/src/gallium/auxiliary/util/u_surface.c +++ b/mesalib/src/gallium/auxiliary/util/u_surface.c @@ -116,6 +116,163 @@ util_create_rgba_texture(struct pipe_context *pipe,  /** + * Copy 2D rect from one place to another. + * Position and sizes are in pixels. + * src_stride may be negative to do vertical flip of pixels from source. + */ +void +util_copy_rect(ubyte * dst, +               enum pipe_format format, +               unsigned dst_stride, +               unsigned dst_x, +               unsigned dst_y, +               unsigned width, +               unsigned height, +               const ubyte * src, +               int src_stride, +               unsigned src_x, +               unsigned src_y) +{ +   unsigned i; +   int src_stride_pos = src_stride < 0 ? -src_stride : src_stride; +   int blocksize = util_format_get_blocksize(format); +   int blockwidth = util_format_get_blockwidth(format); +   int blockheight = util_format_get_blockheight(format); + +   assert(blocksize > 0); +   assert(blockwidth > 0); +   assert(blockheight > 0); + +   dst_x /= blockwidth; +   dst_y /= blockheight; +   width = (width + blockwidth - 1)/blockwidth; +   height = (height + blockheight - 1)/blockheight; +   src_x /= blockwidth; +   src_y /= blockheight; + +   dst += dst_x * blocksize; +   src += src_x * blocksize; +   dst += dst_y * dst_stride; +   src += src_y * src_stride_pos; +   width *= blocksize; + +   if (width == dst_stride && width == src_stride) +      memcpy(dst, src, height * width); +   else { +      for (i = 0; i < height; i++) { +         memcpy(dst, src, width); +         dst += dst_stride; +         src += src_stride; +      } +   } +} + + +/** + * Copy 3D box from one place to another. + * Position and sizes are in pixels. + */ +void +util_copy_box(ubyte * dst, +              enum pipe_format format, +              unsigned dst_stride, unsigned dst_slice_stride, +              unsigned dst_x, unsigned dst_y, unsigned dst_z, +              unsigned width, unsigned height, unsigned depth, +              const ubyte * src, +              int src_stride, unsigned src_slice_stride, +              unsigned src_x, unsigned src_y, unsigned src_z) +{ +   unsigned z; +   dst += dst_z * dst_slice_stride; +   src += src_z * src_slice_stride; +   for (z = 0; z < depth; ++z) { +      util_copy_rect(dst, +                     format, +                     dst_stride, +                     dst_x, dst_y, +                     width, height, +                     src, +                     src_stride, +                     src_x, src_y); + +      dst += dst_slice_stride; +      src += src_slice_stride; +   } +} + + +void +util_fill_rect(ubyte * dst, +               enum pipe_format format, +               unsigned dst_stride, +               unsigned dst_x, +               unsigned dst_y, +               unsigned width, +               unsigned height, +               union util_color *uc) +{ +   const struct util_format_description *desc = util_format_description(format); +   unsigned i, j; +   unsigned width_size; +   int blocksize = desc->block.bits / 8; +   int blockwidth = desc->block.width; +   int blockheight = desc->block.height; + +   assert(blocksize > 0); +   assert(blockwidth > 0); +   assert(blockheight > 0); + +   dst_x /= blockwidth; +   dst_y /= blockheight; +   width = (width + blockwidth - 1)/blockwidth; +   height = (height + blockheight - 1)/blockheight; + +   dst += dst_x * blocksize; +   dst += dst_y * dst_stride; +   width_size = width * blocksize; + +   switch (blocksize) { +   case 1: +      if(dst_stride == width_size) +         memset(dst, uc->ub, height * width_size); +      else { +         for (i = 0; i < height; i++) { +            memset(dst, uc->ub, width_size); +            dst += dst_stride; +         } +      } +      break; +   case 2: +      for (i = 0; i < height; i++) { +         uint16_t *row = (uint16_t *)dst; +         for (j = 0; j < width; j++) +            *row++ = uc->us; +         dst += dst_stride; +      } +      break; +   case 4: +      for (i = 0; i < height; i++) { +         uint32_t *row = (uint32_t *)dst; +         for (j = 0; j < width; j++) +            *row++ = uc->ui; +         dst += dst_stride; +      } +      break; +   default: +      for (i = 0; i < height; i++) { +         ubyte *row = dst; +         for (j = 0; j < width; j++) { +            memcpy(row, uc, blocksize); +            row += blocksize; +         } +         dst += dst_stride; +      } +      break; +   } +} + + +/**   * Fallback function for pipe->resource_copy_region().   * Note: (X,Y)=(0,0) is always the upper-left corner.   */ @@ -133,7 +290,6 @@ util_resource_copy_region(struct pipe_context *pipe,     const uint8_t *src_map;     enum pipe_format src_format, dst_format;     struct pipe_box dst_box; -   int z;     assert(src && dst);     if (!src || !dst) @@ -181,19 +337,14 @@ util_resource_copy_region(struct pipe_context *pipe,        assert(src_box->depth == 1);        memcpy(dst_map, src_map, src_box->width);     } else { -      for (z = 0; z < src_box->depth; ++z) { -         util_copy_rect(dst_map, -                        dst_format, -                        dst_trans->stride, -                        0, 0, -                        src_box->width, src_box->height, -                        src_map, -                        src_trans->stride, -                        0, 0); - -         dst_map += dst_trans->layer_stride; -         src_map += src_trans->layer_stride; -      } +      util_copy_box(dst_map, +                    dst_format, +                    dst_trans->stride, dst_trans->layer_stride, +                    0, 0, 0, +                    src_box->width, src_box->height, src_box->depth, +                    src_map, +                    src_trans->stride, src_trans->layer_stride, +                    0, 0, 0);     }     pipe->transfer_unmap(pipe, dst_trans); diff --git a/mesalib/src/gallium/auxiliary/util/u_surface.h b/mesalib/src/gallium/auxiliary/util/u_surface.h index 6bcb63f3d..dd4d5785e 100644 --- a/mesalib/src/gallium/auxiliary/util/u_surface.h +++ b/mesalib/src/gallium/auxiliary/util/u_surface.h @@ -32,6 +32,8 @@  #include "pipe/p_compiler.h"  #include "pipe/p_state.h" +#include "util/u_pack_color.h" +  #ifdef __cplusplus  extern "C" { @@ -50,6 +52,28 @@ util_create_rgba_texture(struct pipe_context *ctx,  extern void +util_copy_rect(ubyte * dst, enum pipe_format format, +               unsigned dst_stride, unsigned dst_x, unsigned dst_y, +               unsigned width, unsigned height, const ubyte * src, +               int src_stride, unsigned src_x, unsigned src_y); + +extern void +util_copy_box(ubyte * dst, +              enum pipe_format format, +              unsigned dst_stride, unsigned dst_slice_stride, +              unsigned dst_x, unsigned dst_y, unsigned dst_z, +              unsigned width, unsigned height, unsigned depth, +              const ubyte * src, +              int src_stride, unsigned src_slice_stride, +              unsigned src_x, unsigned src_y, unsigned src_z); + +extern void +util_fill_rect(ubyte * dst, enum pipe_format format, +               unsigned dst_stride, unsigned dst_x, unsigned dst_y, +               unsigned width, unsigned height, union util_color *uc); + + +extern void  util_resource_copy_region(struct pipe_context *pipe,                            struct pipe_resource *dst,                            unsigned dst_level, diff --git a/mesalib/src/gallium/auxiliary/util/u_transfer.c b/mesalib/src/gallium/auxiliary/util/u_transfer.c index 8b4c36592..861682553 100644 --- a/mesalib/src/gallium/auxiliary/util/u_transfer.c +++ b/mesalib/src/gallium/auxiliary/util/u_transfer.c @@ -1,5 +1,5 @@  #include "pipe/p_context.h" -#include "util/u_rect.h" +#include "util/u_surface.h"  #include "util/u_inlines.h"  #include "util/u_transfer.h"  #include "util/u_memory.h" @@ -47,21 +47,19 @@ void u_default_transfer_inline_write( struct pipe_context *pipe,     }     else {        const uint8_t *src_data = data; -      unsigned i; -      for (i = 0; i < box->depth; i++) { -         util_copy_rect(map, -                        resource->format, -                        transfer->stride, /* bytes */ -                        0, 0, -                        box->width, -                        box->height, -                        src_data, -                        stride,       /* bytes */ -                        0, 0); -         map += transfer->layer_stride; -         src_data += layer_stride; -      } +      util_copy_box(map, +		    resource->format, +		    transfer->stride, /* bytes */ +		    transfer->layer_stride, /* bytes */ +                    0, 0, 0, +		    box->width, +		    box->height, +		    box->depth, +		    src_data, +		    stride,       /* bytes */ +		    layer_stride, /* bytes */ +		    0, 0, 0);     }     pipe_transfer_unmap(pipe, transfer); | 
