shader: make translate_resq take const char * instead of array

Signed-off-by: Erik Faye-Lund <erik.faye-lund@collabora.com>
Reviewed-By: Gert Wollny <gert.wollny@collabora.com>
macos/master
Erik Faye-Lund 6 years ago
parent 28b358cc01
commit a9f435ce5d
  1. 15
      src/vrend_shader.c

@ -3129,14 +3129,15 @@ static const char *get_atomic_opname(int tgsi_opcode, bool *is_cas)
static void static void
translate_resq(struct dump_ctx *ctx, struct tgsi_full_instruction *inst, translate_resq(struct dump_ctx *ctx, struct tgsi_full_instruction *inst,
const char *srcs[4], char dsts[3][255], const char *writemask) const char *srcs[4], const char *dst, const char *writemask)
{ {
const struct tgsi_full_src_register *src = &inst->Src[0]; const struct tgsi_full_src_register *src = &inst->Src[0];
if (src->Register.File == TGSI_FILE_IMAGE) { if (src->Register.File == TGSI_FILE_IMAGE) {
if (inst->Dst[0].Register.WriteMask & 0x8) { if (inst->Dst[0].Register.WriteMask & 0x8) {
ctx->shader_req_bits |= SHADER_REQ_TXQS | SHADER_REQ_INTS; ctx->shader_req_bits |= SHADER_REQ_TXQS | SHADER_REQ_INTS;
emit_buff(ctx, "%s = %s(imageSamples(%s));\n", dsts[0], get_string(INT_BITS_TO_FLOAT), srcs[0]); emit_buff(ctx, "%s = %s(imageSamples(%s));\n",
dst, get_string(INT_BITS_TO_FLOAT), srcs[0]);
} }
if (inst->Dst[0].Register.WriteMask & 0x7) { if (inst->Dst[0].Register.WriteMask & 0x7) {
const char *swizzle_mask = (ctx->cfg->use_gles && inst->Memory.Texture == TGSI_TEXTURE_1D_ARRAY) ? const char *swizzle_mask = (ctx->cfg->use_gles && inst->Memory.Texture == TGSI_TEXTURE_1D_ARRAY) ?
@ -3145,11 +3146,13 @@ translate_resq(struct dump_ctx *ctx, struct tgsi_full_instruction *inst,
bool skip_emit_writemask = inst->Memory.Texture == TGSI_TEXTURE_BUFFER || bool skip_emit_writemask = inst->Memory.Texture == TGSI_TEXTURE_BUFFER ||
(!ctx->cfg->use_gles && inst->Memory.Texture == TGSI_TEXTURE_1D); (!ctx->cfg->use_gles && inst->Memory.Texture == TGSI_TEXTURE_1D);
emit_buff(ctx, "%s = %s(imageSize(%s)%s%s);\n", dsts[0], get_string(INT_BITS_TO_FLOAT), srcs[0], emit_buff(ctx, "%s = %s(imageSize(%s)%s%s);\n",
swizzle_mask,skip_emit_writemask ? "" : writemask); dst, get_string(INT_BITS_TO_FLOAT), srcs[0],
swizzle_mask, skip_emit_writemask ? "" : writemask);
} }
} else if (src->Register.File == TGSI_FILE_BUFFER) { } else if (src->Register.File == TGSI_FILE_BUFFER) {
emit_buff(ctx, "%s = %s(int(%s.length()) << 2);\n", dsts[0], get_string(INT_BITS_TO_FLOAT), srcs[0]); emit_buff(ctx, "%s = %s(int(%s.length()) << 2);\n",
dst, get_string(INT_BITS_TO_FLOAT), srcs[0]);
} }
} }
@ -5122,7 +5125,7 @@ iter_instruction(struct tgsi_iterate_context *iter,
translate_atomic(ctx, inst, &sinfo, srcs, dsts); translate_atomic(ctx, inst, &sinfo, srcs, dsts);
break; break;
case TGSI_OPCODE_RESQ: case TGSI_OPCODE_RESQ:
translate_resq(ctx, inst, srcs, dsts, writemask); translate_resq(ctx, inst, srcs, dsts[0], writemask);
break; break;
case TGSI_OPCODE_CLOCK: case TGSI_OPCODE_CLOCK:
ctx->shader_req_bits |= SHADER_REQ_SHADER_CLOCK; ctx->shader_req_bits |= SHADER_REQ_SHADER_CLOCK;

Loading…
Cancel
Save