summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJason Ekstrand <[email protected]>2018-08-24 16:05:08 -0500
committerJason Ekstrand <[email protected]>2018-08-25 07:50:45 -0500
commit70de31d0c106f58d6b7e6d5b79b8d90c1c112a3b (patch)
treef009a589c7cea13650c955baf261a538fc755dcd
parentcbd4bc1346f7397242e157bb66099b950a8c5643 (diff)
intel/batch_decoder: Print blend states properly
Reviewed-by: Lionel Landwerlin <[email protected]>
-rw-r--r--src/intel/common/gen_batch_decoder.c17
1 files changed, 16 insertions, 1 deletions
diff --git a/src/intel/common/gen_batch_decoder.c b/src/intel/common/gen_batch_decoder.c
index a57bd93e0f0..6884a999401 100644
--- a/src/intel/common/gen_batch_decoder.c
+++ b/src/intel/common/gen_batch_decoder.c
@@ -641,7 +641,6 @@ decode_dynamic_state_pointers(struct gen_batch_decode_ctx *ctx,
int count)
{
struct gen_group *inst = gen_spec_find_instruction(ctx->spec, p);
- struct gen_group *state = gen_spec_find_struct(ctx->spec, struct_type);
uint32_t state_offset = 0;
@@ -663,6 +662,22 @@ decode_dynamic_state_pointers(struct gen_batch_decode_ctx *ctx,
return;
}
+ struct gen_group *state = gen_spec_find_struct(ctx->spec, struct_type);
+ if (strcmp(struct_type, "BLEND_STATE") == 0) {
+ /* Blend states are different from the others because they have a header
+ * struct called BLEND_STATE which is followed by a variable number of
+ * BLEND_STATE_ENTRY structs.
+ */
+ fprintf(ctx->fp, "%s\n", struct_type);
+ ctx_print_group(ctx, state, state_addr, state_map);
+
+ state_addr += state->dw_length * 4;
+ state_map += state->dw_length * 4;
+
+ struct_type = "BLEND_STATE_ENTRY";
+ state = gen_spec_find_struct(ctx->spec, struct_type);
+ }
+
for (int i = 0; i < count; i++) {
fprintf(ctx->fp, "%s %d\n", struct_type, i);
ctx_print_group(ctx, state, state_addr, state_map);