diff options
| author | Corbin Simpson <MostAwesomeDude@gmail.com> | 2009-05-09 00:38:07 -0700 | 
|---|---|---|
| committer | Corbin Simpson <MostAwesomeDude@gmail.com> | 2009-05-09 00:45:48 -0700 | 
| commit | a738d2b4c2979d7d54064f2ad08da401b28a473b (patch) | |
| tree | 1e9c3833f193c4d95bf67832773a51c846caf34f | |
| parent | c4c5bf31a743bc53a9dbdef7807928dacae7958a (diff) | |
r300-gallium: vs: Make imms work, cleanup some of the switches.
| -rw-r--r-- | src/gallium/drivers/r300/r300_state_tcl.c | 38 | 
1 files changed, 26 insertions, 12 deletions
| diff --git a/src/gallium/drivers/r300/r300_state_tcl.c b/src/gallium/drivers/r300/r300_state_tcl.c index 410a756773..ed9164db49 100644 --- a/src/gallium/drivers/r300/r300_state_tcl.c +++ b/src/gallium/drivers/r300/r300_state_tcl.c @@ -71,16 +71,13 @@ static INLINE unsigned r300_vs_src_type(struct r300_vs_asm* assembler,  {      switch (src->File) {          case TGSI_FILE_NULL: -            /* Probably a zero or one swizzle */ -            return R300_PVS_SRC_REG_INPUT; -            break;          case TGSI_FILE_INPUT: +            /* Probably a zero or one swizzle */              return R300_PVS_SRC_REG_INPUT; -            break;          case TGSI_FILE_TEMPORARY:              return R300_PVS_SRC_REG_TEMPORARY; -            break;          case TGSI_FILE_CONSTANT: +        case TGSI_FILE_IMMEDIATE:              return R300_PVS_SRC_REG_CONSTANT;          default:              debug_printf("r300: vs: Unimplemented src type %d\n", src->File); @@ -89,16 +86,32 @@ static INLINE unsigned r300_vs_src_type(struct r300_vs_asm* assembler,      return 0;  } +static INLINE unsigned r300_vs_src(struct r300_vs_asm* assembler, +                                   struct tgsi_src_register* src) +{ +    switch (src->File) { +        case TGSI_FILE_NULL: +        case TGSI_FILE_INPUT: +        case TGSI_FILE_TEMPORARY: +        case TGSI_FILE_CONSTANT: +            return src->Index; +        case TGSI_FILE_IMMEDIATE: +            return src->Index + assembler->imm_offset; +        default: +            debug_printf("r300: vs: Unimplemented src type %d\n", src->File); +            break; +    } +    return 0; +} +  static INLINE unsigned r300_vs_dst_type(struct r300_vs_asm* assembler,                                          struct tgsi_dst_register* dst)  {      switch (dst->File) {          case TGSI_FILE_TEMPORARY:              return R300_PVS_DST_REG_TEMPORARY; -            break;          case TGSI_FILE_OUTPUT:              return R300_PVS_DST_REG_OUT; -            break;          default:              debug_printf("r300: vs: Unimplemented dst type %d\n", dst->File);              break; @@ -112,10 +125,8 @@ static INLINE unsigned r300_vs_dst(struct r300_vs_asm* assembler,      switch (dst->File) {          case TGSI_FILE_TEMPORARY:              return dst->Index; -            break;          case TGSI_FILE_OUTPUT:              return assembler->tab[dst->Index]; -            break;          default:              debug_printf("r300: vs: Unimplemented dst %d\n", dst->File);              break; @@ -199,21 +210,24 @@ static void r300_vs_emit_inst(struct r300_vertex_shader* vs,              vs->instructions[i].inst3 =                  R300_PVS_SRC_REG_TYPE(r300_vs_src_type(assembler,                              &src[2].SrcRegister)) | -                R300_PVS_SRC_OFFSET(src[2].SrcRegister.Index) | +                R300_PVS_SRC_OFFSET(r300_vs_src(assembler, +                            &src[2].SrcRegister)) |                  R300_PVS_SRC_SWIZZLE(r300_vs_swiz(&src[2]));              /* Fall through */          case 2:              vs->instructions[i].inst2 =                  R300_PVS_SRC_REG_TYPE(r300_vs_src_type(assembler,                              &src[1].SrcRegister)) | -                R300_PVS_SRC_OFFSET(src[1].SrcRegister.Index) | +                R300_PVS_SRC_OFFSET(r300_vs_src(assembler, +                            &src[1].SrcRegister)) |                  R300_PVS_SRC_SWIZZLE(r300_vs_swiz(&src[1]));              /* Fall through */          case 1:              vs->instructions[i].inst1 =                  R300_PVS_SRC_REG_TYPE(r300_vs_src_type(assembler,                              &src[0].SrcRegister)) | -                R300_PVS_SRC_OFFSET(src[0].SrcRegister.Index) | +                R300_PVS_SRC_OFFSET(r300_vs_src(assembler, +                            &src[0].SrcRegister)) |                  /* XXX the icky, it burns */                  R300_PVS_SRC_SWIZZLE(is_scalar ? r300_vs_scalar_swiz(&src[0])                          : r300_vs_swiz(&src[0])); | 
