diff options
author | Eric Anholt <[email protected]> | 2014-08-22 15:02:52 -0700 |
---|---|---|
committer | Eric Anholt <[email protected]> | 2014-09-23 13:40:10 -0700 |
commit | 2e48b286bf21501ac06832799a4b7957bb8ac893 (patch) | |
tree | 2abbc37c478504db4b699b1f8251f51b66800aa4 /src/gallium/drivers/vc4/vc4_qpu_emit.c | |
parent | b7edf30191cae945b4836d683762d0ebed6efbfe (diff) |
vc4: Add support for 8-bit unorm/snorm vertex inputs.
Diffstat (limited to 'src/gallium/drivers/vc4/vc4_qpu_emit.c')
-rw-r--r-- | src/gallium/drivers/vc4/vc4_qpu_emit.c | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/src/gallium/drivers/vc4/vc4_qpu_emit.c b/src/gallium/drivers/vc4/vc4_qpu_emit.c index 3f30f2cd3c5..81b3b8bd784 100644 --- a/src/gallium/drivers/vc4/vc4_qpu_emit.c +++ b/src/gallium/drivers/vc4/vc4_qpu_emit.c @@ -490,6 +490,31 @@ vc4_generate_code(struct vc4_context *vc4, struct vc4_compile *c) break; + case QOP_UNPACK_8A: + case QOP_UNPACK_8B: + case QOP_UNPACK_8C: + case QOP_UNPACK_8D: { + assert(src[0].mux == QPU_MUX_A); + + /* And, since we're setting the pack bits, if the + * destination is in A it would get re-packed. + */ + struct qpu_reg orig_dst = dst; + if (orig_dst.mux == QPU_MUX_A) + dst = qpu_rn(3); + + queue(c, qpu_a_FMAX(dst, src[0], src[0])); + *last_inst(c) |= QPU_SET_FIELD(QPU_UNPACK_8A + + (qinst->op - + QOP_UNPACK_8A), + QPU_UNPACK); + + if (orig_dst.mux == QPU_MUX_A) { + queue(c, qpu_a_MOV(orig_dst, dst)); + } + } + break; + default: assert(qinst->op < ARRAY_SIZE(translate)); assert(translate[qinst->op].op != 0); /* NOPs */ |