radv: Add performance counter reg write.
Needed for reliably writing performance counter selectors. Reviewed-by: Samuel Pitoiset <samuel.pitoiset@gmail.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/16879>
This commit is contained in:

committed by
Marge Bot

parent
71b32a9f75
commit
6cfc2e91e8
@@ -265,6 +265,7 @@
|
|||||||
#define PKT3_IT_OPCODE_C 0xFFFF00FF
|
#define PKT3_IT_OPCODE_C 0xFFFF00FF
|
||||||
#define PKT3_PREDICATE(x) (((x) >> 0) & 0x1)
|
#define PKT3_PREDICATE(x) (((x) >> 0) & 0x1)
|
||||||
#define PKT3_SHADER_TYPE_S(x) (((unsigned)(x)&0x1) << 1)
|
#define PKT3_SHADER_TYPE_S(x) (((unsigned)(x)&0x1) << 1)
|
||||||
|
#define PKT3_RESET_FILTER_CAM(x) (((unsigned)(x)&0x1) << 2)
|
||||||
#define PKT0(index, count) (PKT_TYPE_S(0) | PKT0_BASE_INDEX_S(index) | PKT_COUNT_S(count))
|
#define PKT0(index, count) (PKT_TYPE_S(0) | PKT0_BASE_INDEX_S(index) | PKT_COUNT_S(count))
|
||||||
#define PKT3(op, count, predicate) \
|
#define PKT3(op, count, predicate) \
|
||||||
(PKT_TYPE_S(3) | PKT_COUNT_S(count) | PKT3_IT_OPCODE_S(op) | PKT3_PREDICATE(predicate))
|
(PKT_TYPE_S(3) | PKT_COUNT_S(count) | PKT3_IT_OPCODE_S(op) | PKT3_PREDICATE(predicate))
|
||||||
|
@@ -184,6 +184,26 @@ radeon_set_uconfig_reg_idx(const struct radv_physical_device *pdevice, struct ra
|
|||||||
radeon_emit(cs, value);
|
radeon_emit(cs, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline void
|
||||||
|
radeon_set_perfctr_reg(struct radv_cmd_buffer *cmd_buffer, unsigned reg, unsigned value)
|
||||||
|
{
|
||||||
|
struct radeon_cmdbuf *cs = cmd_buffer->cs;
|
||||||
|
assert(reg >= CIK_UCONFIG_REG_OFFSET && reg < CIK_UCONFIG_REG_END);
|
||||||
|
assert(cs->cdw + 3 <= cs->max_dw);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* On GFX10, there is a bug with the ME implementation of its content addressable memory (CAM),
|
||||||
|
* that means that it can skip register writes due to not taking correctly into account the
|
||||||
|
* fields from the GRBM_GFX_INDEX. With this bit we can force the write.
|
||||||
|
*/
|
||||||
|
bool filter_cam_workaround = cmd_buffer->device->physical_device->rad_info.gfx_level >= GFX10 &&
|
||||||
|
cmd_buffer->qf == RADV_QUEUE_GENERAL;
|
||||||
|
|
||||||
|
radeon_emit(cs, PKT3(PKT3_SET_UCONFIG_REG, 1, 0) | PKT3_RESET_FILTER_CAM(filter_cam_workaround));
|
||||||
|
radeon_emit(cs, (reg - CIK_UCONFIG_REG_OFFSET) >> 2);
|
||||||
|
radeon_emit(cs, value);
|
||||||
|
}
|
||||||
|
|
||||||
static inline void
|
static inline void
|
||||||
radeon_set_privileged_config_reg(struct radeon_cmdbuf *cs, unsigned reg, unsigned value)
|
radeon_set_privileged_config_reg(struct radeon_cmdbuf *cs, unsigned reg, unsigned value)
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user