From: Eric Anholt Date: Tue, 30 Sep 2014 21:19:25 +0000 (-0700) Subject: vc4: Add support for TGSI_OPCODE_CLAMP. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=1bf2d17a60d112c7ca8da7ab0b539991df96a93d;p=mesa.git vc4: Add support for TGSI_OPCODE_CLAMP. This will be used by the shared LIT lowering code. --- diff --git a/src/gallium/drivers/vc4/vc4_program.c b/src/gallium/drivers/vc4/vc4_program.c index 6dc42ac3e32..804a1dc2097 100644 --- a/src/gallium/drivers/vc4/vc4_program.c +++ b/src/gallium/drivers/vc4/vc4_program.c @@ -812,6 +812,17 @@ tgsi_to_qir_cos(struct vc4_compile *c, return sum; } +static struct qreg +tgsi_to_qir_clamp(struct vc4_compile *c, + struct tgsi_full_instruction *tgsi_inst, + enum qop op, struct qreg *src, int i) +{ + return qir_FMAX(c, qir_FMIN(c, + src[0 * 4 + i], + src[2 * 4 + i]), + src[1 * 4 + i]); +} + static void emit_vertex_input(struct vc4_compile *c, int attr) { @@ -1062,6 +1073,7 @@ emit_tgsi_instruction(struct vc4_compile *c, [TGSI_OPCODE_FLR] = { 0, tgsi_to_qir_flr }, [TGSI_OPCODE_SIN] = { 0, tgsi_to_qir_sin }, [TGSI_OPCODE_COS] = { 0, tgsi_to_qir_cos }, + [TGSI_OPCODE_CLAMP] = { 0, tgsi_to_qir_clamp }, }; static int asdf = 0; uint32_t tgsi_op = tgsi_inst->Instruction.Opcode;