diff options
author | Dave Airlie <[email protected]> | 2011-09-26 19:06:40 +0100 |
---|---|---|
committer | Dave Airlie <[email protected]> | 2011-10-09 10:06:18 +0100 |
commit | 0110aa09e5898987ee86586e438ac571075eba3a (patch) | |
tree | 23c17fba5c8f909f6b9af6bae405986ef03b4f11 /src/gallium/drivers/r600/r600_asm.c | |
parent | 4e28e6f6c777841b9ffe7a7ad1e865e2595f70f9 (diff) |
r600g/eg: add integer types support
adds handling for int texture/vertices to evergreen.
TODO r600/700 support.
Signed-off-by: Dave Airlie <[email protected]>
Diffstat (limited to 'src/gallium/drivers/r600/r600_asm.c')
-rw-r--r-- | src/gallium/drivers/r600/r600_asm.c | 22 |
1 files changed, 15 insertions, 7 deletions
diff --git a/src/gallium/drivers/r600/r600_asm.c b/src/gallium/drivers/r600/r600_asm.c index af0351b93c0..663e41f2dba 100644 --- a/src/gallium/drivers/r600/r600_asm.c +++ b/src/gallium/drivers/r600/r600_asm.c @@ -2017,8 +2017,9 @@ void r600_bytecode_dump(struct r600_bytecode *bc) fprintf(stderr, "--------------------------------------\n"); } -static void r600_vertex_data_type(enum pipe_format pformat, unsigned *format, - unsigned *num_format, unsigned *format_comp, unsigned *endian) +static void r600_vertex_data_type(enum pipe_format pformat, + unsigned *format, + unsigned *num_format, unsigned *format_comp, unsigned *endian) { const struct util_format_description *desc; unsigned i; @@ -2146,10 +2147,16 @@ static void r600_vertex_data_type(enum pipe_format pformat, unsigned *format, if (desc->channel[i].type == UTIL_FORMAT_TYPE_SIGNED) { *format_comp = 1; } - if (desc->channel[i].normalized) { - *num_format = 0; - } else { - *num_format = 2; + + *num_format = 0; + if (desc->channel[i].type == UTIL_FORMAT_TYPE_UNSIGNED || + desc->channel[i].type == UTIL_FORMAT_TYPE_SIGNED) { + if (!desc->channel[i].normalized) { + if (desc->channel[i].pure_integer) + *num_format = 1; + else + *num_format = 2; + } } return; out_unknown: @@ -2210,7 +2217,8 @@ int r600_vertex_elements_build_fetch_shader(struct r600_pipe_context *rctx, stru for (i = 0; i < ve->count; i++) { unsigned vbuffer_index; - r600_vertex_data_type(ve->elements[i].src_format, &format, &num_format, &format_comp, &endian); + r600_vertex_data_type(ve->elements[i].src_format, + &format, &num_format, &format_comp, &endian); desc = util_format_description(ve->elements[i].src_format); if (desc == NULL) { r600_bytecode_clear(&bc); |