Better than having pointers flying about.
Signed-off-by: Alyssa Rosenzweig <alyssa.rosenzweig@collabora.com>
/* List of midgard_instructions emitted for the current block */
struct list_head instructions;
/* List of midgard_instructions emitted for the current block */
struct list_head instructions;
+ /* Index of the block in source order */
+ unsigned source_id;
+
bool is_scheduled;
/* List of midgard_bundles emitted (after the scheduler has run) */
bool is_scheduled;
/* List of midgard_bundles emitted (after the scheduler has run) */
int block_count;
struct list_head blocks;
int block_count;
struct list_head blocks;
+ /* TODO merge with block_count? */
+ unsigned block_source_count;
+
/* List of midgard_instructions emitted for the current block */
midgard_block *current_block;
/* List of midgard_instructions emitted for the current block */
midgard_block *current_block;
_mesa_hash_pointer,
_mesa_key_pointer_equal);
_mesa_hash_pointer,
_mesa_key_pointer_equal);
+ blk->source_id = ctx->block_source_count++;
+
void
mir_print_block(midgard_block *block)
{
void
mir_print_block(midgard_block *block)
{
- printf("%p: {\n", block);
+ printf("block%d: {\n", block->source_id);
mir_foreach_instr_in_block(block, ins) {
mir_print_instruction(ins);
mir_foreach_instr_in_block(block, ins) {
mir_print_instruction(ins);
if (block->nr_successors) {
printf(" -> ");
for (unsigned i = 0; i < block->nr_successors; ++i) {
if (block->nr_successors) {
printf(" -> ");
for (unsigned i = 0; i < block->nr_successors; ++i) {
- printf("%p%s", block->successors[i],
+ printf("block%d%s", block->successors[i]->source_id,
(i + 1) != block->nr_successors ? ", " : "");
}
}
(i + 1) != block->nr_successors ? ", " : "");
}
}