From: Eric Anholt Date: Tue, 30 Sep 2014 20:25:24 +0000 (-0700) Subject: vc4: Start using tgsi_lowering for opcodes we haven't supported before. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=4f6e4c7370221b0cf11d6bbc3ddb02799671c818;p=mesa.git vc4: Start using tgsi_lowering for opcodes we haven't supported before. --- diff --git a/src/gallium/drivers/vc4/vc4_program.c b/src/gallium/drivers/vc4/vc4_program.c index 26068e283eb..52de8a88ae7 100644 --- a/src/gallium/drivers/vc4/vc4_program.c +++ b/src/gallium/drivers/vc4/vc4_program.c @@ -33,6 +33,7 @@ #include "util/ralloc.h" #include "tgsi/tgsi_dump.h" #include "tgsi/tgsi_info.h" +#include "tgsi/tgsi_lowering.h" #include "vc4_context.h" #include "vc4_qpu.h" @@ -1730,7 +1731,20 @@ vc4_shader_state_create(struct pipe_context *pctx, if (!so) return NULL; - so->tokens = tgsi_dup_tokens(cso->tokens); + const struct tgsi_lowering_config lowering_config = { + .lower_DST = true, + .lower_XPD = true, + .lower_SCS = true, + .lower_EXP = true, + .lower_LOG = true, + .lower_DPH = true, + .lower_DP2A = true, + }; + + struct tgsi_shader_info info; + so->tokens = tgsi_transform_lowering(&lowering_config, cso->tokens, &info); + if (!so->tokens) + so->tokens = tgsi_dup_tokens(cso->tokens); return so; }