diff options
| author | Michal Krol <michal@vmware.com> | 2009-12-18 09:08:26 +0100 | 
|---|---|---|
| committer | Michal Krol <michal@vmware.com> | 2009-12-18 09:08:26 +0100 | 
| commit | 7855fcb63ba0594cdaee15f8579b66af651828e0 (patch) | |
| tree | 4ec55e91e49cd9600f362c32acc539696a8b1b8b | |
| parent | 465333ab7078daf878ad34ab172ebb15f8a003b3 (diff) | |
| parent | b1ed72ebe2599ec178f51d86fd42f26486b9a19b (diff) | |
Merge branch 'pipe-format-simplify'
83 files changed, 791 insertions, 905 deletions
| diff --git a/progs/rbug/bin_to_bmp.c b/progs/rbug/bin_to_bmp.c index cdae3486ce..03ff622fee 100644 --- a/progs/rbug/bin_to_bmp.c +++ b/progs/rbug/bin_to_bmp.c @@ -25,6 +25,7 @@  #include "pipe/p_compiler.h"  #include "pipe/p_format.h"  #include "pipe/p_state.h" +#include "util/u_format.h"  #include "util/u_memory.h"  #include "util/u_debug.h"  #include "util/u_network.h" @@ -54,10 +55,7 @@ static void dump(unsigned width, unsigned height,                   unsigned src_stride, enum pipe_format src_format,                   uint8_t *data, unsigned src_size)  { -   struct pipe_format_block src_block; -     enum pipe_format dst_format = PIPE_FORMAT_R32G32B32A32_FLOAT; -   struct pipe_format_block dst_block;     unsigned dst_stride;     unsigned dst_size;     float *rgba; @@ -65,14 +63,11 @@ static void dump(unsigned width, unsigned height,     char filename[512];     { -      pf_get_block(src_format, &src_block); -      assert(src_stride >= pf_get_stride(&src_block, width)); -      assert(src_size >= pf_get_2d_size(&src_block, src_stride, width)); +      assert(src_stride >= util_format_get_stride(src_format, width));     }     { -      pf_get_block(dst_format, &dst_block); -      dst_stride = pf_get_stride(&dst_block, width); -      dst_size = pf_get_2d_size(&dst_block, dst_stride, width); +      dst_stride = util_format_get_stride(dst_format, width); +      dst_size = util_format_get_2d_size(dst_format, dst_stride, width);        rgba = MALLOC(dst_size);     } diff --git a/src/gallium/auxiliary/draw/draw_pipe_aaline.c b/src/gallium/auxiliary/draw/draw_pipe_aaline.c index 23d8b609e1..14375426ed 100644 --- a/src/gallium/auxiliary/draw/draw_pipe_aaline.c +++ b/src/gallium/auxiliary/draw/draw_pipe_aaline.c @@ -35,6 +35,8 @@  #include "pipe/p_context.h"  #include "pipe/p_defines.h"  #include "pipe/p_shader_tokens.h" + +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h" diff --git a/src/gallium/auxiliary/draw/draw_pipe_pstipple.c b/src/gallium/auxiliary/draw/draw_pipe_pstipple.c index bcb860da2e..0cc2b71864 100644 --- a/src/gallium/auxiliary/draw/draw_pipe_pstipple.c +++ b/src/gallium/auxiliary/draw/draw_pipe_pstipple.c @@ -38,6 +38,7 @@  #include "pipe/p_defines.h"  #include "pipe/p_shader_tokens.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h" diff --git a/src/gallium/auxiliary/util/u_blit.c b/src/gallium/auxiliary/util/u_blit.c index c9050ca864..3f74e2aa8b 100644 --- a/src/gallium/auxiliary/util/u_blit.c +++ b/src/gallium/auxiliary/util/u_blit.c @@ -42,6 +42,7 @@  #include "util/u_blit.h"  #include "util/u_draw_quad.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h"  #include "util/u_simple_shaders.h" diff --git a/src/gallium/auxiliary/util/u_blitter.c b/src/gallium/auxiliary/util/u_blitter.c index 895af2c8d0..0242b79615 100644 --- a/src/gallium/auxiliary/util/u_blitter.c +++ b/src/gallium/auxiliary/util/u_blitter.c @@ -579,8 +579,8 @@ void util_blitter_copy(struct blitter_context *blitter,     if (!dst->texture || !src->texture)        return; -   is_depth = pf_get_component_bits(src->format, PIPE_FORMAT_COMP_Z) != 0; -   is_stencil = pf_get_component_bits(src->format, PIPE_FORMAT_COMP_S) != 0; +   is_depth = util_format_get_component_bits(src->format, UTIL_FORMAT_COLORSPACE_ZS, 0) != 0; +   is_stencil = util_format_get_component_bits(src->format, UTIL_FORMAT_COLORSPACE_ZS, 1) != 0;     dst_tex_usage = is_depth || is_stencil ? PIPE_TEXTURE_USAGE_DEPTH_STENCIL :                                              PIPE_TEXTURE_USAGE_RENDER_TARGET; diff --git a/src/gallium/auxiliary/util/u_debug.c b/src/gallium/auxiliary/util/u_debug.c index 40633574b0..27e0b0d159 100644 --- a/src/gallium/auxiliary/util/u_debug.c +++ b/src/gallium/auxiliary/util/u_debug.c @@ -64,6 +64,7 @@  #include "pipe/p_format.h"   #include "pipe/p_state.h"   #include "pipe/p_inlines.h"  +#include "util/u_format.h"  #include "util/u_memory.h"   #include "util/u_string.h"   #include "util/u_stream.h"  @@ -670,9 +671,9 @@ void debug_dump_surface(const char *prefix,     debug_dump_image(prefix,                       texture->format, -                    pf_get_blocksize(texture->format),  -                    pf_get_nblocksx(texture->format, transfer->width), -                    pf_get_nblocksy(texture->format, transfer->height), +                    util_format_get_blocksize(texture->format),  +                    util_format_get_nblocksx(texture->format, transfer->width), +                    util_format_get_nblocksy(texture->format, transfer->height),                      transfer->stride,                      data); diff --git a/src/gallium/auxiliary/util/u_format.c b/src/gallium/auxiliary/util/u_format.c index 98ea13b60b..e0724a1a8b 100644 --- a/src/gallium/auxiliary/util/u_format.c +++ b/src/gallium/auxiliary/util/u_format.c @@ -32,15 +32,14 @@  const struct util_format_description *  util_format_description(enum pipe_format format)  { -   const struct util_format_description *desc = util_format_description_table; +   const struct util_format_description *desc; -   while(TRUE) { -      if(desc->format == format) -         return desc; +   if (format >= PIPE_FORMAT_COUNT) { +      return NULL; +   } -      if(desc->format == PIPE_FORMAT_NONE) -         return NULL; +   desc = &util_format_description_table[format]; +   assert(desc->format == format); -      ++desc; -   }; +   return desc;  } diff --git a/src/gallium/auxiliary/util/u_format.csv b/src/gallium/auxiliary/util/u_format.csv index b9cc2aa716..866b18ff16 100644 --- a/src/gallium/auxiliary/util/u_format.csv +++ b/src/gallium/auxiliary/util/u_format.csv @@ -11,6 +11,8 @@ PIPE_FORMAT_A8_UNORM              , arith , 1, 1, un8 ,     ,     ,     , 000x,  PIPE_FORMAT_I8_UNORM              , arith , 1, 1, un8 ,     ,     ,     , xxxx, rgb  PIPE_FORMAT_A8L8_UNORM            , arith , 1, 1, un8 , un8 ,     ,     , xxxy, rgb  PIPE_FORMAT_L16_UNORM             , arith , 1, 1, un16,     ,     ,     , xxx1, rgb +PIPE_FORMAT_YCBCR                 , yuv   , 2, 1, x32 ,     ,     ,     , xyz1, yuv +PIPE_FORMAT_YCBCR_REV             , yuv   , 2, 1, x32 ,     ,     ,     , xyz1, yuv  PIPE_FORMAT_Z16_UNORM             , array , 1, 1, un16,     ,     ,     , x___, zs   PIPE_FORMAT_Z32_UNORM             , array , 1, 1, un32,     ,     ,     , x___, zs   PIPE_FORMAT_Z32_FLOAT             , array , 1, 1, f32 ,     ,     ,     , x___, zs  @@ -97,13 +99,11 @@ PIPE_FORMAT_B8G8R8A8_SRGB         , arith , 1, 1, u8  , u8  , u8  , u8  , zyxw,  PIPE_FORMAT_B8G8R8X8_SRGB         , arith , 1, 1, u8  , u8  , u8  , u8  , zyx1, srgb   PIPE_FORMAT_X8UB8UG8SR8S_NORM     , arith , 1, 1, sn8 , sn8 , un8 , x8  , 1zyx, rgb  PIPE_FORMAT_B6UG5SR5S_NORM        , arith , 1, 1, sn5 , sn5 , un6 ,     , xyz1, rgb -PIPE_FORMAT_YCBCR                 , yuv   , 2, 1, x32 ,     ,     ,     , xyz1, yuv -PIPE_FORMAT_YCBCR_REV             , yuv   , 2, 1, x32 ,     ,     ,     , xyz1, yuv -PIPE_FORMAT_DXT1_RGBA             , dxt   , 4, 4, x64 ,     ,     ,     , xyzw, rgb  PIPE_FORMAT_DXT1_RGB              , dxt   , 4, 4, x64 ,     ,     ,     , xyz1, rgb +PIPE_FORMAT_DXT1_RGBA             , dxt   , 4, 4, x64 ,     ,     ,     , xyzw, rgb  PIPE_FORMAT_DXT3_RGBA             , dxt   , 4, 4, x128,     ,     ,     , xyzw, rgb  PIPE_FORMAT_DXT5_RGBA             , dxt   , 4, 4, x128,     ,     ,     , xyzw, rgb -PIPE_FORMAT_DXT1_SRGBA            , dxt   , 4, 4, x64 ,     ,     ,     , xyzw, srgb  PIPE_FORMAT_DXT1_SRGB             , dxt   , 4, 4, x64 ,     ,     ,     , xyz1, srgb +PIPE_FORMAT_DXT1_SRGBA            , dxt   , 4, 4, x64 ,     ,     ,     , xyzw, srgb  PIPE_FORMAT_DXT3_SRGBA            , dxt   , 4, 4, x128,     ,     ,     , xyzw, srgb  PIPE_FORMAT_DXT5_SRGBA            , dxt   , 4, 4, x128,     ,     ,     , xyzw, srgb diff --git a/src/gallium/auxiliary/util/u_format.h b/src/gallium/auxiliary/util/u_format.h index 19b902db98..97e4d959bc 100644 --- a/src/gallium/auxiliary/util/u_format.h +++ b/src/gallium/auxiliary/util/u_format.h @@ -147,6 +147,209 @@ const struct util_format_description *  util_format_description(enum pipe_format format); +/* + * Format query functions. + */ + +static INLINE boolean  +util_format_is_compressed(enum pipe_format format) +{ +   const struct util_format_description *desc = util_format_description(format); + +   assert(format); +   if (!format) { +      return FALSE; +   } + +   return desc->layout == UTIL_FORMAT_LAYOUT_DXT ? TRUE : FALSE; +} + +static INLINE boolean  +util_format_is_depth_or_stencil(enum pipe_format format) +{ +   const struct util_format_description *desc = util_format_description(format); + +   assert(format); +   if (!format) { +      return FALSE; +   } + +   return desc->colorspace == UTIL_FORMAT_COLORSPACE_ZS ? TRUE : FALSE; +} + +static INLINE boolean  +util_format_is_depth_and_stencil(enum pipe_format format) +{ +   const struct util_format_description *desc = util_format_description(format); + +   assert(format); +   if (!format) { +      return FALSE; +   } + +   if (desc->colorspace != UTIL_FORMAT_COLORSPACE_ZS) { +      return FALSE; +   } + +   return (desc->swizzle[0] != UTIL_FORMAT_SWIZZLE_NONE && +           desc->swizzle[1] != UTIL_FORMAT_SWIZZLE_NONE) ? TRUE : FALSE; +} + + +/** + * Return total bits needed for the pixel format. + */ +static INLINE uint +util_format_get_blocksizebits(enum pipe_format format) +{ +   const struct util_format_description *desc = util_format_description(format); + +   assert(format); +   if (!format) { +      return 0; +   } + +   return desc->block.bits / (desc->block.width * desc->block.height); +} + +/** + * Return bytes per pixel for the given format. + */ +static INLINE uint +util_format_get_blocksize(enum pipe_format format) +{ +   uint bits = util_format_get_blocksizebits(format); + +   assert(bits % 8 == 0); + +   return bits / 8; +} + +static INLINE uint +util_format_get_blockwidth(enum pipe_format format) +{ +   const struct util_format_description *desc = util_format_description(format); + +   assert(format); +   if (!format) { +      return 1; +   } + +   switch (desc->layout) { +   case UTIL_FORMAT_LAYOUT_YUV: +      return 2; +   case UTIL_FORMAT_LAYOUT_DXT: +      return 4; +   default: +      return 1; +   } +} + +static INLINE uint +util_format_get_blockheight(enum pipe_format format) +{ +   const struct util_format_description *desc = util_format_description(format); + +   assert(format); +   if (!format) { +      return 1; +   } + +   switch (desc->layout) { +   case UTIL_FORMAT_LAYOUT_DXT: +      return 4; +   default: +      return 1; +   } +} + +static INLINE unsigned +util_format_get_nblocksx(enum pipe_format format, +                         unsigned x) +{ +   unsigned blockwidth = util_format_get_blockwidth(format); +   return (x + blockwidth - 1) / blockwidth; +} + +static INLINE unsigned +util_format_get_nblocksy(enum pipe_format format, +                         unsigned y) +{ +   unsigned blockheight = util_format_get_blockheight(format); +   return (y + blockheight - 1) / blockheight; +} + +static INLINE unsigned +util_format_get_nblocks(enum pipe_format format, +                        unsigned width, +                        unsigned height) +{ +   return util_format_get_nblocksx(format, width) * util_format_get_nblocksy(format, height); +} + +static INLINE size_t +util_format_get_stride(enum pipe_format format, +                       unsigned width) +{ +   return util_format_get_nblocksx(format, width) * util_format_get_blocksize(format); +} + +static INLINE size_t +util_format_get_2d_size(enum pipe_format format, +                        size_t stride, +                        unsigned height) +{ +   return util_format_get_nblocksy(format, height) * stride; +} + +static INLINE uint +util_format_get_component_bits(enum pipe_format format, +                               enum util_format_colorspace colorspace, +                               uint component) +{ +   const struct util_format_description *desc = util_format_description(format); +   enum util_format_colorspace desc_colorspace; + +   assert(format); +   if (!format) { +      return 0; +   } + +   assert(component < 4); + +   /* Treat RGB and SRGB as equivalent. */ +   if (colorspace == UTIL_FORMAT_COLORSPACE_SRGB) { +      colorspace = UTIL_FORMAT_COLORSPACE_RGB; +   } +   if (desc->colorspace == UTIL_FORMAT_COLORSPACE_SRGB) { +      desc_colorspace = UTIL_FORMAT_COLORSPACE_RGB; +   } else { +      desc_colorspace = desc->colorspace; +   } + +   if (desc_colorspace != colorspace) { +      return 0; +   } + +   switch (desc->swizzle[component]) { +   case UTIL_FORMAT_SWIZZLE_X: +      return desc->channel[0].size; +   case UTIL_FORMAT_SWIZZLE_Y: +      return desc->channel[1].size; +   case UTIL_FORMAT_SWIZZLE_Z: +      return desc->channel[2].size; +   case UTIL_FORMAT_SWIZZLE_W: +      return desc->channel[3].size; +   default: +      return 0; +   } +} + + +/* + * Format access functions. + */ +  void  util_format_read_4f(enum pipe_format format,                      float *dst, unsigned dst_stride,  diff --git a/src/gallium/auxiliary/util/u_format_table.py b/src/gallium/auxiliary/util/u_format_table.py index 2cd0f95678..571cab55dc 100755 --- a/src/gallium/auxiliary/util/u_format_table.py +++ b/src/gallium/auxiliary/util/u_format_table.py @@ -89,6 +89,15 @@ def write_format_table(formats):      print 'const struct util_format_description'      print 'util_format_description_table[] = '      print "{" +    print "   {" +    print "      PIPE_FORMAT_NONE," +    print "      \"PIPE_FORMAT_NONE\"," +    print "      {0, 0, 0}," +    print "      0," +    print "      {{0, 0, 0}, {0, 0, 0}, {0, 0, 0}, {0, 0, 0}}," +    print "      {0, 0, 0, 0}," +    print "      0" +    print "   },"      for format in formats:          print "   {"          print "      %s," % (format.name,) @@ -119,15 +128,6 @@ def write_format_table(formats):          print "      },"          print "      %s," % (colorspace_map(format.colorspace),)          print "   }," -    print "   {" -    print "      PIPE_FORMAT_NONE," -    print "      \"PIPE_FORMAT_NONE\"," -    print "      {0, 0, 0}," -    print "      0," -    print "      {{0, 0, 0}, {0, 0, 0}, {0, 0, 0}, {0, 0, 0}}," -    print "      {0, 0, 0, 0}," -    print "      0" -    print "   },"      print "};" diff --git a/src/gallium/auxiliary/util/u_gen_mipmap.c b/src/gallium/auxiliary/util/u_gen_mipmap.c index 69ff3b9dd9..0dad6ccbc0 100644 --- a/src/gallium/auxiliary/util/u_gen_mipmap.c +++ b/src/gallium/auxiliary/util/u_gen_mipmap.c @@ -41,6 +41,7 @@  #include "pipe/p_shader_tokens.h"  #include "pipe/p_state.h" +#include "util/u_format.h"  #include "util/u_memory.h"  #include "util/u_draw_quad.h"  #include "util/u_gen_mipmap.h" @@ -997,7 +998,7 @@ reduce_2d(enum pipe_format pformat,  {     enum dtype datatype;     uint comps; -   const int bpt = pf_get_blocksize(pformat); +   const int bpt = util_format_get_blocksize(pformat);     const ubyte *srcA, *srcB;     ubyte *dst;     int row; @@ -1036,7 +1037,7 @@ reduce_3d(enum pipe_format pformat,            int dstWidth, int dstHeight, int dstDepth,            int dstRowStride, ubyte *dstPtr)  { -   const int bpt = pf_get_blocksize(pformat); +   const int bpt = util_format_get_blocksize(pformat);     const int border = 0;     int img, row;     int bytesPerSrcImage, bytesPerDstImage; @@ -1160,8 +1161,8 @@ make_2d_mipmap(struct gen_mipmap_state *ctx,     const uint zslice = 0;     uint dstLevel; -   assert(pf_get_blockwidth(pt->format) == 1); -   assert(pf_get_blockheight(pt->format) == 1); +   assert(util_format_get_blockwidth(pt->format) == 1); +   assert(util_format_get_blockheight(pt->format) == 1);     for (dstLevel = baseLevel + 1; dstLevel <= lastLevel; dstLevel++) {        const uint srcLevel = dstLevel - 1; @@ -1205,8 +1206,8 @@ make_3d_mipmap(struct gen_mipmap_state *ctx,     struct pipe_screen *screen = pipe->screen;     uint dstLevel, zslice = 0; -   assert(pf_get_blockwidth(pt->format) == 1); -   assert(pf_get_blockheight(pt->format) == 1); +   assert(util_format_get_blockwidth(pt->format) == 1); +   assert(util_format_get_blockheight(pt->format) == 1);     for (dstLevel = baseLevel + 1; dstLevel <= lastLevel; dstLevel++) {        const uint srcLevel = dstLevel - 1; diff --git a/src/gallium/auxiliary/util/u_pack_color.h b/src/gallium/auxiliary/util/u_pack_color.h index a2e0f26686..7de62d3228 100644 --- a/src/gallium/auxiliary/util/u_pack_color.h +++ b/src/gallium/auxiliary/util/u_pack_color.h @@ -37,6 +37,7 @@  #include "pipe/p_compiler.h"  #include "pipe/p_format.h" +#include "util/u_format.h"  #include "util/u_math.h" @@ -302,7 +303,7 @@ util_pack_color(const float rgba[4], enum pipe_format format, union util_color *     ubyte b = 0;     ubyte a = 0; -   if (pf_size_x(format) <= 8) { +   if (util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 0) <= 8) {        /* format uses 8-bit components or less */        r = float_to_ubyte(rgba[0]);        g = float_to_ubyte(rgba[1]); diff --git a/src/gallium/auxiliary/util/u_rect.c b/src/gallium/auxiliary/util/u_rect.c index 72725b59d2..298fbacecb 100644 --- a/src/gallium/auxiliary/util/u_rect.c +++ b/src/gallium/auxiliary/util/u_rect.c @@ -34,6 +34,7 @@  #include "pipe/p_format.h"  #include "pipe/p_context.h"  #include "pipe/p_screen.h" +#include "util/u_format.h"  #include "util/u_rect.h" @@ -57,9 +58,9 @@ util_copy_rect(ubyte * dst,  {     unsigned i;     int src_stride_pos = src_stride < 0 ? -src_stride : src_stride; -   int blocksize = pf_get_blocksize(format); -   int blockwidth = pf_get_blockwidth(format); -   int blockheight = pf_get_blockheight(format); +   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); @@ -105,9 +106,9 @@ util_fill_rect(ubyte * dst,  {     unsigned i, j;     unsigned width_size; -   int blocksize = pf_get_blocksize(format); -   int blockwidth = pf_get_blockwidth(format); -   int blockheight = pf_get_blockheight(format); +   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); @@ -203,9 +204,9 @@ util_surface_copy(struct pipe_context *pipe,                                          PIPE_TRANSFER_WRITE,                                          dst_x, dst_y, w, h); -   assert(pf_get_blocksize(dst_format) == pf_get_blocksize(src_format)); -   assert(pf_get_blockwidth(dst_format) == pf_get_blockwidth(src_format)); -   assert(pf_get_blockheight(dst_format) == pf_get_blockheight(src_format)); +   assert(util_format_get_blocksize(dst_format) == util_format_get_blocksize(src_format)); +   assert(util_format_get_blockwidth(dst_format) == util_format_get_blockwidth(src_format)); +   assert(util_format_get_blockheight(dst_format) == util_format_get_blockheight(src_format));     src_map = pipe->screen->transfer_map(screen, src_trans);     dst_map = pipe->screen->transfer_map(screen, dst_trans); @@ -270,7 +271,7 @@ util_surface_fill(struct pipe_context *pipe,     if (dst_map) {        assert(dst_trans->stride > 0); -      switch (pf_get_blocksize(dst_trans->texture->format)) { +      switch (util_format_get_blocksize(dst_trans->texture->format)) {        case 1:        case 2:        case 4: diff --git a/src/gallium/auxiliary/util/u_surface.c b/src/gallium/auxiliary/util/u_surface.c index f828908f0b..35c4978204 100644 --- a/src/gallium/auxiliary/util/u_surface.c +++ b/src/gallium/auxiliary/util/u_surface.c @@ -36,6 +36,7 @@  #include "pipe/p_state.h"  #include "pipe/p_defines.h" +#include "util/u_format.h"  #include "util/u_surface.h" diff --git a/src/gallium/auxiliary/util/u_tile.c b/src/gallium/auxiliary/util/u_tile.c index 88c9a1f097..5b8dd1abb9 100644 --- a/src/gallium/auxiliary/util/u_tile.c +++ b/src/gallium/auxiliary/util/u_tile.c @@ -34,6 +34,7 @@  #include "pipe/p_defines.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h"  #include "util/u_rect.h" @@ -52,7 +53,7 @@ pipe_get_tile_raw(struct pipe_transfer *pt,     const void *src;     if (dst_stride == 0) -      dst_stride = pf_get_stride(pt->texture->format, w); +      dst_stride = util_format_get_stride(pt->texture->format, w);     if (pipe_clip_tile(x, y, &w, &h, pt))        return; @@ -81,7 +82,7 @@ pipe_put_tile_raw(struct pipe_transfer *pt,     enum pipe_format format = pt->texture->format;     if (src_stride == 0) -      src_stride = pf_get_stride(format, w); +      src_stride = util_format_get_stride(format, w);     if (pipe_clip_tile(x, y, &w, &h, pt))        return; @@ -1275,7 +1276,7 @@ pipe_get_tile_rgba(struct pipe_transfer *pt,     if (pipe_clip_tile(x, y, &w, &h, pt))        return; -   packed = MALLOC(pf_get_nblocks(format, w, h) * pf_get_blocksize(format)); +   packed = MALLOC(util_format_get_nblocks(format, w, h) * util_format_get_blocksize(format));     if (!packed)        return; @@ -1303,7 +1304,7 @@ pipe_put_tile_rgba(struct pipe_transfer *pt,     if (pipe_clip_tile(x, y, &w, &h, pt))        return; -   packed = MALLOC(pf_get_nblocks(format, w, h) * pf_get_blocksize(format)); +   packed = MALLOC(util_format_get_nblocks(format, w, h) * util_format_get_blocksize(format));     if (!packed)        return; diff --git a/src/gallium/auxiliary/vl/vl_mpeg12_mc_renderer.c b/src/gallium/auxiliary/vl/vl_mpeg12_mc_renderer.c index 4952e9c9f8..ab196c21f8 100644 --- a/src/gallium/auxiliary/vl/vl_mpeg12_mc_renderer.c +++ b/src/gallium/auxiliary/vl/vl_mpeg12_mc_renderer.c @@ -29,6 +29,7 @@  #include <assert.h>  #include <pipe/p_context.h>  #include <pipe/p_inlines.h> +#include <util/u_format.h>  #include <util/u_math.h>  #include <util/u_memory.h>  #include <tgsi/tgsi_parse.h> @@ -1443,7 +1444,7 @@ grab_blocks(struct vl_mpeg12_mc_renderer *r, unsigned mbx, unsigned mby,     assert(r);     assert(blocks); -   tex_pitch = r->tex_transfer[0]->stride / pf_get_blocksize(r->tex_transfer[0]->texture->format); +   tex_pitch = r->tex_transfer[0]->stride / util_format_get_blocksize(r->tex_transfer[0]->texture->format);     texels = r->texels[0] + mbpy * tex_pitch + mbpx;     for (y = 0; y < 2; ++y) { @@ -1482,7 +1483,7 @@ grab_blocks(struct vl_mpeg12_mc_renderer *r, unsigned mbx, unsigned mby,     mbpy /= 2;     for (tb = 0; tb < 2; ++tb) { -      tex_pitch = r->tex_transfer[tb + 1]->stride / pf_get_blocksize(r->tex_transfer[tb + 1]->texture->format); +      tex_pitch = r->tex_transfer[tb + 1]->stride / util_format_get_blocksize(r->tex_transfer[tb + 1]->texture->format);        texels = r->texels[tb + 1] + mbpy * tex_pitch + mbpx;        if ((cbp >> (1 - tb)) & 1) { diff --git a/src/gallium/drivers/cell/ppu/cell_texture.c b/src/gallium/drivers/cell/ppu/cell_texture.c index 77a57aef14..998944f77a 100644 --- a/src/gallium/drivers/cell/ppu/cell_texture.c +++ b/src/gallium/drivers/cell/ppu/cell_texture.c @@ -35,6 +35,8 @@  #include "pipe/p_defines.h"  #include "pipe/p_inlines.h"  #include "pipe/internal/p_winsys_screen.h" + +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h" @@ -65,11 +67,11 @@ cell_texture_layout(struct cell_texture *ct)        w_tile = align(width, TILE_SIZE);        h_tile = align(height, TILE_SIZE); -      ct->stride[level] = pf_get_stride(pt->format, w_tile); +      ct->stride[level] = util_format_get_stride(pt->format, w_tile);        ct->level_offset[level] = ct->buffer_size; -      size = ct->stride[level] * pf_get_nblocksy(pt->format, h_tile); +      size = ct->stride[level] * util_format_get_nblocksy(pt->format, h_tile);        if (pt->target == PIPE_TEXTURE_CUBE)           size *= 6;        else @@ -281,11 +283,11 @@ cell_get_tex_surface(struct pipe_screen *screen,        if (pt->target == PIPE_TEXTURE_CUBE) {           unsigned h_tile = align(ps->height, TILE_SIZE); -         ps->offset += face * pf_get_nblocksy(ps->format, h_tile) * ct->stride[level]; +         ps->offset += face * util_format_get_nblocksy(ps->format, h_tile) * ct->stride[level];        }        else if (pt->target == PIPE_TEXTURE_3D) {           unsigned h_tile = align(ps->height, TILE_SIZE); -         ps->offset += zslice * pf_get_nblocksy(ps->format, h_tile) * ct->stride[level]; +         ps->offset += zslice * util_format_get_nblocksy(ps->format, h_tile) * ct->stride[level];        }        else {           assert(face == 0); @@ -340,11 +342,11 @@ cell_get_tex_transfer(struct pipe_screen *screen,        if (texture->target == PIPE_TEXTURE_CUBE) {           unsigned h_tile = align(u_minify(texture->height0, level), TILE_SIZE); -         ctrans->offset += face * pf_get_nblocksy(texture->format, h_tile) * pt->stride; +         ctrans->offset += face * util_format_get_nblocksy(texture->format, h_tile) * pt->stride;        }        else if (texture->target == PIPE_TEXTURE_3D) {           unsigned h_tile = align(u_minify(texture->height0, level), TILE_SIZE); -         ctrans->offset += zslice * pf_get_nblocksy(texture->format, h_tile) * pt->stride; +         ctrans->offset += zslice * util_format_get_nblocksy(texture->format, h_tile) * pt->stride;        }        else {           assert(face == 0); @@ -397,8 +399,8 @@ cell_transfer_map(struct pipe_screen *screen, struct pipe_transfer *transfer)      * Create a buffer of ordinary memory for the linear texture.      * This is the memory that the user will read/write.      */ -   size = pf_get_stride(pt->format, align(texWidth, TILE_SIZE)) * -          pf_get_nblocksy(pt->format, align(texHeight, TILE_SIZE)); +   size = util_format_get_stride(pt->format, align(texWidth, TILE_SIZE)) * +          util_format_get_nblocksy(pt->format, align(texHeight, TILE_SIZE));     ctrans->map = align_malloc(size, 16);     if (!ctrans->map) @@ -406,7 +408,7 @@ cell_transfer_map(struct pipe_screen *screen, struct pipe_transfer *transfer)     if (transfer->usage & PIPE_TRANSFER_READ) {        /* need to untwiddle the texture to make a linear version */ -      const uint bpp = pf_get_blocksize(ct->base.format); +      const uint bpp = util_format_get_blocksize(ct->base.format);        if (bpp == 4) {           const uint *src = (uint *) (ct->mapped + ctrans->offset);           uint *dst = ctrans->map; @@ -449,7 +451,7 @@ cell_transfer_unmap(struct pipe_screen *screen,        /* The user wrote new texture data into the mapped buffer.         * We need to convert the new linear data into the twiddled/tiled format.         */ -      const uint bpp = pf_get_blocksize(ct->base.format); +      const uint bpp = util_format_get_blocksize(ct->base.format);        if (bpp == 4) {           const uint *src = ctrans->map;           uint *dst = (uint *) (ct->mapped + ctrans->offset); diff --git a/src/gallium/drivers/i915/i915_surface.c b/src/gallium/drivers/i915/i915_surface.c index 24e1024aaa..c693eb30e8 100644 --- a/src/gallium/drivers/i915/i915_surface.c +++ b/src/gallium/drivers/i915/i915_surface.c @@ -32,6 +32,7 @@  #include "pipe/p_inlines.h"  #include "pipe/p_inlines.h"  #include "pipe/internal/p_winsys_screen.h" +#include "util/u_format.h"  #include "util/u_tile.h"  #include "util/u_rect.h" @@ -52,15 +53,15 @@ i915_surface_copy(struct pipe_context *pipe,     struct pipe_texture *spt = &src_tex->base;     assert( dst != src ); -   assert( pf_get_blocksize(dpt->format) == pf_get_blocksize(spt->format) ); -   assert( pf_get_blockwidth(dpt->format) == pf_get_blockwidth(spt->format) ); -   assert( pf_get_blockheight(dpt->format) == pf_get_blockheight(spt->format) ); -   assert( pf_get_blockwidth(dpt->format) == 1 ); -   assert( pf_get_blockheight(dpt->format) == 1 ); +   assert( util_format_get_blocksize(dpt->format) == util_format_get_blocksize(spt->format) ); +   assert( util_format_get_blockwidth(dpt->format) == util_format_get_blockwidth(spt->format) ); +   assert( util_format_get_blockheight(dpt->format) == util_format_get_blockheight(spt->format) ); +   assert( util_format_get_blockwidth(dpt->format) == 1 ); +   assert( util_format_get_blockheight(dpt->format) == 1 );     i915_copy_blit( i915_context(pipe),                     FALSE, -                   pf_get_blocksize(dpt->format), +                   util_format_get_blocksize(dpt->format),                     (unsigned short) src_tex->stride, src_tex->buffer, src->offset,                     (unsigned short) dst_tex->stride, dst_tex->buffer, dst->offset,                     (short) srcx, (short) srcy, (short) dstx, (short) dsty, (short) width, (short) height ); @@ -76,11 +77,11 @@ i915_surface_fill(struct pipe_context *pipe,     struct i915_texture *tex = (struct i915_texture *)dst->texture;     struct pipe_texture *pt = &tex->base; -   assert(pf_get_blockwidth(pt->format) == 1); -   assert(pf_get_blockheight(pt->format) == 1); +   assert(util_format_get_blockwidth(pt->format) == 1); +   assert(util_format_get_blockheight(pt->format) == 1);     i915_fill_blit( i915_context(pipe), -                   pf_get_blocksize(pt->format), +                   util_format_get_blocksize(pt->format),                     (unsigned short) tex->stride,                     tex->buffer, dst->offset,                     (short) dstx, (short) dsty, diff --git a/src/gallium/drivers/i915/i915_texture.c b/src/gallium/drivers/i915/i915_texture.c index b28b413771..50a9e19094 100644 --- a/src/gallium/drivers/i915/i915_texture.c +++ b/src/gallium/drivers/i915/i915_texture.c @@ -35,6 +35,7 @@  #include "pipe/p_defines.h"  #include "pipe/p_inlines.h"  #include "pipe/internal/p_winsys_screen.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h" @@ -129,7 +130,7 @@ i915_miptree_set_image_offset(struct i915_texture *tex,     assert(img < tex->nr_images[level]); -   tex->image_offset[level][img] = y * tex->stride + x * pf_get_blocksize(tex->base.format); +   tex->image_offset[level][img] = y * tex->stride + x * util_format_get_blocksize(tex->base.format);     /*     printf("%s level %d img %d pos %d,%d image_offset %x\n", @@ -151,7 +152,7 @@ i915_scanout_layout(struct i915_texture *tex)  {     struct pipe_texture *pt = &tex->base; -   if (pt->last_level > 0 || pf_get_blocksize(pt->format) != 4) +   if (pt->last_level > 0 || util_format_get_blocksize(pt->format) != 4)        return FALSE;     i915_miptree_set_level_info(tex, 0, 1, @@ -161,18 +162,18 @@ i915_scanout_layout(struct i915_texture *tex)     i915_miptree_set_image_offset(tex, 0, 0, 0, 0);     if (pt->width0 >= 240) { -      tex->stride = power_of_two(pf_get_stride(pt->format, pt->width0)); -      tex->total_nblocksy = align(pf_get_nblocksy(pt->format, pt->height0), 8); +      tex->stride = power_of_two(util_format_get_stride(pt->format, pt->width0)); +      tex->total_nblocksy = align(util_format_get_nblocksy(pt->format, pt->height0), 8);        tex->hw_tiled = INTEL_TILE_X;     } else if (pt->width0 == 64 && pt->height0 == 64) { -      tex->stride = power_of_two(pf_get_stride(pt->format, pt->width0)); -      tex->total_nblocksy = align(pf_get_nblocksy(pt->format, pt->height0), 8); +      tex->stride = power_of_two(util_format_get_stride(pt->format, pt->width0)); +      tex->total_nblocksy = align(util_format_get_nblocksy(pt->format, pt->height0), 8);     } else {        return FALSE;     }     debug_printf("%s size: %d,%d,%d offset %d,%d (0x%x)\n", __FUNCTION__, -      pt->width0, pt->height0, pf_get_blocksize(pt->format), +      pt->width0, pt->height0, util_format_get_blocksize(pt->format),        tex->stride, tex->total_nblocksy, tex->stride * tex->total_nblocksy);     return TRUE; @@ -186,7 +187,7 @@ i915_display_target_layout(struct i915_texture *tex)  {     struct pipe_texture *pt = &tex->base; -   if (pt->last_level > 0 || pf_get_blocksize(pt->format) != 4) +   if (pt->last_level > 0 || util_format_get_blocksize(pt->format) != 4)        return FALSE;     /* fallback to normal textures for small textures */ @@ -199,12 +200,12 @@ i915_display_target_layout(struct i915_texture *tex)                                 1);     i915_miptree_set_image_offset(tex, 0, 0, 0, 0); -   tex->stride = power_of_two(pf_get_stride(pt->format, pt->width0)); -   tex->total_nblocksy = align(pf_get_nblocksy(pt->format, pt->height0), 8); +   tex->stride = power_of_two(util_format_get_stride(pt->format, pt->width0)); +   tex->total_nblocksy = align(util_format_get_nblocksy(pt->format, pt->height0), 8);     tex->hw_tiled = INTEL_TILE_X;     debug_printf("%s size: %d,%d,%d offset %d,%d (0x%x)\n", __FUNCTION__, -      pt->width0, pt->height0, pf_get_blocksize(pt->format), +      pt->width0, pt->height0, util_format_get_blocksize(pt->format),        tex->stride, tex->total_nblocksy, tex->stride * tex->total_nblocksy);     return TRUE; @@ -217,7 +218,7 @@ i915_miptree_layout_2d(struct i915_texture *tex)     unsigned level;     unsigned width = pt->width0;     unsigned height = pt->height0; -   unsigned nblocksy = pf_get_nblocksy(pt->format, pt->width0); +   unsigned nblocksy = util_format_get_nblocksy(pt->format, pt->width0);     /* used for scanouts that need special layouts */     if (pt->tex_usage & PIPE_TEXTURE_USAGE_PRIMARY) @@ -229,7 +230,7 @@ i915_miptree_layout_2d(struct i915_texture *tex)        if (i915_display_target_layout(tex))           return; -   tex->stride = align(pf_get_stride(pt->format, pt->width0), 4); +   tex->stride = align(util_format_get_stride(pt->format, pt->width0), 4);     tex->total_nblocksy = 0;     for (level = 0; level <= pt->last_level; level++) { @@ -242,7 +243,7 @@ i915_miptree_layout_2d(struct i915_texture *tex)        width = u_minify(width, 1);        height = u_minify(height, 1); -      nblocksy = pf_get_nblocksy(pt->format, height); +      nblocksy = util_format_get_nblocksy(pt->format, height);     }  } @@ -255,12 +256,12 @@ i915_miptree_layout_3d(struct i915_texture *tex)     unsigned width = pt->width0;     unsigned height = pt->height0;     unsigned depth = pt->depth0; -   unsigned nblocksy = pf_get_nblocksy(pt->format, pt->height0); +   unsigned nblocksy = util_format_get_nblocksy(pt->format, pt->height0);     unsigned stack_nblocksy = 0;     /* Calculate the size of a single slice.       */ -   tex->stride = align(pf_get_stride(pt->format, pt->width0), 4); +   tex->stride = align(util_format_get_stride(pt->format, pt->width0), 4);     /* XXX: hardware expects/requires 9 levels at minimum.      */ @@ -271,7 +272,7 @@ i915_miptree_layout_3d(struct i915_texture *tex)        width = u_minify(width, 1);        height = u_minify(height, 1); -      nblocksy = pf_get_nblocksy(pt->format, height); +      nblocksy = util_format_get_nblocksy(pt->format, height);     }     /* Fixup depth image_offsets:  @@ -296,14 +297,14 @@ i915_miptree_layout_cube(struct i915_texture *tex)  {     struct pipe_texture *pt = &tex->base;     unsigned width = pt->width0, height = pt->height0; -   const unsigned nblocks = pf_get_nblocksx(pt->format, pt->width0); +   const unsigned nblocks = util_format_get_nblocksx(pt->format, pt->width0);     unsigned level;     unsigned face;     assert(width == height); /* cubemap images are square */     /* double pitch for cube layouts */ -   tex->stride = align(nblocks * pf_get_blocksize(pt->format) * 2, 4); +   tex->stride = align(nblocks * util_format_get_blocksize(pt->format) * 2, 4);     tex->total_nblocksy = nblocks * 4;     for (level = 0; level <= pt->last_level; level++) { @@ -366,8 +367,8 @@ i945_miptree_layout_2d(struct i915_texture *tex)     unsigned y = 0;     unsigned width = pt->width0;     unsigned height = pt->height0; -   unsigned nblocksx = pf_get_nblocksx(pt->format, pt->width0); -   unsigned nblocksy = pf_get_nblocksy(pt->format, pt->height0); +   unsigned nblocksx = util_format_get_nblocksx(pt->format, pt->width0); +   unsigned nblocksy = util_format_get_nblocksy(pt->format, pt->height0);     /* used for scanouts that need special layouts */     if (tex->base.tex_usage & PIPE_TEXTURE_USAGE_PRIMARY) @@ -379,7 +380,7 @@ i945_miptree_layout_2d(struct i915_texture *tex)        if (i915_display_target_layout(tex))           return; -   tex->stride = align(pf_get_stride(pt->format, pt->width0), 4); +   tex->stride = align(util_format_get_stride(pt->format, pt->width0), 4);     /* May need to adjust pitch to accomodate the placement of      * the 2nd mipmap level.  This occurs when the alignment @@ -388,11 +389,11 @@ i945_miptree_layout_2d(struct i915_texture *tex)      */     if (pt->last_level > 0) {        unsigned mip1_nblocksx  -         = align(pf_get_nblocksx(pt->format, u_minify(width, 1)), align_x) -         + pf_get_nblocksx(pt->format, u_minify(width, 2)); +         = align(util_format_get_nblocksx(pt->format, u_minify(width, 1)), align_x) +         + util_format_get_nblocksx(pt->format, u_minify(width, 2));        if (mip1_nblocksx > nblocksx) -         tex->stride = mip1_nblocksx * pf_get_blocksize(pt->format); +         tex->stride = mip1_nblocksx * util_format_get_blocksize(pt->format);     }     /* Pitch must be a whole number of dwords @@ -422,8 +423,8 @@ i945_miptree_layout_2d(struct i915_texture *tex)        width  = u_minify(width, 1);        height = u_minify(height, 1); -      nblocksx = pf_get_nblocksx(pt->format, width); -      nblocksy = pf_get_nblocksy(pt->format, height); +      nblocksx = util_format_get_nblocksx(pt->format, width); +      nblocksy = util_format_get_nblocksy(pt->format, height);     }  } @@ -434,16 +435,16 @@ i945_miptree_layout_3d(struct i915_texture *tex)     unsigned width = pt->width0;     unsigned height = pt->height0;     unsigned depth = pt->depth0; -   unsigned nblocksy = pf_get_nblocksy(pt->format, pt->width0); +   unsigned nblocksy = util_format_get_nblocksy(pt->format, pt->width0);     unsigned pack_x_pitch, pack_x_nr;     unsigned pack_y_pitch;     unsigned level; -   tex->stride = align(pf_get_stride(pt->format, pt->width0), 4); +   tex->stride = align(util_format_get_stride(pt->format, pt->width0), 4);     tex->total_nblocksy = 0;     pack_y_pitch = MAX2(nblocksy, 2); -   pack_x_pitch = tex->stride / pf_get_blocksize(pt->format); +   pack_x_pitch = tex->stride / util_format_get_blocksize(pt->format);     pack_x_nr = 1;     for (level = 0; level <= pt->last_level; level++) { @@ -468,7 +469,7 @@ i945_miptree_layout_3d(struct i915_texture *tex)        if (pack_x_pitch > 4) {           pack_x_pitch >>= 1;           pack_x_nr <<= 1; -         assert(pack_x_pitch * pack_x_nr * pf_get_blocksize(pt->format) <= tex->stride); +         assert(pack_x_pitch * pack_x_nr * util_format_get_blocksize(pt->format) <= tex->stride);        }        if (pack_y_pitch > 2) { @@ -478,7 +479,7 @@ i945_miptree_layout_3d(struct i915_texture *tex)        width = u_minify(width, 1);        height = u_minify(height, 1);        depth = u_minify(depth, 1); -      nblocksy = pf_get_nblocksy(pt->format, height); +      nblocksy = util_format_get_nblocksy(pt->format, height);     }  } @@ -488,7 +489,7 @@ i945_miptree_layout_cube(struct i915_texture *tex)     struct pipe_texture *pt = &tex->base;     unsigned level; -   const unsigned nblocks = pf_get_nblocksx(pt->format, pt->width0); +   const unsigned nblocks = util_format_get_nblocksx(pt->format, pt->width0);     unsigned face;     unsigned width = pt->width0;     unsigned height = pt->height0; @@ -508,9 +509,9 @@ i945_miptree_layout_cube(struct i915_texture *tex)      * or the final row of 4x4, 2x2 and 1x1 faces below this.      */     if (nblocks > 32) -      tex->stride = align(nblocks * pf_get_blocksize(pt->format) * 2, 4); +      tex->stride = align(nblocks * util_format_get_blocksize(pt->format) * 2, 4);     else -      tex->stride = 14 * 8 * pf_get_blocksize(pt->format); +      tex->stride = 14 * 8 * util_format_get_blocksize(pt->format);     tex->total_nblocksy = nblocks * 4; @@ -840,8 +841,8 @@ i915_transfer_map(struct pipe_screen *screen,        return NULL;     return map + i915_transfer(transfer)->offset + -      transfer->y / pf_get_blockheight(format) * transfer->stride + -      transfer->x / pf_get_blockwidth(format) * pf_get_blocksize(format); +      transfer->y / util_format_get_blockheight(format) * transfer->stride + +      transfer->x / util_format_get_blockwidth(format) * util_format_get_blocksize(format);  }  static void diff --git a/src/gallium/drivers/llvmpipe/lp_setup.c b/src/gallium/drivers/llvmpipe/lp_setup.c index b4aabd4d7c..b18f17c0cd 100644 --- a/src/gallium/drivers/llvmpipe/lp_setup.c +++ b/src/gallium/drivers/llvmpipe/lp_setup.c @@ -41,6 +41,7 @@  #include "draw/draw_vertex.h"  #include "pipe/p_shader_tokens.h"  #include "pipe/p_thread.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h"  #include "lp_bld_debug.h" @@ -166,7 +167,7 @@ shade_quads(struct llvmpipe_context *llvmpipe,        assert((y % 2) == 0);        depth = llvmpipe->zsbuf_map +                y*llvmpipe->zsbuf_transfer->stride + -              2*x*pf_get_blocksize(llvmpipe->zsbuf_transfer->texture->format); +              2*x*util_format_get_blocksize(llvmpipe->zsbuf_transfer->texture->format);     }     else        depth = NULL; diff --git a/src/gallium/drivers/llvmpipe/lp_state_surface.c b/src/gallium/drivers/llvmpipe/lp_state_surface.c index c06ce8b75c..ba970cac98 100644 --- a/src/gallium/drivers/llvmpipe/lp_state_surface.c +++ b/src/gallium/drivers/llvmpipe/lp_state_surface.c @@ -35,6 +35,8 @@  #include "draw/draw_context.h" +#include "util/u_format.h" +  /**   * XXX this might get moved someday @@ -88,8 +90,9 @@ llvmpipe_set_framebuffer_state(struct pipe_context *pipe,        if (lp->framebuffer.zsbuf) {           int depth_bits;           double mrd; -         depth_bits = pf_get_component_bits(lp->framebuffer.zsbuf->format, -                                            PIPE_FORMAT_COMP_Z); +         depth_bits = util_format_get_component_bits(lp->framebuffer.zsbuf->format, +                                                     UTIL_FORMAT_COLORSPACE_ZS, +                                                     0);           if (depth_bits > 16) {              mrd = 0.0000001;           } diff --git a/src/gallium/drivers/llvmpipe/lp_texture.c b/src/gallium/drivers/llvmpipe/lp_texture.c index f099f903bd..2c135029ea 100644 --- a/src/gallium/drivers/llvmpipe/lp_texture.c +++ b/src/gallium/drivers/llvmpipe/lp_texture.c @@ -34,6 +34,8 @@  #include "pipe/p_defines.h"  #include "pipe/p_inlines.h"  #include "pipe/internal/p_winsys_screen.h" + +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h" @@ -67,10 +69,10 @@ llvmpipe_texture_layout(struct llvmpipe_screen *screen,        /* Allocate storage for whole quads. This is particularly important         * for depth surfaces, which are currently stored in a swizzled format. */ -      nblocksx = pf_get_nblocksx(pt->format, align(width, 2)); -      nblocksy = pf_get_nblocksy(pt->format, align(height, 2)); +      nblocksx = util_format_get_nblocksx(pt->format, align(width, 2)); +      nblocksy = util_format_get_nblocksy(pt->format, align(height, 2)); -      lpt->stride[level] = align(nblocksx * pf_get_blocksize(pt->format), 16); +      lpt->stride[level] = align(nblocksx * util_format_get_blocksize(pt->format), 16);        lpt->level_offset[level] = buffer_size; @@ -249,11 +251,11 @@ llvmpipe_get_tex_surface(struct pipe_screen *screen,        */        if (pt->target == PIPE_TEXTURE_CUBE) {           unsigned tex_height = ps->height; -         ps->offset += face * pf_get_nblocksy(pt->format, tex_height) * lpt->stride[level]; +         ps->offset += face * util_format_get_nblocksy(pt->format, tex_height) * lpt->stride[level];        }        else if (pt->target == PIPE_TEXTURE_3D) {           unsigned tex_height = ps->height; -         ps->offset += zslice * pf_get_nblocksy(pt->format, tex_height) * lpt->stride[level]; +         ps->offset += zslice * util_format_get_nblocksy(pt->format, tex_height) * lpt->stride[level];        }        else {           assert(face == 0); @@ -312,11 +314,11 @@ llvmpipe_get_tex_transfer(struct pipe_screen *screen,        */        if (texture->target == PIPE_TEXTURE_CUBE) {           unsigned tex_height = u_minify(texture->height0, level); -         lpt->offset += face *  pf_get_nblocksy(texture->format, tex_height) * pt->stride; +         lpt->offset += face *  util_format_get_nblocksy(texture->format, tex_height) * pt->stride;        }        else if (texture->target == PIPE_TEXTURE_3D) {           unsigned tex_height = u_minify(texture->height0, level); -         lpt->offset += zslice * pf_get_nblocksy(texture->format, tex_height) * pt->stride; +         lpt->offset += zslice * util_format_get_nblocksy(texture->format, tex_height) * pt->stride;        }        else {           assert(face == 0); @@ -377,8 +379,8 @@ llvmpipe_transfer_map( struct pipe_screen *_screen,     }     xfer_map = map + llvmpipe_transfer(transfer)->offset + -      transfer->y / pf_get_blockheight(format) * transfer->stride + -      transfer->x / pf_get_blockwidth(format) * pf_get_blocksize(format); +      transfer->y / util_format_get_blockheight(format) * transfer->stride + +      transfer->x / util_format_get_blockwidth(format) * util_format_get_blocksize(format);     /*printf("map = %p  xfer map = %p\n", map, xfer_map);*/     return xfer_map;  } diff --git a/src/gallium/drivers/nv04/nv04_surface_2d.c b/src/gallium/drivers/nv04/nv04_surface_2d.c index 3020806c5d..12df7fd199 100644 --- a/src/gallium/drivers/nv04/nv04_surface_2d.c +++ b/src/gallium/drivers/nv04/nv04_surface_2d.c @@ -1,5 +1,6 @@  #include "pipe/p_context.h"  #include "pipe/p_format.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h" @@ -158,10 +159,10 @@ nv04_surface_copy_swizzle(struct nv04_surface_2d *ctx,  	    sub_w = MIN2(sub_w, w - x);  	    /* Must be 64-byte aligned */ -	    assert(!((dst->offset + nv04_swizzle_bits(dx+x, dy+y) * pf_get_blocksize(dst->texture->format)) & 63)); +	    assert(!((dst->offset + nv04_swizzle_bits(dx+x, dy+y) * util_format_get_blocksize(dst->texture->format)) & 63));  	    BEGIN_RING(chan, swzsurf, NV04_SWIZZLED_SURFACE_OFFSET, 1); -	    OUT_RELOCl(chan, dst_bo, dst->offset + nv04_swizzle_bits(dx+x, dy+y) * pf_get_blocksize(dst->texture->format), +	    OUT_RELOCl(chan, dst_bo, dst->offset + nv04_swizzle_bits(dx+x, dy+y) * util_format_get_blocksize(dst->texture->format),                               NOUVEAU_BO_GART | NOUVEAU_BO_VRAM | NOUVEAU_BO_WR);  	    BEGIN_RING(chan, sifm, NV04_SCALED_IMAGE_FROM_MEMORY_COLOR_CONVERSION, 9); @@ -180,7 +181,7 @@ nv04_surface_copy_swizzle(struct nv04_surface_2d *ctx,  	    OUT_RING  (chan, src_pitch |  			     NV04_SCALED_IMAGE_FROM_MEMORY_FORMAT_ORIGIN_CENTER |  			     NV04_SCALED_IMAGE_FROM_MEMORY_FORMAT_FILTER_POINT_SAMPLE); -	    OUT_RELOCl(chan, src_bo, src->offset + (sy+y) * src_pitch + (sx+x) * pf_get_blocksize(src->texture->format), +	    OUT_RELOCl(chan, src_bo, src->offset + (sy+y) * src_pitch + (sx+x) * util_format_get_blocksize(src->texture->format),                               NOUVEAU_BO_GART | NOUVEAU_BO_VRAM | NOUVEAU_BO_RD);  	    OUT_RING  (chan, 0);  	  } @@ -201,9 +202,9 @@ nv04_surface_copy_m2mf(struct nv04_surface_2d *ctx,  	unsigned src_pitch = ((struct nv04_surface *)src)->pitch;  	unsigned dst_pitch = ((struct nv04_surface *)dst)->pitch;  	unsigned dst_offset = dst->offset + dy * dst_pitch + -	                      dx * pf_get_blocksize(dst->texture->format); +	                      dx * util_format_get_blocksize(dst->texture->format);  	unsigned src_offset = src->offset + sy * src_pitch + -	                      sx * pf_get_blocksize(src->texture->format); +	                      sx * util_format_get_blocksize(src->texture->format);  	MARK_RING (chan, 3 + ((h / 2047) + 1) * 9, 2 + ((h / 2047) + 1) * 2);  	BEGIN_RING(chan, m2mf, NV04_MEMORY_TO_MEMORY_FORMAT_DMA_BUFFER_IN, 2); @@ -222,7 +223,7 @@ nv04_surface_copy_m2mf(struct nv04_surface_2d *ctx,  			   NOUVEAU_BO_VRAM | NOUVEAU_BO_GART | NOUVEAU_BO_WR);  		OUT_RING  (chan, src_pitch);  		OUT_RING  (chan, dst_pitch); -		OUT_RING  (chan, w * pf_get_blocksize(src->texture->format)); +		OUT_RING  (chan, w * util_format_get_blocksize(src->texture->format));  		OUT_RING  (chan, count);  		OUT_RING  (chan, 0x0101);  		OUT_RING  (chan, 0); diff --git a/src/gallium/drivers/nv04/nv04_transfer.c b/src/gallium/drivers/nv04/nv04_transfer.c index d66d6c6346..8446073ae8 100644 --- a/src/gallium/drivers/nv04/nv04_transfer.c +++ b/src/gallium/drivers/nv04/nv04_transfer.c @@ -1,6 +1,7 @@  #include <pipe/p_state.h>  #include <pipe/p_defines.h>  #include <pipe/p_inlines.h> +#include <util/u_format.h>  #include <util/u_memory.h>  #include <util/u_math.h>  #include <nouveau/nouveau_winsys.h> @@ -151,7 +152,7 @@ nv04_transfer_map(struct pipe_screen *pscreen, struct pipe_transfer *ptx)  	                            pipe_transfer_buffer_flags(ptx));  	return map + ns->base.offset + -	       ptx->y * ns->pitch + ptx->x * pf_get_blocksize(ptx->texture->format); +	       ptx->y * ns->pitch + ptx->x * util_format_get_blocksize(ptx->texture->format);  }  static void diff --git a/src/gallium/drivers/nv10/nv10_miptree.c b/src/gallium/drivers/nv10/nv10_miptree.c index 6a52b6af36..908482ad85 100644 --- a/src/gallium/drivers/nv10/nv10_miptree.c +++ b/src/gallium/drivers/nv10/nv10_miptree.c @@ -1,6 +1,7 @@  #include "pipe/p_state.h"  #include "pipe/p_defines.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "nv10_context.h" @@ -23,9 +24,9 @@ nv10_miptree_layout(struct nv10_miptree *nv10mt)  	for (l = 0; l <= pt->last_level; l++) {  		if (swizzled) -			nv10mt->level[l].pitch = pf_get_stride(pt->format, width); +			nv10mt->level[l].pitch = util_format_get_stride(pt->format, width);  		else -			nv10mt->level[l].pitch = pf_get_stride(pt->format, pt->width0); +			nv10mt->level[l].pitch = util_format_get_stride(pt->format, pt->width0);  		nv10mt->level[l].pitch = (nv10mt->level[l].pitch + 63) & ~63;  		nv10mt->level[l].image_offset = diff --git a/src/gallium/drivers/nv10/nv10_transfer.c b/src/gallium/drivers/nv10/nv10_transfer.c index 06bb513417..c664973e90 100644 --- a/src/gallium/drivers/nv10/nv10_transfer.c +++ b/src/gallium/drivers/nv10/nv10_transfer.c @@ -1,6 +1,7 @@  #include <pipe/p_state.h>  #include <pipe/p_defines.h>  #include <pipe/p_inlines.h> +#include <util/u_format.h>  #include <util/u_memory.h>  #include <util/u_math.h>  #include <nouveau/nouveau_winsys.h> @@ -151,7 +152,7 @@ nv10_transfer_map(struct pipe_screen *pscreen, struct pipe_transfer *ptx)  	                            pipe_transfer_buffer_flags(ptx));  	return map + ns->base.offset + -	       ptx->y * ns->pitch + ptx->x * pf_get_blocksize(ptx->texture->format); +	       ptx->y * ns->pitch + ptx->x * util_format_get_blocksize(ptx->texture->format);  }  static void diff --git a/src/gallium/drivers/nv20/nv20_miptree.c b/src/gallium/drivers/nv20/nv20_miptree.c index e2e01bd849..d1291a92e0 100644 --- a/src/gallium/drivers/nv20/nv20_miptree.c +++ b/src/gallium/drivers/nv20/nv20_miptree.c @@ -1,6 +1,7 @@  #include "pipe/p_state.h"  #include "pipe/p_defines.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "nv20_context.h" @@ -27,9 +28,9 @@ nv20_miptree_layout(struct nv20_miptree *nv20mt)  	for (l = 0; l <= pt->last_level; l++) {  		if (wide_pitch && (pt->tex_usage & NOUVEAU_TEXTURE_USAGE_LINEAR)) -			nv20mt->level[l].pitch = align(pf_get_stride(pt->format, pt->width0), 64); +			nv20mt->level[l].pitch = align(util_format_get_stride(pt->format, pt->width0), 64);  		else -			nv20mt->level[l].pitch = pf_get_stride(pt->format, width); +			nv20mt->level[l].pitch = util_format_get_stride(pt->format, width);  		nv20mt->level[l].image_offset =  			CALLOC(nr_faces, sizeof(unsigned)); diff --git a/src/gallium/drivers/nv20/nv20_transfer.c b/src/gallium/drivers/nv20/nv20_transfer.c index 26a73c5143..69b79c809f 100644 --- a/src/gallium/drivers/nv20/nv20_transfer.c +++ b/src/gallium/drivers/nv20/nv20_transfer.c @@ -1,6 +1,7 @@  #include <pipe/p_state.h>  #include <pipe/p_defines.h>  #include <pipe/p_inlines.h> +#include <util/u_format.h>  #include <util/u_memory.h>  #include <util/u_math.h>  #include <nouveau/nouveau_winsys.h> @@ -151,7 +152,7 @@ nv20_transfer_map(struct pipe_screen *pscreen, struct pipe_transfer *ptx)  	                            pipe_transfer_buffer_flags(ptx));  	return map + ns->base.offset + -	       ptx->y * ns->pitch + ptx->x * pf_get_blocksize(ptx->texture->format); +	       ptx->y * ns->pitch + ptx->x * util_format_get_blocksize(ptx->texture->format);  }  static void diff --git a/src/gallium/drivers/nv30/nv30_miptree.c b/src/gallium/drivers/nv30/nv30_miptree.c index 920fe64c32..ce95d9700f 100644 --- a/src/gallium/drivers/nv30/nv30_miptree.c +++ b/src/gallium/drivers/nv30/nv30_miptree.c @@ -1,6 +1,7 @@  #include "pipe/p_state.h"  #include "pipe/p_defines.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "nv30_context.h" @@ -29,9 +30,9 @@ nv30_miptree_layout(struct nv30_miptree *nv30mt)  	for (l = 0; l <= pt->last_level; l++) {  		if (wide_pitch && (pt->tex_usage & NOUVEAU_TEXTURE_USAGE_LINEAR)) -			nv30mt->level[l].pitch = align(pf_get_stride(pt->format, pt->width0), 64); +			nv30mt->level[l].pitch = align(util_format_get_stride(pt->format, pt->width0), 64);  		else -			nv30mt->level[l].pitch = pf_get_stride(pt->format, width); +			nv30mt->level[l].pitch = util_format_get_stride(pt->format, width);  		nv30mt->level[l].image_offset =  			CALLOC(nr_faces, sizeof(unsigned)); diff --git a/src/gallium/drivers/nv30/nv30_transfer.c b/src/gallium/drivers/nv30/nv30_transfer.c index e29bfbd3ef..2255a02cae 100644 --- a/src/gallium/drivers/nv30/nv30_transfer.c +++ b/src/gallium/drivers/nv30/nv30_transfer.c @@ -1,6 +1,7 @@  #include <pipe/p_state.h>  #include <pipe/p_defines.h>  #include <pipe/p_inlines.h> +#include <util/u_format.h>  #include <util/u_memory.h>  #include <util/u_math.h>  #include <nouveau/nouveau_winsys.h> @@ -151,7 +152,7 @@ nv30_transfer_map(struct pipe_screen *pscreen, struct pipe_transfer *ptx)  	                            pipe_transfer_buffer_flags(ptx));  	return map + ns->base.offset + -	       ptx->y * ns->pitch + ptx->x * pf_get_blocksize(ptx->texture->format); +	       ptx->y * ns->pitch + ptx->x * util_format_get_blocksize(ptx->texture->format);  }  static void diff --git a/src/gallium/drivers/nv40/nv40_miptree.c b/src/gallium/drivers/nv40/nv40_miptree.c index 89ddf373e9..b974e68a07 100644 --- a/src/gallium/drivers/nv40/nv40_miptree.c +++ b/src/gallium/drivers/nv40/nv40_miptree.c @@ -1,6 +1,7 @@  #include "pipe/p_state.h"  #include "pipe/p_defines.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "nv40_context.h" @@ -31,9 +32,9 @@ nv40_miptree_layout(struct nv40_miptree *mt)  	for (l = 0; l <= pt->last_level; l++) {  		if (wide_pitch && (pt->tex_usage & NOUVEAU_TEXTURE_USAGE_LINEAR)) -			mt->level[l].pitch = align(pf_get_stride(pt->format, pt->width0), 64); +			mt->level[l].pitch = align(util_format_get_stride(pt->format, pt->width0), 64);  		else -			mt->level[l].pitch = pf_get_stride(pt->format, width); +			mt->level[l].pitch = util_format_get_stride(pt->format, width);  		mt->level[l].image_offset =  			CALLOC(nr_faces, sizeof(unsigned)); diff --git a/src/gallium/drivers/nv40/nv40_transfer.c b/src/gallium/drivers/nv40/nv40_transfer.c index ed5be1cf87..b084a38b48 100644 --- a/src/gallium/drivers/nv40/nv40_transfer.c +++ b/src/gallium/drivers/nv40/nv40_transfer.c @@ -1,6 +1,7 @@  #include <pipe/p_state.h>  #include <pipe/p_defines.h>  #include <pipe/p_inlines.h> +#include <util/u_format.h>  #include <util/u_memory.h>  #include <util/u_math.h>  #include <nouveau/nouveau_winsys.h> @@ -151,7 +152,7 @@ nv40_transfer_map(struct pipe_screen *pscreen, struct pipe_transfer *ptx)  	                            pipe_transfer_buffer_flags(ptx));  	return map + ns->base.offset + -	       ptx->y * ns->pitch + ptx->x * pf_get_blocksize(ptx->texture->format); +	       ptx->y * ns->pitch + ptx->x * util_format_get_blocksize(ptx->texture->format);  }  static void diff --git a/src/gallium/drivers/nv50/nv50_miptree.c b/src/gallium/drivers/nv50/nv50_miptree.c index 9e083b662d..3f1edf0a13 100644 --- a/src/gallium/drivers/nv50/nv50_miptree.c +++ b/src/gallium/drivers/nv50/nv50_miptree.c @@ -23,6 +23,7 @@  #include "pipe/p_state.h"  #include "pipe/p_defines.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "nv50_context.h" @@ -105,10 +106,10 @@ nv50_miptree_create(struct pipe_screen *pscreen, const struct pipe_texture *tmp)  	for (l = 0; l <= pt->last_level; l++) {  		struct nv50_miptree_level *lvl = &mt->level[l]; -		unsigned nblocksy = pf_get_nblocksy(pt->format, height); +		unsigned nblocksy = util_format_get_nblocksy(pt->format, height);  		lvl->image_offset = CALLOC(mt->image_nr, sizeof(int)); -		lvl->pitch = align(pf_get_stride(pt->format, width), 64); +		lvl->pitch = align(util_format_get_stride(pt->format, width), 64);  		lvl->tile_mode = get_tile_mode(nblocksy, depth);  		width = u_minify(width, 1); @@ -130,7 +131,7 @@ nv50_miptree_create(struct pipe_screen *pscreen, const struct pipe_texture *tmp)  			unsigned tile_d = get_tile_depth(lvl->tile_mode);  			size  = lvl->pitch; -			size *= align(pf_get_nblocksy(pt->format, u_minify(pt->height0, l)), tile_h); +			size *= align(util_format_get_nblocksy(pt->format, u_minify(pt->height0, l)), tile_h);  			size *= align(u_minify(pt->depth0, l), tile_d);  			lvl->image_offset[i] = mt->total_size; @@ -222,7 +223,7 @@ nv50_miptree_surface_new(struct pipe_screen *pscreen, struct pipe_texture *pt,  	ps->offset = lvl->image_offset[img];  	if (pt->target == PIPE_TEXTURE_3D) { -		unsigned nb_h = pf_get_nblocksy(pt->format, ps->height); +		unsigned nb_h = util_format_get_nblocksy(pt->format, ps->height);  		ps->offset += get_zslice_offset(lvl->tile_mode, zslice,  						lvl->pitch, nb_h);  	} diff --git a/src/gallium/drivers/nv50/nv50_tex.c b/src/gallium/drivers/nv50/nv50_tex.c index 120aa6f362..c4ca096d6a 100644 --- a/src/gallium/drivers/nv50/nv50_tex.c +++ b/src/gallium/drivers/nv50/nv50_tex.c @@ -25,6 +25,8 @@  #include "nouveau/nouveau_stateobj.h" +#include "util/u_format.h" +  #define _MIXED(pf, t0, t1, t2, t3, cr, cg, cb, ca, f)		\  {                                                       	\  	PIPE_FORMAT_##pf,					\ @@ -90,6 +92,7 @@ nv50_tex_construct(struct nv50_context *nv50, struct nouveau_stateobj *so,  {  	unsigned i;  	uint32_t mode; +	const struct util_format_description *desc;  	for (i = 0; i < NV50_TEX_FORMAT_LIST_SIZE; i++)  		if (nv50_tex_format_list[i].pf == mt->base.base.format) @@ -107,7 +110,10 @@ nv50_tex_construct(struct nv50_context *nv50, struct nouveau_stateobj *so,  	mode |= ((mt->base.bo->tile_mode & 0x0f) << 22) |  		((mt->base.bo->tile_mode & 0xf0) << 21); -	if (pf_type(mt->base.base.format) == PIPE_FORMAT_TYPE_SRGB) +	desc = util_format_description(mt->base.base.format); +	assert(desc); + +	if (desc->colorspace == UTIL_FORMAT_COLORSPACE_SRGB)  		mode |= 0x0400;  	switch (mt->base.base.target) { diff --git a/src/gallium/drivers/nv50/nv50_transfer.c b/src/gallium/drivers/nv50/nv50_transfer.c index 6240a0c757..4d9afa6fed 100644 --- a/src/gallium/drivers/nv50/nv50_transfer.c +++ b/src/gallium/drivers/nv50/nv50_transfer.c @@ -1,6 +1,7 @@  #include "pipe/p_context.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "nv50_context.h" @@ -140,11 +141,11 @@ nv50_transfer_new(struct pipe_screen *pscreen, struct pipe_texture *pt,  		return NULL;  	pipe_texture_reference(&tx->base.texture, pt); -	tx->nblocksx = pf_get_nblocksx(pt->format, u_minify(pt->width0, level)); -	tx->nblocksy = pf_get_nblocksy(pt->format, u_minify(pt->height0, level)); +	tx->nblocksx = util_format_get_nblocksx(pt->format, u_minify(pt->width0, level)); +	tx->nblocksy = util_format_get_nblocksy(pt->format, u_minify(pt->height0, level));  	tx->base.width = w;  	tx->base.height = h; -	tx->base.stride = tx->nblocksx * pf_get_blocksize(pt->format); +	tx->base.stride = tx->nblocksx * util_format_get_blocksize(pt->format);  	tx->base.usage = usage;  	tx->level_pitch = lvl->pitch; @@ -154,8 +155,8 @@ nv50_transfer_new(struct pipe_screen *pscreen, struct pipe_texture *pt,  	tx->level_offset = lvl->image_offset[image];  	tx->level_tiling = lvl->tile_mode;  	tx->level_z = zslice; -	tx->level_x = pf_get_nblocksx(pt->format, x); -	tx->level_y = pf_get_nblocksy(pt->format, y); +	tx->level_x = util_format_get_nblocksx(pt->format, x); +	tx->level_y = util_format_get_nblocksy(pt->format, y);  	ret = nouveau_bo_new(dev, NOUVEAU_BO_GART | NOUVEAU_BO_MAP, 0,  			     tx->nblocksy * tx->base.stride, &tx->bo);  	if (ret) { @@ -164,8 +165,8 @@ nv50_transfer_new(struct pipe_screen *pscreen, struct pipe_texture *pt,  	}  	if (usage & PIPE_TRANSFER_READ) { -		nx = pf_get_nblocksx(pt->format, tx->base.width); -		ny = pf_get_nblocksy(pt->format, tx->base.height); +		nx = util_format_get_nblocksx(pt->format, tx->base.width); +		ny = util_format_get_nblocksy(pt->format, tx->base.height);  		nv50_transfer_rect_m2mf(pscreen, mt->base.bo, tx->level_offset,  					tx->level_pitch, tx->level_tiling, @@ -176,7 +177,7 @@ nv50_transfer_new(struct pipe_screen *pscreen, struct pipe_texture *pt,  					tx->base.stride, tx->bo->tile_mode,  					0, 0, 0,  					tx->nblocksx, tx->nblocksy, 1, -					pf_get_blocksize(pt->format), nx, ny, +					util_format_get_blocksize(pt->format), nx, ny,  					NOUVEAU_BO_VRAM | NOUVEAU_BO_GART,  					NOUVEAU_BO_GART);  	} @@ -191,8 +192,8 @@ nv50_transfer_del(struct pipe_transfer *ptx)  	struct nv50_miptree *mt = nv50_miptree(ptx->texture);  	struct pipe_texture *pt = ptx->texture; -	unsigned nx = pf_get_nblocksx(pt->format, tx->base.width); -	unsigned ny = pf_get_nblocksy(pt->format, tx->base.height); +	unsigned nx = util_format_get_nblocksx(pt->format, tx->base.width); +	unsigned ny = util_format_get_nblocksy(pt->format, tx->base.height);  	if (ptx->usage & PIPE_TRANSFER_WRITE) {  		struct pipe_screen *pscreen = pt->screen; @@ -206,7 +207,7 @@ nv50_transfer_del(struct pipe_transfer *ptx)  					tx->level_x, tx->level_y, tx->level_z,  					tx->nblocksx, tx->nblocksy,  					tx->level_depth, -					pf_get_blocksize(pt->format), nx, ny, +					util_format_get_blocksize(pt->format), nx, ny,  					NOUVEAU_BO_GART, NOUVEAU_BO_VRAM |  					NOUVEAU_BO_GART);  	} diff --git a/src/gallium/drivers/nv50/nv50_vbo.c b/src/gallium/drivers/nv50/nv50_vbo.c index db54380241..f7fa0659e8 100644 --- a/src/gallium/drivers/nv50/nv50_vbo.c +++ b/src/gallium/drivers/nv50/nv50_vbo.c @@ -24,6 +24,8 @@  #include "pipe/p_state.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h" +  #include "nv50_context.h"  static boolean @@ -62,18 +64,25 @@ nv50_prim(unsigned mode)  }  static INLINE uint32_t -nv50_vbo_type_to_hw(unsigned type) +nv50_vbo_type_to_hw(enum pipe_format format)  { -	switch (type) { -	case PIPE_FORMAT_TYPE_FLOAT: +	const struct util_format_description *desc; + +	desc = util_format_description(format); +	assert(desc); + +	switch (desc->channel[0].type) { +	case UTIL_FORMAT_TYPE_FLOAT:  		return NV50TCL_VERTEX_ARRAY_ATTRIB_TYPE_FLOAT; -	case PIPE_FORMAT_TYPE_UNORM: -		return NV50TCL_VERTEX_ARRAY_ATTRIB_TYPE_UNORM; -	case PIPE_FORMAT_TYPE_SNORM: -		return NV50TCL_VERTEX_ARRAY_ATTRIB_TYPE_SNORM; -	case PIPE_FORMAT_TYPE_USCALED: +	case UTIL_FORMAT_TYPE_UNSIGNED: +		if (desc->channel[0].normalized) { +			return NV50TCL_VERTEX_ARRAY_ATTRIB_TYPE_UNORM; +		}  		return NV50TCL_VERTEX_ARRAY_ATTRIB_TYPE_USCALED; -	case PIPE_FORMAT_TYPE_SSCALED: +	case UTIL_FORMAT_TYPE_SIGNED: +		if (desc->channel[0].normalized) { +			return NV50TCL_VERTEX_ARRAY_ATTRIB_TYPE_SNORM; +		}  		return NV50TCL_VERTEX_ARRAY_ATTRIB_TYPE_SSCALED;  	/*  	case PIPE_FORMAT_TYPE_UINT: @@ -120,9 +129,15 @@ nv50_vbo_vtxelt_to_hw(struct pipe_vertex_element *ve)  {  	uint32_t hw_type, hw_size;  	enum pipe_format pf = ve->src_format; -	unsigned size = pf_size_x(pf) << pf_exp2(pf); +	const struct util_format_description *desc; +	unsigned size; -	hw_type = nv50_vbo_type_to_hw(pf_type(pf)); +	desc = util_format_description(pf); +	assert(desc); + +	size = util_format_get_component_bits(pf, UTIL_FORMAT_COLORSPACE_RGB, 0); + +	hw_type = nv50_vbo_type_to_hw(pf);  	hw_size = nv50_vbo_size_to_hw(size, ve->nr_components);  	if (!hw_type || !hw_size) { @@ -131,7 +146,7 @@ nv50_vbo_vtxelt_to_hw(struct pipe_vertex_element *ve)  		return 0x24e80000;  	} -	if (pf_swizzle_x(pf) == 2) /* BGRA */ +	if (desc->swizzle[0] == UTIL_FORMAT_SWIZZLE_Z) /* BGRA */  		hw_size |= (1 << 31); /* no real swizzle bits :-( */  	return (hw_type | hw_size); @@ -319,9 +334,13 @@ nv50_vbo_static_attrib(struct nv50_context *nv50, unsigned attrib,  	float *v;  	int ret;  	enum pipe_format pf = ve->src_format; +	const struct util_format_description *desc; -	if ((pf_type(pf) != PIPE_FORMAT_TYPE_FLOAT) || -	    (pf_size_x(pf) << pf_exp2(pf)) != 32) +	desc = util_format_description(pf); +	assert(desc); + +	if ((desc->channel[0].type != UTIL_FORMAT_TYPE_FLOAT) || +	    util_format_get_component_bits(pf, UTIL_FORMAT_COLORSPACE_RGB, 0) != 32)  		return FALSE;  	ret = nouveau_bo_map(bo, NOUVEAU_BO_RD); @@ -609,7 +628,8 @@ emit_prepare(struct nv50_context *nv50, struct nv50_vbo_emitctx *emit,  	for (i = 0; i < nv50->vtxelt_nr; ++i) {  		struct pipe_vertex_element *ve;  		struct pipe_vertex_buffer *vb; -		unsigned n, type, size; +		unsigned n, size; +		const struct util_format_description *desc;  		ve = &nv50->vtxelt[i];  		vb = &nv50->vtxbuf[ve->vertex_buffer_index]; @@ -621,8 +641,10 @@ emit_prepare(struct nv50_context *nv50, struct nv50_vbo_emitctx *emit,  		emit->map[n] = nouveau_bo(vb->buffer)->map +  			(start * vb->stride + ve->src_offset); -		type = pf_type(ve->src_format); -		size = pf_size_x(ve->src_format) << pf_exp2(ve->src_format); +		desc = util_format_description(ve->src_format); +		assert(desc); + +		size = util_format_get_component_bits(ve->src_format, UTIL_FORMAT_COLORSPACE_RGB, 0);  		assert(ve->nr_components > 0 && ve->nr_components <= 4); diff --git a/src/gallium/drivers/r300/r300_emit.c b/src/gallium/drivers/r300/r300_emit.c index 55c8aa07bd..d7b6511d6d 100644 --- a/src/gallium/drivers/r300/r300_emit.c +++ b/src/gallium/drivers/r300/r300_emit.c @@ -23,6 +23,7 @@  /* r300_emit: Functions for emitting state. */ +#include "util/u_format.h"  #include "util/u_math.h"  #include "r300_context.h" @@ -656,7 +657,7 @@ static boolean r300_validate_aos(struct r300_context *r300)      /* Check if formats and strides are aligned to the size of DWORD. */      for (i = 0; i < r300->vertex_element_count; i++) {          if (vbuf[velem[i].vertex_buffer_index].stride % 4 != 0 || -            pf_get_blocksize(velem[i].src_format) % 4 != 0) { +            util_format_get_blocksize(velem[i].src_format) % 4 != 0) {              return FALSE;          }      } @@ -685,8 +686,8 @@ void r300_emit_aos(struct r300_context* r300, unsigned offset)      for (i = 0; i < aos_count - 1; i += 2) {          vb1 = &vbuf[velem[i].vertex_buffer_index];          vb2 = &vbuf[velem[i+1].vertex_buffer_index]; -        size1 = pf_get_blocksize(velem[i].src_format); -        size2 = pf_get_blocksize(velem[i+1].src_format); +        size1 = util_format_get_blocksize(velem[i].src_format); +        size2 = util_format_get_blocksize(velem[i+1].src_format);          OUT_CS(R300_VBPNTR_SIZE0(size1) | R300_VBPNTR_STRIDE0(vb1->stride) |                 R300_VBPNTR_SIZE1(size2) | R300_VBPNTR_STRIDE1(vb2->stride)); @@ -696,7 +697,7 @@ void r300_emit_aos(struct r300_context* r300, unsigned offset)      if (aos_count & 1) {          vb1 = &vbuf[velem[i].vertex_buffer_index]; -        size1 = pf_get_blocksize(velem[i].src_format); +        size1 = util_format_get_blocksize(velem[i].src_format);          OUT_CS(R300_VBPNTR_SIZE0(size1) | R300_VBPNTR_STRIDE0(vb1->stride));          OUT_CS(vb1->buffer_offset + velem[i].src_offset + offset * vb1->stride); diff --git a/src/gallium/drivers/r300/r300_screen.c b/src/gallium/drivers/r300/r300_screen.c index feb571a23d..a7ef3dbcc2 100644 --- a/src/gallium/drivers/r300/r300_screen.c +++ b/src/gallium/drivers/r300/r300_screen.c @@ -21,6 +21,7 @@   * USE OR OTHER DEALINGS IN THE SOFTWARE. */  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_memory.h"  #include "util/u_simple_screen.h" @@ -357,8 +358,8 @@ static void* r300_transfer_map(struct pipe_screen* screen,      }      return map + r300_transfer(transfer)->offset + -        transfer->y / pf_get_blockheight(format) * transfer->stride + -        transfer->x / pf_get_blockwidth(format) * pf_get_blocksize(format); +        transfer->y / util_format_get_blockheight(format) * transfer->stride + +        transfer->x / util_format_get_blockwidth(format) * util_format_get_blocksize(format);  }  static void r300_transfer_unmap(struct pipe_screen* screen, diff --git a/src/gallium/drivers/r300/r300_state_inlines.h b/src/gallium/drivers/r300/r300_state_inlines.h index e6c1cb54da..dbe42edd91 100644 --- a/src/gallium/drivers/r300/r300_state_inlines.h +++ b/src/gallium/drivers/r300/r300_state_inlines.h @@ -28,6 +28,8 @@  #include "pipe/p_format.h" +#include "util/u_format.h" +  #include "r300_reg.h"  /* Some maths. These should probably find their way to u_math, if needed. */ @@ -443,20 +445,22 @@ static INLINE uint32_t r300_translate_gb_pipes(int pipe_count)  static INLINE unsigned pf_component_count(enum pipe_format format) {      unsigned count = 0; -    if (pf_layout(format) != PIPE_FORMAT_LAYOUT_RGBAZS) { -        return count; +    if (util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 0)) { +        count++;      } - -    if (pf_size_x(format)) { +    if (util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 1)) { +        count++; +    } +    if (util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 2)) {          count++;      } -    if (pf_size_y(format)) { +    if (util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 3)) {          count++;      } -    if (pf_size_z(format)) { +    if (util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_ZS, 0)) {          count++;      } -    if (pf_size_w(format)) { +    if (util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_ZS, 1)) {          count++;      } @@ -467,19 +471,23 @@ static INLINE unsigned pf_component_count(enum pipe_format format) {  static INLINE uint16_t  r300_translate_vertex_data_type(enum pipe_format format) {      uint32_t result = 0; +    const struct util_format_description *desc;      unsigned components = pf_component_count(format); -    if (pf_layout(format) != PIPE_FORMAT_LAYOUT_RGBAZS) { +    desc = util_format_description(format); + +    if (desc->layout != UTIL_FORMAT_LAYOUT_ARITH && +        desc->layout != UTIL_FORMAT_LAYOUT_ARRAY) {          debug_printf("r300: Bad format %s in %s:%d\n", pf_name(format),              __FUNCTION__, __LINE__);          assert(0);      } -    switch (pf_type(format)) { +    switch (desc->channel[0].type) {          /* Half-floats, floats, doubles */ -        case PIPE_FORMAT_TYPE_FLOAT: -            switch (pf_size_x(format)) { -                case 4: +        case UTIL_FORMAT_TYPE_FLOAT: +            switch (util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 0)) { +                case 32:                      result = R300_DATA_TYPE_FLOAT_1 + (components - 1);                      break;                  default: @@ -488,19 +496,15 @@ r300_translate_vertex_data_type(enum pipe_format format) {                      assert(0);              }              break; -        /* Normalized unsigned ints */ -        case PIPE_FORMAT_TYPE_UNORM: -        /* Normalized signed ints */ -        case PIPE_FORMAT_TYPE_SNORM: -        /* Non-normalized unsigned ints */ -        case PIPE_FORMAT_TYPE_USCALED: -        /* Non-normalized signed ints */ -        case PIPE_FORMAT_TYPE_SSCALED: -            switch (pf_size_x(format)) { -                case 1: +        /* Unsigned ints */ +        case UTIL_FORMAT_TYPE_UNSIGNED: +        /* Signed ints */ +        case UTIL_FORMAT_TYPE_SIGNED: +            switch (util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 0)) { +                case 8:                      result = R300_DATA_TYPE_BYTE;                      break; -                case 2: +                case 16:                      if (components > 2) {                          result = R300_DATA_TYPE_SHORT_4;                      } else { @@ -510,8 +514,8 @@ r300_translate_vertex_data_type(enum pipe_format format) {                  default:                      debug_printf("r300: Bad format %s in %s:%d\n",                          pf_name(format), __FUNCTION__, __LINE__); -                    debug_printf("r300: pf_size_x(format) == %d\n", -                        pf_size_x(format)); +                    debug_printf("r300: util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 0) == %d\n", +                        util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 0));                      assert(0);              }              break; @@ -521,12 +525,11 @@ r300_translate_vertex_data_type(enum pipe_format format) {              assert(0);      } -    if (pf_type(format) == PIPE_FORMAT_TYPE_SSCALED) { +    if (desc->channel[0].type == UTIL_FORMAT_TYPE_SIGNED) {          result |= R300_SIGNED; -    } else if (pf_type(format) == PIPE_FORMAT_TYPE_UNORM) { +    } +    if (desc->channel[0].normalized) {          result |= R300_NORMALIZE; -    } else if (pf_type(format) == PIPE_FORMAT_TYPE_SNORM) { -        result |= (R300_SIGNED | R300_NORMALIZE);      }      return result; @@ -534,17 +537,21 @@ r300_translate_vertex_data_type(enum pipe_format format) {  static INLINE uint16_t  r300_translate_vertex_data_swizzle(enum pipe_format format) { +    const struct util_format_description *desc = util_format_description(format); + +    assert(format); -    if (pf_layout(format) != PIPE_FORMAT_LAYOUT_RGBAZS) { +    if (desc->layout != UTIL_FORMAT_LAYOUT_ARITH && +        desc->layout != UTIL_FORMAT_LAYOUT_ARRAY) {          debug_printf("r300: Bad format %s in %s:%d\n",              pf_name(format), __FUNCTION__, __LINE__);          return 0;      } -    return ((pf_swizzle_x(format) << R300_SWIZZLE_SELECT_X_SHIFT) | -        (pf_swizzle_y(format) << R300_SWIZZLE_SELECT_Y_SHIFT) | -        (pf_swizzle_z(format) << R300_SWIZZLE_SELECT_Z_SHIFT) | -        (pf_swizzle_w(format) << R300_SWIZZLE_SELECT_W_SHIFT) | +    return ((desc->swizzle[0] << R300_SWIZZLE_SELECT_X_SHIFT) | +        (desc->swizzle[1] << R300_SWIZZLE_SELECT_Y_SHIFT) | +        (desc->swizzle[2] << R300_SWIZZLE_SELECT_Z_SHIFT) | +        (desc->swizzle[3] << R300_SWIZZLE_SELECT_W_SHIFT) |          (0xf << R300_WRITE_ENA_SHIFT));  } diff --git a/src/gallium/drivers/r300/r300_texture.c b/src/gallium/drivers/r300/r300_texture.c index 63fc6a235a..9a96206a4d 100644 --- a/src/gallium/drivers/r300/r300_texture.c +++ b/src/gallium/drivers/r300/r300_texture.c @@ -22,6 +22,7 @@  #include "pipe/p_screen.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h" @@ -105,7 +106,7 @@ unsigned r300_texture_get_stride(struct r300_texture* tex, unsigned level)          return 0;      } -    return align(pf_get_stride(tex->tex.format, u_minify(tex->tex.width0, level)), 32); +    return align(util_format_get_stride(tex->tex.format, u_minify(tex->tex.width0, level)), 32);  }  static void r300_setup_miptree(struct r300_texture* tex) @@ -115,7 +116,7 @@ static void r300_setup_miptree(struct r300_texture* tex)      int i;      for (i = 0; i <= base->last_level; i++) { -        unsigned nblocksy = pf_get_nblocksy(base->format, u_minify(base->height0, i)); +        unsigned nblocksy = util_format_get_nblocksy(base->format, u_minify(base->height0, i));          stride = r300_texture_get_stride(tex, i);          layer_size = stride * nblocksy; @@ -128,7 +129,7 @@ static void r300_setup_miptree(struct r300_texture* tex)          tex->offset[i] = align(tex->size, 32);          tex->size = tex->offset[i] + size;          tex->layer_size[i] = layer_size; -        tex->pitch[i] = stride / pf_get_blocksize(base->format); +        tex->pitch[i] = stride / util_format_get_blocksize(base->format);          debug_printf("r300: Texture miptree: Level %d "                  "(%dx%dx%d px, pitch %d bytes)\n", @@ -244,7 +245,7 @@ static struct pipe_texture*      tex->tex.screen = screen;      tex->stride_override = *stride; -    tex->pitch[0] = *stride / pf_get_blocksize(base->format); +    tex->pitch[0] = *stride / util_format_get_blocksize(base->format);      r300_setup_flags(tex);      r300_setup_texture_state(tex, r300_screen(screen)->caps->is_r500); diff --git a/src/gallium/drivers/softpipe/sp_state_surface.c b/src/gallium/drivers/softpipe/sp_state_surface.c index bc0e201130..a518248bb1 100644 --- a/src/gallium/drivers/softpipe/sp_state_surface.c +++ b/src/gallium/drivers/softpipe/sp_state_surface.c @@ -35,6 +35,8 @@  #include "draw/draw_context.h" +#include "util/u_format.h" +  /**   * XXX this might get moved someday @@ -80,8 +82,9 @@ softpipe_set_framebuffer_state(struct pipe_context *pipe,        if (sp->framebuffer.zsbuf) {           int depth_bits;           double mrd; -         depth_bits = pf_get_component_bits(sp->framebuffer.zsbuf->format, -                                            PIPE_FORMAT_COMP_Z); +         depth_bits = util_format_get_component_bits(sp->framebuffer.zsbuf->format, +                                                     UTIL_FORMAT_COLORSPACE_ZS, +                                                     0);           if (depth_bits > 16) {              mrd = 0.0000001;           } diff --git a/src/gallium/drivers/softpipe/sp_texture.c b/src/gallium/drivers/softpipe/sp_texture.c index 4f946ccfcf..a9436a3394 100644 --- a/src/gallium/drivers/softpipe/sp_texture.c +++ b/src/gallium/drivers/softpipe/sp_texture.c @@ -32,6 +32,8 @@  #include "pipe/p_defines.h"  #include "pipe/p_inlines.h" + +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h" @@ -63,11 +65,11 @@ softpipe_texture_layout(struct pipe_screen *screen,     pt->depth0 = depth;     for (level = 0; level <= pt->last_level; level++) { -      spt->stride[level] = pf_get_stride(pt->format, width); +      spt->stride[level] = util_format_get_stride(pt->format, width);        spt->level_offset[level] = buffer_size; -      buffer_size += (pf_get_nblocksy(pt->format, height) * +      buffer_size += (util_format_get_nblocksy(pt->format, height) *                        ((pt->target == PIPE_TEXTURE_CUBE) ? 6 : depth) *                        spt->stride[level]); @@ -237,11 +239,11 @@ softpipe_get_tex_surface(struct pipe_screen *screen,        ps->zslice = zslice;        if (pt->target == PIPE_TEXTURE_CUBE) { -         ps->offset += face * pf_get_nblocksy(pt->format, u_minify(pt->height0, level)) * +         ps->offset += face * util_format_get_nblocksy(pt->format, u_minify(pt->height0, level)) *                         spt->stride[level];        }        else if (pt->target == PIPE_TEXTURE_3D) { -         ps->offset += zslice * pf_get_nblocksy(pt->format, u_minify(pt->height0, level)) * +         ps->offset += zslice * util_format_get_nblocksy(pt->format, u_minify(pt->height0, level)) *                         spt->stride[level];        }        else { @@ -297,7 +299,7 @@ softpipe_get_tex_transfer(struct pipe_screen *screen,     spt = CALLOC_STRUCT(softpipe_transfer);     if (spt) {        struct pipe_transfer *pt = &spt->base; -      int nblocksy = pf_get_nblocksy(texture->format, u_minify(texture->height0, level)); +      int nblocksy = util_format_get_nblocksy(texture->format, u_minify(texture->height0, level));        pipe_texture_reference(&pt->texture, texture);        pt->x = x;        pt->y = y; @@ -374,8 +376,8 @@ softpipe_transfer_map( struct pipe_screen *screen,     }     xfer_map = map + softpipe_transfer(transfer)->offset + -      transfer->y / pf_get_blockheight(format) * transfer->stride + -      transfer->x / pf_get_blockwidth(format) * pf_get_blocksize(format); +      transfer->y / util_format_get_blockheight(format) * transfer->stride + +      transfer->x / util_format_get_blockwidth(format) * util_format_get_blocksize(format);     /*printf("map = %p  xfer map = %p\n", map, xfer_map);*/     return xfer_map;  } diff --git a/src/gallium/drivers/softpipe/sp_tile_cache.c b/src/gallium/drivers/softpipe/sp_tile_cache.c index 04f61d16c4..112a6fe0cf 100644 --- a/src/gallium/drivers/softpipe/sp_tile_cache.c +++ b/src/gallium/drivers/softpipe/sp_tile_cache.c @@ -33,6 +33,7 @@   */  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_memory.h"  #include "util/u_tile.h"  #include "sp_tile_cache.h" @@ -238,7 +239,7 @@ clear_tile(struct softpipe_cached_tile *tile,  {     uint i, j; -   switch (pf_get_blocksize(format)) { +   switch (util_format_get_blocksize(format)) {     case 1:        memset(tile->data.any, clear_value, TILE_SIZE * TILE_SIZE);        break; diff --git a/src/gallium/drivers/svga/svga_screen_texture.c b/src/gallium/drivers/svga/svga_screen_texture.c index 3700a80bf1..2224c2d394 100644 --- a/src/gallium/drivers/svga/svga_screen_texture.c +++ b/src/gallium/drivers/svga/svga_screen_texture.c @@ -29,6 +29,7 @@  #include "pipe/p_defines.h"  #include "pipe/p_inlines.h"  #include "pipe/p_thread.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h" @@ -158,8 +159,8 @@ svga_transfer_dma_band(struct svga_transfer *st,                  st->base.x + st->base.width,                  y + h,                  st->base.zslice + 1, -                pf_get_blocksize(texture->base.format)*8/ -                (pf_get_blockwidth(texture->base.format)*pf_get_blockheight(texture->base.format))); +                util_format_get_blocksize(texture->base.format)*8/ +                (util_format_get_blockwidth(texture->base.format)*util_format_get_blockheight(texture->base.format)));     box.x = st->base.x;     box.y = y; @@ -209,7 +210,7 @@ svga_transfer_dma(struct svga_transfer *st,     }     else {        unsigned y, h, srcy; -      unsigned blockheight = pf_get_blockheight(st->base.texture->format); +      unsigned blockheight = util_format_get_blockheight(st->base.texture->format);        h = st->hw_nblocksy * blockheight;        srcy = 0;        for(y = 0; y < st->base.height; y += h) { @@ -319,7 +320,7 @@ svga_texture_create(struct pipe_screen *screen,      */  #if 0     if((templat->tex_usage & PIPE_TEXTURE_USAGE_RENDER_TARGET) && -      !pf_is_compressed(templat->format)) +      !util_format_is_compressed(templat->format))        tex->key.flags |= SVGA3D_SURFACE_HINT_RENDERTARGET;  #endif @@ -771,8 +772,8 @@ svga_get_tex_transfer(struct pipe_screen *screen,     struct svga_screen *ss = svga_screen(screen);     struct svga_winsys_screen *sws = ss->sws;     struct svga_transfer *st; -   unsigned nblocksx = pf_get_nblocksx(texture->format, w); -   unsigned nblocksy = pf_get_nblocksy(texture->format, h); +   unsigned nblocksx = util_format_get_nblocksx(texture->format, w); +   unsigned nblocksy = util_format_get_nblocksy(texture->format, h);     /* We can't map texture storage directly */     if (usage & PIPE_TRANSFER_MAP_DIRECTLY) @@ -786,7 +787,7 @@ svga_get_tex_transfer(struct pipe_screen *screen,     st->base.y = y;     st->base.width = w;     st->base.height = h; -   st->base.stride = nblocksx*pf_get_blocksize(texture->format); +   st->base.stride = nblocksx*util_format_get_blocksize(texture->format);     st->base.usage = usage;     st->base.face = face;     st->base.level = level; @@ -931,7 +932,7 @@ svga_get_tex_sampler_view(struct pipe_context *pipe, struct pipe_texture *pt,        if (min_lod == 0 && max_lod >= pt->last_level)           view = FALSE; -      if (pf_is_compressed(pt->format) && view) { +      if (util_format_is_compressed(pt->format) && view) {           format = svga_translate_format_render(pt->format);        } @@ -1070,7 +1071,7 @@ svga_screen_buffer_from_texture(struct pipe_texture *texture,         svga_translate_format(texture->format),         stex->handle); -   *stride = pf_get_stride(texture->format, texture->width0); +   *stride = util_format_get_stride(texture->format, texture->width0);     return *buffer != NULL;  } diff --git a/src/gallium/drivers/svga/svga_state_vs.c b/src/gallium/drivers/svga/svga_state_vs.c index f1b0daf9f6..44b7ceb4fa 100644 --- a/src/gallium/drivers/svga/svga_state_vs.c +++ b/src/gallium/drivers/svga/svga_state_vs.c @@ -25,6 +25,7 @@  #include "pipe/p_inlines.h"  #include "pipe/p_defines.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "translate/translate.h" @@ -210,7 +211,7 @@ static int update_zero_stride( struct svga_context *svga,           mapped_buffer = pipe_buffer_map_range(svga->pipe.screen,                                                  vbuffer->buffer,                                                 vel->src_offset, -                                               pf_get_blocksize(vel->src_format), +                                               util_format_get_blocksize(vel->src_format),                                                 PIPE_BUFFER_USAGE_CPU_READ);           translate->set_buffer(translate, vel->vertex_buffer_index,                                 mapped_buffer, diff --git a/src/gallium/drivers/trace/tr_rbug.c b/src/gallium/drivers/trace/tr_rbug.c index af1d7f3224..c31b1d8698 100644 --- a/src/gallium/drivers/trace/tr_rbug.c +++ b/src/gallium/drivers/trace/tr_rbug.c @@ -26,6 +26,7 @@   **************************************************************************/ +#include "util/u_format.h"  #include "util/u_string.h"  #include "util/u_memory.h"  #include "util/u_simple_list.h" @@ -203,9 +204,9 @@ trace_rbug_texture_info(struct trace_rbug *tr_rbug, struct rbug_header *header,                                 &t->width0, 1,                                 &t->height0, 1,                                 &t->depth0, 1, -                               pf_get_blockwidth(t->format), -                               pf_get_blockheight(t->format), -                               pf_get_blocksize(t->format), +                               util_format_get_blockwidth(t->format), +                               util_format_get_blockheight(t->format), +                               util_format_get_blocksize(t->format),                                 t->last_level,                                 t->nr_samples,                                 t->tex_usage, @@ -254,11 +255,11 @@ trace_rbug_texture_read(struct trace_rbug *tr_rbug, struct rbug_header *header,     rbug_send_texture_read_reply(tr_rbug->con, serial,                                  t->texture->format, -                                pf_get_blockwidth(t->texture->format), -                                pf_get_blockheight(t->texture->format), -                                pf_get_blocksize(t->texture->format), +                                util_format_get_blockwidth(t->texture->format), +                                util_format_get_blockheight(t->texture->format), +                                util_format_get_blocksize(t->texture->format),                                  (uint8_t*)map, -                                t->stride * pf_get_nblocksy(t->texture->format, t->height), +                                t->stride * util_format_get_nblocksy(t->texture->format, t->height),                                  t->stride,                                  NULL); diff --git a/src/gallium/drivers/trace/tr_screen.c b/src/gallium/drivers/trace/tr_screen.c index f69f7da000..ac20a47af1 100644 --- a/src/gallium/drivers/trace/tr_screen.c +++ b/src/gallium/drivers/trace/tr_screen.c @@ -25,6 +25,7 @@   *   **************************************************************************/ +#include "util/u_format.h"  #include "util/u_memory.h"  #include "util/u_simple_list.h" @@ -425,7 +426,7 @@ trace_screen_transfer_unmap(struct pipe_screen *_screen,     struct pipe_transfer *transfer = tr_trans->transfer;     if(tr_trans->map) { -      size_t size = pf_get_nblocksy(transfer->texture->format, transfer->width) * transfer->stride; +      size_t size = util_format_get_nblocksy(transfer->texture->format, transfer->width) * transfer->stride;        trace_dump_call_begin("pipe_screen", "transfer_write"); diff --git a/src/gallium/include/pipe/p_format.h b/src/gallium/include/pipe/p_format.h index e6bba777d3..6bfff1cc59 100644 --- a/src/gallium/include/pipe/p_format.h +++ b/src/gallium/include/pipe/p_format.h @@ -40,353 +40,133 @@ extern "C" {  #endif  /** - * The pipe_format enum is a 32-bit wide bitfield that encodes all the - * information needed to uniquely describe a pixel format. - */ - -/** - * Possible format layouts are encoded in the first 2 bits. - * The interpretation of the remaining 30 bits depends on a particular - * format layout. - */ -#define PIPE_FORMAT_LAYOUT_RGBAZS   0 -#define PIPE_FORMAT_LAYOUT_YCBCR    1 -#define PIPE_FORMAT_LAYOUT_DXT      2  /**< XXX temporary? */ -#define PIPE_FORMAT_LAYOUT_MIXED    3 - -static INLINE uint pf_layout(uint f)  /**< PIPE_FORMAT_LAYOUT_ */ -{ -   return f & 0x3; -} - -/** - * RGBAZS Format Layout. - */ - -/** - * Format component selectors for RGBAZS & MIXED layout. - */ -#define PIPE_FORMAT_COMP_R    0 -#define PIPE_FORMAT_COMP_G    1 -#define PIPE_FORMAT_COMP_B    2 -#define PIPE_FORMAT_COMP_A    3 -#define PIPE_FORMAT_COMP_0    4 -#define PIPE_FORMAT_COMP_1    5 -#define PIPE_FORMAT_COMP_Z    6 -#define PIPE_FORMAT_COMP_S    7 - -/** - * Format types for RGBAZS layout. - */ -#define PIPE_FORMAT_TYPE_UNKNOWN 0 -#define PIPE_FORMAT_TYPE_FLOAT   1  /**< 16/32/64-bit/channel formats */ -#define PIPE_FORMAT_TYPE_UNORM   2  /**< uints, normalized to [0,1] */ -#define PIPE_FORMAT_TYPE_SNORM   3  /**< ints, normalized to [-1,1] */ -#define PIPE_FORMAT_TYPE_USCALED 4  /**< uints, not normalized */ -#define PIPE_FORMAT_TYPE_SSCALED 5  /**< ints, not normalized */ -#define PIPE_FORMAT_TYPE_SRGB    6  /**< sRGB colorspace */ -#define PIPE_FORMAT_TYPE_FIXED   7  /**< 16.16 fixed point */ - - -/** - * Because the destination vector is assumed to be RGBA FLOAT, we - * need to know how to swizzle and expand components from the source - * vector. - * Let's take U_A1_R5_G5_B5 as an example. X swizzle is A, X size - * is 1 bit and type is UNORM. So we take the most significant bit - * from source vector, convert 0 to 0.0 and 1 to 1.0 and save it - * in the last component of the destination RGBA component. - * Next, Y swizzle is R, Y size is 5 and type is UNORM. We normalize - * those 5 bits into [0.0; 1.0] range and put it into second - * component of the destination vector. Rinse and repeat for - * components Z and W. - * If any of size fields is zero, it means the source format contains - * less than four components. - * If any swizzle is 0 or 1, the corresponding destination component - * should be filled with 0.0 and 1.0, respectively. - */ -typedef uint pipe_format_rgbazs_t; - -static INLINE uint pf_get(pipe_format_rgbazs_t f, uint shift, uint mask) -{ -   return (f >> shift) & mask; -} - -#define pf_swizzle_x(f)       pf_get(f, 2, 0x7)  /**< PIPE_FORMAT_COMP_ */ -#define pf_swizzle_y(f)       pf_get(f, 5, 0x7)  /**< PIPE_FORMAT_COMP_ */ -#define pf_swizzle_z(f)       pf_get(f, 8, 0x7)  /**< PIPE_FORMAT_COMP_ */ -#define pf_swizzle_w(f)       pf_get(f, 11, 0x7) /**< PIPE_FORMAT_COMP_ */ -#define pf_swizzle_xyzw(f,i)  pf_get(f, 2+((i)*3), 0x7) -#define pf_size_x(f)          pf_get(f, 14, 0x7) /**< Size of X */ -#define pf_size_y(f)          pf_get(f, 17, 0x7) /**< Size of Y */ -#define pf_size_z(f)          pf_get(f, 20, 0x7) /**< Size of Z */ -#define pf_size_w(f)          pf_get(f, 23, 0x7) /**< Size of W */ -#define pf_size_xyzw(f,i)     pf_get(f, 14+((i)*3), 0x7) -#define pf_exp2(f)            pf_get(f, 26, 0x7) /**< Scale size by 2 ^ exp2 */ -#define pf_type(f)            pf_get(f, 29, 0x7) /**< PIPE_FORMAT_TYPE_ */ - -/** - * Helper macro to encode the above structure into a 32-bit value. - */ -#define _PIPE_FORMAT_RGBAZS( SWZ, SIZEX, SIZEY, SIZEZ, SIZEW, EXP2, TYPE ) (\ -   (PIPE_FORMAT_LAYOUT_RGBAZS << 0) |\ -   ((SWZ) << 2) |\ -   ((SIZEX) << 14) |\ -   ((SIZEY) << 17) |\ -   ((SIZEZ) << 20) |\ -   ((SIZEW) << 23) |\ -   ((EXP2) << 26) |\ -   ((TYPE) << 29) ) - -/** - * Helper macro to encode the swizzle part of the structure above. - */ -#define _PIPE_FORMAT_SWZ( SWZX, SWZY, SWZZ, SWZW ) (((SWZX) << 0) | ((SWZY) << 3) | ((SWZZ) << 6) | ((SWZW) << 9)) - -/** - * Shorthand macro for RGBAZS layout with component sizes in 1-bit units. - */ -#define _PIPE_FORMAT_RGBAZS_1( SWZ, SIZEX, SIZEY, SIZEZ, SIZEW, TYPE )\ -   _PIPE_FORMAT_RGBAZS( SWZ, SIZEX, SIZEY, SIZEZ, SIZEW, 0, TYPE ) - -/** - * Shorthand macro for RGBAZS layout with component sizes in 2-bit units. - */ -#define _PIPE_FORMAT_RGBAZS_2( SWZ, SIZEX, SIZEY, SIZEZ, SIZEW, TYPE )\ -   _PIPE_FORMAT_RGBAZS( SWZ, SIZEX, SIZEY, SIZEZ, SIZEW, 1, TYPE ) - -/** - * Shorthand macro for RGBAZS layout with component sizes in 8-bit units. - */ -#define _PIPE_FORMAT_RGBAZS_8( SWZ, SIZEX, SIZEY, SIZEZ, SIZEW, TYPE )\ -   _PIPE_FORMAT_RGBAZS( SWZ, SIZEX, SIZEY, SIZEZ, SIZEW, 3, TYPE ) - -/** - * Shorthand macro for RGBAZS layout with component sizes in 64-bit units. - */ -#define _PIPE_FORMAT_RGBAZS_64( SWZ, SIZEX, SIZEY, SIZEZ, SIZEW, TYPE )\ -   _PIPE_FORMAT_RGBAZS( SWZ, SIZEX, SIZEY, SIZEZ, SIZEW, 6, TYPE ) - -typedef uint pipe_format_mixed_t; - -/* NOTE: Use pf_swizzle_* and pf_size_* macros for swizzles and sizes. - */ - -#define pf_mixed_sign_x(f)       pf_get( f, 26, 0x1 )       /*< Sign of X */ -#define pf_mixed_sign_y(f)       pf_get( f, 27, 0x1 )       /*< Sign of Y */ -#define pf_mixed_sign_z(f)       pf_get( f, 28, 0x1 )       /*< Sign of Z */ -#define pf_mixed_sign_w(f)       pf_get( f, 29, 0x1 )       /*< Sign of W */ -#define pf_mixed_sign_xyzw(f, i) pf_get( f, 26 + (i), 0x1 ) -#define pf_mixed_normalized(f)   pf_get( f, 30, 0x1 )       /*< Type is NORM (1) or SCALED (0) */ -#define pf_mixed_scale8(f)       pf_get( f, 31, 0x1 )       /*< Scale size by either one (0) or eight (1) */ - -/** - * Helper macro to encode the above structure into a 32-bit value. - */ -#define _PIPE_FORMAT_MIXED( SWZ, SIZEX, SIZEY, SIZEZ, SIZEW, SIGNX, SIGNY, SIGNZ, SIGNW, NORMALIZED, SCALE8 ) (\ -   (PIPE_FORMAT_LAYOUT_MIXED << 0) |\ -   ((SWZ) << 2) |\ -   ((SIZEX) << 14) |\ -   ((SIZEY) << 17) |\ -   ((SIZEZ) << 20) |\ -   ((SIZEW) << 23) |\ -   ((SIGNX) << 26) |\ -   ((SIGNY) << 27) |\ -   ((SIGNZ) << 28) |\ -   ((SIGNW) << 29) |\ -   ((NORMALIZED) << 30) |\ -   ((SCALE8) << 31) ) - -/** - * Shorthand macro for common format swizzles. - */ -#define _PIPE_FORMAT_R001 _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_1 ) -#define _PIPE_FORMAT_RG01 _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_G, PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_1 ) -#define _PIPE_FORMAT_RGB1 _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_G, PIPE_FORMAT_COMP_B, PIPE_FORMAT_COMP_1 ) -#define _PIPE_FORMAT_RGBA _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_G, PIPE_FORMAT_COMP_B, PIPE_FORMAT_COMP_A ) -#define _PIPE_FORMAT_ARGB _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_A, PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_G, PIPE_FORMAT_COMP_B ) -#define _PIPE_FORMAT_ABGR _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_A, PIPE_FORMAT_COMP_B, PIPE_FORMAT_COMP_G, PIPE_FORMAT_COMP_R ) -#define _PIPE_FORMAT_BGRA _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_B, PIPE_FORMAT_COMP_G, PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_A ) -#define _PIPE_FORMAT_1RGB _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_1, PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_G, PIPE_FORMAT_COMP_B ) -#define _PIPE_FORMAT_1BGR _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_1, PIPE_FORMAT_COMP_B, PIPE_FORMAT_COMP_G, PIPE_FORMAT_COMP_R ) -#define _PIPE_FORMAT_BGR1 _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_B, PIPE_FORMAT_COMP_G, PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_1 ) -#define _PIPE_FORMAT_0000 _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_0 ) -#define _PIPE_FORMAT_000R _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_R ) -#define _PIPE_FORMAT_RRR1 _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_1 ) -#define _PIPE_FORMAT_RRRR _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_R ) -#define _PIPE_FORMAT_RRRG _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_R, PIPE_FORMAT_COMP_G ) -#define _PIPE_FORMAT_Z000 _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_Z, PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_0 ) -#define _PIPE_FORMAT_0Z00 _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_Z, PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_0 ) -#define _PIPE_FORMAT_SZ00 _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_S, PIPE_FORMAT_COMP_Z, PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_0 ) -#define _PIPE_FORMAT_ZS00 _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_Z, PIPE_FORMAT_COMP_S, PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_0 ) -#define _PIPE_FORMAT_S000 _PIPE_FORMAT_SWZ( PIPE_FORMAT_COMP_S, PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_0, PIPE_FORMAT_COMP_0 ) - -/** - * YCBCR Format Layout. - */ - -/** - * This only contains a flag that indicates whether the format is reversed or - * not. - */ -typedef uint pipe_format_ycbcr_t; - -/** - * Helper macro to encode the above structure into a 32-bit value. - */ -#define _PIPE_FORMAT_YCBCR( REV ) (\ -   (PIPE_FORMAT_LAYOUT_YCBCR << 0) |\ -   ((REV) << 2) ) - -static INLINE uint pf_rev(pipe_format_ycbcr_t f) -{ -   return (f >> 2) & 0x1; -} - - -/** -  * Compresssed format layouts (this will probably change) -  */ -#define _PIPE_FORMAT_DXT( LEVEL, RSIZE, GSIZE, BSIZE, ASIZE, TYPE ) \ -   ((PIPE_FORMAT_LAYOUT_DXT << 0) | \ -    ((LEVEL) << 2) | \ -    ((RSIZE) << 5) | \ -    ((GSIZE) << 8) | \ -    ((BSIZE) << 11) | \ -    ((ASIZE) << 14) | \ -    ((TYPE) << 29)) - - - -/**   * Texture/surface image formats (preliminary)   */  /* KW: Added lots of surface formats to support vertex element layout - * definitions, and eventually render-to-vertex-buffer.  Could - * consider making float/int/uint/scaled/normalized a separate - * parameter, but on the other hand there are special cases like - * z24s8, compressed textures, ycbcr, etc that won't fit that model. + * definitions, and eventually render-to-vertex-buffer.   */  enum pipe_format { -   PIPE_FORMAT_NONE                  = _PIPE_FORMAT_RGBAZS_1 ( _PIPE_FORMAT_0000, 0, 0, 0, 0, PIPE_FORMAT_TYPE_UNKNOWN ), -   PIPE_FORMAT_A8R8G8B8_UNORM        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_ARGB, 1, 1, 1, 1, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_X8R8G8B8_UNORM        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_1RGB, 1, 1, 1, 1, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_B8G8R8A8_UNORM        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_BGRA, 1, 1, 1, 1, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_B8G8R8X8_UNORM        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_BGR1, 1, 1, 1, 1, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_A1R5G5B5_UNORM        = _PIPE_FORMAT_RGBAZS_1 ( _PIPE_FORMAT_ARGB, 1, 5, 5, 5, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_A4R4G4B4_UNORM        = _PIPE_FORMAT_RGBAZS_1 ( _PIPE_FORMAT_ARGB, 4, 4, 4, 4, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_R5G6B5_UNORM          = _PIPE_FORMAT_RGBAZS_1 ( _PIPE_FORMAT_RGB1, 5, 6, 5, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_A2B10G10R10_UNORM     = _PIPE_FORMAT_RGBAZS_2 ( _PIPE_FORMAT_ABGR, 1, 5, 5, 5, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_L8_UNORM              = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RRR1, 1, 1, 1, 0, PIPE_FORMAT_TYPE_UNORM ), /**< ubyte luminance */ -   PIPE_FORMAT_A8_UNORM              = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_000R, 0, 0, 0, 1, PIPE_FORMAT_TYPE_UNORM ), /**< ubyte alpha */ -   PIPE_FORMAT_I8_UNORM              = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RRRR, 1, 1, 1, 1, PIPE_FORMAT_TYPE_UNORM ), /**< ubyte intensity */ -   PIPE_FORMAT_A8L8_UNORM            = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RRRG, 1, 1, 1, 1, PIPE_FORMAT_TYPE_UNORM ), /**< ubyte alpha, luminance */ -   PIPE_FORMAT_L16_UNORM             = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RRR1, 2, 2, 2, 0, PIPE_FORMAT_TYPE_UNORM ), /**< ushort luminance */ -   PIPE_FORMAT_YCBCR                 = _PIPE_FORMAT_YCBCR( 0 ), -   PIPE_FORMAT_YCBCR_REV             = _PIPE_FORMAT_YCBCR( 1 ), -   PIPE_FORMAT_Z16_UNORM             = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_Z000, 2, 0, 0, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_Z32_UNORM             = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_Z000, 4, 0, 0, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_Z32_FLOAT             = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_Z000, 4, 0, 0, 0, PIPE_FORMAT_TYPE_FLOAT ), -   PIPE_FORMAT_S8Z24_UNORM           = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_SZ00, 1, 3, 0, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_Z24S8_UNORM           = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_ZS00, 3, 1, 0, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_X8Z24_UNORM           = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_0Z00, 1, 3, 0, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_Z24X8_UNORM           = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_Z000, 3, 1, 0, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_S8_UNORM              = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_S000, 1, 0, 0, 0, PIPE_FORMAT_TYPE_UNORM ), /**< ubyte stencil */ -   PIPE_FORMAT_R64_FLOAT             = _PIPE_FORMAT_RGBAZS_64( _PIPE_FORMAT_R001, 1, 0, 0, 0, PIPE_FORMAT_TYPE_FLOAT ), -   PIPE_FORMAT_R64G64_FLOAT          = _PIPE_FORMAT_RGBAZS_64( _PIPE_FORMAT_RG01, 1, 1, 0, 0, PIPE_FORMAT_TYPE_FLOAT ), -   PIPE_FORMAT_R64G64B64_FLOAT       = _PIPE_FORMAT_RGBAZS_64( _PIPE_FORMAT_RGB1, 1, 1, 1, 0, PIPE_FORMAT_TYPE_FLOAT ), -   PIPE_FORMAT_R64G64B64A64_FLOAT    = _PIPE_FORMAT_RGBAZS_64( _PIPE_FORMAT_RGBA, 1, 1, 1, 1, PIPE_FORMAT_TYPE_FLOAT ), -   PIPE_FORMAT_R32_FLOAT             = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_R001, 4, 0, 0, 0, PIPE_FORMAT_TYPE_FLOAT ), -   PIPE_FORMAT_R32G32_FLOAT          = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RG01, 4, 4, 0, 0, PIPE_FORMAT_TYPE_FLOAT ), -   PIPE_FORMAT_R32G32B32_FLOAT       = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 4, 4, 4, 0, PIPE_FORMAT_TYPE_FLOAT ), -   PIPE_FORMAT_R32G32B32A32_FLOAT    = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 4, 4, 4, 4, PIPE_FORMAT_TYPE_FLOAT ), -   PIPE_FORMAT_R32_UNORM             = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_R001, 4, 0, 0, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_R32G32_UNORM          = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RG01, 4, 4, 0, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_R32G32B32_UNORM       = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 4, 4, 4, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_R32G32B32A32_UNORM    = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 4, 4, 4, 4, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_R32_USCALED           = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_R001, 4, 0, 0, 0, PIPE_FORMAT_TYPE_USCALED ), -   PIPE_FORMAT_R32G32_USCALED        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RG01, 4, 4, 0, 0, PIPE_FORMAT_TYPE_USCALED ), -   PIPE_FORMAT_R32G32B32_USCALED     = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 4, 4, 4, 0, PIPE_FORMAT_TYPE_USCALED ), -   PIPE_FORMAT_R32G32B32A32_USCALED  = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 4, 4, 4, 4, PIPE_FORMAT_TYPE_USCALED ), -   PIPE_FORMAT_R32_SNORM             = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_R001, 4, 0, 0, 0, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_R32G32_SNORM          = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RG01, 4, 4, 0, 0, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_R32G32B32_SNORM       = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 4, 4, 4, 0, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_R32G32B32A32_SNORM    = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 4, 4, 4, 4, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_R32_SSCALED           = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_R001, 4, 0, 0, 0, PIPE_FORMAT_TYPE_SSCALED ), -   PIPE_FORMAT_R32G32_SSCALED        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RG01, 4, 4, 0, 0, PIPE_FORMAT_TYPE_SSCALED ), -   PIPE_FORMAT_R32G32B32_SSCALED     = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 4, 4, 4, 0, PIPE_FORMAT_TYPE_SSCALED ), -   PIPE_FORMAT_R32G32B32A32_SSCALED  = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 4, 4, 4, 4, PIPE_FORMAT_TYPE_SSCALED ), -   PIPE_FORMAT_R16_UNORM             = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_R001, 2, 0, 0, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_R16G16_UNORM          = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RG01, 2, 2, 0, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_R16G16B16_UNORM       = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 2, 2, 2, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_R16G16B16A16_UNORM    = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 2, 2, 2, 2, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_R16_USCALED           = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_R001, 2, 0, 0, 0, PIPE_FORMAT_TYPE_USCALED ), -   PIPE_FORMAT_R16G16_USCALED        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RG01, 2, 2, 0, 0, PIPE_FORMAT_TYPE_USCALED ), -   PIPE_FORMAT_R16G16B16_USCALED     = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 2, 2, 2, 0, PIPE_FORMAT_TYPE_USCALED ), -   PIPE_FORMAT_R16G16B16A16_USCALED  = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 2, 2, 2, 2, PIPE_FORMAT_TYPE_USCALED ), -   PIPE_FORMAT_R16_SNORM             = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_R001, 2, 0, 0, 0, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_R16G16_SNORM          = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RG01, 2, 2, 0, 0, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_R16G16B16_SNORM       = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 2, 2, 2, 0, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_R16G16B16A16_SNORM    = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 2, 2, 2, 2, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_R16_SSCALED           = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_R001, 2, 0, 0, 0, PIPE_FORMAT_TYPE_SSCALED ), -   PIPE_FORMAT_R16G16_SSCALED        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RG01, 2, 2, 0, 0, PIPE_FORMAT_TYPE_SSCALED ), -   PIPE_FORMAT_R16G16B16_SSCALED     = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 2, 2, 2, 0, PIPE_FORMAT_TYPE_SSCALED ), -   PIPE_FORMAT_R16G16B16A16_SSCALED  = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 2, 2, 2, 2, PIPE_FORMAT_TYPE_SSCALED ), -   PIPE_FORMAT_R8_UNORM              = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_R001, 1, 0, 0, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_R8G8_UNORM            = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RG01, 1, 1, 0, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_R8G8B8_UNORM          = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 1, 1, 1, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_R8G8B8A8_UNORM        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 1, 1, 1, 1, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_R8G8B8X8_UNORM        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 1, 1, 1, 1, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_R8_USCALED            = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_R001, 1, 0, 0, 0, PIPE_FORMAT_TYPE_USCALED ), -   PIPE_FORMAT_R8G8_USCALED          = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RG01, 1, 1, 0, 0, PIPE_FORMAT_TYPE_USCALED ), -   PIPE_FORMAT_R8G8B8_USCALED        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 1, 1, 1, 0, PIPE_FORMAT_TYPE_USCALED ), -   PIPE_FORMAT_R8G8B8A8_USCALED      = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 1, 1, 1, 1, PIPE_FORMAT_TYPE_USCALED ), -   PIPE_FORMAT_R8G8B8X8_USCALED      = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 1, 1, 1, 1, PIPE_FORMAT_TYPE_USCALED ), -   PIPE_FORMAT_R8_SNORM              = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_R001, 1, 0, 0, 0, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_R8G8_SNORM            = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RG01, 1, 1, 0, 0, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_R8G8B8_SNORM          = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 1, 1, 1, 0, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_R8G8B8A8_SNORM        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 1, 1, 1, 1, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_R8G8B8X8_SNORM        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 1, 1, 1, 1, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_B6G5R5_SNORM          = _PIPE_FORMAT_RGBAZS_1 ( _PIPE_FORMAT_BGR1, 6, 5, 5, 0, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_A8B8G8R8_SNORM        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_BGRA, 1, 1, 1, 1, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_X8B8G8R8_SNORM        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_BGR1, 1, 1, 1, 1, PIPE_FORMAT_TYPE_SNORM ), -   PIPE_FORMAT_R8_SSCALED            = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_R001, 1, 0, 0, 0, PIPE_FORMAT_TYPE_SSCALED ), -   PIPE_FORMAT_R8G8_SSCALED          = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RG01, 1, 1, 0, 0, PIPE_FORMAT_TYPE_SSCALED ), -   PIPE_FORMAT_R8G8B8_SSCALED        = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 1, 1, 1, 0, PIPE_FORMAT_TYPE_SSCALED ), -   PIPE_FORMAT_R8G8B8A8_SSCALED      = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 1, 1, 1, 1, PIPE_FORMAT_TYPE_SSCALED ), -   PIPE_FORMAT_R8G8B8X8_SSCALED      = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 1, 1, 1, 1, PIPE_FORMAT_TYPE_SSCALED ), -   PIPE_FORMAT_R32_FIXED             = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_R001, 4, 0, 0, 0, PIPE_FORMAT_TYPE_FIXED ), -   PIPE_FORMAT_R32G32_FIXED          = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RG01, 4, 4, 0, 0, PIPE_FORMAT_TYPE_FIXED ), -   PIPE_FORMAT_R32G32B32_FIXED       = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 4, 4, 4, 0, PIPE_FORMAT_TYPE_FIXED ), -   PIPE_FORMAT_R32G32B32A32_FIXED    = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 4, 4, 4, 4, PIPE_FORMAT_TYPE_FIXED ), +   PIPE_FORMAT_NONE                  = 0, +   PIPE_FORMAT_A8R8G8B8_UNORM        = 1, +   PIPE_FORMAT_X8R8G8B8_UNORM        = 2, +   PIPE_FORMAT_B8G8R8A8_UNORM        = 3, +   PIPE_FORMAT_B8G8R8X8_UNORM        = 4, +   PIPE_FORMAT_A1R5G5B5_UNORM        = 5, +   PIPE_FORMAT_A4R4G4B4_UNORM        = 6, +   PIPE_FORMAT_R5G6B5_UNORM          = 7, +   PIPE_FORMAT_A2B10G10R10_UNORM     = 8, +   PIPE_FORMAT_L8_UNORM              = 9,    /**< ubyte luminance */ +   PIPE_FORMAT_A8_UNORM              = 10,   /**< ubyte alpha */ +   PIPE_FORMAT_I8_UNORM              = 11,   /**< ubyte intensity */ +   PIPE_FORMAT_A8L8_UNORM            = 12,   /**< ubyte alpha, luminance */ +   PIPE_FORMAT_L16_UNORM             = 13,   /**< ushort luminance */ +   PIPE_FORMAT_YCBCR                 = 14, +   PIPE_FORMAT_YCBCR_REV             = 15, +   PIPE_FORMAT_Z16_UNORM             = 16, +   PIPE_FORMAT_Z32_UNORM             = 17, +   PIPE_FORMAT_Z32_FLOAT             = 18, +   PIPE_FORMAT_S8Z24_UNORM           = 19, +   PIPE_FORMAT_Z24S8_UNORM           = 20, +   PIPE_FORMAT_X8Z24_UNORM           = 21, +   PIPE_FORMAT_Z24X8_UNORM           = 22, +   PIPE_FORMAT_S8_UNORM              = 23,   /**< ubyte stencil */ +   PIPE_FORMAT_R64_FLOAT             = 24, +   PIPE_FORMAT_R64G64_FLOAT          = 25, +   PIPE_FORMAT_R64G64B64_FLOAT       = 26, +   PIPE_FORMAT_R64G64B64A64_FLOAT    = 27, +   PIPE_FORMAT_R32_FLOAT             = 28, +   PIPE_FORMAT_R32G32_FLOAT          = 29, +   PIPE_FORMAT_R32G32B32_FLOAT       = 30, +   PIPE_FORMAT_R32G32B32A32_FLOAT    = 31, +   PIPE_FORMAT_R32_UNORM             = 32, +   PIPE_FORMAT_R32G32_UNORM          = 33, +   PIPE_FORMAT_R32G32B32_UNORM       = 34, +   PIPE_FORMAT_R32G32B32A32_UNORM    = 35, +   PIPE_FORMAT_R32_USCALED           = 36, +   PIPE_FORMAT_R32G32_USCALED        = 37, +   PIPE_FORMAT_R32G32B32_USCALED     = 38, +   PIPE_FORMAT_R32G32B32A32_USCALED  = 39, +   PIPE_FORMAT_R32_SNORM             = 40, +   PIPE_FORMAT_R32G32_SNORM          = 41, +   PIPE_FORMAT_R32G32B32_SNORM       = 42, +   PIPE_FORMAT_R32G32B32A32_SNORM    = 43, +   PIPE_FORMAT_R32_SSCALED           = 44, +   PIPE_FORMAT_R32G32_SSCALED        = 45, +   PIPE_FORMAT_R32G32B32_SSCALED     = 46, +   PIPE_FORMAT_R32G32B32A32_SSCALED  = 47, +   PIPE_FORMAT_R16_UNORM             = 48, +   PIPE_FORMAT_R16G16_UNORM          = 49, +   PIPE_FORMAT_R16G16B16_UNORM       = 50, +   PIPE_FORMAT_R16G16B16A16_UNORM    = 51, +   PIPE_FORMAT_R16_USCALED           = 52, +   PIPE_FORMAT_R16G16_USCALED        = 53, +   PIPE_FORMAT_R16G16B16_USCALED     = 54, +   PIPE_FORMAT_R16G16B16A16_USCALED  = 55, +   PIPE_FORMAT_R16_SNORM             = 56, +   PIPE_FORMAT_R16G16_SNORM          = 57, +   PIPE_FORMAT_R16G16B16_SNORM       = 58, +   PIPE_FORMAT_R16G16B16A16_SNORM    = 59, +   PIPE_FORMAT_R16_SSCALED           = 60, +   PIPE_FORMAT_R16G16_SSCALED        = 61, +   PIPE_FORMAT_R16G16B16_SSCALED     = 62, +   PIPE_FORMAT_R16G16B16A16_SSCALED  = 63, +   PIPE_FORMAT_R8_UNORM              = 64, +   PIPE_FORMAT_R8G8_UNORM            = 65, +   PIPE_FORMAT_R8G8B8_UNORM          = 66, +   PIPE_FORMAT_R8G8B8A8_UNORM        = 67, +   PIPE_FORMAT_R8G8B8X8_UNORM        = 68, +   PIPE_FORMAT_R8_USCALED            = 69, +   PIPE_FORMAT_R8G8_USCALED          = 70, +   PIPE_FORMAT_R8G8B8_USCALED        = 71, +   PIPE_FORMAT_R8G8B8A8_USCALED      = 72, +   PIPE_FORMAT_R8G8B8X8_USCALED      = 73, +   PIPE_FORMAT_R8_SNORM              = 74, +   PIPE_FORMAT_R8G8_SNORM            = 75, +   PIPE_FORMAT_R8G8B8_SNORM          = 76, +   PIPE_FORMAT_R8G8B8A8_SNORM        = 77, +   PIPE_FORMAT_R8G8B8X8_SNORM        = 78, +   PIPE_FORMAT_B6G5R5_SNORM          = 79, +   PIPE_FORMAT_A8B8G8R8_SNORM        = 80, +   PIPE_FORMAT_X8B8G8R8_SNORM        = 81, +   PIPE_FORMAT_R8_SSCALED            = 82, +   PIPE_FORMAT_R8G8_SSCALED          = 83, +   PIPE_FORMAT_R8G8B8_SSCALED        = 84, +   PIPE_FORMAT_R8G8B8A8_SSCALED      = 85, +   PIPE_FORMAT_R8G8B8X8_SSCALED      = 86, +   PIPE_FORMAT_R32_FIXED             = 87, +   PIPE_FORMAT_R32G32_FIXED          = 88, +   PIPE_FORMAT_R32G32B32_FIXED       = 89, +   PIPE_FORMAT_R32G32B32A32_FIXED    = 90,     /* sRGB formats */ -   PIPE_FORMAT_L8_SRGB               = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RRR1, 1, 1, 1, 0, PIPE_FORMAT_TYPE_SRGB ), -   PIPE_FORMAT_A8L8_SRGB             = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RRRG, 1, 1, 1, 1, PIPE_FORMAT_TYPE_SRGB ), -   PIPE_FORMAT_R8G8B8_SRGB           = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 1, 1, 1, 0, PIPE_FORMAT_TYPE_SRGB ), -   PIPE_FORMAT_R8G8B8A8_SRGB         = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGBA, 1, 1, 1, 1, PIPE_FORMAT_TYPE_SRGB ), -   PIPE_FORMAT_R8G8B8X8_SRGB         = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_RGB1, 1, 1, 1, 1, PIPE_FORMAT_TYPE_SRGB ), -   PIPE_FORMAT_A8R8G8B8_SRGB         = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_ARGB, 1, 1, 1, 1, PIPE_FORMAT_TYPE_SRGB ), -   PIPE_FORMAT_X8R8G8B8_SRGB         = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_1RGB, 1, 1, 1, 1, PIPE_FORMAT_TYPE_SRGB ), -   PIPE_FORMAT_B8G8R8A8_SRGB         = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_BGRA, 1, 1, 1, 1, PIPE_FORMAT_TYPE_SRGB ), -   PIPE_FORMAT_B8G8R8X8_SRGB         = _PIPE_FORMAT_RGBAZS_8 ( _PIPE_FORMAT_BGR1, 1, 1, 1, 1, PIPE_FORMAT_TYPE_SRGB ), +   PIPE_FORMAT_L8_SRGB               = 91, +   PIPE_FORMAT_A8L8_SRGB             = 92, +   PIPE_FORMAT_R8G8B8_SRGB           = 93, +   PIPE_FORMAT_R8G8B8A8_SRGB         = 94, +   PIPE_FORMAT_R8G8B8X8_SRGB         = 95, +   PIPE_FORMAT_A8R8G8B8_SRGB         = 96, +   PIPE_FORMAT_X8R8G8B8_SRGB         = 97, +   PIPE_FORMAT_B8G8R8A8_SRGB         = 98, +   PIPE_FORMAT_B8G8R8X8_SRGB         = 99,     /* mixed formats */ -   PIPE_FORMAT_X8UB8UG8SR8S_NORM     = _PIPE_FORMAT_MIXED( _PIPE_FORMAT_1BGR, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1 ), -   PIPE_FORMAT_B6UG5SR5S_NORM        = _PIPE_FORMAT_MIXED( _PIPE_FORMAT_BGR1, 6, 5, 5, 0, 0, 1, 1, 0, 1, 0 ), +   PIPE_FORMAT_X8UB8UG8SR8S_NORM     = 100, +   PIPE_FORMAT_B6UG5SR5S_NORM        = 101,     /* compressed formats */ -   PIPE_FORMAT_DXT1_RGB              = _PIPE_FORMAT_DXT( 1, 8, 8, 8, 0, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_DXT1_RGBA             = _PIPE_FORMAT_DXT( 1, 8, 8, 8, 8, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_DXT3_RGBA             = _PIPE_FORMAT_DXT( 3, 8, 8, 8, 8, PIPE_FORMAT_TYPE_UNORM ), -   PIPE_FORMAT_DXT5_RGBA             = _PIPE_FORMAT_DXT( 5, 8, 8, 8, 8, PIPE_FORMAT_TYPE_UNORM ), +   PIPE_FORMAT_DXT1_RGB              = 102, +   PIPE_FORMAT_DXT1_RGBA             = 103, +   PIPE_FORMAT_DXT3_RGBA             = 104, +   PIPE_FORMAT_DXT5_RGBA             = 105,     /* sRGB, compressed */ -   PIPE_FORMAT_DXT1_SRGB             = _PIPE_FORMAT_DXT( 1, 8, 8, 8, 0, PIPE_FORMAT_TYPE_SRGB ), -   PIPE_FORMAT_DXT1_SRGBA            = _PIPE_FORMAT_DXT( 1, 8, 8, 8, 8, PIPE_FORMAT_TYPE_SRGB ), -   PIPE_FORMAT_DXT3_SRGBA            = _PIPE_FORMAT_DXT( 3, 8, 8, 8, 8, PIPE_FORMAT_TYPE_SRGB ), -   PIPE_FORMAT_DXT5_SRGBA            = _PIPE_FORMAT_DXT( 5, 8, 8, 8, 8, PIPE_FORMAT_TYPE_SRGB ) +   PIPE_FORMAT_DXT1_SRGB             = 106, +   PIPE_FORMAT_DXT1_SRGBA            = 107, +   PIPE_FORMAT_DXT3_SRGBA            = 108, +   PIPE_FORMAT_DXT5_SRGBA            = 109, + +   PIPE_FORMAT_COUNT  };  /** @@ -394,205 +174,6 @@ enum pipe_format {   */  extern const char *pf_name( enum pipe_format format ); -/** - * Return bits for a particular component. - * \param comp  component index, starting at 0 - */ -static INLINE uint pf_get_component_bits( enum pipe_format format, uint comp ) -{ -   uint size; - -   if (pf_swizzle_x(format) == comp) { -      size = pf_size_x(format); -   } -   else if (pf_swizzle_y(format) == comp) { -      size = pf_size_y(format); -   } -   else if (pf_swizzle_z(format) == comp) { -      size = pf_size_z(format); -   } -   else if (pf_swizzle_w(format) == comp) { -      size = pf_size_w(format); -   } -   else { -      size = 0; -   } -   if (pf_layout( format ) == PIPE_FORMAT_LAYOUT_RGBAZS) -      return size << pf_exp2( format ); -   return size << (pf_mixed_scale8( format ) * 3); -} - - -/** - * Return total bits needed for the pixel format per block. - */ -static INLINE uint pf_get_blocksizebits( enum pipe_format format ) -{ -   switch (pf_layout(format)) { -   case PIPE_FORMAT_LAYOUT_RGBAZS: -   case PIPE_FORMAT_LAYOUT_MIXED: -      return -         pf_get_component_bits( format, PIPE_FORMAT_COMP_0 ) + -         pf_get_component_bits( format, PIPE_FORMAT_COMP_1 ) + -         pf_get_component_bits( format, PIPE_FORMAT_COMP_R ) + -         pf_get_component_bits( format, PIPE_FORMAT_COMP_G ) + -         pf_get_component_bits( format, PIPE_FORMAT_COMP_B ) + -         pf_get_component_bits( format, PIPE_FORMAT_COMP_A ) + -         pf_get_component_bits( format, PIPE_FORMAT_COMP_Z ) + -         pf_get_component_bits( format, PIPE_FORMAT_COMP_S ); -   case PIPE_FORMAT_LAYOUT_YCBCR: -      assert( format == PIPE_FORMAT_YCBCR || format == PIPE_FORMAT_YCBCR_REV ); -      return 32; -   case PIPE_FORMAT_LAYOUT_DXT: -        switch(format) { -        case PIPE_FORMAT_DXT1_RGBA: -        case PIPE_FORMAT_DXT1_RGB: -        case PIPE_FORMAT_DXT1_SRGBA: -        case PIPE_FORMAT_DXT1_SRGB: -           return 64; -        case PIPE_FORMAT_DXT3_RGBA: -        case PIPE_FORMAT_DXT5_RGBA: -        case PIPE_FORMAT_DXT3_SRGBA: -        case PIPE_FORMAT_DXT5_SRGBA: -           return 128; -        default: -           assert( 0 ); -           return 0; -        } - -   default: -      assert( 0 ); -      return 0; -   } -} - -/** - * Return bytes per element for the given format. - */ -static INLINE uint pf_get_blocksize( enum pipe_format format ) -{ -   assert(pf_get_blocksizebits(format) % 8 == 0); -   return pf_get_blocksizebits(format) / 8; -} - -static INLINE uint pf_get_blockwidth( enum pipe_format format ) -{ -   switch (pf_layout(format)) { -   case PIPE_FORMAT_LAYOUT_YCBCR: -      return 2; -   case PIPE_FORMAT_LAYOUT_DXT: -      return 4; -   default: -      return 1; -   } -} - -static INLINE uint pf_get_blockheight( enum pipe_format format ) -{ -   switch (pf_layout(format)) { -   case PIPE_FORMAT_LAYOUT_DXT: -      return 4; -   default: -      return 1; -   } -} - -static INLINE unsigned -pf_get_nblocksx(enum pipe_format format, unsigned x) -{ -   unsigned blockwidth = pf_get_blockwidth(format); -   return (x + blockwidth - 1) / blockwidth; -} - -static INLINE unsigned -pf_get_nblocksy(enum pipe_format format, unsigned y) -{ -   unsigned blockheight = pf_get_blockheight(format); -   return (y + blockheight - 1) / blockheight; -} - -static INLINE unsigned -pf_get_nblocks(enum pipe_format format, unsigned width, unsigned height) -{ -   return pf_get_nblocksx(format, width) * pf_get_nblocksy(format, height); -} - -static INLINE size_t -pf_get_stride(enum pipe_format format, unsigned width) -{ -   return pf_get_nblocksx(format, width) * pf_get_blocksize(format); -} - -static INLINE size_t -pf_get_2d_size(enum pipe_format format, size_t stride, unsigned height) -{ -   return pf_get_nblocksy(format, height) * stride; -} - -static INLINE boolean  -pf_is_depth_or_stencil( enum pipe_format format ) -{ -   return (pf_get_component_bits( format, PIPE_FORMAT_COMP_Z ) + -           pf_get_component_bits( format, PIPE_FORMAT_COMP_S )) != 0; -} - -static INLINE boolean  -pf_is_depth_and_stencil( enum pipe_format format ) -{ -   return (pf_get_component_bits( format, PIPE_FORMAT_COMP_Z ) != 0 && -           pf_get_component_bits( format, PIPE_FORMAT_COMP_S ) != 0); -} - -/** DEPRECATED: For backwards compatibility */ -static INLINE boolean -pf_is_depth_stencil( enum pipe_format format ) -{ -   return pf_is_depth_or_stencil( format ); -} - -static INLINE boolean  -pf_is_compressed( enum pipe_format format ) -{ -   return pf_layout(format) == PIPE_FORMAT_LAYOUT_DXT ? TRUE : FALSE; -} - -static INLINE boolean  -pf_is_ycbcr( enum pipe_format format ) -{ -   return pf_layout(format) == PIPE_FORMAT_LAYOUT_YCBCR ? TRUE : FALSE; -} - -static INLINE boolean  -pf_has_alpha( enum pipe_format format ) -{ -   switch (pf_layout(format)) { -   case PIPE_FORMAT_LAYOUT_RGBAZS: -   case PIPE_FORMAT_LAYOUT_MIXED: -      /* FIXME: pf_get_component_bits( PIPE_FORMAT_A8L8_UNORM, PIPE_FORMAT_COMP_A ) should not return 0 right? */ -      if(format == PIPE_FORMAT_A8_UNORM ||  -         format == PIPE_FORMAT_A8L8_UNORM ||  -         format == PIPE_FORMAT_A8L8_SRGB) -         return TRUE; -      return pf_get_component_bits( format, PIPE_FORMAT_COMP_A ) ? TRUE : FALSE; -   case PIPE_FORMAT_LAYOUT_YCBCR: -      return FALSE;  -   case PIPE_FORMAT_LAYOUT_DXT: -      switch (format) { -      case PIPE_FORMAT_DXT1_RGBA: -      case PIPE_FORMAT_DXT3_RGBA: -      case PIPE_FORMAT_DXT5_RGBA: -      case PIPE_FORMAT_DXT1_SRGBA: -      case PIPE_FORMAT_DXT3_SRGBA: -      case PIPE_FORMAT_DXT5_SRGBA: -         return TRUE; -      default: -         return FALSE; -      } -   default: -      assert( 0 ); -      return FALSE; -   } -}  enum pipe_video_chroma_format  { diff --git a/src/gallium/state_trackers/dri/dri_drawable.c b/src/gallium/state_trackers/dri/dri_drawable.c index 099cf1e064..4b12243ddf 100644 --- a/src/gallium/state_trackers/dri/dri_drawable.c +++ b/src/gallium/state_trackers/dri/dri_drawable.c @@ -44,6 +44,7 @@  #include "state_tracker/st_context.h"  #include "state_tracker/st_cb_fbo.h" +#include "util/u_format.h"  #include "util/u_memory.h"  #include "util/u_rect.h" diff --git a/src/gallium/state_trackers/egl/egl_surface.c b/src/gallium/state_trackers/egl/egl_surface.c index 737bdfdd34..0b60b5be05 100644 --- a/src/gallium/state_trackers/egl/egl_surface.c +++ b/src/gallium/state_trackers/egl/egl_surface.c @@ -12,6 +12,7 @@  #include "state_tracker/drm_api.h" +#include "util/u_format.h"  #include "util/u_rect.h"  /* diff --git a/src/gallium/state_trackers/python/p_device.i b/src/gallium/state_trackers/python/p_device.i index 2dc995adb0..fb793d5cbd 100644 --- a/src/gallium/state_trackers/python/p_device.i +++ b/src/gallium/state_trackers/python/p_device.i @@ -112,6 +112,10 @@ struct st_device {        struct pipe_texture templat;        memset(&templat, 0, sizeof(templat));        templat.format = format; +<<<<<<< HEAD +      util_format_get_block(templat.format, &templat.block); +======= +>>>>>>> master        templat.width0 = width;        templat.height0 = height;        templat.depth0 = depth; diff --git a/src/gallium/state_trackers/python/st_sample.c b/src/gallium/state_trackers/python/st_sample.c index 97ca2afc54..9637741421 100644 --- a/src/gallium/state_trackers/python/st_sample.c +++ b/src/gallium/state_trackers/python/st_sample.c @@ -30,6 +30,7 @@  #include "pipe/p_format.h"  #include "pipe/p_state.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_tile.h"  #include "util/u_math.h"  #include "util/u_memory.h" @@ -461,7 +462,7 @@ st_sample_dxt_pixel_block(enum pipe_format format,           for(ch = 0; ch < 4; ++ch)              rgba[y*rgba_stride + x*4 + ch] = (float)(data[i].rgba[y*4*4 + x*4 + ch])/255.0f; -   memcpy(raw, data[i].raw, pf_get_blocksize(format)); +   memcpy(raw, data[i].raw, util_format_get_blocksize(format));  } @@ -473,7 +474,7 @@ st_sample_generic_pixel_block(enum pipe_format format,  {     unsigned i;     unsigned x, y, ch; -   int blocksize = pf_get_blocksize(format); +   int blocksize = util_format_get_blocksize(format);     for(i = 0; i < blocksize; ++i)        raw[i] = (uint8_t)st_random(); @@ -548,11 +549,11 @@ st_sample_surface(struct st_surface *surface, float *rgba)     if (raw) {        enum pipe_format format = texture->format;        uint x, y; -      int nblocksx = pf_get_nblocksx(format, width); -      int nblocksy = pf_get_nblocksy(format, height); -      int blockwidth = pf_get_blockwidth(format); -      int blockheight = pf_get_blockheight(format); -      int blocksize = pf_get_blocksize(format); +      int nblocksx = util_format_get_nblocksx(format, width); +      int nblocksy = util_format_get_nblocksy(format, height); +      int blockwidth = util_format_get_blockwidth(format); +      int blockheight = util_format_get_blockheight(format); +      int blocksize = util_format_get_blocksize(format);        for (y = 0; y < nblocksy; ++y) { diff --git a/src/gallium/state_trackers/python/st_softpipe_winsys.c b/src/gallium/state_trackers/python/st_softpipe_winsys.c index 43c61af1ff..a3294e877a 100644 --- a/src/gallium/state_trackers/python/st_softpipe_winsys.c +++ b/src/gallium/state_trackers/python/st_softpipe_winsys.c @@ -40,6 +40,7 @@  #include "pipe/p_format.h"  #include "pipe/p_context.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h"  #include "softpipe/sp_winsys.h" @@ -168,8 +169,8 @@ st_softpipe_surface_buffer_create(struct pipe_winsys *winsys,     const unsigned alignment = 64;     unsigned nblocksy; -   nblocksy = pf_get_nblocksy(format, height); -   *stride = align(pf_get_stride(format, width), alignment); +   nblocksy = util_format_get_nblocksy(format, height); +   *stride = align(util_format_get_stride(format, width), alignment);     return winsys->buffer_create(winsys, alignment,                                  usage, diff --git a/src/gallium/state_trackers/python/tests/base.py b/src/gallium/state_trackers/python/tests/base.py index 202ccfc350..b022d073fd 100755 --- a/src/gallium/state_trackers/python/tests/base.py +++ b/src/gallium/state_trackers/python/tests/base.py @@ -47,7 +47,7 @@ for name, value in globals().items():          formats[value] = name  def is_depth_stencil_format(format): -    # FIXME: make and use binding to pf_is_depth_stencil +    # FIXME: make and use binding to util_format_is_depth_or_stencil      return format in (          PIPE_FORMAT_Z32_UNORM,          PIPE_FORMAT_Z24S8_UNORM, diff --git a/src/gallium/state_trackers/vega/api_filters.c b/src/gallium/state_trackers/vega/api_filters.c index eb135c1ff4..2f984fb7b9 100644 --- a/src/gallium/state_trackers/vega/api_filters.c +++ b/src/gallium/state_trackers/vega/api_filters.c @@ -38,6 +38,7 @@  #include "pipe/p_screen.h"  #include "pipe/p_shader_tokens.h" +#include "util/u_format.h"  #include "util/u_memory.h" diff --git a/src/gallium/state_trackers/vega/image.c b/src/gallium/state_trackers/vega/image.c index 172311851e..278ba6d46e 100644 --- a/src/gallium/state_trackers/vega/image.c +++ b/src/gallium/state_trackers/vega/image.c @@ -39,6 +39,7 @@  #include "pipe/p_screen.h"  #include "pipe/p_inlines.h"  #include "util/u_blit.h" +#include "util/u_format.h"  #include "util/u_tile.h"  #include "util/u_memory.h"  #include "util/u_math.h" diff --git a/src/gallium/state_trackers/vega/mask.c b/src/gallium/state_trackers/vega/mask.c index 868c28239a..42300bb6d5 100644 --- a/src/gallium/state_trackers/vega/mask.c +++ b/src/gallium/state_trackers/vega/mask.c @@ -36,6 +36,7 @@  #include "pipe/p_context.h"  #include "pipe/p_screen.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_memory.h"  struct vg_mask_layer { diff --git a/src/gallium/state_trackers/vega/paint.c b/src/gallium/state_trackers/vega/paint.c index 785c982943..cc73771d35 100644 --- a/src/gallium/state_trackers/vega/paint.c +++ b/src/gallium/state_trackers/vega/paint.c @@ -34,6 +34,7 @@  #include "pipe/p_compiler.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_memory.h"  #include "util/u_math.h" diff --git a/src/gallium/state_trackers/vega/renderer.c b/src/gallium/state_trackers/vega/renderer.c index c85dae0282..271abafbef 100644 --- a/src/gallium/state_trackers/vega/renderer.c +++ b/src/gallium/state_trackers/vega/renderer.c @@ -35,6 +35,7 @@  #include "pipe/p_shader_tokens.h"  #include "util/u_draw_quad.h" +#include "util/u_format.h"  #include "util/u_simple_shaders.h"  #include "util/u_memory.h"  #include "util/u_rect.h" diff --git a/src/gallium/state_trackers/vega/vg_tracker.c b/src/gallium/state_trackers/vega/vg_tracker.c index 5a286b1449..e503913275 100644 --- a/src/gallium/state_trackers/vega/vg_tracker.c +++ b/src/gallium/state_trackers/vega/vg_tracker.c @@ -31,6 +31,7 @@  #include "pipe/p_context.h"  #include "pipe/p_inlines.h"  #include "pipe/p_screen.h" +#include "util/u_format.h"  #include "util/u_memory.h"  #include "util/u_math.h"  #include "util/u_rect.h" @@ -56,7 +57,7 @@ create_texture(struct pipe_context *pipe, enum pipe_format format,     templ.depth0 = 1;     templ.last_level = 0; -   if (pf_get_component_bits(format, PIPE_FORMAT_COMP_S)) { +   if (util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_ZS, 1)) {        templ.tex_usage = PIPE_TEXTURE_USAGE_DEPTH_STENCIL;     } else {        templ.tex_usage = (PIPE_TEXTURE_USAGE_DISPLAY_TARGET | diff --git a/src/gallium/state_trackers/wgl/stw_framebuffer.c b/src/gallium/state_trackers/wgl/stw_framebuffer.c index 6d09501981..129a6298a7 100644 --- a/src/gallium/state_trackers/wgl/stw_framebuffer.c +++ b/src/gallium/state_trackers/wgl/stw_framebuffer.c @@ -30,6 +30,7 @@  #include "main/context.h"  #include "pipe/p_format.h"  #include "pipe/p_screen.h" +#include "util/u_format.h"  #include "state_tracker/st_context.h"  #include "state_tracker/st_public.h" @@ -267,15 +268,13 @@ stw_framebuffer_allocate(        enum pipe_format colorFormat, depthFormat, stencilFormat;        colorFormat = pfi->color_format; -       -      assert(pf_layout( pfi->depth_stencil_format ) == PIPE_FORMAT_LAYOUT_RGBAZS ); -    -      if(pf_get_component_bits( pfi->depth_stencil_format, PIPE_FORMAT_COMP_Z )) + +      if(util_format_get_component_bits(pfi->depth_stencil_format, UTIL_FORMAT_COLORSPACE_ZS, 0))           depthFormat = pfi->depth_stencil_format;        else           depthFormat = PIPE_FORMAT_NONE; -      if(pf_get_component_bits( pfi->depth_stencil_format, PIPE_FORMAT_COMP_S )) +      if(util_format_get_component_bits(pfi->depth_stencil_format, UTIL_FORMAT_COLORSPACE_ZS, 1))           stencilFormat = pfi->depth_stencil_format;        else           stencilFormat = PIPE_FORMAT_NONE; diff --git a/src/gallium/state_trackers/wgl/stw_pixelformat.c b/src/gallium/state_trackers/wgl/stw_pixelformat.c index 7abe5d9f7f..54cc361412 100644 --- a/src/gallium/state_trackers/wgl/stw_pixelformat.c +++ b/src/gallium/state_trackers/wgl/stw_pixelformat.c @@ -32,6 +32,7 @@  #include "pipe/p_defines.h"  #include "pipe/p_screen.h" +#include "util/u_format.h"  #include "util/u_debug.h"  #include "stw_icd.h" @@ -132,14 +133,12 @@ stw_pixelformat_add(     if(stw_dev->pixelformat_extended_count >= STW_MAX_PIXELFORMATS)        return; -   assert(pf_layout( color->format ) == PIPE_FORMAT_LAYOUT_RGBAZS ); -   assert(pf_get_component_bits( color->format, PIPE_FORMAT_COMP_R ) == color->bits.red ); -   assert(pf_get_component_bits( color->format, PIPE_FORMAT_COMP_G ) == color->bits.green ); -   assert(pf_get_component_bits( color->format, PIPE_FORMAT_COMP_B ) == color->bits.blue ); -   assert(pf_get_component_bits( color->format, PIPE_FORMAT_COMP_A ) == color->bits.alpha ); -   assert(pf_layout( depth->format ) == PIPE_FORMAT_LAYOUT_RGBAZS ); -   assert(pf_get_component_bits( depth->format, PIPE_FORMAT_COMP_Z ) == depth->bits.depth ); -   assert(pf_get_component_bits( depth->format, PIPE_FORMAT_COMP_S ) == depth->bits.stencil ); +   assert(util_format_get_component_bits(color->format, UTIL_FORMAT_COLORSPACE_RGB, 0) == color->bits.red); +   assert(util_format_get_component_bits(color->format, UTIL_FORMAT_COLORSPACE_RGB, 1) == color->bits.green); +   assert(util_format_get_component_bits(color->format, UTIL_FORMAT_COLORSPACE_RGB, 2) == color->bits.blue); +   assert(util_format_get_component_bits(color->format, UTIL_FORMAT_COLORSPACE_RGB, 3) == color->bits.alpha); +   assert(util_format_get_component_bits(depth->format, UTIL_FORMAT_COLORSPACE_ZS, 0) == depth->bits.depth); +   assert(util_format_get_component_bits(depth->format, UTIL_FORMAT_COLORSPACE_ZS, 1) == depth->bits.stencil);     pfi = &stw_dev->pixelformats[stw_dev->pixelformat_extended_count]; diff --git a/src/gallium/state_trackers/xorg/xorg_crtc.c b/src/gallium/state_trackers/xorg/xorg_crtc.c index 82dae194c4..c776faa53f 100644 --- a/src/gallium/state_trackers/xorg/xorg_crtc.c +++ b/src/gallium/state_trackers/xorg/xorg_crtc.c @@ -50,6 +50,7 @@  #endif  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_rect.h"  #ifdef HAVE_LIBKMS diff --git a/src/gallium/state_trackers/xorg/xorg_dri2.c b/src/gallium/state_trackers/xorg/xorg_dri2.c index bdd6a8b205..fd82f4fa1d 100644 --- a/src/gallium/state_trackers/xorg/xorg_dri2.c +++ b/src/gallium/state_trackers/xorg/xorg_dri2.c @@ -40,6 +40,7 @@  #include "pipe/p_state.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_rect.h"  /* Make all the #if cases in the code esier to read */ @@ -92,7 +93,7 @@ dri2_do_create_buffer(DrawablePtr pDraw, DRI2BufferPtr buffer, unsigned int form      case 9:  #endif  	if (exa_priv->depth_stencil_tex && -	    !pf_is_depth_stencil(exa_priv->depth_stencil_tex->format)) +	    !util_format_is_depth_or_stencil(exa_priv->depth_stencil_tex->format))  	    exa_priv->depth_stencil_tex = NULL;          /* Fall through */      case DRI2BufferDepth: diff --git a/src/gallium/state_trackers/xorg/xorg_exa.c b/src/gallium/state_trackers/xorg/xorg_exa.c index 55b87aefa1..1769c12e80 100644 --- a/src/gallium/state_trackers/xorg/xorg_exa.c +++ b/src/gallium/state_trackers/xorg/xorg_exa.c @@ -43,6 +43,7 @@  #include "pipe/p_state.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_rect.h"  #include "util/u_math.h"  #include "util/u_debug.h" diff --git a/src/gallium/state_trackers/xorg/xorg_renderer.c b/src/gallium/state_trackers/xorg/xorg_renderer.c index 248d658ac2..ba15f8a784 100644 --- a/src/gallium/state_trackers/xorg/xorg_renderer.c +++ b/src/gallium/state_trackers/xorg/xorg_renderer.c @@ -5,6 +5,7 @@  #include "cso_cache/cso_context.h"  #include "util/u_draw_quad.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h"  #include "util/u_rect.h" diff --git a/src/gallium/state_trackers/xorg/xorg_xv.c b/src/gallium/state_trackers/xorg/xorg_xv.c index 92ca5e32ef..6b5a41a372 100644 --- a/src/gallium/state_trackers/xorg/xorg_xv.c +++ b/src/gallium/state_trackers/xorg/xorg_xv.c @@ -13,6 +13,8 @@  #include "pipe/p_screen.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h" +  /*XXX get these from pipe's texture limits */  #define IMAGE_MAX_WIDTH		2048  #define IMAGE_MAX_HEIGHT	2048 diff --git a/src/gallium/winsys/drm/nouveau/drm/nouveau_drm_api.c b/src/gallium/winsys/drm/nouveau/drm/nouveau_drm_api.c index 8d95826c9a..7106a06492 100644 --- a/src/gallium/winsys/drm/nouveau/drm/nouveau_drm_api.c +++ b/src/gallium/winsys/drm/nouveau/drm/nouveau_drm_api.c @@ -1,5 +1,6 @@  #include "pipe/p_context.h"  #include "pipe/p_state.h" +#include "util/u_format.h"  #include "util/u_memory.h"  #include "nouveau_drm_api.h" @@ -246,7 +247,7 @@ nouveau_drm_handle_from_pt(struct drm_api *api, struct pipe_screen *pscreen,  		return false;  	*handle = mt->bo->handle; -	*stride = pf_get_stride(mt->base.format, mt->base.width0); +	*stride = util_format_get_stride(mt->base.format, mt->base.width0);  	return true;  } diff --git a/src/gallium/winsys/drm/radeon/core/radeon_buffer.c b/src/gallium/winsys/drm/radeon/core/radeon_buffer.c index cb8d2c2cf2..b8be059ce8 100644 --- a/src/gallium/winsys/drm/radeon/core/radeon_buffer.c +++ b/src/gallium/winsys/drm/radeon/core/radeon_buffer.c @@ -35,6 +35,7 @@  #include "radeon_bo_gem.h"  #include "softpipe/sp_texture.h"  #include "r300_context.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include <X11/Xutil.h> @@ -121,8 +122,8 @@ static struct pipe_buffer *radeon_surface_buffer_create(struct pipe_winsys *ws,      const unsigned alignment = 64;      unsigned nblocksy, size; -    nblocksy = pf_get_nblocksy(format, height); -    *stride = align(pf_get_stride(format, width), alignment); +    nblocksy = util_format_get_nblocksy(format, height); +    *stride = align(util_format_get_stride(format, width), alignment);      size = *stride * nblocksy;      return radeon_buffer_create(ws, 64, usage, size); diff --git a/src/gallium/winsys/egl_xlib/sw_winsys.c b/src/gallium/winsys/egl_xlib/sw_winsys.c index d5644c161f..6ee3ede38c 100644 --- a/src/gallium/winsys/egl_xlib/sw_winsys.c +++ b/src/gallium/winsys/egl_xlib/sw_winsys.c @@ -38,6 +38,7 @@  #include "pipe/internal/p_winsys_screen.h"  #include "pipe/p_state.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h" @@ -162,8 +163,8 @@ surface_buffer_create(struct pipe_winsys *winsys,     const unsigned alignment = 64;     unsigned nblocksy; -   nblocksy = pf_get_nblocksy(format, height); -   *stride = align(pf_get_stride(format, width), alignment); +   nblocksy = util_format_get_nblocksy(format, height); +   *stride = align(util_format_get_stride(format, width), alignment);     return winsys->buffer_create(winsys, alignment,                                  usage, diff --git a/src/gallium/winsys/g3dvl/xlib/xsp_winsys.c b/src/gallium/winsys/g3dvl/xlib/xsp_winsys.c index b8c8502d7b..f15bcd37b5 100644 --- a/src/gallium/winsys/g3dvl/xlib/xsp_winsys.c +++ b/src/gallium/winsys/g3dvl/xlib/xsp_winsys.c @@ -30,6 +30,7 @@  #include <pipe/internal/p_winsys_screen.h>  #include <pipe/p_state.h>  #include <pipe/p_inlines.h> +#include <util/u_format.h>  #include <util/u_memory.h>  #include <util/u_math.h>  #include <softpipe/sp_winsys.h> @@ -140,8 +141,8 @@ static struct pipe_buffer* xsp_surface_buffer_create     const unsigned int ALIGNMENT = 1;     unsigned nblocksy; -   nblocksy = pf_get_nblocksy(format, height); -   *stride = align(pf_get_stride(format, width), ALIGNMENT); +   nblocksy = util_format_get_nblocksy(format, height); +   *stride = align(util_format_get_stride(format, width), ALIGNMENT);     return pws->buffer_create(pws, ALIGNMENT, usage,                               *stride * nblocksy); diff --git a/src/gallium/winsys/gdi/gdi_llvmpipe_winsys.c b/src/gallium/winsys/gdi/gdi_llvmpipe_winsys.c index 81c46c0a96..7d076be3a3 100644 --- a/src/gallium/winsys/gdi/gdi_llvmpipe_winsys.c +++ b/src/gallium/winsys/gdi/gdi_llvmpipe_winsys.c @@ -39,6 +39,7 @@  #include "pipe/p_format.h"  #include "pipe/p_context.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h"  #include "llvmpipe/lp_winsys.h" @@ -136,8 +137,8 @@ gdi_llvmpipe_displaytarget_create(struct llvmpipe_winsys *winsys,     gdt->width = width;     gdt->height = height; -   bpp = pf_get_blocksizebits(format); -   cpp = pf_get_blocksize(format); +   bpp = util_format_get_blocksizebits(format); +   cpp = util_format_get_blocksize(format);     gdt->stride = align(width * cpp, alignment);     gdt->size = gdt->stride * height; diff --git a/src/gallium/winsys/gdi/gdi_softpipe_winsys.c b/src/gallium/winsys/gdi/gdi_softpipe_winsys.c index 173fa5b6fe..2ad794c3f0 100644 --- a/src/gallium/winsys/gdi/gdi_softpipe_winsys.c +++ b/src/gallium/winsys/gdi/gdi_softpipe_winsys.c @@ -42,6 +42,7 @@  #include "pipe/p_format.h"  #include "pipe/p_context.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h"  #include "softpipe/sp_winsys.h" @@ -162,8 +163,8 @@ gdi_softpipe_surface_buffer_create(struct pipe_winsys *winsys,     const unsigned alignment = 64;     unsigned nblocksy; -   nblocksy = pf_get_nblocksy(format, height); -   *stride = align(pf_get_stride(format, width), alignment); +   nblocksy = util_format_get_nblocksy(format, height); +   *stride = align(util_format_get_stride(format, width), alignment);     return winsys->buffer_create(winsys, alignment,                                  usage, @@ -270,10 +271,10 @@ gdi_softpipe_present(struct pipe_screen *screen,      memset(&bmi, 0, sizeof(BITMAPINFO));      bmi.bmiHeader.biSize = sizeof(BITMAPINFOHEADER); -    bmi.bmiHeader.biWidth = texture->stride[surface->level] / pf_get_blocksize(surface->format); +    bmi.bmiHeader.biWidth = texture->stride[surface->level] / util_format_get_blocksize(surface->format);      bmi.bmiHeader.biHeight= -(long)surface->height;      bmi.bmiHeader.biPlanes = 1; -    bmi.bmiHeader.biBitCount = pf_get_blocksizebits(surface->format); +    bmi.bmiHeader.biBitCount = util_format_get_blocksizebits(surface->format);      bmi.bmiHeader.biCompression = BI_RGB;      bmi.bmiHeader.biSizeImage = 0;      bmi.bmiHeader.biXPelsPerMeter = 0; diff --git a/src/gallium/winsys/xlib/xlib_cell.c b/src/gallium/winsys/xlib/xlib_cell.c index b078de23b7..47ae0519a4 100644 --- a/src/gallium/winsys/xlib/xlib_cell.c +++ b/src/gallium/winsys/xlib/xlib_cell.c @@ -45,6 +45,7 @@  #include "pipe/p_format.h"  #include "pipe/p_context.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h" @@ -288,8 +289,8 @@ xm_surface_buffer_create(struct pipe_winsys *winsys,     const unsigned alignment = 64;     unsigned nblocksy; -   nblocksy = pf_get_nblocksy(format, height); -   *stride = align(pf_get_stride(format, width), alignment); +   nblocksy = util_format_get_nblocksy(format, height); +   *stride = align(util_format_get_stride(format, width), alignment);     return winsys->buffer_create(winsys, alignment,                                  usage, diff --git a/src/gallium/winsys/xlib/xlib_llvmpipe.c b/src/gallium/winsys/xlib/xlib_llvmpipe.c index 41f3e248e8..2a434b5fd2 100644 --- a/src/gallium/winsys/xlib/xlib_llvmpipe.c +++ b/src/gallium/winsys/xlib/xlib_llvmpipe.c @@ -44,6 +44,7 @@  #include "pipe/p_format.h"  #include "pipe/p_context.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h"  #include "llvmpipe/lp_winsys.h" @@ -261,10 +262,10 @@ xm_llvmpipe_display(struct xmesa_buffer *xm_buffer,     {        if (xm_dt->tempImage == NULL)        { -         assert(pf_get_blockwidth(xm_dt->format) == 1); -         assert(pf_get_blockheight(xm_dt->format) == 1); +         assert(util_format_get_blockwidth(xm_dt->format) == 1); +         assert(util_format_get_blockheight(xm_dt->format) == 1);           alloc_shm_ximage(xm_dt, xm_buffer, -                          xm_dt->stride / pf_get_blocksize(xm_dt->format), +                          xm_dt->stride / util_format_get_blocksize(xm_dt->format),                            xm_dt->height);        } @@ -330,8 +331,8 @@ xm_displaytarget_create(struct llvmpipe_winsys *winsys,     xm_dt->width = width;     xm_dt->height = height; -   nblocksy = pf_get_nblocksy(format, height); -   xm_dt->stride = align(pf_get_stride(format, width), alignment); +   nblocksy = util_format_get_nblocksy(format, height); +   xm_dt->stride = align(util_format_get_stride(format, width), alignment);     size = xm_dt->stride * nblocksy;  #ifdef USE_XSHM diff --git a/src/gallium/winsys/xlib/xlib_softpipe.c b/src/gallium/winsys/xlib/xlib_softpipe.c index 69a5dcc2b7..f7c0099584 100644 --- a/src/gallium/winsys/xlib/xlib_softpipe.c +++ b/src/gallium/winsys/xlib/xlib_softpipe.c @@ -42,6 +42,7 @@  #include "pipe/p_format.h"  #include "pipe/p_context.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_memory.h"  #include "softpipe/sp_winsys.h" @@ -254,10 +255,10 @@ xlib_softpipe_display_surface(struct xmesa_buffer *b,     {        if (xm_buf->tempImage == NULL)         { -         assert(pf_get_blockwidth(surf->texture->format) == 1); -         assert(pf_get_blockheight(surf->texture->format) == 1); +         assert(util_format_get_blockwidth(surf->texture->format) == 1); +         assert(util_format_get_blockheight(surf->texture->format) == 1);           alloc_shm_ximage(xm_buf, b, spt->stride[surf->level] / -                          pf_get_blocksize(surf->texture->format), surf->height); +                          util_format_get_blocksize(surf->texture->format), surf->height);        }        ximage = xm_buf->tempImage; @@ -362,8 +363,8 @@ xm_surface_buffer_create(struct pipe_winsys *winsys,     const unsigned alignment = 64;     unsigned nblocksy, size; -   nblocksy = pf_get_nblocksy(format, height); -   *stride = align(pf_get_stride(format, width), alignment); +   nblocksy = util_format_get_nblocksy(format, height); +   *stride = align(util_format_get_stride(format, width), alignment);     size = *stride * nblocksy;  #ifdef USE_XSHM diff --git a/src/mesa/state_tracker/st_cb_clear.c b/src/mesa/state_tracker/st_cb_clear.c index e83b6c92ef..72b30e7c04 100644 --- a/src/mesa/state_tracker/st_cb_clear.c +++ b/src/mesa/state_tracker/st_cb_clear.c @@ -52,6 +52,7 @@  #include "pipe/p_inlines.h"  #include "pipe/p_state.h"  #include "pipe/p_defines.h" +#include "util/u_format.h"  #include "util/u_pack_color.h"  #include "util/u_simple_shaders.h"  #include "util/u_draw_quad.h" @@ -341,7 +342,7 @@ static INLINE GLboolean  check_clear_depth_with_quad(GLcontext *ctx, struct gl_renderbuffer *rb)  {     const struct st_renderbuffer *strb = st_renderbuffer(rb); -   const GLboolean isDS = pf_is_depth_and_stencil(strb->surface->format); +   const GLboolean isDS = util_format_is_depth_and_stencil(strb->surface->format);     if (ctx->Scissor.Enabled &&         (ctx->Scissor.X != 0 || @@ -365,7 +366,7 @@ static INLINE GLboolean  check_clear_stencil_with_quad(GLcontext *ctx, struct gl_renderbuffer *rb)  {     const struct st_renderbuffer *strb = st_renderbuffer(rb); -   const GLboolean isDS = pf_is_depth_and_stencil(strb->surface->format); +   const GLboolean isDS = util_format_is_depth_and_stencil(strb->surface->format);     const GLuint stencilMax = 0xff;     const GLboolean maskStencil        = (ctx->Stencil.WriteMask[0] & stencilMax) != stencilMax; diff --git a/src/mesa/state_tracker/st_cb_drawpixels.c b/src/mesa/state_tracker/st_cb_drawpixels.c index 1baff19040..7c664267d4 100644 --- a/src/mesa/state_tracker/st_cb_drawpixels.c +++ b/src/mesa/state_tracker/st_cb_drawpixels.c @@ -63,6 +63,7 @@  #include "tgsi/tgsi_ureg.h"  #include "util/u_tile.h"  #include "util/u_draw_quad.h" +#include "util/u_format.h"  #include "util/u_math.h"  #include "util/u_rect.h"  #include "shader/prog_instruction.h" @@ -647,7 +648,7 @@ draw_stencil_pixels(GLcontext *ctx, GLint x, GLint y,     }     if(format != GL_DEPTH_STENCIL &&  -      pf_get_component_bits( strb->format, PIPE_FORMAT_COMP_Z ) != 0) +      util_format_get_component_bits(strb->format, UTIL_FORMAT_COLORSPACE_ZS, 0) != 0)        usage = PIPE_TRANSFER_READ_WRITE;     else        usage = PIPE_TRANSFER_WRITE; @@ -842,7 +843,7 @@ copy_stencil_pixels(GLcontext *ctx, GLint srcx, GLint srcy,                            GL_STENCIL_INDEX, GL_UNSIGNED_BYTE,                            &ctx->DefaultPacking, buffer); -   if(pf_get_component_bits( rbDraw->format, PIPE_FORMAT_COMP_Z ) != 0) +   if(util_format_get_component_bits(rbDraw->format, UTIL_FORMAT_COLORSPACE_ZS, 0) != 0)        usage = PIPE_TRANSFER_READ_WRITE;     else        usage = PIPE_TRANSFER_WRITE; @@ -856,8 +857,8 @@ copy_stencil_pixels(GLcontext *ctx, GLint srcx, GLint srcy,  					   usage, dstx, dsty,  					   width, height); -   assert(pf_get_blockwidth(ptDraw->texture->format) == 1); -   assert(pf_get_blockheight(ptDraw->texture->format) == 1); +   assert(util_format_get_blockwidth(ptDraw->texture->format) == 1); +   assert(util_format_get_blockheight(ptDraw->texture->format) == 1);     /* map the stencil buffer */     drawMap = screen->transfer_map(screen, ptDraw); @@ -1083,7 +1084,7 @@ st_CopyPixels(GLcontext *ctx, GLint srcx, GLint srcy,        if (ST_DEBUG & DEBUG_FALLBACK)           debug_printf("%s: fallback processing\n", __FUNCTION__); -      if (type == GL_DEPTH && pf_is_depth_and_stencil(pt->format)) +      if (type == GL_DEPTH && util_format_is_depth_and_stencil(pt->format))           transfer_usage = PIPE_TRANSFER_READ_WRITE;        else           transfer_usage = PIPE_TRANSFER_WRITE; diff --git a/src/mesa/state_tracker/st_cb_fbo.c b/src/mesa/state_tracker/st_cb_fbo.c index ead8e22888..45ce34a85f 100644 --- a/src/mesa/state_tracker/st_cb_fbo.c +++ b/src/mesa/state_tracker/st_cb_fbo.c @@ -49,6 +49,7 @@  #include "st_public.h"  #include "st_texture.h" +#include "util/u_format.h"  #include "util/u_rect.h" @@ -104,8 +105,8 @@ st_renderbuffer_alloc_storage(GLcontext * ctx, struct gl_renderbuffer *rb,        assert(strb->format != PIPE_FORMAT_NONE); -      strb->stride = pf_get_stride(strb->format, width); -      size = pf_get_2d_size(strb->format, strb->stride, height); +      strb->stride = util_format_get_stride(strb->format, width); +      size = util_format_get_2d_size(strb->format, strb->stride, height);        strb->data = _mesa_malloc(size); @@ -130,7 +131,7 @@ st_renderbuffer_alloc_storage(GLcontext * ctx, struct gl_renderbuffer *rb,        template.depth0 = 1;        template.last_level = 0;        template.nr_samples = rb->NumSamples; -      if (pf_is_depth_stencil(format)) { +      if (util_format_is_depth_or_stencil(format)) {           template.tex_usage = PIPE_TEXTURE_USAGE_DEPTH_STENCIL;        }        else { diff --git a/src/mesa/state_tracker/st_cb_texture.c b/src/mesa/state_tracker/st_cb_texture.c index 6d136f5abf..6e1ecb1c50 100644 --- a/src/mesa/state_tracker/st_cb_texture.c +++ b/src/mesa/state_tracker/st_cb_texture.c @@ -62,6 +62,7 @@  #include "pipe/p_shader_tokens.h"  #include "util/u_tile.h"  #include "util/u_blit.h" +#include "util/u_format.h"  #include "util/u_surface.h"  #include "util/u_math.h" @@ -204,7 +205,7 @@ static GLuint  default_usage(enum pipe_format fmt)  {     GLuint usage = PIPE_TEXTURE_USAGE_SAMPLER; -   if (pf_is_depth_stencil(fmt)) +   if (util_format_is_depth_or_stencil(fmt))        usage |= PIPE_TEXTURE_USAGE_DEPTH_STENCIL;     else        usage |= PIPE_TEXTURE_USAGE_RENDER_TARGET; @@ -633,7 +634,7 @@ st_TexImage(GLcontext * ctx,     if (stImage->pt) {        if (format == GL_DEPTH_COMPONENT && -          pf_is_depth_and_stencil(stImage->pt->format)) +          util_format_is_depth_and_stencil(stImage->pt->format))           transfer_usage = PIPE_TRANSFER_READ_WRITE;        else           transfer_usage = PIPE_TRANSFER_WRITE; @@ -832,7 +833,7 @@ decompress_with_blit(GLcontext * ctx, GLenum target, GLint level,     /* copy/pack data into user buffer */     if (st_equal_formats(stImage->pt->format, format, type)) {        /* memcpy */ -      const uint bytesPerRow = width * pf_get_blocksize(stImage->pt->format); +      const uint bytesPerRow = width * util_format_get_blocksize(stImage->pt->format);        ubyte *map = screen->transfer_map(screen, tex_xfer);        GLuint row;        for (row = 0; row < height; row++) { @@ -889,7 +890,7 @@ st_get_tex_image(GLcontext * ctx, GLenum target, GLint level,     GLubyte *dest;     if (stImage->pt && -       pf_is_compressed(stImage->pt->format) && +       util_format_is_compressed(stImage->pt->format) &&         !compressed_dst) {        /* Need to decompress the texture.         * We'll do this by rendering a textured quad. @@ -914,7 +915,7 @@ st_get_tex_image(GLcontext * ctx, GLenum target, GLint level,                                              PIPE_TRANSFER_READ, 0, 0,                                              stImage->base.Width,                                              stImage->base.Height); -      texImage->RowStride = stImage->transfer->stride / pf_get_blocksize(stImage->pt->format); +      texImage->RowStride = stImage->transfer->stride / util_format_get_blocksize(stImage->pt->format);     }     else {        /* Otherwise, the image should actually be stored in @@ -1040,7 +1041,7 @@ st_TexSubimage(GLcontext *ctx, GLint dims, GLenum target, GLint level,        unsigned face = _mesa_tex_target_to_face(target);        if (format == GL_DEPTH_COMPONENT && -          pf_is_depth_and_stencil(stImage->pt->format)) +          util_format_is_depth_and_stencil(stImage->pt->format))           transfer_usage = PIPE_TRANSFER_READ_WRITE;        else           transfer_usage = PIPE_TRANSFER_WRITE; @@ -1177,7 +1178,7 @@ st_CompressedTexSubImage2D(GLcontext *ctx, GLenum target, GLint level,                                              xoffset, yoffset,                                              width, height); -      srcBlockStride = pf_get_stride(pformat, width); +      srcBlockStride = util_format_get_stride(pformat, width);        dstBlockStride = stImage->transfer->stride;     } else {        assert(stImage->pt); @@ -1191,16 +1192,16 @@ st_CompressedTexSubImage2D(GLcontext *ctx, GLenum target, GLint level,        return;     } -   assert(xoffset % pf_get_blockwidth(pformat) == 0); -   assert(yoffset % pf_get_blockheight(pformat) == 0); -   assert(width % pf_get_blockwidth(pformat) == 0); -   assert(height % pf_get_blockheight(pformat) == 0); +   assert(xoffset % util_format_get_blockwidth(pformat) == 0); +   assert(yoffset % util_format_get_blockheight(pformat) == 0); +   assert(width % util_format_get_blockwidth(pformat) == 0); +   assert(height % util_format_get_blockheight(pformat) == 0); -   for (y = 0; y < height; y += pf_get_blockheight(pformat)) { +   for (y = 0; y < height; y += util_format_get_blockheight(pformat)) {        /* don't need to adjust for xoffset and yoffset as st_texture_image_map does that */ -      const char *src = (const char*)data + srcBlockStride * pf_get_nblocksy(pformat, y); -      char *dst = (char*)texImage->Data + dstBlockStride * pf_get_nblocksy(pformat, y); -      memcpy(dst, src, pf_get_stride(pformat, width)); +      const char *src = (const char*)data + srcBlockStride * util_format_get_nblocksy(pformat, y); +      char *dst = (char*)texImage->Data + dstBlockStride * util_format_get_nblocksy(pformat, y); +      memcpy(dst, src, util_format_get_stride(pformat, width));     }     if (stImage->pt) { @@ -1264,7 +1265,7 @@ fallback_copy_texsubimage(GLcontext *ctx, GLenum target, GLint level,     if ((baseFormat == GL_DEPTH_COMPONENT ||          baseFormat == GL_DEPTH_STENCIL) && -       pf_is_depth_and_stencil(stImage->pt->format)) +       util_format_is_depth_and_stencil(stImage->pt->format))        transfer_usage = PIPE_TRANSFER_READ_WRITE;     else        transfer_usage = PIPE_TRANSFER_WRITE; @@ -1690,10 +1691,10 @@ copy_image_data_to_texture(struct st_context *st,                              dstLevel,                              stImage->base.Data,                              stImage->base.RowStride *  -                            pf_get_blocksize(stObj->pt->format), +                            util_format_get_blocksize(stObj->pt->format),                              stImage->base.RowStride *                              stImage->base.Height * -                            pf_get_blocksize(stObj->pt->format)); +                            util_format_get_blocksize(stObj->pt->format));        _mesa_align_free(stImage->base.Data);        stImage->base.Data = NULL;     } diff --git a/src/mesa/state_tracker/st_format.c b/src/mesa/state_tracker/st_format.c index 93125afe9e..a06621d2b7 100644 --- a/src/mesa/state_tracker/st_format.c +++ b/src/mesa/state_tracker/st_format.c @@ -42,42 +42,34 @@  #include "pipe/p_context.h"  #include "pipe/p_defines.h"  #include "pipe/p_screen.h" +#include "util/u_format.h"  #include "st_context.h"  #include "st_format.h" -static GLuint -format_bits( -   pipe_format_rgbazs_t  info, -   GLuint comp ) -{ -   return pf_get_component_bits( (enum pipe_format) info, comp ); -}  static GLuint -format_max_bits( -   pipe_format_rgbazs_t  info ) +format_max_bits(enum pipe_format format)  { -   GLuint   size = format_bits( info, PIPE_FORMAT_COMP_R ); +   GLuint size = util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 0); -   size = MAX2( size, format_bits( info, PIPE_FORMAT_COMP_G ) ); -   size = MAX2( size, format_bits( info, PIPE_FORMAT_COMP_B ) ); -   size = MAX2( size, format_bits( info, PIPE_FORMAT_COMP_A ) ); -   size = MAX2( size, format_bits( info, PIPE_FORMAT_COMP_Z ) ); -   size = MAX2( size, format_bits( info, PIPE_FORMAT_COMP_S ) ); +   size = MAX2(size, util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 1)); +   size = MAX2(size, util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 2)); +   size = MAX2(size, util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 3)); +   size = MAX2(size, util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_ZS, 0)); +   size = MAX2(size, util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_ZS, 1));     return size;  }  static GLuint -format_size( -   pipe_format_rgbazs_t  info ) +format_size(enum pipe_format format)  {     return -      format_bits( info, PIPE_FORMAT_COMP_R ) + -      format_bits( info, PIPE_FORMAT_COMP_G ) + -      format_bits( info, PIPE_FORMAT_COMP_B ) + -      format_bits( info, PIPE_FORMAT_COMP_A ) + -      format_bits( info, PIPE_FORMAT_COMP_Z ) + -      format_bits( info, PIPE_FORMAT_COMP_S ); +      util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 0) + +      util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 1) + +      util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 2) + +      util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 3) + +      util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_ZS, 0) + +      util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_ZS, 1);  }  /* @@ -86,11 +78,13 @@ format_size(  GLboolean  st_get_format_info(enum pipe_format format, struct pipe_format_info *pinfo)  { -   if (pf_layout(format) == PIPE_FORMAT_LAYOUT_RGBAZS) { -      pipe_format_rgbazs_t info; +   const struct util_format_description *desc; -      info = format; +   desc = util_format_description(format); +   assert(desc); +   if (desc->layout == UTIL_FORMAT_LAYOUT_ARITH || +       desc->layout == UTIL_FORMAT_LAYOUT_ARRAY) {  #if 0        printf("%s\n", pf_name( format ) );  #endif @@ -103,22 +97,22 @@ st_get_format_info(enum pipe_format format, struct pipe_format_info *pinfo)           pinfo->datatype = GL_UNSIGNED_INT_24_8;        }        else { -         const GLuint size = format_max_bits( info ); +         const GLuint size = format_max_bits(format);           if (size == 8) { -            if (pf_type(info) == PIPE_FORMAT_TYPE_UNORM) +            if (desc->channel[0].type == UTIL_FORMAT_TYPE_UNSIGNED)                 pinfo->datatype = GL_UNSIGNED_BYTE;              else                 pinfo->datatype = GL_BYTE;           }           else if (size == 16) { -            if (pf_type(info) == PIPE_FORMAT_TYPE_UNORM) +            if (desc->channel[0].type == UTIL_FORMAT_TYPE_UNSIGNED)                 pinfo->datatype = GL_UNSIGNED_SHORT;              else                 pinfo->datatype = GL_SHORT;           }           else {              assert( size <= 32 ); -            if (pf_type(info) == PIPE_FORMAT_TYPE_UNORM) +            if (desc->channel[0].type == UTIL_FORMAT_TYPE_UNSIGNED)                 pinfo->datatype = GL_UNSIGNED_INT;              else                 pinfo->datatype = GL_INT; @@ -126,23 +120,23 @@ st_get_format_info(enum pipe_format format, struct pipe_format_info *pinfo)        }        /* Component bits */ -      pinfo->red_bits = format_bits( info, PIPE_FORMAT_COMP_R ); -      pinfo->green_bits = format_bits( info, PIPE_FORMAT_COMP_G ); -      pinfo->blue_bits = format_bits( info, PIPE_FORMAT_COMP_B ); -      pinfo->alpha_bits = format_bits( info, PIPE_FORMAT_COMP_A ); -      pinfo->depth_bits = format_bits( info, PIPE_FORMAT_COMP_Z ); -      pinfo->stencil_bits = format_bits( info, PIPE_FORMAT_COMP_S ); +      pinfo->red_bits = util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 0); +      pinfo->green_bits = util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 1); +      pinfo->blue_bits = util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 2); +      pinfo->alpha_bits = util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 3); +      pinfo->depth_bits = util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_ZS, 0); +      pinfo->stencil_bits = util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_ZS, 1);        pinfo->luminance_bits = 0;        pinfo->intensity_bits = 0;        /* Format size */ -      pinfo->size = format_size( info ) / 8; +      pinfo->size = format_size(format) / 8;        /* Luminance & Intensity bits */ -      if( pf_swizzle_x(info) == PIPE_FORMAT_COMP_R && -          pf_swizzle_y(info) == PIPE_FORMAT_COMP_R && -          pf_swizzle_z(info) == PIPE_FORMAT_COMP_R ) { -         if( pf_swizzle_w(info) == PIPE_FORMAT_COMP_R ) { +      if (desc->swizzle[0] == UTIL_FORMAT_SWIZZLE_X && +          desc->swizzle[1] == UTIL_FORMAT_SWIZZLE_X && +          desc->swizzle[2] == UTIL_FORMAT_SWIZZLE_X) { +         if (desc->swizzle[3] == UTIL_FORMAT_SWIZZLE_X) {              pinfo->intensity_bits = pinfo->red_bits;           }           else { @@ -153,7 +147,7 @@ st_get_format_info(enum pipe_format format, struct pipe_format_info *pinfo)        pinfo->mesa_format = st_pipe_format_to_mesa_format(format);     } -   else if (pf_layout(format) == PIPE_FORMAT_LAYOUT_YCBCR) { +   else if (desc->layout == UTIL_FORMAT_LAYOUT_YUV) {        pinfo->mesa_format = MESA_FORMAT_YCBCR;        pinfo->datatype = GL_UNSIGNED_SHORT;        pinfo->size = 2; /* two bytes per "texel" */ diff --git a/src/mesa/state_tracker/st_gen_mipmap.c b/src/mesa/state_tracker/st_gen_mipmap.c index 7700551830..5a433dd7b9 100644 --- a/src/mesa/state_tracker/st_gen_mipmap.c +++ b/src/mesa/state_tracker/st_gen_mipmap.c @@ -37,6 +37,7 @@  #include "pipe/p_context.h"  #include "pipe/p_defines.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_gen_mipmap.h"  #include "util/u_math.h" @@ -146,8 +147,8 @@ fallback_generate_mipmap(GLcontext *ctx, GLenum target,        srcData = (ubyte *) screen->transfer_map(screen, srcTrans);        dstData = (ubyte *) screen->transfer_map(screen, dstTrans); -      srcStride = srcTrans->stride / pf_get_blocksize(srcTrans->texture->format); -      dstStride = dstTrans->stride / pf_get_blocksize(dstTrans->texture->format); +      srcStride = srcTrans->stride / util_format_get_blocksize(srcTrans->texture->format); +      dstStride = dstTrans->stride / util_format_get_blocksize(dstTrans->texture->format);        _mesa_generate_mipmap_level(target, datatype, comps,                                    0 /*border*/, diff --git a/src/mesa/state_tracker/st_texture.c b/src/mesa/state_tracker/st_texture.c index 3035d78b61..8a3e4cd3ac 100644 --- a/src/mesa/state_tracker/st_texture.c +++ b/src/mesa/state_tracker/st_texture.c @@ -43,6 +43,7 @@  #include "pipe/p_context.h"  #include "pipe/p_defines.h"  #include "pipe/p_inlines.h" +#include "util/u_format.h"  #include "util/u_rect.h"  #include "util/u_math.h" @@ -405,7 +406,7 @@ st_bind_texture_surface(struct pipe_surface *ps, int target, int level,     }     /* map pipe format to base format for now */ -   if (pf_get_component_bits(format, PIPE_FORMAT_COMP_A) > 0) +   if (util_format_get_component_bits(format, UTIL_FORMAT_COLORSPACE_RGB, 3) > 0)        internalFormat = GL_RGBA;     else        internalFormat = GL_RGB; | 
