diff options
| author | Jakob Bornecrantz <wallbraker@gmail.com> | 2010-03-25 13:45:42 +0100 | 
|---|---|---|
| committer | Jakob Bornecrantz <wallbraker@gmail.com> | 2010-03-26 01:21:52 +0100 | 
| commit | fe306e7ea5e789adc955653d9be8cd7f8af47264 (patch) | |
| tree | f7db836fcde2667acccdb884aa763ce22b8044a0 /src | |
| parent | 84a8347b9f6ef0c1b2519e9bd5fef2ce3c85afb7 (diff) | |
draw: Add EMIT_4UB_BGRA format
Needed for i915g, also fixed swizzle in draw_vs_aos_io.
Diffstat (limited to 'src')
| -rw-r--r-- | src/gallium/auxiliary/draw/draw_vertex.c | 7 | ||||
| -rw-r--r-- | src/gallium/auxiliary/draw/draw_vertex.h | 7 | ||||
| -rw-r--r-- | src/gallium/auxiliary/draw/draw_vs_aos_io.c | 12 | ||||
| -rw-r--r-- | src/gallium/drivers/i915/i915_prim_emit.c | 7 | ||||
| -rw-r--r-- | src/gallium/drivers/i915/i915_state_derived.c | 4 | ||||
| -rw-r--r-- | src/gallium/drivers/nvfx/nvfx_draw.c | 6 | 
6 files changed, 33 insertions, 10 deletions
| diff --git a/src/gallium/auxiliary/draw/draw_vertex.c b/src/gallium/auxiliary/draw/draw_vertex.c index 18921ad717..a4f5e882c0 100644 --- a/src/gallium/auxiliary/draw/draw_vertex.c +++ b/src/gallium/auxiliary/draw/draw_vertex.c @@ -102,6 +102,13 @@ draw_dump_emitted_vertex(const struct vertex_info *vinfo, const uint8_t *data)           debug_printf("%u ", *data++);           debug_printf("%u ", *data++);           break; +      case EMIT_4UB_BGRA: +         debug_printf("EMIT_4UB_BGRA:\t"); +         debug_printf("%u ", *data++); +         debug_printf("%u ", *data++); +         debug_printf("%u ", *data++); +         debug_printf("%u ", *data++); +         break;        default:           assert(0);        } diff --git a/src/gallium/auxiliary/draw/draw_vertex.h b/src/gallium/auxiliary/draw/draw_vertex.h index 24c5a48b2e..ca27237126 100644 --- a/src/gallium/auxiliary/draw/draw_vertex.h +++ b/src/gallium/auxiliary/draw/draw_vertex.h @@ -54,7 +54,8 @@ enum attrib_emit {     EMIT_2F,     EMIT_3F,     EMIT_4F, -   EMIT_4UB  /**< XXX may need variations for RGBA vs BGRA, etc */ +   EMIT_4UB, /**< is RGBA like the rest */ +   EMIT_4UB_BGRA  }; @@ -157,6 +158,8 @@ static INLINE unsigned draw_translate_vinfo_format(enum attrib_emit emit)        return PIPE_FORMAT_R32G32B32A32_FLOAT;     case EMIT_4UB:        return PIPE_FORMAT_R8G8B8A8_UNORM; +   case EMIT_4UB_BGRA: +      return PIPE_FORMAT_B8G8R8A8_UNORM;     default:        assert(!"unexpected format");        return PIPE_FORMAT_NONE; @@ -179,6 +182,8 @@ static INLINE unsigned draw_translate_vinfo_size(enum attrib_emit emit)        return 4 * sizeof(float);     case EMIT_4UB:        return 4 * sizeof(unsigned char); +   case EMIT_4UB_BGRA: +      return 4 * sizeof(unsigned char);     default:        assert(!"unexpected format");        return 0; diff --git a/src/gallium/auxiliary/draw/draw_vs_aos_io.c b/src/gallium/auxiliary/draw/draw_vs_aos_io.c index ece1ddde0c..8f8bbe7cb8 100644 --- a/src/gallium/auxiliary/draw/draw_vs_aos_io.c +++ b/src/gallium/auxiliary/draw/draw_vs_aos_io.c @@ -401,13 +401,11 @@ static boolean emit_output( struct aos_compilation *cp,        emit_store_R32G32B32A32(cp, ptr, dataXMM);        break;     case EMIT_4UB: -      if (1) { -         emit_swizzle(cp, dataXMM, dataXMM, SHUF(Z,Y,X,W)); -         emit_store_R8G8B8A8_UNORM(cp, ptr, dataXMM); -      } -      else { -         emit_store_R8G8B8A8_UNORM(cp, ptr, dataXMM); -      } +      emit_store_R8G8B8A8_UNORM(cp, ptr, dataXMM); +      break; +   case EMIT_4UB_BGRA: +      emit_swizzle(cp, dataXMM, dataXMM, SHUF(Z,Y,X,W)); +      emit_store_R8G8B8A8_UNORM(cp, ptr, dataXMM);        break;     default:        AOS_ERROR(cp, "unhandled output format"); diff --git a/src/gallium/drivers/i915/i915_prim_emit.c b/src/gallium/drivers/i915/i915_prim_emit.c index d9a5c40ab9..dd997e2cf4 100644 --- a/src/gallium/drivers/i915/i915_prim_emit.c +++ b/src/gallium/drivers/i915/i915_prim_emit.c @@ -102,6 +102,13 @@ emit_hw_vertex( struct i915_context *i915,           count += 4;           break;        case EMIT_4UB: +         OUT_BATCH( pack_ub4(float_to_ubyte( attrib[0] ), +                             float_to_ubyte( attrib[1] ), +                             float_to_ubyte( attrib[2] ), +                             float_to_ubyte( attrib[3] )) ); +         count += 1; +         break; +      case EMIT_4UB_BGRA:           OUT_BATCH( pack_ub4(float_to_ubyte( attrib[2] ),                               float_to_ubyte( attrib[1] ),                               float_to_ubyte( attrib[0] ), diff --git a/src/gallium/drivers/i915/i915_state_derived.c b/src/gallium/drivers/i915/i915_state_derived.c index 0eb1e3f91a..4da46772b5 100644 --- a/src/gallium/drivers/i915/i915_state_derived.c +++ b/src/gallium/drivers/i915/i915_state_derived.c @@ -101,14 +101,14 @@ static void calculate_vertex_layout( struct i915_context *i915 )     /* primary color */     if (colors[0]) {        src = draw_find_shader_output(i915->draw, TGSI_SEMANTIC_COLOR, 0); -      draw_emit_vertex_attr(&vinfo, EMIT_4UB, colorInterp, src); +      draw_emit_vertex_attr(&vinfo, EMIT_4UB_BGRA, colorInterp, src);        vinfo.hwfmt[0] |= S4_VFMT_COLOR;     }     /* secondary color */     if (colors[1]) {        src = draw_find_shader_output(i915->draw, TGSI_SEMANTIC_COLOR, 1); -      draw_emit_vertex_attr(&vinfo, EMIT_4UB, colorInterp, src); +      draw_emit_vertex_attr(&vinfo, EMIT_4UB_BGRA, colorInterp, src);        vinfo.hwfmt[0] |= S4_VFMT_SPEC_FOG;     } diff --git a/src/gallium/drivers/nvfx/nvfx_draw.c b/src/gallium/drivers/nvfx/nvfx_draw.c index 5379b29efd..68e50a3647 100644 --- a/src/gallium/drivers/nvfx/nvfx_draw.c +++ b/src/gallium/drivers/nvfx/nvfx_draw.c @@ -79,6 +79,12 @@ nvfx_render_vertex(struct nvfx_context *nvfx, const struct vertex_header *v)  					    float_to_ubyte(v->data[idx][1]),  					    float_to_ubyte(v->data[idx][2]),  					    float_to_ubyte(v->data[idx][3]))); +		case EMIT_4UB_BGRA: +			BEGIN_RING(chan, eng3d, NV34TCL_VTX_ATTR_4UB(hw), 1); +			OUT_RING  (chan, pack_ub4(float_to_ubyte(v->data[idx][2]), +					    float_to_ubyte(v->data[idx][1]), +					    float_to_ubyte(v->data[idx][0]), +					    float_to_ubyte(v->data[idx][3])));  			break;  		default:  			assert(0); | 
