diff options
author | Dave Airlie <[email protected]> | 2012-11-03 20:51:45 +1000 |
---|---|---|
committer | Dave Airlie <[email protected]> | 2012-11-09 10:29:26 +1000 |
commit | 309fda2fb28dfe7e8b9be31806346125bef13b21 (patch) | |
tree | 97259d4e5a5a0971dc13d1e4e493916c066c9ce0 /src/gallium/auxiliary | |
parent | 8c0ccce30038f5d28e74f7f4b5b5c0bbd8ac6dbe (diff) |
softpipe: add ARB_texture_cube_map_array support (v1.1)
This adds support to the softpipe texture sampler and tgsi exec.
In order to handle the extra input to the texture sampling,
I've had to expand the interfaces to take a c1 value for storing
the texture compare value for the TEX2 case.
v1.1: add comments (Brian)
Reviewed-by: Brian Paul <[email protected]>
Signed-off-by: Dave Airlie <[email protected]>
Diffstat (limited to 'src/gallium/auxiliary')
-rw-r--r-- | src/gallium/auxiliary/tgsi/tgsi_exec.c | 120 | ||||
-rw-r--r-- | src/gallium/auxiliary/tgsi/tgsi_exec.h | 13 |
2 files changed, 103 insertions, 30 deletions
diff --git a/src/gallium/auxiliary/tgsi/tgsi_exec.c b/src/gallium/auxiliary/tgsi/tgsi_exec.c index 0b58f097ecf..428227d735f 100644 --- a/src/gallium/auxiliary/tgsi/tgsi_exec.c +++ b/src/gallium/auxiliary/tgsi/tgsi_exec.c @@ -1709,6 +1709,7 @@ fetch_texel( struct tgsi_sampler *sampler, const union tgsi_exec_channel *t, const union tgsi_exec_channel *p, const union tgsi_exec_channel *c0, + const union tgsi_exec_channel *c1, enum tgsi_sampler_control control, union tgsi_exec_channel *r, union tgsi_exec_channel *g, @@ -1718,7 +1719,7 @@ fetch_texel( struct tgsi_sampler *sampler, uint j; float rgba[TGSI_NUM_CHANNELS][TGSI_QUAD_SIZE]; - sampler->get_samples(sampler, s->f, t->f, p->f, c0->f, control, rgba); + sampler->get_samples(sampler, s->f, t->f, p->f, c0->f, c1->f, control, rgba); for (j = 0; j < 4; j++) { r->f[j] = rgba[0][j]; @@ -1734,19 +1735,25 @@ fetch_texel( struct tgsi_sampler *sampler, #define TEX_MODIFIER_LOD_BIAS 2 #define TEX_MODIFIER_EXPLICIT_LOD 3 - +/* + * execute a texture instruction. + * + * modifier is used to control the channel routing for the\ + * instruction variants like proj, lod, and texture with lod bias. + * sampler indicates which src register the sampler is contained in. + */ static void exec_tex(struct tgsi_exec_machine *mach, const struct tgsi_full_instruction *inst, - uint modifier) + uint modifier, uint sampler) { - const uint unit = inst->Src[1].Register.Index; - union tgsi_exec_channel r[4]; + const uint unit = inst->Src[sampler].Register.Index; + union tgsi_exec_channel r[4], cubearraycomp, cubelod; const union tgsi_exec_channel *lod = &ZeroVec; enum tgsi_sampler_control control; uint chan; - if (modifier != TEX_MODIFIER_NONE) { + if (modifier != TEX_MODIFIER_NONE && (sampler == 1)) { FETCH(&r[3], 0, TGSI_CHAN_W); if (modifier != TEX_MODIFIER_PROJECTED) { lod = &r[3]; @@ -1768,7 +1775,7 @@ exec_tex(struct tgsi_exec_machine *mach, } fetch_texel(mach->Samplers[unit], - &r[0], &ZeroVec, &ZeroVec, lod, /* S, T, P, LOD */ + &r[0], &ZeroVec, &ZeroVec, lod, &ZeroVec, /* S, T, P, LOD */ control, &r[0], &r[1], &r[2], &r[3]); /* R, G, B, A */ break; @@ -1781,7 +1788,7 @@ exec_tex(struct tgsi_exec_machine *mach, } fetch_texel(mach->Samplers[unit], - &r[0], &ZeroVec, &r[2], lod, /* S, T, P, LOD */ + &r[0], &ZeroVec, &r[2], lod, &ZeroVec, /* S, T, P, LOD */ control, &r[0], &r[1], &r[2], &r[3]); /* R, G, B, A */ break; @@ -1801,7 +1808,7 @@ exec_tex(struct tgsi_exec_machine *mach, } fetch_texel(mach->Samplers[unit], - &r[0], &r[1], &r[2], lod, /* S, T, P, LOD */ + &r[0], &r[1], &r[2], lod, &ZeroVec, /* S, T, P, LOD */ control, &r[0], &r[1], &r[2], &r[3]); /* outputs */ break; @@ -1815,7 +1822,7 @@ exec_tex(struct tgsi_exec_machine *mach, } fetch_texel(mach->Samplers[unit], - &r[0], &r[1], &ZeroVec, lod, /* S, T, P, LOD */ + &r[0], &r[1], &ZeroVec, lod, &ZeroVec, /* S, T, P, LOD */ control, &r[0], &r[1], &r[2], &r[3]); /* outputs */ break; @@ -1829,7 +1836,7 @@ exec_tex(struct tgsi_exec_machine *mach, } fetch_texel(mach->Samplers[unit], - &r[0], &r[1], &r[2], lod, /* S, T, P, LOD */ + &r[0], &r[1], &r[2], lod, &ZeroVec, /* S, T, P, LOD */ control, &r[0], &r[1], &r[2], &r[3]); /* outputs */ break; @@ -1845,7 +1852,7 @@ exec_tex(struct tgsi_exec_machine *mach, } fetch_texel(mach->Samplers[unit], - &r[0], &r[1], &r[2], lod, /* S, T, P, LOD */ + &r[0], &r[1], &r[2], lod, &ZeroVec, /* S, T, P, LOD */ control, &r[0], &r[1], &r[2], &r[3]); /* outputs */ break; @@ -1857,7 +1864,24 @@ exec_tex(struct tgsi_exec_machine *mach, FETCH(&r[3], 0, TGSI_CHAN_W); fetch_texel(mach->Samplers[unit], - &r[0], &r[1], &r[2], &r[3], /* S, T, P, LOD */ + &r[0], &r[1], &r[2], &r[3], &ZeroVec, /* S, T, P, LOD */ + control, + &r[0], &r[1], &r[2], &r[3]); /* outputs */ + break; + case TGSI_TEXTURE_CUBE_ARRAY: + FETCH(&r[0], 0, TGSI_CHAN_X); + FETCH(&r[1], 0, TGSI_CHAN_Y); + FETCH(&r[2], 0, TGSI_CHAN_Z); + FETCH(&r[3], 0, TGSI_CHAN_W); + + if (modifier == TEX_MODIFIER_EXPLICIT_LOD || + modifier == TEX_MODIFIER_LOD_BIAS) + FETCH(&cubelod, 1, TGSI_CHAN_X); + else + cubelod = ZeroVec; + + fetch_texel(mach->Samplers[unit], + &r[0], &r[1], &r[2], &r[3], &cubelod, /* S, T, P, LOD */ control, &r[0], &r[1], &r[2], &r[3]); /* outputs */ break; @@ -1874,11 +1898,24 @@ exec_tex(struct tgsi_exec_machine *mach, } fetch_texel(mach->Samplers[unit], - &r[0], &r[1], &r[2], lod, + &r[0], &r[1], &r[2], lod, &ZeroVec, control, &r[0], &r[1], &r[2], &r[3]); break; + case TGSI_TEXTURE_SHADOWCUBE_ARRAY: + FETCH(&r[0], 0, TGSI_CHAN_X); + FETCH(&r[1], 0, TGSI_CHAN_Y); + FETCH(&r[2], 0, TGSI_CHAN_Z); + FETCH(&r[3], 0, TGSI_CHAN_W); + + FETCH(&cubearraycomp, 1, TGSI_CHAN_X); + + fetch_texel(mach->Samplers[unit], + &r[0], &r[1], &r[2], &r[3], &cubearraycomp, /* S, T, P, LOD */ + control, + &r[0], &r[1], &r[2], &r[3]); /* outputs */ + break; default: assert(0); } @@ -1920,7 +1957,7 @@ exec_txd(struct tgsi_exec_machine *mach, FETCH(&r[0], 0, TGSI_CHAN_X); fetch_texel(mach->Samplers[unit], - &r[0], &ZeroVec, &ZeroVec, &ZeroVec, /* S, T, P, BIAS */ + &r[0], &ZeroVec, &ZeroVec, &ZeroVec, &ZeroVec, /* S, T, P, BIAS */ tgsi_sampler_lod_bias, &r[0], &r[1], &r[2], &r[3]); /* R, G, B, A */ break; @@ -1937,7 +1974,7 @@ exec_txd(struct tgsi_exec_machine *mach, FETCH(&r[2], 0, TGSI_CHAN_Z); fetch_texel(mach->Samplers[unit], - &r[0], &r[1], &r[2], &ZeroVec, /* inputs */ + &r[0], &r[1], &r[2], &ZeroVec, &ZeroVec, /* inputs */ tgsi_sampler_lod_bias, &r[0], &r[1], &r[2], &r[3]); /* outputs */ break; @@ -1945,13 +1982,13 @@ exec_txd(struct tgsi_exec_machine *mach, case TGSI_TEXTURE_2D_ARRAY: case TGSI_TEXTURE_3D: case TGSI_TEXTURE_CUBE: - + case TGSI_TEXTURE_CUBE_ARRAY: FETCH(&r[0], 0, TGSI_CHAN_X); FETCH(&r[1], 0, TGSI_CHAN_Y); FETCH(&r[2], 0, TGSI_CHAN_Z); fetch_texel(mach->Samplers[unit], - &r[0], &r[1], &r[2], &ZeroVec, + &r[0], &r[1], &r[2], &ZeroVec, &ZeroVec, tgsi_sampler_lod_bias, &r[0], &r[1], &r[2], &r[3]); break; @@ -1964,7 +2001,7 @@ exec_txd(struct tgsi_exec_machine *mach, FETCH(&r[3], 0, TGSI_CHAN_W); fetch_texel(mach->Samplers[unit], - &r[0], &r[1], &r[2], &r[3], + &r[0], &r[1], &r[2], &r[3], &ZeroVec, tgsi_sampler_lod_bias, &r[0], &r[1], &r[2], &r[3]); break; @@ -2121,7 +2158,7 @@ exec_sample(struct tgsi_exec_machine *mach, } fetch_texel(mach->Samplers[sampler_unit], - &r[0], &ZeroVec, &ZeroVec, lod, /* S, T, P, LOD */ + &r[0], &ZeroVec, &ZeroVec, lod, &ZeroVec, /* S, T, P, LOD */ control, &r[0], &r[1], &r[2], &r[3]); /* R, G, B, A */ break; @@ -2143,7 +2180,7 @@ exec_sample(struct tgsi_exec_machine *mach, } fetch_texel(mach->Samplers[sampler_unit], - &r[0], &r[1], &r[2], lod, /* S, T, P, LOD */ + &r[0], &r[1], &r[2], lod, &ZeroVec, /* S, T, P, LOD */ control, &r[0], &r[1], &r[2], &r[3]); /* outputs */ break; @@ -2151,6 +2188,7 @@ exec_sample(struct tgsi_exec_machine *mach, case TGSI_TEXTURE_2D_ARRAY: case TGSI_TEXTURE_3D: case TGSI_TEXTURE_CUBE: + case TGSI_TEXTURE_CUBE_ARRAY: FETCH(&r[0], 0, TGSI_CHAN_X); FETCH(&r[1], 0, TGSI_CHAN_Y); FETCH(&r[2], 0, TGSI_CHAN_Z); @@ -2162,7 +2200,7 @@ exec_sample(struct tgsi_exec_machine *mach, } fetch_texel(mach->Samplers[sampler_unit], - &r[0], &r[1], &r[2], lod, + &r[0], &r[1], &r[2], lod, &ZeroVec, control, &r[0], &r[1], &r[2], &r[3]); break; @@ -2177,7 +2215,7 @@ exec_sample(struct tgsi_exec_machine *mach, assert(modifier != TEX_MODIFIER_PROJECTED); fetch_texel(mach->Samplers[sampler_unit], - &r[0], &r[1], &r[2], &r[3], + &r[0], &r[1], &r[2], &r[3], &ZeroVec, control, &r[0], &r[1], &r[2], &r[3]); break; @@ -2212,7 +2250,7 @@ exec_sample_d(struct tgsi_exec_machine *mach, FETCH(&r[0], 0, TGSI_CHAN_X); fetch_texel(mach->Samplers[sampler_unit], - &r[0], &ZeroVec, &ZeroVec, &ZeroVec, /* S, T, P, BIAS */ + &r[0], &ZeroVec, &ZeroVec, &ZeroVec, &ZeroVec, /* S, T, P, BIAS */ tgsi_sampler_lod_bias, &r[0], &r[1], &r[2], &r[3]); /* R, G, B, A */ break; @@ -2227,20 +2265,21 @@ exec_sample_d(struct tgsi_exec_machine *mach, FETCH(&r[2], 0, TGSI_CHAN_Z); fetch_texel(mach->Samplers[sampler_unit], - &r[0], &r[1], &r[2], &ZeroVec, /* inputs */ + &r[0], &r[1], &r[2], &ZeroVec, &ZeroVec, /* inputs */ tgsi_sampler_lod_bias, &r[0], &r[1], &r[2], &r[3]); /* outputs */ break; case TGSI_TEXTURE_3D: case TGSI_TEXTURE_CUBE: + case TGSI_TEXTURE_CUBE_ARRAY: FETCH(&r[0], 0, TGSI_CHAN_X); FETCH(&r[1], 0, TGSI_CHAN_Y); FETCH(&r[2], 0, TGSI_CHAN_Z); fetch_texel(mach->Samplers[sampler_unit], - &r[0], &r[1], &r[2], &ZeroVec, + &r[0], &r[1], &r[2], &ZeroVec, &ZeroVec, tgsi_sampler_lod_bias, &r[0], &r[1], &r[2], &r[3]); break; @@ -3643,14 +3682,14 @@ exec_instruction( /* simple texture lookup */ /* src[0] = texcoord */ /* src[1] = sampler unit */ - exec_tex(mach, inst, TEX_MODIFIER_NONE); + exec_tex(mach, inst, TEX_MODIFIER_NONE, 1); break; case TGSI_OPCODE_TXB: /* Texture lookup with lod bias */ /* src[0] = texcoord (src[0].w = LOD bias) */ /* src[1] = sampler unit */ - exec_tex(mach, inst, TEX_MODIFIER_LOD_BIAS); + exec_tex(mach, inst, TEX_MODIFIER_LOD_BIAS, 1); break; case TGSI_OPCODE_TXD: @@ -3666,14 +3705,14 @@ exec_instruction( /* Texture lookup with explit LOD */ /* src[0] = texcoord (src[0].w = LOD) */ /* src[1] = sampler unit */ - exec_tex(mach, inst, TEX_MODIFIER_EXPLICIT_LOD); + exec_tex(mach, inst, TEX_MODIFIER_EXPLICIT_LOD, 1); break; case TGSI_OPCODE_TXP: /* Texture lookup with projection */ /* src[0] = texcoord (src[0].w = projection) */ /* src[1] = sampler unit */ - exec_tex(mach, inst, TEX_MODIFIER_PROJECTED); + exec_tex(mach, inst, TEX_MODIFIER_PROJECTED, 1); break; case TGSI_OPCODE_UP2H: @@ -4208,6 +4247,27 @@ exec_instruction( exec_vector_unary(mach, inst, micro_isgn, TGSI_EXEC_DATA_INT, TGSI_EXEC_DATA_INT); break; + case TGSI_OPCODE_TEX2: + /* simple texture lookup */ + /* src[0] = texcoord */ + /* src[1] = compare */ + /* src[2] = sampler unit */ + exec_tex(mach, inst, TEX_MODIFIER_NONE, 2); + break; + case TGSI_OPCODE_TXB2: + /* simple texture lookup */ + /* src[0] = texcoord */ + /* src[1] = bias */ + /* src[2] = sampler unit */ + exec_tex(mach, inst, TEX_MODIFIER_LOD_BIAS, 2); + break; + case TGSI_OPCODE_TXL2: + /* simple texture lookup */ + /* src[0] = texcoord */ + /* src[1] = lod */ + /* src[2] = sampler unit */ + exec_tex(mach, inst, TEX_MODIFIER_EXPLICIT_LOD, 2); + break; default: assert( 0 ); } diff --git a/src/gallium/auxiliary/tgsi/tgsi_exec.h b/src/gallium/auxiliary/tgsi/tgsi_exec.h index 0ecb4e952bb..fc1ee09abf3 100644 --- a/src/gallium/auxiliary/tgsi/tgsi_exec.h +++ b/src/gallium/auxiliary/tgsi/tgsi_exec.h @@ -100,11 +100,24 @@ enum tgsi_sampler_control { struct tgsi_sampler { /** Get samples for four fragments in a quad */ + /* this interface contains 5 sets of channels that vary + * depending on the sampler. + * s - the first texture coordinate for sampling. + * t - the second texture coordinate for sampling - unused for 1D, + layer for 1D arrays. + * p - the third coordinate for sampling for 3D, cube, cube arrays, + * layer for 2D arrays. Compare value for 1D/2D shadows. + * c0 - lod value for lod variants, compare value for shadow cube + * and shadow 2d arrays. + * c1 - cube array only - lod for cube map arrays + * compare for shadow cube map arrays. + */ void (*get_samples)(struct tgsi_sampler *sampler, const float s[TGSI_QUAD_SIZE], const float t[TGSI_QUAD_SIZE], const float p[TGSI_QUAD_SIZE], const float c0[TGSI_QUAD_SIZE], + const float c1[TGSI_QUAD_SIZE], enum tgsi_sampler_control control, float rgba[TGSI_NUM_CHANNELS][TGSI_QUAD_SIZE]); void (*get_dims)(struct tgsi_sampler *sampler, int level, |