diff options
author | Rob Clark <[email protected]> | 2020-03-19 16:29:57 -0700 |
---|---|---|
committer | Marge Bot <[email protected]> | 2020-03-27 22:41:36 +0000 |
commit | d20a06e40199f4082cea73a3636b87823c76ed2b (patch) | |
tree | 673f47c8c408d715acc6b688724c19289c230f0d | |
parent | 29992a039e9959110139353664b7eb12d991e8d0 (diff) |
freedreno/ir3/ra: add helper to map name to instruction
Extract out a helper from the select_reg callback. And include all the
instructions in the hashtable, not just SFU. This will be useful in the
following commits.
Signed-off-by: Rob Clark <[email protected]>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/4272>
-rw-r--r-- | src/freedreno/ir3/ir3_ra.c | 59 |
1 files changed, 36 insertions, 23 deletions
diff --git a/src/freedreno/ir3/ir3_ra.c b/src/freedreno/ir3/ir3_ra.c index 6398cc381b2..b6c9b686b5e 100644 --- a/src/freedreno/ir3/ir3_ra.c +++ b/src/freedreno/ir3/ir3_ra.c @@ -103,6 +103,8 @@ */ +static struct ir3_instruction * name_to_instr(struct ir3_ra_ctx *ctx, unsigned name); + /* does it conflict? */ static inline bool intersects(unsigned a_start, unsigned a_end, unsigned b_start, unsigned b_end) @@ -406,21 +408,17 @@ ra_select_reg_merged(unsigned int n, BITSET_WORD *regs, void *data) * dependencies, and it potentially avoids needing (ss) syncs to * for write after read hazards: */ - struct hash_entry *entry = _mesa_hash_table_search(ctx->name_to_instr, &n); - if (entry) { - struct ir3_instruction *instr = entry->data; - - if (is_sfu(instr) && instr->regs[1]->instr) { - struct ir3_instruction *src = instr->regs[1]->instr; - unsigned src_n = scalar_name(ctx, src, 0); + struct ir3_instruction *instr = name_to_instr(ctx, n); + if (is_sfu(instr) && instr->regs[1]->instr) { + struct ir3_instruction *src = instr->regs[1]->instr; + unsigned src_n = scalar_name(ctx, src, 0); - unsigned reg = ra_get_node_reg(ctx->g, src_n); + unsigned reg = ra_get_node_reg(ctx->g, src_n); - /* Check if the src register has been assigned yet: */ - if (reg != NO_REG) { - if (BITSET_TEST(regs, reg)) { - return reg; - } + /* Check if the src register has been assigned yet: */ + if (reg != NO_REG) { + if (BITSET_TEST(regs, reg)) { + return reg; } } } @@ -498,6 +496,17 @@ ra_init(struct ir3_ra_ctx *ctx) } } +/* Map the name back to instruction: */ +static struct ir3_instruction * +name_to_instr(struct ir3_ra_ctx *ctx, unsigned name) +{ + struct hash_entry *entry = _mesa_hash_table_search(ctx->name_to_instr, &name); + if (entry) + return entry->data; + unreachable("invalid name"); + return NULL; +} + static void ra_destroy(struct ir3_ra_ctx *ctx) { @@ -602,6 +611,20 @@ ra_block_compute_live_ranges(struct ir3_ra_ctx *ctx, struct ir3_block *block) for (unsigned i = 0; i < n; i++) { unsigned name = scalar_name(ctx, instr, i); + /* split/collect instructions have duplicate names + * as real instructions, so they skip the hashtable: + */ + if (ctx->name_to_instr && !((instr->opc == OPC_META_SPLIT) || + (instr->opc == OPC_META_COLLECT))) { + /* this is slightly annoying, we can't just use an + * integer on the stack + */ + unsigned *key = ralloc(ctx->name_to_instr, unsigned); + *key = name; + debug_assert(!_mesa_hash_table_search(ctx->name_to_instr, key)); + _mesa_hash_table_insert(ctx->name_to_instr, key, instr); + } + /* tex instructions actually have a wrmask, and * don't touch masked out components. We can't do * anything useful about that in the first pass, @@ -614,16 +637,6 @@ ra_block_compute_live_ranges(struct ir3_ra_ctx *ctx, struct ir3_block *block) def(name, instr); - if (ctx->name_to_instr && is_sfu(instr)) { - /* this is slightly annoying, we can't just use an - * integer on the stack - */ - unsigned *key = ralloc(ctx->name_to_instr, unsigned); - *key = name; - debug_assert(!_mesa_hash_table_search(ctx->name_to_instr, key)); - _mesa_hash_table_insert(ctx->name_to_instr, key, instr); - } - if ((instr->opc == OPC_META_INPUT) && first_non_input) use(name, first_non_input); |