intel/mi_builder: add a way to reserve a register

Will be useful for GRL metakernels.

Reviewed-by: Lionel Landwerlin <lionel.g.landwerlin@intel.com>
Acked-by: Caio Oliveira <caio.oliveira@intel.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/16970>
This commit is contained in:
Jason Ekstrand
2021-02-26 17:13:25 -06:00
committed by Marge Bot
parent a5e5e6aa0f
commit b7296e11ae
+15
View File
@@ -226,6 +226,21 @@ mi_new_gpr(struct mi_builder *b)
.reg = _MI_BUILDER_GPR_BASE + gpr * 8,
};
}
static inline struct mi_value
mi_reserve_gpr(struct mi_builder *b, unsigned gpr)
{
assert(gpr < MI_BUILDER_NUM_ALLOC_GPRS);
assert(!(b->gprs & (1 << gpr)));
assert(b->gpr_refs[gpr] == 0);
b->gprs |= (1u << gpr);
b->gpr_refs[gpr] = 128; /* Enough that we won't unref it */
return (struct mi_value) {
.type = MI_VALUE_TYPE_REG64,
.reg = _MI_BUILDER_GPR_BASE + gpr * 8,
};
}
#endif /* GFX_VERx10 >= 75 */
/** Take a reference to a mi_value